Aucune description

George Baugh 8a85cb3a4b Send DB logs into their own file per worker, allow preload-app il y a 7 mois
.github d5bab21dcd Create Funding.yml il y a 3 ans
bin 8a85cb3a4b Send DB logs into their own file per worker, allow preload-app il y a 7 mois
config 056236bae5 Fix #295 il y a 8 mois
etc 6ca7a50bb8 Reload, not restart, other fix il y a 8 mois
fail2ban f726828266 make fail2ban fixes il y a 8 mois
images 26aa721b81 added a readme for buildah il y a 3 ans
lib 8a85cb3a4b Send DB logs into their own file per worker, allow preload-app il y a 7 mois
nginx 258d2e8288 Add nginx reverse proxy configuration. il y a 8 mois
schema 92b945772f Add a database logging backend. il y a 7 mois
service-files e14a0f41f9 Better service standup opts il y a 2 ans
t 97edb9e0b5 unit tests yay il y a 2 ans
www 92b945772f Add a database logging backend. il y a 7 mois
.gitignore 8a85cb3a4b Send DB logs into their own file per worker, allow preload-app il y a 7 mois
.perltidyrc 4579c59c1c Mass Tidy il y a 10 mois
CHANGELOG aa68fc34ab removed -x il y a 3 ans
Dockerfile d1133dca24 remove bad make target from makefile il y a 2 ans
Dockerfile.build 5074e5a975 remove unneeded AS statements il y a 3 ans
LICENSE aa68fc34ab removed -x il y a 3 ans
Makefile 8a85cb3a4b Send DB logs into their own file per worker, allow preload-app il y a 7 mois
Makefile.PL d5941359ca Fix #305: use Trog::TOTP, remove UUID::Tiny altogether il y a 7 mois
Readme.md 12f79da1e7 Add *rudimentary* support for uwsgi, can still squeeze out some juice here il y a 2 ans
call.pl 734ac51eb7 Mass tidy il y a 8 mois
docker-exfil.sh c76fee1fe6 make docker exfil work on windows mingw il y a 3 ans
dockerdeploy.sh 5b2f374b4a Fix #171 il y a 3 ans
fulldeploy.sh 9933224850 set +x on fulldeploy il y a 3 ans
package-lock.json e6afa02bec Work towards #164: Add means of transforming renders into emails il y a 2 ans
package.json e6afa02bec Work towards #164: Add means of transforming renders into emails il y a 2 ans
profile.sh 54842cc739 Massive speedups with memoization il y a 2 ans
tcms 05cf835ce3 Remove missing conf param, leave notes for future il y a 8 mois

Readme.md

tCMS

A flexible perl CMS which supports multiple data models and content types

Deployment is currently:

  • make depend
  • make install

Then:

  • Set up proxy rule in your webserver
  • open tmux or screen
  • starman -p $PORT www/server.psgi OR (if you want tCMS as a systemd service for the current user):
  • PORT=$PORT make install-service

$PORT being whatever port you want it to sit on.

TODO: Make the makefile not rewrite itself when running make! Reset for now after run.

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

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.

Migration of tCMS1 sites

See migrate.pl, and modify the $docroot variable appropriately

Content Types

Content templates are modular. Add in a template to /templates/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:

  • Microblogs
  • Blogs
  • Files (Video/Audio/Images/Other)
  • About Pages
  • Post Series

Planned development:

  • Presentations
  • Test Plans / Issues (crossover with App::Prove::Elasticsearch)

Embedding Posts within other Posts

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:

  • embed : default, shows the post with a recessed border as an excerpt.
  • media : only show media portion of the post, if any.
  • inline : show everything about the post, save for the title.

These will be added as classes to the embedded post, so you can theme this appropriately.

Data Models

  • DUMMY - A JSON blob. Used for testing mostly, but could be handy for very small sites.
  • Flat File - Pretty much the tCMS1 data model; a migration script is forthcoming

Planned Development:

  • Elasticsearch - Documents are ideally indexed in a search engine, should be nice and fast too.
  • Git - More for the APE crossover

Supported PSGI servers

Starman and uWSGI

In production, I would expect you to run under uWSGI, and the tcms command in the TLD runs this. Otherwise, you can run www/server.psgi to start starman normally.

Ideas to come:

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