Project home: https://bues.ch Original repository at: https://git.bues.ch/git/cms.git https://bues.ch

Michael Buesch dbc7b5236a Print message, if cython module fails to load 2 years ago
cms 463e33ca6f resolver: Return needle from $(contains 3 years ago
example f82022e80a Update example macros 4 years ago
.gitignore 94df127121 .gitignore: Add __pycache__ 4 years ago
README.rst dbc7b5236a Print message, if cython module fails to load 2 years ago
TODO a4e0639a7f Remove header todo entry 4 years ago
build.sh 47917de33a build: Enable -O3 4 years ago
cleantree.sh 1a27b66f22 Add cleaning helper script 4 years ago
cms-cli 6a03a38e7e cli: Enable debugging 4 years ago
index.wsgi dbc7b5236a Print message, if cython module fails to load 2 years ago
setup.py c6040adba0 setup: Add support for profile build 4 years ago
setup_cython.py 7ea91af783 Remove Cython3 support 4 years ago

README.rst

cms.py - simple WSGI/Python based CMS script
============================================

Copyright (c) 2011-2021 Michael Buesch


Installing
==========

Just clone the cms.git repository to some directory where apache has access to.
In the configuration example below the directory will be ``/var/cms``

Then create the database directory named ``db`` inside of the cloned directory.
You may start with the example db:

``cp -r /var/cms/example/db /var/cms/``


Configuring Apache httpd
========================

Install the Apache WSGI module. On Debian Linux, this is libapache2-mod-wsgi-py3.
Create a new config file /etc/apache2/conf.d/wsgi with content similar to
the following Debian based example:

.. code::

# Adjust "user" and "group" to your system.
WSGIDaemonProcess wsgi processes=10 threads=1 display-name=apache-wsgi user=www-data group=www-data python-path=/var/cms
WSGIApplicationGroup %{GLOBAL}
WSGIPythonOptimize 1
# /cms is the base URL path to the CMS.
# /var/cms is where index.wsgi and the db directory live.
# /var/www is the path to the static files.
# Adjust these paths to your setup.
WSGIScriptAlias /cms /var/cms/index.wsgi
SetEnv cms.domain example.com
SetEnv cms.cmsBase /var/cms
SetEnv cms.wwwBase /var/www
SetEnv cms.maxPostContentLength 1048576
SetEnv cms.debug 1

WSGIProcessGroup wsgi
AllowOverride None
Options -ExecCGI -MultiViews +SymLinksIfOwnerMatch -Indexes
Require all granted

# Redirect all 404 to the CMS 404 handler (optional)
ErrorDocument 404 /cms/__nopage/__nogroup.html