Ei kuvausta

George S. Baugh 77512ce67e kill hardcoded post categories for real finally? 4 vuotta sitten
.github d5bab21dcd Create Funding.yml 5 vuotta sitten
bin a145c16f0b more #130: Data routes for posts/ look to work in dummy mode. 4 vuotta sitten
config b12546fa1d tCMS 2.0: Now with more perl 5 vuotta sitten
data 97681cb7a9 post addition appears to work, need to work on ordering 4 vuotta sitten
images 26aa721b81 added a readme for buildah 5 vuotta sitten
lib 77512ce67e kill hardcoded post categories for real finally? 4 vuotta sitten
schema a145c16f0b more #130: Data routes for posts/ look to work in dummy mode. 4 vuotta sitten
service-files 04a6bbd46c Cruise Control for Cool 5 vuotta sitten
t e0f343aea3 wip 5 vuotta sitten
www a776167e6c user icon links 4 vuotta sitten
.gitignore 3767b5fc4d add meta to gitignore 5 vuotta sitten
CHANGELOG aa68fc34ab removed -x 5 vuotta sitten
Dockerfile 5074e5a975 remove unneeded AS statements 4 vuotta sitten
Dockerfile.build 5074e5a975 remove unneeded AS statements 4 vuotta sitten
LICENSE aa68fc34ab removed -x 5 vuotta sitten
Makefile 4e73dcbe5c remove dup curl dec 4 vuotta sitten
Makefile.PL 3b4f4df58f Fix #161: make sure IO::String dep is present 5 vuotta sitten
Readme.md 1c917c5f15 add important note to embed classes 4 vuotta sitten
docker-exfil.sh c76fee1fe6 make docker exfil work on windows mingw 4 vuotta sitten
dockerdeploy.sh 5b2f374b4a Fix #171 4 vuotta sitten
fulldeploy.sh 9933224850 set +x on fulldeploy 5 vuotta sitten

Readme.md

tCMS

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

Deployment is currently:

  • make depend
  • make install
  • Set up proxy rule in your webserver
  • open tmux or screen
  • starman -p $PORT www/server.psgi

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

  • Microblogs
  • Blogs
  • Video
  • Audio
  • Files
  • About Pages

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

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