diff options
Diffstat (limited to 'sql-ledger/doc')
-rw-r--r-- | sql-ledger/doc/COPYING | 355 | ||||
-rw-r--r-- | sql-ledger/doc/README | 287 | ||||
-rw-r--r-- | sql-ledger/doc/UPGRADE-1.6-1.8 | 61 | ||||
-rw-r--r-- | sql-ledger/doc/UPGRADE-1.8-1.8.3 | 23 | ||||
-rw-r--r-- | sql-ledger/doc/UPGRADE-1.8.3-1.8.4 | 10 | ||||
-rw-r--r-- | sql-ledger/doc/UPGRADE-1.8.4-1.8.5 | 18 | ||||
-rw-r--r-- | sql-ledger/doc/UPGRADE-1.8.5-1.8.7 | 6 | ||||
-rw-r--r-- | sql-ledger/doc/UPGRADE-1.8.7-2.0.0 | 20 | ||||
-rw-r--r-- | sql-ledger/doc/UPGRADE-2.0-2.0.8 | 8 | ||||
-rw-r--r-- | sql-ledger/doc/copyright | 23 | ||||
-rw-r--r-- | sql-ledger/doc/faq.html | 747 |
11 files changed, 0 insertions, 1558 deletions
diff --git a/sql-ledger/doc/COPYING b/sql-ledger/doc/COPYING deleted file mode 100644 index 083bb4150..000000000 --- a/sql-ledger/doc/COPYING +++ /dev/null @@ -1,355 +0,0 @@ -<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2//EN"> -<HTML> -<HEAD> -<TITLE>GNU General Public License</TITLE> -</HEAD> - -<BODY BGCOLOR=ffffff> - - -<pre> - GNU GENERAL PUBLIC LICENSE - Version 2, June 1991 - - Copyright (C) 1989, 1991 Free Software Foundation, Inc. - 675 Mass Ave, Cambridge, MA 02139, USA - - Everyone is permitted to copy and distribute verbatim copies - of this license document, but changing it is not allowed. - - - Preamble - - The licenses for most software are designed to take away your -freedom to share and change it. By contrast, the GNU General Public -License is intended to guarantee your freedom to share and change free -software--to make sure the software is free for all its users. This -General Public License applies to most of the Free Software -Foundation's software and to any other program whose authors commit to -using it. (Some other Free Software Foundation software is covered by -the GNU Library General Public License instead.) You can apply it to -your programs, too. - - When we speak of free software, we are referring to freedom, not -price. Our General Public Licenses are designed to make sure that you -have the freedom to distribute copies of free software (and charge for -this service if you wish), that you receive source code or can get it -if you want it, that you can change the software or use pieces of it -in new free programs; and that you know you can do these things. - - To protect your rights, we need to make restrictions that forbid -anyone to deny you these rights or to ask you to surrender the rights. -These restrictions translate to certain responsibilities for you if you -distribute copies of the software, or if you modify it. - - For example, if you distribute copies of such a program, whether -gratis or for a fee, you must give the recipients all the rights that -you have. You must make sure that they, too, receive or can get the -source code. And you must show them these terms so they know their -rights. - - We protect your rights with two steps: (1) copyright the software, and -(2) offer you this license which gives you legal permission to copy, -distribute and/or modify the software. - - Also, for each author's protection and ours, we want to make certain -that everyone understands that there is no warranty for this free -software. If the software is modified by someone else and passed on, we -want its recipients to know that what they have is not the original, so -that any problems introduced by others will not reflect on the original -authors' reputations. - - Finally, any free program is threatened constantly by software -patents. We wish to avoid the danger that redistributors of a free -program will individually obtain patent licenses, in effect making the -program proprietary. To prevent this, we have made it clear that any -patent must be licensed for everyone's free use or not licensed at all. - - The precise terms and conditions for copying, distribution and -modification follow. - - GNU GENERAL PUBLIC LICENSE - TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION - - 0. This License applies to any program or other work which contains -a notice placed by the copyright holder saying it may be distributed -under the terms of this General Public License. The "Program", below, -refers to any such program or work, and a "work based on the Program" -means either the Program or any derivative work under copyright law: -that is to say, a work containing the Program or a portion of it, -either verbatim or with modifications and/or translated into another -language. (Hereinafter, translation is included without limitation in -the term "modification".) Each licensee is addressed as "you". - -Activities other than copying, distribution and modification are not -covered by this License; they are outside its scope. The act of -running the Program is not restricted, and the output from the Program -is covered only if its contents constitute a work based on the -Program (independent of having been made by running the Program). -Whether that is true depends on what the Program does. - - 1. You may copy and distribute verbatim copies of the Program's -source code as you receive it, in any medium, provided that you -conspicuously and appropriately publish on each copy an appropriate -copyright notice and disclaimer of warranty; keep intact all the -notices that refer to this License and to the absence of any warranty; -and give any other recipients of the Program a copy of this License -along with the Program. - -You may charge a fee for the physical act of transferring a copy, and -you may at your option offer warranty protection in exchange for a fee. - - 2. You may modify your copy or copies of the Program or any portion -of it, thus forming a work based on the Program, and copy and -distribute such modifications or work under the terms of Section 1 -above, provided that you also meet all of these conditions: - - a) You must cause the modified files to carry prominent notices - stating that you changed the files and the date of any change. - - b) You must cause any work that you distribute or publish, that in - whole or in part contains or is derived from the Program or any - part thereof, to be licensed as a whole at no charge to all third - parties under the terms of this License. - - c) If the modified program normally reads commands interactively - when run, you must cause it, when started running for such - interactive use in the most ordinary way, to print or display an - announcement including an appropriate copyright notice and a - notice that there is no warranty (or else, saying that you provide - a warranty) and that users may redistribute the program under - these conditions, and telling the user how to view a copy of this - License. (Exception: if the Program itself is interactive but - does not normally print such an announcement, your work based on - the Program is not required to print an announcement.) - -These requirements apply to the modified work as a whole. If -identifiable sections of that work are not derived from the Program, -and can be reasonably considered independent and separate works in -themselves, then this License, and its terms, do not apply to those -sections when you distribute them as separate works. But when you -distribute the same sections as part of a whole which is a work based -on the Program, the distribution of the whole must be on the terms of -this License, whose permissions for other licensees extend to the -entire whole, and thus to each and every part regardless of who wrote it. - -Thus, it is not the intent of this section to claim rights or contest -your rights to work written entirely by you; rather, the intent is to -exercise the right to control the distribution of derivative or -collective works based on the Program. - -In addition, mere aggregation of another work not based on the Program -with the Program (or with a work based on the Program) on a volume of -a storage or distribution medium does not bring the other work under -the scope of this License. - - 3. You may copy and distribute the Program (or a work based on it, -under Section 2) in object code or executable form under the terms of -Sections 1 and 2 above provided that you also do one of the following: - - a) Accompany it with the complete corresponding machine-readable - source code, which must be distributed under the terms of Sections - 1 and 2 above on a medium customarily used for software interchange; or, - - b) Accompany it with a written offer, valid for at least three - years, to give any third party, for a charge no more than your - cost of physically performing source distribution, a complete - machine-readable copy of the corresponding source code, to be - distributed under the terms of Sections 1 and 2 above on a medium - customarily used for software interchange; or, - - c) Accompany it with the information you received as to the offer - to distribute corresponding source code. (This alternative is - allowed only for noncommercial distribution and only if you - received the program in object code or executable form with such - an offer, in accord with Subsection b above.) - -The source code for a work means the preferred form of the work for -making modifications to it. For an executable work, complete source -code means all the source code for all modules it contains, plus any -associated interface definition files, plus the scripts used to -control compilation and installation of the executable. However, as a -special exception, the source code distributed need not include -anything that is normally distributed (in either source or binary -form) with the major components (compiler, kernel, and so on) of the -operating system on which the executable runs, unless that component -itself accompanies the executable. - -If distribution of executable or object code is made by offering -access to copy from a designated place, then offering equivalent -access to copy the source code from the same place counts as -distribution of the source code, even though third parties are not -compelled to copy the source along with the object code. - - 4. You may not copy, modify, sublicense, or distribute the Program -except as expressly provided under this License. Any attempt -otherwise to copy, modify, sublicense or distribute the Program is -void, and will automatically terminate your rights under this License. -However, parties who have received copies, or rights, from you under -this License will not have their licenses terminated so long as such -parties remain in full compliance. - - 5. You are not required to accept this License, since you have not -signed it. However, nothing else grants you permission to modify or -distribute the Program or its derivative works. These actions are -prohibited by law if you do not accept this License. Therefore, by -modifying or distributing the Program (or any work based on the -Program), you indicate your acceptance of this License to do so, and -all its terms and conditions for copying, distributing or modifying -the Program or works based on it. - - 6. Each time you redistribute the Program (or any work based on the -Program), the recipient automatically receives a license from the -original licensor to copy, distribute or modify the Program subject to -these terms and conditions. You may not impose any further -restrictions on the recipients' exercise of the rights granted herein. -You are not responsible for enforcing compliance by third parties to -this License. - - 7. If, as a consequence of a court judgment or allegation of patent -infringement or for any other reason (not limited to patent issues), -conditions are imposed on you (whether by court order, agreement or -otherwise) that contradict the conditions of this License, they do not -excuse you from the conditions of this License. If you cannot -distribute so as to satisfy simultaneously your obligations under this -License and any other pertinent obligations, then as a consequence you -may not distribute the Program at all. For example, if a patent -license would not permit royalty-free redistribution of the Program by -all those who receive copies directly or indirectly through you, then -the only way you could satisfy both it and this License would be to -refrain entirely from distribution of the Program. - -If any portion of this section is held invalid or unenforceable under -any particular circumstance, the balance of the section is intended to -apply and the section as a whole is intended to apply in other -circumstances. - -It is not the purpose of this section to induce you to infringe any -patents or other property right claims or to contest validity of any -such claims; this section has the sole purpose of protecting the -integrity of the free software distribution system, which is -implemented by public license practices. Many people have made -generous contributions to the wide range of software distributed -through that system in reliance on consistent application of that -system; it is up to the author/donor to decide if he or she is willing -to distribute software through any other system and a licensee cannot -impose that choice. - -This section is intended to make thoroughly clear what is believed to -be a consequence of the rest of this License. - - 8. If the distribution and/or use of the Program is restricted in -certain countries either by patents or by copyrighted interfaces, the -original copyright holder who places the Program under this License -may add an explicit geographical distribution limitation excluding -those countries, so that distribution is permitted only in or among -countries not thus excluded. In such case, this License incorporates -the limitation as if written in the body of this License. - - 9. The Free Software Foundation may publish revised and/or new versions -of the General Public License from time to time. Such new versions will -be similar in spirit to the present version, but may differ in detail to -address new problems or concerns. - -Each version is given a distinguishing version number. If the Program -specifies a version number of this License which applies to it and "any -later version", you have the option of following the terms and conditions -either of that version or of any later version published by the Free -Software Foundation. If the Program does not specify a version number of -this License, you may choose any version ever published by the Free Software -Foundation. - - 10. If you wish to incorporate parts of the Program into other free -programs whose distribution conditions are different, write to the author -to ask for permission. For software which is copyrighted by the Free -Software Foundation, write to the Free Software Foundation; we sometimes -make exceptions for this. Our decision will be guided by the two goals -of preserving the free status of all derivatives of our free software and -of promoting the sharing and reuse of software generally. - - NO WARRANTY - - 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY -FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN -OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES -PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED -OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF -MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS -TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE -PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, -REPAIR OR CORRECTION. - - 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING -WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR -REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, -INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING -OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED -TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY -YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER -PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE -POSSIBILITY OF SUCH DAMAGES. - - END OF TERMS AND CONDITIONS - Appendix: How to Apply These Terms to Your New Programs - - If you develop a new program, and you want it to be of the greatest -possible use to the public, the best way to achieve this is to make it -free software which everyone can redistribute and change under these terms. - - To do so, attach the following notices to the program. It is safest -to attach them to the start of each source file to most effectively -convey the exclusion of warranty; and each file should have at least -the "copyright" line and a pointer to where the full notice is found. - - <one line to give the program's name and a brief idea of what it does.> - Copyright (C) 19yy <name of author> - - This program is free software; you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation; either version 2 of the License, or - (at your option) any later version. - - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. - - You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - -Also add information on how to contact you by electronic and paper mail. - -If the program is interactive, make it output a short notice like this -when it starts in an interactive mode: - - Gnomovision version 69, Copyright (C) 19yy name of author - Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. - This is free software, and you are welcome to redistribute it - under certain conditions; type `show c' for details. - -The hypothetical commands `show w' and `show c' should show the appropriate -parts of the General Public License. Of course, the commands you use may -be called something other than `show w' and `show c'; they could even be -mouse-clicks or menu items--whatever suits your program. - -You should also get your employer (if you work as a programmer) or your -school, if any, to sign a "copyright disclaimer" for the program, if -necessary. Here is a sample; alter the names: - - Yoyodyne, Inc., hereby disclaims all copyright interest in the program - `Gnomovision' (which makes passes at compilers) written by James Hacker. - - <signature of Ty Coon>, 1 April 1989 - Ty Coon, President of Vice - -This General Public License does not permit incorporating your program into -proprietary programs. If your program is a subroutine library, you may -consider it more useful to permit linking proprietary applications with the -library. If this is what you want to do, use the GNU Library General -Public License instead of this License. - - -</BODY> -</HTML> - diff --git a/sql-ledger/doc/README b/sql-ledger/doc/README deleted file mode 100644 index 7585f5357..000000000 --- a/sql-ledger/doc/README +++ /dev/null @@ -1,287 +0,0 @@ - SQL-Ledger Accounting - Version 2.0 - - -DESCRIPTION: ------------- -SQL-Ledger is a double-entry accounting program written -in perl. It has been tested with PostgreSQL, Oracle, -Apache, Netscape, Mozilla, Galeon, Explorer, Links, Lynx, -Konqueror, Voyager, W3M and Opera clients on Linux, FreeBSD, -Solaris, Windows and Mac computers. - -Data is stored in a SQL server, either locally or remote, -the display is through a text or GUI web browser. The system -is linked by a chart of accounts. All transactions for AR, -AP and GL are stored in a transaction table. Hyper-links -from the chart of accounts let you view transactions posted -through AR, AP and GL. - -Configuration files let you specify to which SQL server -to connect to, personal preferences such as company name, -language, number and date format, etc. - -The admin script can be used to create, edit or delete users -and to create and delete datasets and to setup the Chart -of Accounts and templates needed for the system. -It can be used for PostgreSQL and Oracle. If you want to -use another SQL server the tables and chart of accounts -must be created by hand. - -You can have a group of users using the same dataset and -templates for generating Invoices, Income Statements and -Balance Sheets or a different set altogether. - -Templates are supplied in html and tex format to generate -most of the forms. Forms can be printed to screen, sent -to a printer or to a mailer agent. To use the tex forms -latex must be installed. Most systems have a latex binary -installed by default. Latex is also available for Windows -and the Mac so we stay compatible across all major platforms. - - -COPYRIGHT: ----------- -You may distribute under the terms of the GNU License. - - -LATEST VERSION: ---------------- -available from http://www.sql-ledger.org - - -PLATFORMS: ----------- -Non specific, see requirements. - - -REQUIREMENTS: -------------- -1 - Perl, 5+ -2 - http server (Apache, NCSA, httpi, ...) -3 - SQL Server with transaction support (PostgreSQL 7.0+, Oracle) -4 - DBD (DBD-Pg, DBD-Oracle) -5 - DBI -6 - LaTeX (optional) - - -FOREIGN LANGUAGE SUPPORT: -------------------------- -All the required files are in locale/country_code -The main files are 'all' and 'missing'. You can enter -translated strings in either file. When you are done -run locales.pl from the command line to rebuild the -required files. - -Some of the translation files are not 100% complete. -If strings are missing, English is used instead. - - -INSTALLATION: -------------- -unpack the tar.gz file in /usr/local - - tar xzvf sql-ledger-x.x.x.tar.gz - -you should now have everything in /usr/local/sql-ledger - -copy sql-ledger.conf.default to sql-ledger.conf - -edit sql-ledger.conf - -create a file sql-ledger-httpd.conf in the same location -where your httpd.conf is and copy the next section into the file - - Alias /sql-ledger/ /usr/local/sql-ledger/ - <Directory /usr/local/sql-ledger> - AddHandler cgi-script .pl - Options ExecCGI Includes FollowSymlinks - </Directory> - - <Directory /usr/local/sql-ledger/users> - Order Deny,Allow - Deny from All - </Directory> - -edit httpd.conf and add - - # SQL-Ledger - Include <ServerRoot>/sql-ledger-httpd.conf - -Note: Replace <ServerRoot> with the server's root directory! - -restart your web server. - - -Note: /usr/local/sql-ledger is only a suggested -path, you can install in any directory. - - -INSTALLATION WITH setup.pl: ---------------------------- -Make a directory - - mkdir /usr/local/sql-ledger - -Copy setup.pl to /usr/local/sql-ledger - -run setup.pl as root and follow the prompts. - -Go to the next step, "PREPARE YOUR SQL SERVER". - - -SET PERMISSION: ---------------- -change directory to /usr/local/sql-ledger - -# chown nobody:nobody users templates - -replace nobody:nobody with the web server -user of your system. Some systems use -apache:apache, www, www-data, ... - - -PREPARE YOUR SQL SERVER: ------------------------- - - PostgreSQL: - ----------- - add one database user with create database privileges - to manage the datasets and tables for SQL-Ledger - - # su postgres - $ createuser -d sql-ledger - - if you use passwords to access postgres set the user up with a password - $ createuser -d -P sql-ledger - - Answer no to the following question. - Shall the new user be allowed to create more new users? (y/n) n - - You can add more database users to keep datasets - separated. Each dataset belongs to one company. - - - ORACLE: - ------- - add one user and one tablespace - all datasets share the same tablespace - - -SETUP A DATABASE AND THE TABLES: --------------------------------- -Load your web browser and connect to -http://localhost/sql-ledger/admin.pl - -Tables are created with the "Database -Administration" function. - -Select the "Database Administration" link, -enter a host, port and user you created in the -previous step. - -The "Create Dataset" link queries the server -for existing datasets and displays them in a -column. Then you enter a name for the new -dataset and select one of the Chart of Accounts -and click on Continue. -Your new dataset and the tables will be created -and the selected Chart of Accounts loaded. The -owner of the tables is the user you entered in -the previous screen. - -NOTE: Be patient, some of the charts are really -big and take some time to create. - -The "Delete Dataset" link queries the server -for datasets which are in use by SQL-Ledger -and are not used by any members. This may -take a while to figure out. "Be patient". -If there are any datasets not in use, you get -a screen with the datasets listed where you -can select the one you want to delete. - -NOTE: you cannot manage any other datasets -from this interface, only the datasets used -by SQL-Ledger. - - -SETUP A USER: -------------- -Load your web browser and connect to -http://localhost/sql-ledger/admin.pl - -Click on "Add User". In the Database -section select the driver and enter -the user you used to create the dataset. - - -LOAD THE ACCOUNTING PROGRAM: ----------------------------- -Load your web browser and connect to -http://localhost/sql-ledger/login.pl - - -UPGRADING TO A NEWER VERSION: ------------------------------ -1. unpack the new version over top -2. check the doc directory for specific notes -3. load admin.pl - click on "Database Administration" - enter the dba in the "Connect to" field - click on "Update Dataset" - select the datasets and click "Continue" - - -UPGRADING WITH setup.pl: ------------------------- -run setup.pl from the command line and follow -the prompts. - - -INSTALLATION CHECKLIST: ------------------------ -1. untar SL somewhere -2. change permissions for the users and templates directory -3. edit httpd.conf -4. edit sql-ledger.conf -5. a) add the database user sql-ledger in PostgreSQL - b) add a tablespace and the database user sql-ledger in Oracle -6. load admin.pl -7. create datasets for the companies -8. add users - - In the Database section enter - - a) PostgreSQL - - Host: for local connections leave empty - Dataset: the dataset created in step 7 - Port: for local connections leave empty - User: sql-ledger - Password: password for sql-ledger - - b) Oracle - - SID: system ID - Port: the port Oracle is listening on - Dataset: the dataset created in step 7 - Password: password for connection - - -IF SOMETHING DOESN'T WORK: --------------------------- -There is a FAQ online which addresses various questions. -see http://www.sql-ledger.org/misc/faq.html - -There are also several mailing lists at -http://www.sql-ledger.org/misc/mailinglist.html -where you can go for help. - -If you require support you can order online at -http://www.sql-ledger.com/misc/support.html - - -===================================================================== -December 4, 2002 - diff --git a/sql-ledger/doc/UPGRADE-1.6-1.8 b/sql-ledger/doc/UPGRADE-1.6-1.8 deleted file mode 100644 index b5631b283..000000000 --- a/sql-ledger/doc/UPGRADE-1.6-1.8 +++ /dev/null @@ -1,61 +0,0 @@ -Upgrading from version 1.6 to 1.8 - -1. make a backup copy of your databases and SQL-Ledger, just in case! - $ cd /usr/local/www/sql-ledger - $ pg_dump database > db.out - $ tar cvf ~/sql-ledger.tar . - -2. install SQL-Ledger over top of your old installation - $ cd /usr/local/www - $ tar zxvf sql-ledger-1.8.0.tar.gz - -3. change the tables to the new layout - $ cd sql-ledger/sql - $ psql database < upgrade-1.6-1.8.sql - -4. copy the new master templates to your template directory - $ cd ../templates - - $ cp Default-email_purchase_order.html your_template_dir/email_purchase_order.html - $ cp Default-purchase_order.html your_template_dir/purchase_order.html - $ cp Default-email_sales_order.html your_template_dir/email_sales_order.html - $ cp Default-sales_order.html your_template_dir/sales_order.html - -5. Two new accounts were hopefully added to your chart of accounts - One account for Foreign Exchange Gains and one for - Foreign Exchange Losses - edit and change to suit your COA. You can safely change - the account number too. - -6. Edit your preferences - - In field 'Stylesheet' enter -> sql-ledger.css - Stylesheet is in the css directory - - Add your foreign currencies in the Currencies field - The first currency in the list is your default - i.e CDN:USD:EUR:YEN - If you used a nativecurr than it should be listed in the - new currencies field. - -7. <%nativecurr%> has changed to <%currency%> - edit all your templates and change nativecurr to currency - -8. I also added four more variables which can be used in your templates. - <%contact%>, <%shiptocontact%>, <%shiptophone%>, <%shiptofax%> - -9. Nameing convention for templates has changed from an - underscore to a minus sign. If you designed your own - master templates rename the templates from - industry_invoice.html to industry-invoice.html, - industry_packing_list.html to industry-packing_list.html, etc. - The minus sign is used to separate the name and list them in - the setup screen. - - This change only applies to the master templates in the - templates root directory NOT the individual templates which - are used by users. - -It looks more than it really is. Steps 1 to 4 are important, -the rest is for fine tuning and info. - diff --git a/sql-ledger/doc/UPGRADE-1.8-1.8.3 b/sql-ledger/doc/UPGRADE-1.8-1.8.3 deleted file mode 100644 index babed3793..000000000 --- a/sql-ledger/doc/UPGRADE-1.8-1.8.3 +++ /dev/null @@ -1,23 +0,0 @@ -Upgrading from version 1.8.(0-2) to 1.8.3 - -1. install SQL-Ledger over top of your old installation - $ cd /usr/local - $ tar zxvf sql-ledger-1.8.3.tar.gz - -2. copy sql-ledger.conf.default to sql-ledger.conf - $ cp sql-ledger.conf.default sql-ledger.conf - - if you modified sql-ledger.conf merge the changes from the - .default file rather than copying over top. - -3. copy the new master templates to your template directory - $ cd ../templates - - $ cp Default-invoice.tex your_template_dir/invoice.tex - $ cp Default-packing_list.tex your_template_dir/packing_list.tex - $ cp Default-purchase_order.tex your_template_dir/purchase_order.tex - $ cp Default-sales_order.tex your_template_dir/sales_order.tex - -4. edit sql-ledger.conf - instructions are in the file - diff --git a/sql-ledger/doc/UPGRADE-1.8.3-1.8.4 b/sql-ledger/doc/UPGRADE-1.8.3-1.8.4 deleted file mode 100644 index c3ecdf5af..000000000 --- a/sql-ledger/doc/UPGRADE-1.8.3-1.8.4 +++ /dev/null @@ -1,10 +0,0 @@ -Upgrading from version 1.8.3 to 1.8.4 - -1. install SQL-Ledger over top of your old installation - $ cd /usr/local - $ tar zxvf sql-ledger-1.8.4.tar.gz - -2. update the tables with the admin script - - You will not be able to log in until you upgraded the tables. - diff --git a/sql-ledger/doc/UPGRADE-1.8.4-1.8.5 b/sql-ledger/doc/UPGRADE-1.8.4-1.8.5 deleted file mode 100644 index e8c32e1bf..000000000 --- a/sql-ledger/doc/UPGRADE-1.8.4-1.8.5 +++ /dev/null @@ -1,18 +0,0 @@ -Upgrading from version 1.8.4 to 1.8.5 - -1. install SQL-Ledger over top of your old installation - $ cd /usr/local - $ tar zxvf sql-ledger-1.8.5.tar.gz - -2. update the tables with the admin script - - You will not be able to log in until you upgraded the tables. - - -There are two new variables (<%customernumber%> and <%vendornumber%>) -which can be used in the forms. These may be used instead of the -internally generated customer_id and vendor_id. - -Typically these numbers are used to retrieve a customer, vendor -by some ID. In most counter operations the phone number is used. - diff --git a/sql-ledger/doc/UPGRADE-1.8.5-1.8.7 b/sql-ledger/doc/UPGRADE-1.8.5-1.8.7 deleted file mode 100644 index 992238c3a..000000000 --- a/sql-ledger/doc/UPGRADE-1.8.5-1.8.7 +++ /dev/null @@ -1,6 +0,0 @@ -Upgrading from version 1.8.5 to 1.8.7 - -1. install SQL-Ledger over top of your old installation - $ cd /usr/local - $ tar zxvf sql-ledger-1.8.7.tar.gz - diff --git a/sql-ledger/doc/UPGRADE-1.8.7-2.0.0 b/sql-ledger/doc/UPGRADE-1.8.7-2.0.0 deleted file mode 100644 index e16ba7556..000000000 --- a/sql-ledger/doc/UPGRADE-1.8.7-2.0.0 +++ /dev/null @@ -1,20 +0,0 @@ -Upgrading to Version 2.0.0 - -1. install SQL-Ledger over top of your old installation - $ cd /usr/local - $ tar zxvf sql-ledger-2.0.0.tar.gz - -2. load admin.pl and update the tables - - You will not be able to log in until the tables are up to date. - -3. copy the new templates to your personal template directory - - $ cd templates - $ cp Default-check.tex dir/check.tex - $ cp Default-receipt.tex dir/receipt.tex - $ cp Default-statement.html dir/statement.html - $ cp Default-statement.tex dir/statement.tex - - replace 'dir' with your directory name - diff --git a/sql-ledger/doc/UPGRADE-2.0-2.0.8 b/sql-ledger/doc/UPGRADE-2.0-2.0.8 deleted file mode 100644 index 6ddff62ac..000000000 --- a/sql-ledger/doc/UPGRADE-2.0-2.0.8 +++ /dev/null @@ -1,8 +0,0 @@ -Upgrading from version 2.0.[0-7] to 2.0.8 - -1. install SQL-Ledger over top of your old installation - $ cd /usr/local - $ tar zxvf sql-ledger-2.0.8.tar.gz - -2. update your datasets with the admin script - diff --git a/sql-ledger/doc/copyright b/sql-ledger/doc/copyright deleted file mode 100644 index d493a3d21..000000000 --- a/sql-ledger/doc/copyright +++ /dev/null @@ -1,23 +0,0 @@ -###################################################################### -# SQL-Ledger Accounting -# Copyright (c) 2003, Dieter Simader -# -# Author: Dieter Simader -# Email: dsimader@sql-ledger.org -# Web: http://www.sql-ledger.org -# -# This program is free software; you can redistribute it and/or modify -# it under the terms of the GNU General Public License as published by -# the Free Software Foundation; either version 2 of the License, or -# (at your option) any later version. -# -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY; without even the implied warranty of -# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -# GNU General Public License for more details. -# You should have received a copy of the GNU General Public License -# along with this program; if not, write to the Free Software -# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. -# -####################################################################### - diff --git a/sql-ledger/doc/faq.html b/sql-ledger/doc/faq.html deleted file mode 100644 index 0f6f237ca..000000000 --- a/sql-ledger/doc/faq.html +++ /dev/null @@ -1,747 +0,0 @@ -<ul> -<p><li><h4>Sub-menus and Apache 2.0</h4> -Some versions of Apache 2.0 (2.0.44+) don't expand sub-menus and generate -a 500 error at various points. This stems from workaround developed for -earlier versions of Apache 2.0. It looks like this workaround must now be -disabled. If you get an error or the sub-menus don't expand edit -SL/Form.pm and comment lines 80-82. -<pre> - # for Apache 2 we escape strings twice -# if (($ENV{SERVER_SOFTWARE} =~ /Apache\/2/) && !$beenthere) { -# $str = $self->escape($str, 1); -# } -</pre> - - -<p><li><h4>About installation</h4> -The easiest is to use the setup.pl script as root. -You don't need to know very much about your system, just login as root, -run 'perl setup.pl' and follow the prompts. -<p>setup.pl does not check for missing software packages and it is your -responsibility to make sure you have the required pieces -installed either from source or from a package supplied with your distro. - -<p>Requirements are clearly indicated in the README file and on the -download page. - - -<p><li><h4>IDENT Authentication failed for user "postgres"</h4> - -This error has everything to do with the way the distros set up -access rights for postgres. They are way too restrictive and leave you -wondering what to do next. - -<p>Do yourself a favour and change authentication in pg_hba.conf to - -<pre> -local all trust</pre> - -<p>until you have figured what all this stuff in pg_hba.conf does. - -<p><b>NOBODY</b>, I repeat, <b>NOBODY</b>, from the Internet will be able to -connect to postgres. You can't even connect from the inside LAN, the only -one who is allowed to connect are clients originating from localhost. - -<p>Read a bit about the different authentication settings and change -them as you see fit. -It is all described in detail in pg_hba.conf - -<p>If you can't find the file, there is a wonderful utility called find. -Use it. -<pre> -# find /usr/local -type f -name 'pg_hba.conf' -</pre> - - -<p><li><h4>DBD-Pg for Mandrake 9.0</h4> -Mandrake did not package a compiled DBD-Pg package again, so install DBD-Pg -from the source package. -Install perl-DBD-Pg-1.01-4mdk.i586.rpm from the 'contrib' area. -(Mandrake / 9.0 / contrib / RPMS) - -<p><li><h4>LaTeX error</h4> -If for some reason LaTeX produces an error message check for strange -characters in your account description and parts description -and use \usepackage[latin1]{inputenc} in the preamble. - - -<p><li><h4>LaTeX templates</h4> -If you don't want to edit tex code by hand, -you could use Lyx, Abiword, or any WYSIWYG editor capable of exporting -latex code. -To do that you must change the tokens for parameters <% and %> to something -like << and >>. % is the comment character in tex. There is also a -pagebreak block which must be commented out. -When you are done with the changes -replace << and >> with <% and %> and uncomment the pagebreak block. - -<p>LaTeX is difficult but it also offers a much superior interface to produce -professionally looking forms in postscript and PDF format. -Unfortunately with power comes some pain too. - - -<p><li><h4>W3M</h4> -pass terminal=mozilla when you start w3m -<pre>$ w3m -F http://localhost/sql-ledger/login.pl?terminal=mozilla</pre> - -To use without frames -<pre>$ w3m http://localhost/sql-ledger/login.pl?terminal=lynx</pre> - -<p><li><h4>PDF option disappeared</h4> -Edit sql-ledger.conf and set $latex = 1; -<br>sql-ledger.conf is perl code, check if it compiles, if it does not -the internal defaults are used which set $latex to 0, hence no PDF option. - -<p><li><h4>SQL-Ledger on Mac Os X 10.1.5</h4> -Jaume Teixi put together -<a href=http://www.rocacorbit.com/techdocs/sql_ledger_os_x.html> -installation instructions</a> to run SL on a Mac. -<br>The instructions are for 1.8.5 however they still apply to any of the -newer versions. - -<p><li><h4>Installation on Windows (WIN32)</h4> -<ul> -<li>install Apache, perl, -<a href=http://techdocs.postgresql.org/guides/InstallingOnWindows>Postgres</a> -or Oracle, DBI and the appropriate DBD -module -<br>if you can't compile DBD-Pg here is a precompiled -<a href=http://www.edmund-mergl.de/export/>DBD-Pg module</a> -<li>download the latest version of <a href=/cgi-bin/nav.pl?page=source/index.html&title=Download>SQL-Ledger</a> -<li>extract the files to c:\apache\sql-ledger -<li>download -<a href=../source/sql-ledger-windows.tar.gz>sql-ledger-windows.tar.gz</a> -and extract the files to c:\apache\sql-ledger - <br>the shebang line is changed to c:\perl\bin\perl and the symlinks - are regular files -<br>answer with 'Yes' to overwrite existing files. -<li>edit c:\apache\conf\httpd.conf and add -<pre> -Alias /sql-ledger/ "C:/apache/sql-ledger/" -<Directory "c:/apache/sql-ledger"> - AllowOverride All - AddHandler cgi-script .pl - Options +ExecCGI - Order Allow,Deny - Allow from All -</Directory> - -<Directory "c:/apache/sql-ledger/users"> - Order Deny,Allow - Deny from All -</Directory> -</pre> - -<li>start Apache -<li>start Postgres|Oracle -<li>connect to http://localhost/sql-ledger/admin.pl and setup users -and datasets -<li>connect to http://localhost/sql-ledger/login.pl and login - -</ul> - -<p><li><h4>Installation on Windows /w cygwin</h4> -<ul> -<li>install <a href=http://sources.redhat.com/cygwin/>cygwin</a> -Apache, perl, postgres, gcc and lynx -<li>install <a href=http://search.cpan.org/search?module=DBI>DBI</a> -<li>tar zxvf DBI-1.30.tar.gz -<li>cd DBI-1.30 -<li>perl Makefile.PL -<li>make install -<li>install <a href=http://search.cpan.org/search?dist=DBD-Pg>DBD-Pg</a> -<li>tar -zxvf DBD-Pg-1.13.tar.gz -<li>export POSTGRES_INCLUDE=/usr/include/postgresql -<li>export POSTGRES_LIB=/usr/lib/postgresql -<li>cd DBD-Pg-1.13 -<li>perl Makefile.PL -<li>make install -<li>edit /etc/apache/httpd.conf and add -<pre> -AddHandler cgi-script .pl -Alias /sql-ledger/ /var/www/sql-ledger/ -<Directory /var/www/sql-ledger> - Options +ExecCGI -</Directory> - -<Directory /var/www/sql-ledger/users> - Order Deny,Allow - Deny from All -</Directory> -</pre> -<li>install SQL-Ledger -<li>cd /var/www -<li>mkdir sql-ledger -<li>download <a href=/cgi-bin/download.pl?setup.pl>setup.pl</a> and save the file -in /var/www/sql-ledger -<li>cd /var/www/sql-ledger -<li>perl setup.pl -</ul> - -<p><li><h4>What do I enter for the language</h4> -If you use English, nothing, if you want to use a foreign language for -the login screen and admin stuff enter the language code. All the -language specific files are in the locale directory. The long form for -the language is in the LANGUAGE file. - -<p><li><h4>Mandrake 9.0 permission denied error</h4> -Mandrake says to add this to your commonhttpd.conf -<pre> -<Directory /usr/local/sql-ledger> - AllowOverride All - Options -MultiViews -Indexes -FollowSymLinks - Order allow,deny - Allow from all -</Directory> - -The way apache starts is it: -Blocks all access to the physical file system / -Opens access to the physical file system /var/www/html -Opens access to the physical file system /var/www/perl -Opens access to the physical file system /var/www/cgi-bin -Opens access to the physical file system /var/www/protected-cgi-bin -Opens access to the physical file system /home/*/public_html -Opens access to the physical file system /home/*/public_html/cgi-bin -Opens access to the physical file system /var/www/icons -Opens access to the physical file system /usr/share/doc - -Since you're trying to access files outside of those allowed paths, you -have to specifically allow it. It's done this way because of some past -exploits with the pathnames. Rather than trust that there will never be -another bug within apache that will let you get somewhere you don't -want, you set it up securely out of the box so that apache won't let -itself go somewhere that you don't want it to. -</pre> - - -<p><li><h4>Incorrect Dataset version</h4> -The dataset you are trying to use is not compatible with the version. -When you upgrade datasets use the same database user in the "User" -field as the one listed in the Database section for the user. - - -<p><li><h4>Mandrake 8.2</h4> -Mandrake did not include the package "perl-DBD-Pg-1.01-1mdk.i586.rpm" -You can install the package from Mandrake 8.1 - - -<p><li><h4>printing to a printer</h4> -Setup a printer in the "Printer" field in the users preferences. -i.e lpr -Plaser -and set $latex = 1 in sql-ledger.conf -LaTeX must be installed for this to work. - -<p>To send the document to the printer check the "Postscript" or "PDF" format, -enter the number of copies and click on the "Print" button. - -<p>The printer field is available only when you edit the user's -preferences with admin.pl. - -<p>Note: html format is for screen preview. Use your browser's -print function. - - -<p><li><h4>beginning balances</h4> -Add a GL Journal entry and enter the beginning balance for your accounts. -Use your balance sheet. If you also want to add open invoices, add the invoices -and make the appropriate adjustments. Your balance sheet includes these -amounts! - - -<p><li><h4>cost for parts and service</h4> -the cost will be updated when you purchase goods and services. You can -enter the cost manually. This is so you can have a cost on file without -making a purchase. - - -<p><li><h4>establish a beginning inventory</h4> -add the parts with a purchase invoice. Use the <b>real cost</b> for the items -not zero. If you use zero cost then the cost of goods will be zero when you -sell the item. - - -<p><li><h4>Assemblies</h4> -Assemblies are manufactured goods assembled from parts, services and -assemblies. Because you do not buy assemblies you 'stock assemblies' by -adding assembled units to your inventory. The quantity for individual parts -is reduced and the quantity for the assembly increased. To disassemble an -assembly you simply return the parts to inventory by entering a negative -quantity for the number of assemblies to stock. - - -<p><li><h4>customizing SQL-Ledger</h4> -The <a href=/cgi-bin/nav.pl?page=feature/api.html&title=Application%20Interface>application interface</a> -consists of a global and private interface. - - -<p><li><h4>DBD-Pg not installed</h4> - -Most modern distributions now package DBD-Pg. If it is -not packaged follow this recipe to get it working. - -<ul> - <li>check if you have the header files for PostgreSQL - <br>$ find / -name 'libpq-fe.h' - <br>if nothing shows up install the development package for PostgreSQL - <li>download and untar DBD-Pg - <li>set the environment variables POSTGRES_LIB and POSTGRES_INCLUDE - <li>cd to DBD-Pg directory - <br>as ordinary user - <br>$ perl Makefile.PL - <br>$ make - <br>$ make test - <br>if all went well su to root - <br># make install - <li>remove DBD-Pg -</ul> - - -<p><li><h4>SuSE 8.1 installation</h4> -<ol> -<li>Install the following using YaST2: - -<p>- perl-DBD-Pg -<br>- postgresql -<br>- postgresql-contrib -<br>- postgresql-devl -<br>- postgresql-docs -<br>- postgresql-libs -<br>- postgresql-perl -<br>- postgresql-server -<br>- postgresql-test - -<p><li>Setup directories and paths for PostgreSQL: - -<p>> sux - (change to root) - -<p>- If not done by the installation, setup disk directory for your db: -<br># mkdir /var/lib/pgsql/data -<br># chown postgres /var/lib/pgsql/data - -<p><li>Initialize the database, and start it, as below: -<p>Note that there are man pages for initdb and pg_ctl. - -<p># touch /var/log/pgsql -<br># chown postgres:postgres /var/log/pgsql -<br># sux postgres - -<p>- Initialize postgres: -<br>> /usr/bin/initdb -D /var/lib/pgsql/data -<br>(creating ... Success...) - -<p>- Start the postgres daemon: -<br>> /usr/bin/pg_ctl -D /var/lib/pgsql/data -l /var/log/pgsql start (start db) -<br>(postmaster successfully started) - -<p><li>Quick-test the server (still as user postgres): - -<p>- > psql -d template1 -<br>(Welcome ... \q to exit psql) -<br>\q - -<p>- Try setting up another db user: - -<p>> createuser <db-user> (<db-user> should match an existing Linux user) -<br>Shall the new user be allowed to create databases? (y/n) y -<br>Shall the new user be allowed to create more new users? (y/n) n - -<p>Unless a problem with DBD::Pg (perl interface), postgres is ready to go. - -<p><li>If a previous sql-ledger database needs to be installed, -<br>do the following as postgres user. Steps for dumping the old db, - and building the new follow: - -<p>> sux postgres -<br>> psql template1 -<br>=# CREATE DATABASE my_database; (create your database) -<br>=# \q -<br>> cd /var/lib/pgsql/backups (assuming your backups are here) -<br>The next command should have been performed earlier from the - previous installed version of postgres and your database: -<br>> pg_dump -d my_database.sql.bak (from previous ver postgres) -<br>> cp my_database.sql.bak my_database.sql -<br>- Use vi to change all occurrances of 'current_date' to current_date - in file my_database.sql . -<br>The vi command for this is :g/'current_date'/s//current_date/g -<br>> psql my_database < my_database.sql > my_database.log -<br>- Check my_database.log for errors. - -<p><li>Download setup.pl and run it as root while on line to the internet: - -<p># mkdir /usr/local/sql-ledger -<br># cd /usr/local/sql-ledger -<br># ./setup.pl -<br>- Enter i -<br>- Enter httpd owner and group if different than displayed default. -<br>(Download occurs and status is displayed...) - -<p><li>Setup the new sql-ledger with database. - -<p>- Surf to http://my_computer/sql-ledger/admin.pl -<br>- Click enter (no password needed). -<br>->Database Administration -<br>- Leave fields Host and Port enpty for local installations. -<br> - Enter your database name in the "Connect to" field. -<br> - Enter the database user you setup (postgres, sql-ledger, etc.) -<br> - Enter a password, only if a password is assigned to the database. -<br> - To update an existing sql-ledger database: ->Update Database -<br> Should see: The following Datasets need to be updated. -<br> ->Continue -<br> Do more admin. You will need to setup at least one login. -<br> To exit: ->Database Admin - -<p><li>See if it works: - -<p> - Surf to http://my_computer/sql-ledger/login.pl -<br> - Enter the login name you just created. Main menu screen should appear. -</ol> - - - -<p><li><h4>Redhat Installation</h4> - -<ul> -<li>Install apache1.3.12-25.i386.rpm -<li>Install perl5.6.0-9.i386.rpm -<li>Install postgresql-7.0.2-17.i386.rpm -<li>Install postgresql-server-7.0.2-17.i386.rpm -<li>Install postgresql-devel-7.0.2-17.i386.rpm (POSTGRES_INCLUDE) -<li>tar xvzf DBI-1.14.tar.gz -<li>cd DBI-1.14 -<li>perl Makefile.PL -<li>make -<li>make install -<li>cd .. -<li>tar xvzf DBD-Pg-0.95 -<li>cd DBD-Pg-0.95 -<li>export POSTGRES_LIB=/usr/lib/pgsql -<li>export POSTGRES_INCLUDE=/usr/include/pgsql -<li>perl Makefile.PL -<li>make -<li>make install -<li>install SQL-Ledger -</ul> - -<p>Some of the applications have newer versions however the installation -instructions remain the same. Just substitute the old version with a newer -version. - - -<p><li><h4>Debian Installation</h4> - -<ul> -<li>unpack into /usr/local/www/sql-ledger -<li>install postgresql (Dselect) -<li>install apache (Dselect) -<li>install libdbi-perl (Dselect) -<li>install libdbd-pg-perl (Dselect) -<li>install libpgperl (Dselect) -<li>modify /etc/postgresql/postgresql.conf - <br>TCPIP_SOCKET = 1 -<li>create a user for managing SQL-Ledger databases -<br>from root -<br>su postgres -<br>$ createuser -d sql-ledger -<br>if you use passwords to access postgres set the user up with a password -<br>$ createuser -d -P sql-ledger -<li>change /etc/apache/httpd.conf and add -<pre> -AddHandler cgi-script .pl -Alias /sql-ledger/ /usr/local/www/sql-ledger/ -<Directory /usr/local/www/sql-ledger> - Options +ExecCGI -</Directory> - -<Directory /usr/local/www/sql-ledger/users> - Order Deny,Allow - Deny from All -</Directory> -</pre> -<li>restart apache -<li>change fileownership of users and templates to www-data - <br>chown www-data: users templates -<li>From browser enter http://localhost/sql-ledger/admin.pl -<li>Login as the postgres user (account manager) you have created (above) -<br>Create a DB -<br>Create users - -<li>then enter http://localhost/sql-ledger/login.pl -<br>Login as one of the users you have just created - -</ul> - -<p> -The long version was provided by Gordon Haverland. -<p> -<ul> -<li>You need to unpack the SQL-Ledger package (compressed tar archive) - someplace. Unpacking it in<pre> - /usr/local/www/sql-ledger.</pre> - Remember where you have unpacked it. -<li>SQL-Ledger requires that the PostgreSQL database be installed. -This is a very full-featured database, and has many associated -packages. SQL-Ledger requires version 7.0 or better. The name -of the basic package on Debian is postgresql. To find if you -already have postgresql installed, and if so what version, the -following command should work:<pre> - dpkg -l | grep -i 'ii postgresql '</pre> - A typical response would be:<pre> - ii postgresql 7.1.3-5 Object....[stuff deleted]</pre> - Indicating, that version 7.1.3 is installed (the -5 is a - Debian patch level). You can use dselect or apt-get to install - postgresql if you need to. You can visit the Debian maintainer's - page for much more information on related packages at<pre> - http://people.debian.org/~elphick/postgresql/</pre> - Older versions of Debian's PostgreSQL installation use a file - called postmaster.init, while newer versions use a file called - postmaster.conf, either residing in /etc/postgresql. -<li>SQL-Ledger requires a HTTP server (or daemon) which is capable of - handling CGI scripts. Apache is the one which is recommended, - version 1.3 or better. Debian calls the base package apache. - Debian has two alternative versions of Apache, one with mod-perl - (apache-perl) support compiled in, and the other with SSL - (secure sockets layer - apache-ssl) support. SQL-Ledger doesn't - require mod-perl or SSL support, but works with either if - you need it installed for other functions you have. Older versions - of Debian Apache installations, spread the configuration of the - server across 3 files (srm.conf, access.conf and httpd.conf). - Newer versions have consolidated all of this to httpd.conf. -<li>SQL-Ledger uses the Data Base Interface perl module for communication - with PostgreSQL. The CPAN (Comprehensive Perl Archive Network) - name for this module is DBI. Debian calls this module - libdbi-perl. You should probably deselect (or apt-get) the - Debian version of this module to minimize upgrading headaches in - the future. -<li>DBI requires the use of an implementation specific Data Base - Driver. In our case, we need the PostgreSQL specific one. - CPAN calls this module DBD::PG, Debian calls it libdbd-pg-perl. - You should use dselect (or apt-get) to install it. -<li>One more layer of Perl - PostgreSQL support is needed. Debian - calls this last package libpgperl. Use dselect or apt-get to - install it. (You should be able to install all 5 packages at - one time.) -<li>We need to allow your PostgreSQL database to accept queries - in a network manner. To do this, we need to change the value - of the TCPIP_SOCKET to 1. In newer - PostgreSQL installs, this variable will be someplace in - /etc/postgresql/postgreslq.conf (older installs will be - postmaster.init, same directory. Note: you shouldn't have - both files there.) Start up your favorite text editor, find - the line with that variable on it, change the "no" to a "yes", - and make sure the line isn't commented out (a "#" in front - of it on the same line). -<li>PostgreSQL has a set of users and passwords independent of - normal user logins. We need to set up a PostgreSQL user - to "own" the SQL-Ledger data (choose a name that makes sense - to you, it shouldn't be "root" or "postgres"). The (PostgreSQL) - program for doing this is called "createuser". To make this - SQL-Ledger owner user, we first need to "become" the PostgreSQL - superuser (on Debian, this is "postgres"), and then we will - run the createuser program. So, once we are logged in as root: -<pre> - # su postgres - $ createuser -d sql-ledger - ... - $ exit - # -</pre> - As shown above, we then typed "exit" after createuser was done, - to stop being the "postgres" user. The "-d" switch (you called - also use "--createdb") specifies that this user can create - databases. -<li>We need to adjust the configuration of the HTTP server Apache - next. Older Apache installations (srm.conf, access.conf and - httpd.conf) need changes in srm.conf and httpd.conf. Newer - installations just need to edit /etc/apache/httpd.conf. First, - we need to instruct the server that files that end in ".pl" - are to be treated as "cgi-script"s (srm.conf if separate).<pre> - AddHandler cgi-script .pl</pre> - Second, we need to map our SQL-Ledger installation to be easy - for users to find it (in srm.conf if separate).<pre> - Alias /sql-ledger/ /usr/local/www/sql-ledger/</pre> - The "/" at the end of sql-ledger in both strings is important! - Next, we need to allow the server to execute files from those - directories, include things and follow links. This information - is in httpd.conf (old or new installations).<pre> - <Directory /usr/local/www/sql-ledger> - Options ExecCGI Includes FollowSymLinks - </Directory></pre> - If we decided to put SQL-Ledger somewhere other than - /usr/local/www/sql-ledger, we would use different paths above. -<li>All the files in the "users" and "templates" subdirectories - of /usr/local/www/sql-ledger need to be owned by "www-data".<pre> - # cd /usr/local/www/sql-ledger - # chown www-data:www-data users templates users/members</pre> - You may get an "error" about users/members not existing. It - is safe to ignore this error. -<li>Restart the apache server.<pre> - /etc/init.d/apache restart</pre> -<li>From a browser, visit the URL<pre> - http://localhost/sql-ledger/admin.pl</pre> -<li>Login as the PostgreSQL user responsible for the SQL-Ledger - database you set up. Create a database and create - at least one user. (It's not a good idea to access your - SQL-Ledger data as the "owner" of the data on a regular basis.) -<li>Visit<pre> - http://localhost/sql-ledger/login.pl</pre> - and login as the user you created</pre> - -</ul> - - -<p><li><h4>login.pl has compilation error</h4> - -This could be because of a missing configuration file in the users directory - -<p>check the permission for the users directory. The directory must be -set writeable for the webserver. If your webserver runs under nobody.nogroup -set it to -<pre> -drwxrwx--x 2 johndoe nogroup 1024 May 26 16:49 users - -or - -drwx--x--x 2 nobody nogroup 1024 May 26 16:49 users -</pre> - - -<p><li><h4>script not executing, shows in browser instead</h4> - -Add - -<pre> - AddHandler cgi-script .pl -</pre> - -in your httpd.conf file. - - -<p><li><h4>unknown terminal!</h4> -the frontend script couldn't figure out which browser you are using -<p>include the terminal variable on the URL -<pre> - http://localhost/sql-ledger/login.pl?terminal=lynx</pre> -<p>Valid terminal variables are lynx and mozilla - - -<p><li><h4>permission denied at filesystem level</h4> - -Check if your web server has write permission to write to the following -files and directories: -<pre> - users/ - templates/ - users/members - - # chown nobody:nogroup users templates users/members -</pre> - - -<p><li><h4>permission denied to access tables</h4> -The user you entered in the "Database section" must be a valid -database user who has the rights to access the tables. - -<p>If the tables are owned by 'john' and you enter 'mary' as the dba -you might run into this problem if mary doesn't have the rights to -access tables owned by john. - - -<p><li><h4>html and graphics files don't show up on screen</h4> - -Enable Includes and FollowSymlinks Options in your httpd.conf file -<pre> <Directory /usr/local/sql-ledger> - Options ExecCGI Includes FollowSymlinks - </Directory> -</pre> - - -<p><li><h4>Can I use mySQL</h4> - -No. mySQL lacks certain features required by SQL-Ledger. - - -<p><li><h4>switch display to a foreign language</h4> - -Load your preferences and select the language. -<br>Language selection is in accordance to -<a href=http://www.unece.org/cefact/locode/service/main.htm> -ISO 3166-1</a> standards. - - -<p><li><h4>Text shows in English when I use a foreign language</h4> - -This is because the corresponding hash entry is missing. -Add the missing text in the locale/cc/all or locale/cc/missing -file and run 'perl locales.pl' to rebuild the individual files. - -<br>cc refers to the country code. - - -<p><li><h4>switch to a foreign language for the login and admin screen</h4> - -Edit sql-ledger.conf and enter the code for the variable -$language. If your language specific files are in 'locales/cc', enter 'cc' - - -</ul> - -<p> -<hr> -<a name=security> -<h1>SQL-Ledger security</h1> -</a> - -<ul> -<li>The security features built into SQL-Ledger provide encrypted passwords -and access control which makes it fairly safe out of the box to run even in -front of a firewall. -Some precautions which are out of our control must be taken though. -It matters where you install SL and how you configure your web and SQL server. - -<pre> - Typical setups: - - /usr/local/vh/www <- DocumentRoot for virtual host - /usr/local/vh/sql-ledger <- Alias for sql-ledger - /usr/local/vh/users <- users directory out of reach - -<hr width=60% align=left> - /usr/local/vh/www <- DocumentRoot for virtual host - /usr/local/vh/www/sql-ledger <- Alias for sql-ledger - /usr/local/vh/www/sql-ledger/users <- users configuration files and tmp space - - <Directory /usr/local/vh/www/sql-ledger/users> <- disable webserver access - Order Deny,Allow for users directory - Deny from All - </Directory> - -</pre> - -The location for the users directory can be specified in sql-ledger.conf - -<p><li>Set permission for the users and templates directory to 711 -(most restrictive) - -<p><li>If you do not want anyone to change the templates with the built-in -editor set the files in templates/directory/ to read only or disable -the menu item to edit the templates. - -<p><li>For PostgreSQL you can set who has access to the server in the file -pg_hba.conf -<br>Authentication crypt does not work because not all SQL servers -accept encrypted passwords. - -<p><li>in addition you can secure the tables from unauthorized access by -setting up a different database user and GRANT rights. For instance, -users without DELETE rights will still be able to use the program, change -customers or vendors but will not be able to delete transactions. -To lock all the tables GRANT SELECT rights only. - -<p><li>Other security options include a secure shell, your webserver's -authentication system, SSL, encrypted tunnels, ... - -</ul> - -</BODY> -</HTML> - |