>>>>> "Chris" == Chris Travers <..hidden..> writes: >> My proposal is to move all of the wrapper .pl files out of the >> root directory into a directory which could be called "htdocs" or >> something like this. >> Chris> I think Erik has been suggesting moving all the Perl files Chris> into a src directory. I don't see that happening before 1.4 Chris> because it would make svn merging a big of an additional Chris> pain, but I like that idea. The current directory structure So the idea would be that "." would still be DocumentRoot? I agree that it has to be coordinated well because of the SVN pain. Perhaps this is a reason to call something "2.0" :-) Chris> is in fact very developer friendly, and I am not sure I want Chris> to force a lot of hacks in that way to deal with it. So I Chris> don't foresee the specifics here being accepted. I actually find it very developer unfriendly :-) I have to configure a system apache, and a postgresql. There is no single script to start me off working. I hope you will have a chance to look at the skeleton stuff: it saves me time, and therefore I will continue to adapt it to my local needs. Chris> However, I think the problem you are trying to solve is a Chris> real and a valid one. I just think we can solve it without Chris> making it hard for me to run 1.2, 1.3, and 1.4 in parallel at Chris> the same time. By parallel, I guess you do not mean making it easy to have three directories with three databases -- because I do not think it changes things. I guess you mean that it makes it easier to be able to apply patches to older versions? Chris> Here is my suggestion, which is to focus on tweaking the make Chris> process rather than the current file structure: Chris> 1) Tweak the Makefile.PL so that make install ONLY installs Chris> the LedgerSMB.pm, and the files in the LedgerSMB directory. You mean, I think, installs into a system directory? Chris> 2) Create a separate make install webapp target which accepts Chris> a directory in some way and allows you to install/configure Chris> the web app in a directory of your choice. This would copy Chris> the top level .pl files, the bin/* files and the UI Chris> directory. Note that scripts/* is moved into Chris> LedgerSMB/Scripts for 1.4 so that would all go into somewhere Chris> in $ENV{PERLLIB} so, I suggest that it be a script, and I suggest that the distro packagers are going to want to run this... on the target system, after asking the admin what directory. Chris> Long-run, the ideal thing would be to get rid of all the Chris> files that go into the web app directory except for a single Chris> request handler. I have been hoping that lsmb would grow better URLs such that I can more easily tell my less clueful colleagues, "go http://accounting/reconcilliation/1060"; rather than "click here, click there, etc..." Maybe others want the opposite. But, what you mean by "single request handler"? Because there could be stuff to the right of that request handler piece. >> Now, almost all of the real functionality is now in the bin/ >> directory, and this would be among the things that could go >> somewhere else when installed, rather than being under >> DocumentRoot. >> Chris> I don't see us doing this with the bin/ scripts. Sorry. The Chris> reason is that these are big scripts that came from Chris> SQL-Ledger and they are pretty brittle. I would not be I didn't understand that the bin/* is the legacy. Yes, do not touch! :-) Chris> 2) Support a make install-based approach. Right now make Chris> install creates significant supportability issues. However, Chris> if we allow one to make install, it could be downloaded into Ah, you thought perhaps I wanted to insist on "make install". Just the opposite... I want to *support*, but as a developer, I don't want it at all. >> My reasons for suggesting this are twofold: >> >> 1) depth-in-security: misconfigured web servers can not allow >> writing to things they can not see. Chris> I am not quite sure I understand your concern here. If the file isn't in DocumentRoot, it's much harder for web server to return it, or write to it. Chris> Right now the LedgerSMB logic only works for web apps, but we Chris> are putting a lot of effort into trying to ensure that you Chris> could build GUI's for it also. The current core logic has a Chris> bit of a problem in that the way it is installed only works Chris> for a web app and if you make install, that causes Chris> supportability issues. I think getting this sort of thing Chris> working for 1.4 needs to be a priority. +1000. Also, RESTful scripting and other stuff. -- ] He who is tired of Weird Al is tired of life! | firewalls [ ] Michael Richardson, Sandelman Software Works, Ottawa, ON |net architect[ ] ..hidden.. http://www.sandelman.ottawa.on.ca/ |device driver[ Kyoto Plus: watch the video <http://www.youtube.com/watch?v=kzx1ycLXQSE> then sign the petition.
Attachment:
pgpBMdDHAu9aX.pgp
Description: PGP signature