George Baugh 74a1b55cf5 WIP towards presentation support and auto-reload | 1 lună în urmă | |
---|---|---|
.github | 3 ani în urmă | |
bin | 4 luni în urmă | |
config | 4 luni în urmă | |
dns | 4 luni în urmă | |
etc | 8 luni în urmă | |
fail2ban | 6 luni în urmă | |
git-hooks | 4 luni în urmă | |
images | 3 ani în urmă | |
lib | 1 lună în urmă | |
5 luni în urmă | ||
nginx | 5 luni în urmă | |
schema | 6 luni în urmă | |
service-files | 5 luni în urmă | |
t | 2 ani în urmă | |
ufw | 5 luni în urmă | |
www | 1 lună în urmă | |
.gitignore | 1 lună în urmă | |
.perltidyrc | 10 luni în urmă | |
CHANGELOG | 3 ani în urmă | |
Dockerfile | 2 ani în urmă | |
Dockerfile.build | 3 ani în urmă | |
Installer.mk | 1 lună în urmă | |
LICENSE | 3 ani în urmă | |
Makefile.PL | 1 lună în urmă | |
Readme.md | 1 lună în urmă | |
call.pl | 8 luni în urmă | |
docker-exfil.sh | 3 ani în urmă | |
dockerdeploy.sh | 3 ani în urmă | |
fulldeploy.sh | 3 ani în urmă | |
package-lock.json | 2 ani în urmă | |
package.json | 2 ani în urmă | |
profile.sh | 2 ani în urmă | |
tcms | 4 luni în urmă | |
tcms-uwsgi | 4 luni în urmă |
A flexible perl CMS which supports multiple data models and content types. Should be readily portable/hostable between any other system that runs tCMS due to being largely self-contained.
tCMS is built fully around ubuntu hosts at the moment.
Deployment is currently:
Then:
sudo ./tcms
OR (if you want tCMS as a systemd service for the current user):make install-service
This sets up nginx, reverse proxy and SSL certs for you. You must set up the user which runs tCMS to have the primary group www-data if you want to be able to run without sudo or run as a usermode service. It is strongly suggested that you chmod everything but the run/ directory to be 0700, particularly in a shared environment.
It also sets up the mailserver and DNS for you.
You should add the pdns group to the user you use to run tCMS, so that the zone management features will work.
A Dockerfile and deployment scripts are provided for your convenience in building/running containers based on this:
# Build and run the server
./fulldeploy.sh
# Just run the server with latest changes
./dockerdeploy.sh
# Extract configuration & local data, then spin down the server
./docker-exfil.sh
There is also podman container code; see images/README.md
The user guide is self-hosted; After you first login, hit the 'Manual' section in the backend.
Rate-Limiting is expected to be handled at the level of the webserver proxying requests to this application. See ufw/setup-rules as an example of the easy way to setup rules/limiting for all the services you need to run tCMS.
See migrate.pl, and modify the $docroot variable appropriately
Content templates are modular. Add in a template to www/templates/html/components/forms which describe the content and how to edit it. Our post data storage being JSON allows us the flexibility to have any kind of meta associated with posts, so go hog wild.
Currently supported:
Planned development:
If you know a Post's ID (see the numbers at the end of it's URI when viewing it's permalink denoted by the chain emoji) You can embed template logic into your posts like so:
<: embed(12345, 'embed') :>
The first parameter is the ID number of the post. The second parameter is the formatting style:
These will be added as classes to the embedded post, so you can theme this appropriately.
Planned Development:
Starman and uWSGI
In production, I would expect you to run under uWSGI, and the tcms-uwsgi
command in the TLD runs this.
Otherwise, you can run tcms
to start starman normally.
domain picker at top -- manage all your web properties from one place
login and registration (forces email for a domain to allow posting on said domain) User data also stored in ES -- it's their profile page!
Error and Access logs immediately dumped into ES for EZ viewing in grafana
Automatic analytics!
Multiple auth models (ldap, oauth etc)
Builtin paywall -- add in LDAP users not on primary domain, give differing privs Have all content able to assign to paywall packages
One click share to social via oauth Mailing list blasts for paywall content