Skip to content

vladh/cerca

 
 

Repository files navigation

Cerca

lean forum software

Meaning:

  • to search, quest, run (it)
  • near, close, around, nearby, nigh (es)
  • approximately, roughly (en; from circa)

This piece of software was created after a long time of pining for a new wave of forums hangs. The reason it exists are many. To harbor longer form discussions, and for crawling through threads and topics. For habitually visiting the site to see if anything new happened, as opposed to being obtrusively notified when in the middle of something else. For that sweet tinge of nostalgia that comes with the terrain, from having grown up in pace with the sprawling phpBB forum communities of the mid noughties.

It was written for the purpose of powering the nascent Merveilles community forums.

Features

  • Customizable: Many of Cerca's facets are customizable and the structure is intentionally simple to enable DIY modification
  • Private: Threads are public viewable by default but new threads may be set as private, restricting views to logged-in users only
  • Easy admin: A simple admin panel lets you add users, reset passwords, and remove old accounts. Impactful actions require two admins to perform, or a week of time to pass without a veto from any admin
  • Invites: Fully-featured system for creating both one-time and multi-use invites. Admins can monitor invite redemption by batch as well as issue and delete batches of invites. Accessible using the same simple type of web interface that services the rest of the forum's administration tasks.
  • Transparency: Actions taken by admins are viewable by any logged-in user in the form of a moderation log
  • Low maintenance: Cerca is architected to minimize maintenance and hosting costs by carefully choosing which features it supports, how they work, and which features are intentionally omitted
  • RSS: Receive updates when threads are created or new posts are made by subscribing to the forum RSS feed

Installation

Assuming you're using Linux with systemd, which is the most common scenario, follow these steps.

  1. Create a user: useradd -r cerca
  2. Make sure user can't log in: usermod -s /bin/false cerca
  3. Build cerca: make
  4. Install cerca: sudo make install
  5. Copy nginx config from contrib/nginx.conf to the appropriate place in /etc/nginx/ and adjust according to your needs
  6. Reload nginx config: sudo systemctl reload nginx
  7. Copy service file: cp contrib/cerca.service /etc/systemd/system/cerca.service
  8. Reload service file: systemctl daemon-reload
  9. Enable and immediately start cerca: systemctl enable --now cerca
  10. Add a user for yourself: cerca adduser -database /var/lib/cerca/forum.db -username <username>
  11. Make yourself an admin: cerca makeadmin -database /var/lib/cerca/forum.db -username <username>

Feel free to inspect logs with journalctl -feu cerca.

Other features

Here is the complete help for the cerca command:

USAGE:
  run the forum

  cerca -config <path-to-cerca.toml>
  cerca -config <path-to-cerca.toml> -dev

COMMANDS:
  adduser    create a new user
  makeadmin  make an existing user an admin
  migrate    manage database migrations
  resetpw    reset a user's password
  genauthkey generate and output an authkey for use with `cerca run`
  version    output version information

OPTIONS:
  -config string
        config and settings file containing cerca's customizations (default "cerca.toml")
  -dev
        trigger development mode
  -port int
        port to run the forum on (default 8272)

For example, you can reset a user's password with cerca resetpw -database /var/lib/cerca/forum.db -username <username>.

Config

Cerca supports community customization.

The installation process will create a config file in /etc/cerca/config.toml, which you are free to customise. You can also specify your own config file location with the -config option.

The installation process also copies sample content files to /var/lib/cerca/content, which you can then edit.

Contributing

If you want to join the fun, first have a gander at the CONTRIBUTING.md document. It lays out the overall idea of the project, and outlines what kind of contributions will help improve the project.

Translations

Cerca supports use with different natural languages. To translate Cerca into your language, please have a look at the existing translations (i18n.go) and submit yours as a pull request.

Local development

Install golang.

To launch a local instance of the forum on Linux:

go run ./cmd/cerca -dev

It should respond Serving forum on :8277. You can now go to http://localhost:8277.

Building a binary

go build ./cmd/cerca

Building with reduced size

This is optional, but if you want to minimize the size of the binary follow the instructions below. Less useful for active development, more useful for sending binaries to other computers.

Pass -ldflags="-s -w" when building your binary:

go build -ldflags="-s -w" ./cmd/cerca

Additionally, run upx on any generated binary:

upx --lzma cerca

About

lean forum software

Resources

License

Contributing

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 78.3%
  • HTML 20.5%
  • Other 1.2%