Master repository for the LedgerSMB project
ehuelsmann Merge pull request #3888 from nick-prater/remove-unused-subtotal_cols
Remove unused subtotal_cols() method from Report modules
Latest commit 12a28fa Oct 20, 2018
Failed to load latest commit information.
.github Add note about skipping Travis CI tests to default PR template Dec 31, 2017
.tx * Add transifex administration directory Dec 24, 2015
UI Merge pull request #3887 from ehuelsmann/update-package.json Oct 19, 2018
bin * Complete renaming/moving pre-defined JSON responses (and complete m… Sep 19, 2018
doc * Remove CSSDIR variable Jun 3, 2018
lib Remove unused subtotal_cols() method from Report modules Oct 20, 2018
locale * Update translations in order to update Report-Msgid-Bugs-To (Closes #… Jun 27, 2018
old Merge pull request #3880 from nick-prater/refactor-get_account Oct 15, 2018
sql Remove menu option 'General Journal > Add Accounts' Oct 19, 2018
t * Output explanation only in verbose mode (silences tests on Travis) Sep 28, 2018
templates * Update templates now line-breaks are the template's responsibility Feb 25, 2018
utils Update the development PSGI to cope with new location (#3724) Jul 4, 2018
xt Fix critic test failures Oct 19, 2018
.gitattributes * Merge adjacent additions in sql/changes/LOADORDER instead of confli… Jan 1, 2017
.gitignore * Hide test output from git status Jun 24, 2016
.gitmodules * More submodule fixes May 17, 2016
.proverc * Compensate the fact that '.proverc' isn't included in the tarbal an… Aug 11, 2017
.travis.yml Update the development PSGI to cope with new location (#3724) Jul 4, 2018
CONTRIBUTORS * Update CONTRIBUTORS to list Nick as a committee member Mar 23, 2018
COPYRIGHT Initial Import Sep 1, 2006
Changelog Update Changelog Oct 14, 2018
LICENSE Removing executable bit from documentation Mar 24, 2007
Makefile * Recent behaviour of our minification changed May 31, 2018 Update Sep 1, 2018
cpanfile Fix minimum Plack::Request version to access QUERY_STRING Sep 5, 2018


Small and Medium business accounting and ERP

CII Best Practices Build Status GPLv2 Licence Coverage Status Docker Mentioned in Awesome <awesome-selfhosted>


LedgerSMB is a free integrated web application accounting system, featuring double entry accounting, budgetting, invoicing, quotations, projects, timecards, inventory management, shipping and more ...

The UI allows world-wide accessibility; with its data stored in the enterprise-strength PostgreSQL open source database system, the system is known to operate smoothly for businesses with thousands of transactions per week. Screens and customer visible output are defined in templates, allowing easy and fast customization. Supported output formats are PDF, CSV, HTML, ODF and more.

Directly send orders and invoices from the built-in e-mail function to your customers or RFQs (request for quotation) to your vendors with PDF attachments.

System requirements

Note that these are the system requirements for LedgerSMB 1.7; the planned next minor release. Please check the system requirements for the 1.5 production version and 1.6 version.


  • Perl 5.18+
  • PostgreSQL 9.4+
  • Web server (e.g. nginx, Apache, lighttpd)

The web external server is only required for production installs; for evaluation purposes a simpler setup can be used, as detailed below.


A Dojo 1.13 compatible web browser is all that's required on the client (except IE8 and 9); it includes Chrome as of version 13, FireFox as of 3.6 and MS Internet Explorer as of version 10 and a wide range of mobile browsers.

Quick start (Docker compose)

The quickest way to get the Docker image up and running is by using the docker-compose file available through the GitHub repository at:

which sets up both the LedgerSMB image and a supporting database image for production purposes (i.e. with persistent (database) data, with the exception of one thing: setting up an Nginx or Apache reverse proxy with TLS 1.2 support -- a requirement if you want to access your installation over any type of network.

See the documentation on Docker Hub.

Quick start (from source)

The instructions below are for getting started quickly; the project's site provides in-depth installation instructions for production installs.

System (library) dependencies

The following non-Perl (system) dependencies need to be in place for the cpanm command mentioned below to work, in addition to what's documented on the How to install CPAN modules page on CPAN.

  • cpanminus This can be manually installed, or installed as a system package. It may not be necessary to install cpanminus if you are only going to install from debian packages.
  • PostgreSQL client libraries
  • PostgreSQL server
  • DBD::Pg 3.4.2+ (so cpanm recognises that it won't need to compile it) This package is called libdbd-pg-perl in Debian and perl-DBD-Pg in RedHat/Fedora
  • make This is used by cpan dependencies during thier build process

Then, some of the features listed below have system requirements as well:

  • latex-pdf-ps depends on these binaries or libraries:
    • latex (usually provided through a texlive package)
    • pdflatex
    • dvitopdf
    • dvitops
    • pdftops

Perl module dependencies

This section depends on a working local::lib installation as well as an installed cpanm executable. Both should be available from your distribution's package repository (Debian calls them liblocal-lib-perl and cpanminus respectively). cpanm depends on the make and gcc commands being available.

NOTE: gcc can be removed after all cpan dependencies are installed. However, it may be necessary to reinstall it if additional modules are required during an upgrade

To install the Perl module dependencies, run:

 $ cpanm --quiet --notest --with-feature=starman [other features] --installdeps .

NOTE: Don't miss the "." at the end of the cpanm command! Don't forget to make sure the environment variable PERL5LIB=/home/ledgersmb/perl5/lib/perl5 points at the running user's perl5 dir Also, NEVER run cpanm as root, it's best to run it as the user you intend to run ledgersmb as when possible. This installs the cpan modules in ~/perl5 If you can't run it as the final user, don't worry, just run it as any user (eg: johnny), and make sure the environment variable PERL5LIB=/home/johhny/perl5/lib/perl5 points at jonny's perl5 dir

Setting the PERL5 environment variable is normally done by editing the initscript, or systemd service file. If you are running manually, then you will need to set and export PERL5 before running starman/plack

The following features may be selected by specifying --with-feature=<feature>:

Feature Description
latex-pdf-ps Enable PDF and PostScript output
starman Starman Perl/PSGI webserver
openoffice document output
edi (EXPERIMENTAL) X12 EDI support
xls Excel output filters (xls+xlsx)

Note: The example command contains --with-feature=starman for the purpose of the quick start.

When not installing as root or through sudo, cpanm will install unfulfilled library dependencies into a location which can be used with local::lib.

The in-depth installation instructions contain a list of distribution provided packages to reduce the number of dependencies installed from CPAN.


  1. For the pdf-ps target, LaTeX is required.

PostgreSQL configuration

While it's possible to use LedgerSMB with the standard postgres user, it's good practice to create a separate 'LedgerSMB database administrator':

$ sudo -u postgres createuser --no-superuser --createdb --login \
          --createrole --pwprompt lsmb_dbadmin
Enter password for new role: ****
Enter it again: ****

The pg_hba.conf file should have at least these lines in it (order of the entries matters):

local   all                            postgres                         peer
local   all                            all                              peer
host    all                            postgres     reject
host    all                            postgres        ::1/128          reject
host    postgres,template0,template1   lsmb_dbadmin     md5
host    postgres,template0,template1   lsmb_dbadmin    ::1/128          md5
host    postgres,template0,template1   all        reject
host    postgres,template0,template1   all             ::1/128          reject
host    all                            all        md5
host    all                            all             ::1/128          md5

Note: pg_hba.conf can be found in /etc/postgresql/<version>/main/ on Debian and in /var/lib/pgsql/data/ on RedHat/Fedora

After editing the pg_hba.conf file, reload the PostgreSQL server (or without 'sudo' by running the commands as root user):

 $ sudo service postgresql reload
 # -or-
 $ sudo /etc/init.d/postgresql reload

Configure LedgerSMB

(Installation from tarball is highly preferred over installation from GitHub for production installs.)

 $ cp doc/conf/ledgersmb.conf.default ledgersmb.conf

Running Starman

With the above steps completed, the system is ready to run the web server:

NOTE: DO NOT run starman (or any web service) as root, this is considered a serious security issue, and as such LedgerSMB doesn't support it. Instead, if you need to start LedgerSMB from a root process, drop privileges to a user that doesn't have write access to the LedgerSMB Directories first. Most daemonising mechanisms (eg: systemd) provide a mechanism to do this. Do not use the starman --user= mechanism, it currently drops privileges too late.

 $ starman -I lib -I old/lib --listen localhost:5762 bin/ledgersmb-server.psgi
2016/05/12-02:14:57 Starman::Server (type Net::Server::PreFork) starting! pid(xxxx)
Resolved [*]:5762 to [::]:5762, IPv6
Not including resolved host [] IPv4 because it will be handled by [::] IPv6
Binding to TCP port 5762 on host :: with IPv6
Setting gid to "1000 1000 24 25 27 29 30 44 46 108 111 121 1000"

Environment Variables

All regular Perl environment variables can be used. In particular, it's important to make sure PERL5LIB is set correctly when setting up local::lib for the first time.

We support the following Environment Variables within our code

  • LSMB_WORKINGDIR : Optional
    • Causes a chdir to the specified directory as the first thing done in starman.psgi
    • If not set the current dir is used.
    • An example would be

We support the following Environment Variables for our dependencies

  • PGHOST : Optional
    • Specifies the Postgres server Domain Name or IP address
  • PGPORT : Optional
    • Sepcifies the Postgres server Port
  • PGSSLMODE : Optional
    • Enables SSL for the Postgres connection

All Environment Variables supported by our dependencies should be passed through to them, that includes the standard Postgres Variables and others

Next steps

The system is installed and should be available for evaluation through

The system is ready for preparation for first use.

Project information

Web site:

Live chat:


Mailing list archives:

Mailing lists:


Project contributors

Source code contributors can be found in the project's Git commit history as well as in the CONTRIBUTORS file in the repository root.

Translation contributions can be found in the project's Git commit history as well as in the Transifex project Timeline.


Copyright (c) 2006 - 2018 The LedgerSMB Project contributors
Copyright (c) 1999 - 2006 DWS Systems Inc (under the name SQL Ledger)