mirror of
https://github.com/ledgersmb/ledgersmb-docker.git
synced 2025-10-24 04:57:25 -04:00
Compare commits
96 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
f951646c81 | ||
|
2615228ba6 | ||
|
6b4aac814c | ||
|
0d560b92d7 | ||
|
9dba5f4490 | ||
|
0172dc1684 | ||
|
b53c4a3689 | ||
|
a16d23bfa9 | ||
|
9ccc327468 | ||
|
028d8c45ed | ||
|
cf4256a20e | ||
|
83e1bbe8cd | ||
|
690fac08be | ||
|
7264d72638 | ||
|
e4e43b838e | ||
|
952ef62e6a | ||
|
b68f6d1672 | ||
|
575e91da47 | ||
|
f6422f03c3 | ||
|
06ccefa8b6 | ||
|
fb18381bdd | ||
|
b095cb9bb6 | ||
|
4c56e98a65 | ||
|
7dcd5c1709 | ||
|
5adfac5a82 | ||
|
d11e525fac | ||
|
94ca69315a | ||
|
1b6a2f5c99 | ||
|
eea2bbdbdd | ||
|
894393e781 | ||
|
6468e9e9f2 | ||
|
69cc364527 | ||
|
0210dce1d0 | ||
|
ba2bdd0dda | ||
|
6249141929 | ||
|
09a79b8258 | ||
|
4776803ef8 | ||
|
0a12f5c735 | ||
|
d808dd0b14 | ||
|
13b4e0f933 | ||
|
892592505f | ||
|
708a5afebc | ||
|
34d10ae0e0 | ||
|
f5909088f0 | ||
|
34a2270cf3 | ||
|
9881c06e5d | ||
|
c65adc6042 | ||
|
f9ee2e86ab | ||
|
e34a6a1326 | ||
|
1d0da66881 | ||
|
da2254dd4c | ||
|
cd3d2f573d | ||
|
1d4430ecfa | ||
|
a90ac97832 | ||
|
733413dd16 | ||
|
aeab695a50 | ||
|
dd13647ec6 | ||
|
2b689e9791 | ||
|
bef6697325 | ||
|
09d2d73db8 | ||
|
db8e441a8f | ||
|
638e0813e0 | ||
|
d265b58372 | ||
|
2fc8e55367 | ||
|
69b959f591 | ||
|
c7da8194cb | ||
|
e0338aa303 | ||
|
4dbd5a2a26 | ||
|
fafaea715e | ||
|
b8694aa449 | ||
|
98a5696570 | ||
|
0d1483d78f | ||
|
bde9b780b1 | ||
|
fd7c04d170 | ||
|
364cf01203 | ||
|
dbf99f981d | ||
|
fa4aa9dae0 | ||
|
8f3875acb0 | ||
|
4905f2a469 | ||
|
cd9e3037f7 | ||
|
e4f4d31922 | ||
|
4a8d6dc6b6 | ||
|
22ac547e94 | ||
|
0627a33477 | ||
|
4da73006fa | ||
|
a53dd55ecf | ||
|
99ba66e9b7 | ||
|
756c28ad4f | ||
|
719672490f | ||
|
75c8c8f0b0 | ||
|
5390be8aac | ||
|
2738fc3728 | ||
|
edaa2008af | ||
|
04b1786414 | ||
|
293fd65da4 | ||
|
0034b44033 |
171
Dockerfile
171
Dockerfile
@@ -1,76 +1,141 @@
|
|||||||
FROM perl:5
|
# Build time variables
|
||||||
MAINTAINER Freelock john@freelock.com
|
|
||||||
|
ARG SRCIMAGE=debian:trixie-slim
|
||||||
|
|
||||||
|
|
||||||
|
FROM $SRCIMAGE AS builder
|
||||||
|
|
||||||
|
ENV LSMB_VERSION=master
|
||||||
|
|
||||||
|
|
||||||
|
RUN set -x ; \
|
||||||
|
DEBIAN_FRONTEND="noninteractive" apt-get -y update && \
|
||||||
|
DEBIAN_FRONTEND="noninteractive" apt-get -y upgrade && \
|
||||||
|
DEBIAN_FRONTEND="noninteractive" apt-get -y install dh-make-perl libmodule-cpanfile-perl git wget && \
|
||||||
|
apt-file update
|
||||||
|
|
||||||
|
RUN set -x ; \
|
||||||
|
cd /srv && \
|
||||||
|
git clone --depth 1 --recursive -b $LSMB_VERSION https://github.com/ledgersmb/LedgerSMB.git ledgersmb && \
|
||||||
|
cd ledgersmb && \
|
||||||
|
( ( for lib in $( cpanfile-dump --with-all-features --recommends --no-configure --no-build --no-test ) ; \
|
||||||
|
do \
|
||||||
|
if dh-make-perl locate "$lib" 2>/dev/null ; \
|
||||||
|
then \
|
||||||
|
: \
|
||||||
|
else \
|
||||||
|
echo no : $lib ; \
|
||||||
|
fi ; \
|
||||||
|
done ) | grep -v dh-make-perl | grep -v 'not found' | grep -vi 'is in Perl ' | cut -d' ' -f4 | sort | uniq | tee /srv/derived-deps ) && \
|
||||||
|
cat /srv/derived-deps
|
||||||
|
|
||||||
|
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# The real image build starts here
|
||||||
|
#
|
||||||
|
#
|
||||||
|
|
||||||
|
|
||||||
|
FROM $SRCIMAGE
|
||||||
|
LABEL org.opencontainers.image.authors="LedgerSMB project <devel@lists.ledgersmb.org>"
|
||||||
|
|
||||||
# Install Perl, Tex, Starman, psql client, and all dependencies
|
# Install Perl, Tex, Starman, psql client, and all dependencies
|
||||||
RUN DEBIAN_FRONTENT=noninteractive && \
|
#
|
||||||
apt-get update && apt-get -y install \
|
# Without libclass-c3-xs-perl, everything grinds to a halt;
|
||||||
git \
|
# add it, because it's a 'recommends' it the dep tree, which
|
||||||
libdatetime-perl libdbi-perl libdbd-pg-perl \
|
# we're skipping, normally
|
||||||
libcgi-simple-perl libtemplate-perl libmime-lite-perl \
|
#
|
||||||
liblocale-maketext-lexicon-perl libtest-exception-perl \
|
# Installing psql client directly from instructions at https://wiki.postgresql.org/wiki/Apt
|
||||||
libtest-trap-perl liblog-log4perl-perl libmath-bigint-gmp-perl \
|
# That mitigates issues where the PG instance is running a newer version than this container
|
||||||
libfile-mimeinfo-perl libtemplate-plugin-number-format-perl \
|
|
||||||
libdatetime-format-strptime-perl libconfig-general-perl \
|
|
||||||
libdatetime-format-strptime-perl libio-stringy-perl libmoose-perl \
|
|
||||||
libconfig-inifiles-perl libnamespace-autoclean-perl \
|
|
||||||
libcarp-always-perl libjson-perl \
|
|
||||||
libtemplate-plugin-latex-perl texlive-latex-recommended \
|
|
||||||
libnet-tclink-perl \
|
|
||||||
libxml-twig-perl \
|
|
||||||
starman \
|
|
||||||
postgresql-client-9.4 \
|
|
||||||
ssmtp
|
|
||||||
|
|
||||||
# Nodejs for doing Dojo build
|
COPY --from=builder /srv/derived-deps /tmp/derived-deps
|
||||||
RUN curl -sL https://deb.nodesource.com/setup_6.x | bash - && \
|
|
||||||
apt-get install -y nodejs
|
|
||||||
|
RUN set -x ; \
|
||||||
|
echo "APT::Install-Recommends \"false\";\nAPT::Install-Suggests \"false\";\n" > /etc/apt/apt.conf.d/00recommends && \
|
||||||
|
DEBIAN_FRONTEND="noninteractive" apt-get -y update && \
|
||||||
|
DEBIAN_FRONTEND="noninteractive" apt-get -y upgrade && \
|
||||||
|
DEBIAN_FRONTEND="noninteractive" apt-get -y install \
|
||||||
|
wget ca-certificates gnupg \
|
||||||
|
$( cat /tmp/derived-deps ) \
|
||||||
|
libclass-c3-xs-perl \
|
||||||
|
texlive-plain-generic texlive-latex-recommended texlive-fonts-recommended \
|
||||||
|
texlive-xetex fonts-liberation \
|
||||||
|
lsb-release && \
|
||||||
|
echo "deb [signed-by=/etc/apt/keyrings/postgresql.asc] http://apt.postgresql.org/pub/repos/apt/ $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list && \
|
||||||
|
wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc > /etc/apt/keyrings/postgresql.asc && \
|
||||||
|
DEBIAN_FRONTEND="noninteractive" apt-get -y update && \
|
||||||
|
DEBIAN_FRONTEND="noninteractive" apt-get -y install postgresql-client && \
|
||||||
|
DEBIAN_FRONTEND="noninteractive" apt-get -y autoremove && \
|
||||||
|
DEBIAN_FRONTEND="noninteractive" apt-get -y autoclean && \
|
||||||
|
rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
# Java is required for closure compiler in Dojo build
|
|
||||||
RUN DEBIAN_FRONTENT=noninteractive && apt-get install -y openjdk-7-jre
|
|
||||||
|
|
||||||
# Build time variables
|
# Build time variables
|
||||||
ENV LSMB_VERSION 1.5.0-beta-5
|
ENV LSMB_VERSION=master
|
||||||
|
ENV NODE_PATH=/usr/local/lib/node_modules
|
||||||
|
|
||||||
# Install LedgerSMB
|
|
||||||
RUN cd /srv && \
|
|
||||||
git clone --recursive -b master https://github.com/ledgersmb/LedgerSMB.git ledgersmb
|
|
||||||
|
|
||||||
WORKDIR /srv/ledgersmb
|
###########################################################
|
||||||
|
# Java & Nodejs for doing Dojo build
|
||||||
|
|
||||||
# 1.5 requirements
|
# These packages are only needed during the dojo build
|
||||||
RUN cpanm --quiet --notest \
|
ENV DOJO_Build_Deps="git make gcc libperl-dev curl nodejs npm cpanminus"
|
||||||
--with-feature=starman \
|
# These packages can be removed after the dojo build
|
||||||
--with-feature=latex-pdf-ps \
|
ENV DOJO_Build_Deps_removal="${DOJO_Build_Deps} nodejs npm cpanminus"
|
||||||
--with-feature=openoffice \
|
|
||||||
--installdeps .
|
|
||||||
|
|
||||||
# Build dojo
|
# RUN (wget --quiet -O - https://deb.nodesource.com/setup_22.x | bash -) && \
|
||||||
RUN make dojo
|
RUN DEBIAN_FRONTEND="noninteractive" apt-get -y update && \
|
||||||
|
DEBIAN_FRONTEND="noninteractive" apt-get -y install ${DOJO_Build_Deps} && \
|
||||||
|
npm i -g --no-save yarn && \
|
||||||
|
cd /srv && \
|
||||||
|
git clone --depth 1 --recursive -b $LSMB_VERSION https://github.com/ledgersmb/LedgerSMB.git ledgersmb && \
|
||||||
|
cd ledgersmb && \
|
||||||
|
cpanm --metacpan --quiet --notest \
|
||||||
|
--with-feature=starman \
|
||||||
|
--with-feature=latex-pdf-ps \
|
||||||
|
--with-feature=openoffice \
|
||||||
|
--installdeps . && \
|
||||||
|
make js && \
|
||||||
|
DEBIAN_FRONTEND="noninteractive" apt-get -y purge ${DOJO_Build_Deps_removal} && \
|
||||||
|
rm -rf /usr/local/lib/node_modules && \
|
||||||
|
DEBIAN_FRONTEND="noninteractive" apt-get -y autoremove && \
|
||||||
|
DEBIAN_FRONTEND="noninteractive" apt-get -y autoclean && \
|
||||||
|
rm -rf ~/.cpanm && \
|
||||||
|
rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
|
# Cleanup args that are for internal use
|
||||||
|
ENV DOJO_Build_Deps=
|
||||||
|
ENV DOJO_Build_Deps_removal=
|
||||||
|
ENV NODE_PATH=
|
||||||
|
|
||||||
# Configure outgoing mail to use host, other run time variable defaults
|
# Configure outgoing mail to use host, other run time variable defaults
|
||||||
|
|
||||||
## sSMTP
|
## MAIL
|
||||||
ENV SSMTP_ROOT ar@example.com
|
ENV LSMB_MAIL_SMTPHOST=172.17.0.1
|
||||||
ENV SSMTP_MAILHUB 172.17.0.1
|
#ENV LSMB_MAIL_SMTPPORT=25
|
||||||
ENV SSMTP_HOSTNAME 172.17.0.1
|
#ENV LSMB_MAIL_SMTPSENDER_HOSTNAME=(container hostname)
|
||||||
#ENV SSMTP_USE_STARTTLS
|
#ENV LSMB_MAIL_SMTPTLS=
|
||||||
#ENV SSMTP_AUTH_USER
|
#ENV LSMB_MAIL_SMTPUSER=
|
||||||
#ENV SSMTP_AUTH_PASS
|
#ENV LSMB_MAIL_SMTPPASS=
|
||||||
ENV SSMTP_FROMLINE_OVERRIDE YES
|
#ENV LSMB_MAIL_SMTPAUTHMECH=
|
||||||
#ENV SSMTP_AUTH_METHOD
|
|
||||||
|
|
||||||
ENV POSTGRES_HOST postgres
|
ENV POSTGRES_HOST=postgres
|
||||||
|
ENV POSTGRES_PORT=5432
|
||||||
|
ENV DEFAULT_DB=lsmb
|
||||||
|
|
||||||
COPY start.sh /usr/local/bin/start.sh
|
COPY start.sh /usr/local/bin/start.sh
|
||||||
COPY update_ssmtp.sh /usr/local/bin/update_ssmtp.sh
|
|
||||||
|
|
||||||
RUN chown www-data /etc/ssmtp /etc/ssmtp/ssmtp.conf && \
|
RUN chmod +x /usr/local/bin/start.sh && \
|
||||||
chmod +x /usr/local/bin/update_ssmtp.sh /usr/local/bin/start.sh && \
|
mkdir -p /var/www
|
||||||
mkdir -p /var/www
|
|
||||||
|
|
||||||
|
# Work around an aufs bug related to directory permissions:
|
||||||
|
RUN mkdir -p /tmp && \
|
||||||
|
chmod 1777 /tmp
|
||||||
|
|
||||||
# Internal Port Expose
|
# Internal Port Expose
|
||||||
EXPOSE 5762
|
EXPOSE 5762
|
||||||
#USER www-data
|
|
||||||
|
|
||||||
|
USER www-data
|
||||||
CMD ["start.sh"]
|
CMD ["start.sh"]
|
||||||
|
220
README.md
220
README.md
@@ -1,103 +1,221 @@
|
|||||||
# ledgersmb-docker - EXPERIMENTAL
|
# ledgersmb-docker
|
||||||
|
|
||||||
Dockerfile for LedgerSMB Docker image
|
Dockerfile for LedgerSMB Docker image
|
||||||
|
|
||||||
This is a work in progress to make a docker image for running LedgerSMB. It should not be relied upon for production use!
|
# Supported tags
|
||||||
|
|
||||||
# Supported tags and respective `Dockerfile` links
|
- `1.13`, `1.13.x`, `latest` - Latest official release from the 1.13 branch
|
||||||
|
- `1.12`, `1.12.x` - Latest official release from the 1.12 branch
|
||||||
- `dev-master` - Master branch from git, unstable
|
- `1.11`, `1.11.x` - Latest official release from the 1.11 branch
|
||||||
- `1.5`, `1.5.x` - Latest release tarball from 1.5 branch
|
- `1.10`, `1.10.38` - Last official release from the 1.10 branch
|
||||||
- `1.4`, `latest` - Latest tagged release of git 1.4 branch
|
- `1.9`, `1.9.30` - Last official release from 1.9 branch (End-of-Life)
|
||||||
|
- `1.8`, `1.8.31` - Last official release from 1.8 branch (End-of-Life)
|
||||||
|
- `1.7`, `1.7.41` - Last official release from 1.7 branch (End-of-Life)
|
||||||
|
- `1.6`, `1.6.33` - Last official release from 1.6 branch (End-of-Life)
|
||||||
|
- `1.5`, `1.5.30` - Last official release from 1.5 branch (End-of-Life)
|
||||||
|
- `1.4`, `1.4.42` - Last official release from 1.4 branch (End-of-Life)
|
||||||
|
- `master` - Master branch from git, unstable
|
||||||
|
|
||||||
|
Containers supporting the development process are provided
|
||||||
|
through the ledgersmb-dev-docker project. See https://github.com/ledgersmb/ledgersmb-dev-docker/blob/master/README.md#getting-started.
|
||||||
|
|
||||||
# What is LedgerSMB?
|
# What is LedgerSMB?
|
||||||
The LedgerSMB project's priority is to provide an extremely capable yet user-friendly accounting and ERP solution to small to mid-size businesses in all locales where there is interest in using the software. The focus on small to mid-size businesses offers an opportunity to provide a positive user experience in ways which are not present in larger organizations. LedgerSMB ought to strive to be both the ideal SMB accounting/ERP package and also a solution that a start-up will never outgrow. The goals mentioned above will help us provide this ideal solution by allowing us to focus both on technical architecture and on user experience.
|
|
||||||
|
LedgerSMB is a user-friendly accounting and ERP solution for small to
|
||||||
|
mid-size businesses. It comes with support for many languages and support
|
||||||
|
for different locales.
|
||||||
|
|
||||||
|
The project aims to be the solution a start-up never outgrows.
|
||||||
|
|
||||||
|
|
||||||
# How is this image designed to be used?
|
# How is this image designed to be used?
|
||||||
|
|
||||||
This Docker image is built to provide a self-contained LedgerSMB instance. To be functional, you need to connect it to a running Postgres installation. The official Postgres container will work as is, if you link it to the LedgerSMB instance at startup, or you can provide environment variables to an appropriate Postgres server.
|
This image is designed to be used in conjunction with a running PostgreSQL
|
||||||
|
instance (such as may be provided through a separate image).
|
||||||
|
|
||||||
LedgerSMB provides an http interface built on Starman out of the box, listening on port 5762. We do not recommend exposing this port, because we strongly recommend encrypting all connections using SSL/TLS. For production use, we recommend running a web server configured with SSL, such as Nginx or Apache, and proxying connections to LedgerSMB.
|
This image exposes port 5762 running a Starman HTTP application server. We
|
||||||
|
do not recommend exposing this port publicly, because
|
||||||
|
|
||||||
The other services you will need to put this in production are an SMTP gateway (set environment variables for SSMTP at container startup) and optionally a local print server (e.g. CUPS) installation. The print service is not currently supported in this Docker image, but pull requests are welcomed ;-)
|
1. The Starman author recommends it
|
||||||
|
2. We strongly recommend TLS encryption of all application traffic
|
||||||
|
|
||||||
|
While the exposed port can be used for quick evaluation, it's recommended
|
||||||
|
to add the TLS layer by applying Nginx or Apache as reverse proxy.
|
||||||
|
|
||||||
|
Enabling optional functionalities such as outgoing e-mail and printing
|
||||||
|
could require additional setup of a mail service or CUPS printer service.
|
||||||
|
|
||||||
# How to use this image
|
# How to use this image
|
||||||
|
|
||||||
## Start a postgres instance
|
This image can be installed either automatically with the Docker compose file
|
||||||
|
manually with docker only.
|
||||||
|
|
||||||
docker run --name some-postgres -e POSTGRES_PASSWORD=mysecretpassword -d postgres
|
❌ Do not use unofficial or AI-generated Docker Compose examples. These are
|
||||||
|
often incomplete, break silently, or skip required services.
|
||||||
|
|
||||||
This image includes `EXPOSE 5432` (the postgres port), so standard container linking will make it automatically available to the linked containers. The default `postgres` user and database are created in the entrypoint with `initdb`.
|
## Docker-Compose installation and start
|
||||||
|
|
||||||
> The postgres database is a default database meant for use by users, utilities and third party applications.
|
This image provides `docker-compose.yml` which can be used to pull related
|
||||||
> [postgresql.org/docs](http://www.postgresql.org/docs/9.3/interactive/app-initdb.html)
|
images, install them, establish an internal network for their communications,
|
||||||
|
adjust environment variables, start and stop LedgerSMB. The only instructions
|
||||||
|
required, after the optional edition of the file to adjust the environment
|
||||||
|
variables, are:
|
||||||
|
|
||||||
## Start LedgerSMB
|
```plain
|
||||||
|
$ docker-compose pull
|
||||||
|
$ docker-compose up
|
||||||
|
```
|
||||||
|
|
||||||
docker run --name myledger --link some-postgres:postgres -d ledgersmb/ledgersmb
|
This will set up two containers: (1) a PostgreSQL container with persistent
|
||||||
|
storage which is retained between container updates and (2) a LedgerSMB
|
||||||
|
container configured to connect to the PostgreSQL container as its database
|
||||||
|
server.
|
||||||
|
|
||||||
## Set up LedgerSMB
|
The database username and password are:
|
||||||
|
|
||||||
Visit http://myledger:5762/setup.pl (you can forward port 5762 to the host machine, or lookup the IP address for the "myledger" container if running on localhost)
|
```plain
|
||||||
|
username: postgres
|
||||||
|
password: abc
|
||||||
|
```
|
||||||
|
|
||||||
Log in with the "postgres" user and the password you set when starting up the Postgres container, and provide the name of a company database you want to create.
|
## Manual installation
|
||||||
|
|
||||||
Once you have completed the setup, you have a fully functional LedgerSMB instance running!
|
This section assumes availability of a PostgreSQL server to attach to the
|
||||||
|
LedgerSMB image as the database server.
|
||||||
|
|
||||||
Visit http://myledger:5762/login.pl to log in and get started.
|
### Start LedgerSMB
|
||||||
|
|
||||||
|
```plain
|
||||||
|
$ docker run -d -p 5762:5762 --name myledger \
|
||||||
|
-e POSTGRES_HOST=<ip/hostname> ledgersmb/ledgersmb:latest
|
||||||
|
```
|
||||||
|
|
||||||
|
This command maps port 5762 of your container to port 5762 in your host. The
|
||||||
|
web application inside the container should now be accessible through
|
||||||
|
http://localhost:5762/setup.pl and http://localhost:5762/login.pl.
|
||||||
|
|
||||||
|
Below are more variables which determine container configuration,
|
||||||
|
like `POSTGRES_HOST` above.
|
||||||
|
|
||||||
|
# Set up LedgerSMB
|
||||||
|
|
||||||
|
* Visit http://myledger:5762/setup.pl.
|
||||||
|
* Log in with the "postgres" user and the password `abc` as given above -
|
||||||
|
or with the credentials of your own database server in case of a manual
|
||||||
|
setup - and provide the name of a company (= database name) you want to
|
||||||
|
create.
|
||||||
|
* Go over the steps presented in the browser
|
||||||
|
|
||||||
|
Once you have completed the setup steps, you have a fully functional
|
||||||
|
LedgerSMB instance running!
|
||||||
|
|
||||||
|
Visit http://localhost:5762/login.pl to log in and get started.
|
||||||
|
|
||||||
# Updating the LedgerSMB container
|
# Updating the LedgerSMB container
|
||||||
|
|
||||||
No persistant data is stored in the LedgerSMB container. All LedgerSMB data is stored in Postgres, so you can stop/destroy/run a new LedgerSMB container, and as long as you link it to the Postgres database, you should be able to pick up where you left off.
|
No persistant data is stored in the LedgerSMB container.
|
||||||
|
|
||||||
|
All LedgerSMB data is stored in Postgres, so you can stop/destroy/run a
|
||||||
|
new LedgerSMB container as often as you want.
|
||||||
|
|
||||||
# Environment Variables
|
# Environment Variables
|
||||||
|
|
||||||
The LedgerSMB image uses several environment variables which are easy to miss. While none of the variables are required, they may significantly aid you in using the image.
|
The LedgerSMB image uses several environment variables. They are all optional.
|
||||||
|
|
||||||
### `POSTGRES_HOST` = 'postgres'
|
|
||||||
|
|
||||||
This environment variable is used to specify the hostname of the Postgres server. The default is "postgres", which will find the container linked in.
|
## `POSTGRES_HOST`
|
||||||
|
|
||||||
If you set this to another hostname, LedgerSMB will attempt to connect to that hostname instead.
|
Default: postgres
|
||||||
|
|
||||||
### `SSMTP_ROOT` `SSMTP_MAILHUB` `SSMTP_HOSTNAME` `SSMTP_USE_STARTTLS` `SSMTP_AUTH_USER` `SSMTP_AUTH_PASS` `SSMTP_METHOD` `SSMTP_FROMLINE_OVERRIDE`
|
Specifies the hostname of the PostgreSQL server to connect to. If you use
|
||||||
|
a PostgreSQL image, set it to the name of that image.
|
||||||
|
|
||||||
|
## `POSTGRES_PORT`
|
||||||
|
|
||||||
|
Default: 5432
|
||||||
|
|
||||||
|
Port on which the PostgreSQL server is running.
|
||||||
|
|
||||||
|
## `DEFAULT_DB`
|
||||||
|
|
||||||
|
Default: lsmb
|
||||||
|
|
||||||
|
Set this if you want to automatically log in to a particular LedgerSMB database
|
||||||
|
without needing to enter the name of that database on the login.pl login screen.
|
||||||
|
|
||||||
|
## `LSMB_WORKERS`
|
||||||
|
|
||||||
|
Default: 5
|
||||||
|
|
||||||
|
Set this if you want to run in a memory-constrained environment. E.g. set it to
|
||||||
|
2 when running in a 1 GB memory setup. Please do note that this may adversely
|
||||||
|
affect the performance experience of users.
|
||||||
|
|
||||||
|
## Mail configuration
|
||||||
|
|
||||||
|
### Before 1.8.0
|
||||||
|
|
||||||
|
These variables are used to set outgoing SMTP defaults.
|
||||||
|
|
||||||
|
* `SSMTP_ROOT` (config: `Root` -- DEPRECATED)
|
||||||
|
* `SSMTP_MAILHUB` (config: `Mailhub`)
|
||||||
|
* `SSMTP_HOSTNAME` (config: `Hostname`)
|
||||||
|
* `SSMTP_USE_STARTTLS` (config: `UseSTARTTLS`)
|
||||||
|
* `SSMTP_AUTH_USER` (config: `AuthUser`)
|
||||||
|
* `SSMTP_AUTH_PASS` (config: `AuthPass`)
|
||||||
|
* `SSMTP_AUTH_METHOD` (config: `AuthMethod` -- DEPRECATED)
|
||||||
|
* `SSMTP_FROMLINE_OVERRIDE` (config: `FromLineOverride` -- DEPRECATED)
|
||||||
|
|
||||||
|
`SSMTP_MAILHUB` defaults to the default docker0 interface, so if your host is
|
||||||
|
already configured to relay mail, this should relay successfully with only
|
||||||
|
the root and hostname set.
|
||||||
|
|
||||||
|
Use the other environment variables to relay mail through a different host.
|
||||||
|
Use the [ssmtp.conf man
|
||||||
|
page](https://www.systutorials.com/docs/linux/man/5-ssmtp.conf/) to look up
|
||||||
|
the meaning and function of each of the mail configuration keys.
|
||||||
|
|
||||||
|
### 1.8.0 and higher (under development)
|
||||||
|
|
||||||
|
As of 1.8.0, the image is based on Debian Buster instead of Debian Stretch;
|
||||||
|
with Buster, the `ssmtp` program has been removed from Debian, this image
|
||||||
|
had to change strategy. The main application always came with built-in e-mail
|
||||||
|
yet with the deprecation, the abilities have expanded.
|
||||||
|
|
||||||
|
The following parameters are now supported to set mail preferences:
|
||||||
|
|
||||||
|
* `LSMB_MAIL_SMTPHOST`
|
||||||
|
* `LSMB_MAIL_SMTPPORT`
|
||||||
|
* `LSMB_MAIL_SMTPTLS`
|
||||||
|
* `LSMB_MAIL_SMTPSENDER_HOSTNAME`
|
||||||
|
* `LSMB_MAIL_SMTPUSER`
|
||||||
|
* `LSMB_MAIL_SMTPPASS`
|
||||||
|
* `LSMB_MAIL_SMTPAUTHMECH`
|
||||||
|
|
||||||
These variables are used to set outgoing SMTP defaults. To set the outgoing email address, set SSMTP_ROOT, and SSMTP_HOSTNAME at a minimum -- SSMTP_MAILHUB defaults to the default docker0 interface, so if your host is already configured to relay mail, this should relay successfully with only those two set.
|
|
||||||
|
|
||||||
Use the other environment variables to relay mail through another host.
|
|
||||||
|
|
||||||
# Troubleshooting/Developing
|
# Troubleshooting/Developing
|
||||||
|
|
||||||
You can connect to a running container using:
|
Currently the LedgerSMB installation is in /srv/ledgersmb
|
||||||
|
and the startup & config script is /usr/bin/start.sh.
|
||||||
|
|
||||||
> docker exec -ti myledger /bin/bash
|
|
||||||
|
|
||||||
... this will give you a shell inside the container where you can inspect/troubleshoot the installation.
|
|
||||||
|
|
||||||
Currently the LedgerSMB installation is in /srv/ledgersmb, and the startup/config script is /usr/bin/start.sh.
|
|
||||||
|
|
||||||
|
|
||||||
# Supported Docker versions
|
|
||||||
|
|
||||||
This image is officially supported on Docker version 1.11.1.
|
|
||||||
|
|
||||||
Support for older versions is provided on a best-effort basis.
|
|
||||||
|
|
||||||
# User Feedback
|
# User Feedback
|
||||||
|
|
||||||
## Documentation
|
|
||||||
|
|
||||||
This is a brand new effort, and we will be adding documentation to the http://ledgersmb.org site when we get a chance.
|
|
||||||
|
|
||||||
## Issues
|
## Issues
|
||||||
|
|
||||||
If you have any problems with or questions about this image or LedgerSMB, please contact us on the [mailing list](http://ledgersmb.org/topic/support/mailing-lists-rss-and-nntp-feeds) or through a [GitHub issue](https://github.com/ledgersmb/ledgersmb-docker/issues).
|
If you have any problems with or questions about this image or LedgerSMB,
|
||||||
|
please contact us on the [mailing list](http://ledgersmb.org/topic/support/mailing-lists-rss-and-nntp-feeds)
|
||||||
|
or through a [GitHub issue](https://github.com/ledgersmb/ledgersmb-docker/issues).
|
||||||
|
|
||||||
You can also reach some of the official LedgerSMB maintainers via the `#ledgersmb` IRC channel on [Freenode](https://freenode.net), or on the bridged [Matrix](https://matrix.org) room in [#ledgersmb:matrix.org](https://matrix.to/#/#ledgersmb:matrix.org). The [Vector.im](https://vector.im/beta/#/room/#ledgersmb:matrix.org) Matrix client is highly recommended.
|
You can also reach some of the official LedgerSMB maintainers via the
|
||||||
|
`#ledgersmb` IRC channel on [Freenode](https://freenode.net), or on the
|
||||||
|
bridged [Matrix](https://matrix.org) room in [#ledgersmb:matrix.org](https://matrix.to/#/#ledgersmb:matrix.org).
|
||||||
|
The [Riot.im](https://riot.im/app/#/room/#ledgersmb:matrix.org) Matrix client is highly recommended.
|
||||||
|
|
||||||
|
|
||||||
## Contributing
|
## Contributing
|
||||||
|
|
||||||
You are invited to contribute new features, fixes, or updates, large or small; we are always thrilled to receive pull requests, and do our best to process them as fast as we can.
|
You are invited to contribute new features, fixes, or updates, large or small;
|
||||||
|
we are always thrilled to receive pull requests, and do our best to process
|
||||||
|
them as fast as we can.
|
||||||
|
81
docker-compose.yml
Normal file
81
docker-compose.yml
Normal file
@@ -0,0 +1,81 @@
|
|||||||
|
# This docker-compose file creates one
|
||||||
|
# compose 'project' consisting of two containers
|
||||||
|
#
|
||||||
|
# 1. The PostgreSQL data container
|
||||||
|
# 2. The LedgerSMB application container
|
||||||
|
#
|
||||||
|
# LedgerSMB persists all its data in the database,
|
||||||
|
# so no special care needs to be taken on
|
||||||
|
# container upgrades. With PostgreSQL, data is
|
||||||
|
# persisted across upgrades by the use of a
|
||||||
|
# special 'dbdata' volume
|
||||||
|
|
||||||
|
version: "3.2"
|
||||||
|
services:
|
||||||
|
# Note that the container needs to be named "postgres" here,
|
||||||
|
# because that allows us to use the default hostname ("postgres")
|
||||||
|
# from the LedgerSMB configuration
|
||||||
|
postgres:
|
||||||
|
image: postgres:14-alpine
|
||||||
|
environment:
|
||||||
|
# Replace the password below for a secure setup
|
||||||
|
POSTGRES_PASSWORD: abc
|
||||||
|
PGDATA: /var/lib/postgresql/data/pgdata
|
||||||
|
networks:
|
||||||
|
- internal
|
||||||
|
volumes:
|
||||||
|
- "pgdata:/var/lib/postgresql/data"
|
||||||
|
lsmb:
|
||||||
|
depends_on:
|
||||||
|
- postgres
|
||||||
|
image: ghcr.io/ledgersmb/ledgersmb:master
|
||||||
|
networks:
|
||||||
|
- internal
|
||||||
|
- default
|
||||||
|
# Uncomment the 'ports' section to map the LedgerSMB container port (5762)
|
||||||
|
# to the host's port of the same number, thus making LedgerSMB
|
||||||
|
# available on http://<host-dns-or-ip>:5762/
|
||||||
|
# SECURITY NOTE: Do this for evaluation purposes only!
|
||||||
|
# In production, be sure to use SSL/TLS to protect user's passwords
|
||||||
|
# and other sensitive data
|
||||||
|
# ports:
|
||||||
|
# - "5762:5762"
|
||||||
|
environment:
|
||||||
|
# The LSMB_WORKERS environment variable lets you select the number
|
||||||
|
# of processes serving HTTP requests. The default number of 2 workers
|
||||||
|
# is geared toward limited-memory situations (1 GB). In order to
|
||||||
|
# improve the performance experience, increase memory and the
|
||||||
|
# number of workers
|
||||||
|
#
|
||||||
|
LSMB_WORKERS: 2
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# SSMTP_ROOT:
|
||||||
|
# SSMTP_HOSTNAME:
|
||||||
|
# SSMTP_MAILHUB:
|
||||||
|
# SSMTP_AUTH_USER:
|
||||||
|
# SSMTP_AUTH_PASS:
|
||||||
|
# SSMTP_AUTH_METHOD:
|
||||||
|
# SSMTP_USE_STARTTLS:
|
||||||
|
# SSMTP_FROMLINE_OVERRIDE:
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# The PROXY_IP environment variable lets you set the IP address
|
||||||
|
# (range) of the reverse proxy used for TLS termination, which forwards
|
||||||
|
# its requests to this container. When this reverse proxy runs on the
|
||||||
|
# Docker host, the default below applies. In case the reverse proxy is
|
||||||
|
# hosted in a separate container, this setting needs to be adjusted.
|
||||||
|
#
|
||||||
|
# PROXY_IP: 172.17.0.1/12
|
||||||
|
|
||||||
|
# having the dbdata volume is required to persist our
|
||||||
|
# data between PostgreSQL container updates; without
|
||||||
|
# that, the data is contained in the same volume as
|
||||||
|
# the rest of the image and on update/upgrade, the
|
||||||
|
# data will be lost.
|
||||||
|
volumes:
|
||||||
|
pgdata:
|
||||||
|
|
||||||
|
|
||||||
|
networks:
|
||||||
|
internal:
|
132
start.sh
132
start.sh
@@ -1,15 +1,109 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
update_ssmtp.sh
|
|
||||||
cd /srv/ledgersmb
|
cd /srv/ledgersmb
|
||||||
|
|
||||||
|
if [[ -n "$SSMTP_ROOT" ]]; then
|
||||||
|
echo "\$SSMTP_ROOT set; parameter is deprecated and will be ignored"
|
||||||
|
LSMB_HAVE_DEPRECATED=1
|
||||||
|
fi
|
||||||
|
if [[ -n "$SSMTP_FROMLINE_OVERRIDE" ]]; then
|
||||||
|
echo "\$SSMTP_FROMLINE_OVERRIDE set; parameter is deprecated and will be ignored"
|
||||||
|
LSMB_HAVE_DEPRECATED=1
|
||||||
|
fi
|
||||||
|
if [[ -n "$SSMTP_MAILHUB" ]]; then
|
||||||
|
echo "\$SSMTP_MAILHUB set; parameter is deprecated"
|
||||||
|
if [[ -z "$LSMB_MAIL_SMTPHOST" ]]; then
|
||||||
|
echo " Deriving \$LSMB_MAIL_SMTPHOST setting from \$SSMTP_MAILHUB"
|
||||||
|
LSMB_MAIL_SMTPHOST=${SSMTP_MAILHUB%:*}
|
||||||
|
fi
|
||||||
|
if [[ -z "$LSMB_MAIL_SMTPPORT" ]]; then
|
||||||
|
echo " Deriving \$LSMB_MAIL_SMTPPORT setting from \$SSMTP_MAILHUB"
|
||||||
|
LSMB_MAIL_SMTPPORT=${SSMTP_MAILHUB#*:}
|
||||||
|
fi
|
||||||
|
LSMB_HAVE_DEPRECATED=1
|
||||||
|
fi
|
||||||
|
if [[ -n "$SSMTP_HOSTNAME" ]]; then
|
||||||
|
echo "\$SSMTP_HOSTNAME set; parameter is deprecated"
|
||||||
|
if [[ -z "$LSMB_MAIL_SMTPSENDER_HOSTNAME" ]]; then
|
||||||
|
echo " Deriving \$LSMB_MAIL_SMTPSENDER_HOSTNAME setting from \$SSMTP_HOSTNAME"
|
||||||
|
LSMB_MAIL_SMTPSENDER_HOSTNAME=$SSMTP_HOSTNAME
|
||||||
|
fi
|
||||||
|
LSMB_HAVE_DEPRECATED=1
|
||||||
|
fi
|
||||||
|
if [[ -n "$SSMTP_USE_STARTTLS" ]]; then
|
||||||
|
echo "\$SSMTP_USE_STARTTLS set; parameter is deprecated"
|
||||||
|
if [[ -z "$LSMB_MAIL_SMTPTLS" ]]; then
|
||||||
|
echo " Deriving \$LSMB_MAIL_SMTPSENDER_HOSTNAME setting from \$SSMTP_USE_STARTTLS"
|
||||||
|
LSMB_MAIL_SMTPTLS=$SSMTP_USE_STARTTLS
|
||||||
|
fi
|
||||||
|
LSMB_HAVE_DEPRECATED=1
|
||||||
|
fi
|
||||||
|
if [[ -n "$SSMTP_AUTH_USER" ]]; then
|
||||||
|
echo "\$SSMTP_AUTH_USER set; parameter is deprecated"
|
||||||
|
if [[ -z "$LSMB_MAIL_SMTPUSER" ]]; then
|
||||||
|
echo " Deriving \$LSMB_MAIL_SMTPUSER setting from \$SSMTP_AUTH_USER"
|
||||||
|
LSMB_MAIL_SMTPUSER=$SSMTP_AUTH_USER
|
||||||
|
fi
|
||||||
|
LSMB_HAVE_DEPRECATED=1
|
||||||
|
fi
|
||||||
|
if [[ -n "$SSMTP_AUTH_PASS" ]]; then
|
||||||
|
echo "\$SSMTP_AUTH_PASS set; parameter is deprecated"
|
||||||
|
if [[ -z "$LSMB_MAIL_SMTPPASS" ]]; then
|
||||||
|
echo " Deriving \$LSMB_MAIL_SMTPPASS setting from \$SSMTP_AUTH_PASS"
|
||||||
|
LSMB_MAIL_SMTPPASS=$SSMTP_AUTH_PASS
|
||||||
|
fi
|
||||||
|
LSMB_HAVE_DEPRECATED=1
|
||||||
|
fi
|
||||||
|
if [[ -n "$SSMTP_AUTH_METHOD" ]]; then
|
||||||
|
echo "\$SSMTP_AUTH_METHOD set; parameter is deprecated"
|
||||||
|
if [[ -z "$LSMB_MAIL_SMTPAUTHMECH" ]]; then
|
||||||
|
echo " Deriving \$LSMB_MAIL_SMTPAUTHMECH setting from \$SSMTP_AUTH_METHOD"
|
||||||
|
LSMB_MAIL_SMTPAUTHMECH=$SSMTP_AUTH_METHOD
|
||||||
|
fi
|
||||||
|
LSMB_HAVE_DEPRECATED=1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -n "$LSMB_HAVE_DEPRECATED" ]]; then
|
||||||
|
echo "!!! DEPRECATED \$SSMTP_* PARAMETERS WILL BE REMOVED in the 1.9 image!!!"
|
||||||
|
fi
|
||||||
|
# This was never a parameter: ?
|
||||||
|
# if [[ -n "$SSMTP_USE_TLS" ]]; then
|
||||||
|
# echo "\$SSMTP_USE_TLS set; parameter is deprecated"
|
||||||
|
# if [[ -z "$LSMB_MAIL_SMTPTLS" ]]; then
|
||||||
|
# echo " Deriving \$LSMB_MAIL_SMTPSENDER_HOSTNAME setting from \$SSMTP_MAILHUB"
|
||||||
|
# if [[ "$SSMTP_USE_TLS" == "yes" ]]; then
|
||||||
|
# LSMB_MAIL_SMTPTLS=raw
|
||||||
|
# else
|
||||||
|
# LSMB_MAIL_SMTPTLS=no
|
||||||
|
# fi
|
||||||
|
# fi
|
||||||
|
# fi
|
||||||
|
|
||||||
|
|
||||||
if [[ ! -f ledgersmb.conf ]]; then
|
if [[ ! -f ledgersmb.conf ]]; then
|
||||||
cp conf/ledgersmb.conf.default ledgersmb.conf
|
cat <<EOF >/tmp/ledgersmb.conf
|
||||||
sed -i \
|
[main]
|
||||||
-e "s/\(cache_templates = \).*\$/cache_templates = 1/g" \
|
cache_templates = 1
|
||||||
-e "s/\(host = \).*\$/\1$POSTGRES_HOST/g" \
|
|
||||||
-e "s%\(sendmail = \).*%\1/usr/bin/ssmtp%g" \
|
[database]
|
||||||
/srv/ledgersmb/ledgersmb.conf
|
host = $POSTGRES_HOST
|
||||||
|
port = $POSTGRES_PORT
|
||||||
|
default_db = $DEFAULT_DB
|
||||||
|
|
||||||
|
[mail]
|
||||||
|
${LSMB_MAIL_SMTPHOST:+smtphost=$LSMB_MAIL_SMTPHOST
|
||||||
|
}${LSMB_MAIL_SMTPPORT:+smtpport=$LSMB_MAIL_SMTPPORT
|
||||||
|
}${LSMB_MAIL_SMTPSENDER_HOSTNAME:+smtpsender_hostname=$LSMB_MAIL_SMTPSENDER_HOSTNAME
|
||||||
|
}${LSMB_MAIL_SMTPTLS:+smtptls=$LSMB_MAIL_SMTPTLS
|
||||||
|
}${LSMB_MAIL_SMTPUSER:+smtpuser=$LSMB_MAIL_SMTPUSER
|
||||||
|
}${LSMB_MAIL_SMTPPASS:+smtppass=$LSMB_MAIL_SMTPPASS
|
||||||
|
}${LSMB_MAIL_SMTPAUTHMECH:+smtpauthmech=$LSMB_MAIL_SMTPAUTHMECH
|
||||||
|
}
|
||||||
|
|
||||||
|
[proxy]
|
||||||
|
ip=${PROXY_IP:-172.17.0.1/12}
|
||||||
|
EOF
|
||||||
|
export LSMB_CONFIG_FILE='/tmp/ledgersmb.conf'
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Currently unmaintained/untested
|
# Currently unmaintained/untested
|
||||||
@@ -19,15 +113,17 @@ fi
|
|||||||
# --postgres_password "$POSTGRES_PASS"
|
# --postgres_password "$POSTGRES_PASS"
|
||||||
#fi
|
#fi
|
||||||
|
|
||||||
# Needed for modules loaded by cpanm
|
|
||||||
export PERL5LIB
|
|
||||||
for PerlLib in /usr/lib/perl5* /usr/local/lib/perl5*/site_perl/* ; do
|
|
||||||
[[ -d "$PerlLib" ]] && {
|
|
||||||
PERL5LIB="$PerlLib";
|
|
||||||
echo -e "\tmaybe: $PerlLib";
|
|
||||||
}
|
|
||||||
done ;
|
|
||||||
echo "Selected PERL5LIB=$PERL5LIB";
|
|
||||||
|
|
||||||
# start ledgersmb
|
# start ledgersmb
|
||||||
exec starman --port 5762 tools/starman.psgi
|
# --preload-app allows application initialization to kill the entire
|
||||||
|
# starman instance (instead of just the worker, which will immediately
|
||||||
|
# get restarted); it also has a positive effect on memory use
|
||||||
|
|
||||||
|
echo '--------- LEDGERSMB CONFIGURATION: ledgersmb.conf'
|
||||||
|
cat ${LSMB_CONFIG_FILE:-ledgersmb.conf}
|
||||||
|
echo '--------- LEDGERSMB CONFIGURATION --- END'
|
||||||
|
|
||||||
|
# ':5762:' suppresses an uninitialized variable warning in starman
|
||||||
|
# the last colon means "don't connect using tls"; without it, there's a warning
|
||||||
|
exec starman --listen :5762: --workers ${LSMB_WORKERS:-5} \
|
||||||
|
-I lib -I old/lib \
|
||||||
|
--preload-app bin/ledgersmb-server.psgi
|
||||||
|
@@ -1,18 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
ConfiguredComment='# install script update_ssmtp.sh has configured ssmtp'
|
|
||||||
grep -qc "$ConfiguredComment" /etc/ssmtp.conf && {
|
|
||||||
echo "smtp configured."
|
|
||||||
exit
|
|
||||||
}
|
|
||||||
|
|
||||||
sed -i \
|
|
||||||
-e "s/\(root=\).*\$/\1$SSMTP_ROOT/g" \
|
|
||||||
-e "s/\(mailhub=\).*\$/\1$SSMTP_MAILHUB/g" \
|
|
||||||
-e "s/\(hostname=\).*\$/\1$SSMTP_HOSTNAME/g" \
|
|
||||||
/etc/ssmtp/ssmtp.conf
|
|
||||||
[ -z "$SSMTP_USE_STARTTLS" ] || echo "UseSTARTTLS=$SSMTP_USE_STARTTLS" >> /etc/ssmtp/ssmtp.conf
|
|
||||||
[ -z "$SSMTP_AUTH_USER" ] || echo "AuthUser=$SSMTP_AUTH_USER" >> /etc/ssmtp/ssmtp.conf
|
|
||||||
[ -z "$SSMTP_AUTH_PASS" ] || echo "AuthPass=$SSMTP_AUTH_PASS" >> /etc/ssmtp/ssmtp.conf
|
|
||||||
[ -z "$SSMTP_AUTH_METHOD" ] || echo "AuthMethod=$SSMTP_AUTH_METHOD" >> /etc/ssmtp/ssmtp.conf
|
|
||||||
[ -z "$SSMTP_FROMLINE_OVERRIDE" ] || echo "FromLineOverride=$SSMTP_FROMLINE_OVERRIDE" >> /etc/ssmtp/ssmtp.conf
|
|
||||||
echo "$ConfiguredComment" >> /etc/ssmtp/ssmtp.conf
|
|
Reference in New Issue
Block a user