Skip to content

xvw/muhokama

Repository files navigation

Muhokama

Muhokama (which means "discussion" in Uzbek) is a web application that powers a rudimentary forum because Slack, Discord and IRC are, in our opinion, not very suitable for long conversations and message tracking.

Getting started

Muhokama is an OCaml application (>= 4.13.1), so it needs to be installed. And for lack of originality the application is based on a PostgreSQL database (which must be installed and properly configured). For the sake of comfort, GNU/Make is an optional but recommended addiction. (All examples in this tutorial assume that make is available).

Once the repository is locally cloned, go to the root of the project. To locate all dependencies at the root of the project (locally) rather than globally, creating a local switch is recommended:

opam update
opam switch create . ocaml-base-compiler.4.14.0 --deps-only -y
eval $(opam env)

When the local switch build procedure is complete you can simply run the following two commands to retrieve the project dependencies and to retrieve the development dependencies (the second one is optional):

make deps
make dev-deps

Initialization of the database

Assuming a role has been created for the current user, you can simply issue the command make init-database which will create a user muhokama and and ask for a password to be entered in a prompter, and two databases:

  • muhokama_dev: the database populated by the development server to test the application locally;
  • muhokama_test: the database used for the integration tests.

The configuration is provisioned by environment variables:

export POSTGRESQL_ADDON_HOST=localhost
export POSTGRESQL_ADDON_PORT=5432
export POSTGRESQL_ADDON_DB=muhokama_dev
export POSTGRESQL_ADDON_USER=muhokama
export POSTGRESQL_ADDON_PASSWORD=muhokama
export LOG_LEVEL=debug
export POSTGRESQL_ADDON_CONNECTION_POOL=5

Running integration test

Running integration tests (with the make test-integration command) requires the presence of a .test_env file at the root of the project which exports environment variables specific to running integration tests.

Interaction using muhokama.exe

The main actions are orchestrable via the muhokama.exe binary. Once the project is compiled (using, for example, make build) it is possible to invoke the tool with dune exec ./bin/muhokama.exe PARAMS or dune exec bin/muhokama.exe -- PARAMS. The second invocation recompiles (if needed) the binary. Each subcommand can display its man page using the --help flag.

Basic usage

  • dune exec ./bin/muhokama.exe : Display the man page of the binary.
  • dune exec ./bin/muhokama.exe -- server.launch : Start the application.
    • --port X : Specifies the TCP port on which the server is listening. Defaults to 4000

Database

  • dune exec ./bin/muhokama.exe -- db.migrate : Build a migration context and performs missing migrations.
    • --to N : Specifies the target state. Can be behind or beyond the current state.
 Given the migration context being 2 and migrations 3 to 5 pending.
   `db.migrate` will execute migration 3 to 5.

 Given the migration context being 5.
   `db.migrate --to 2` will play `5.down`, `4.down` and `3.down`.

 Given the migration context being 0 with migrations 1 to 5 pending.
   `db.migrate --to 2` will play `1.up` and `2.up`.
  • dune exec ./bin/muhokama.exe -- db.migrate.reset : Rollback database to state 0, drop and then create the migration table again.

Utilities

  • dune exec ./bin/muhokama.exe -- user.list : List all registered users (regardless of their status).
  • dune exec ./bin/muhokama.exe -- user.set-state : Update the status of a user.
    • -U : Specifies user uuid. Required
    • -S : Specifies user state. Must be one of (inactive, member, moderator, admin). Required

Deploy on clever cloud

  1. Create a docker application with a postgreSQL add-on
  2. Add the following environment variable to the docker application
  • CC_DOCKER_EXPOSED_HTTP_PORT="4000"
  • POSTGRESQL_ADDON_CONNECTION_POOL="5"

"5" is the maximum connections for free databases, you can adapt PGSQL_CONNECTION_POOL in accordance to the pool of your plan

  1. In Information of the docker application, check the following options:
  • Zero downtime deployment
  • Enable dedicated build instance (Must be minimum S)
  • Cancel ongoing deployment on new push
  • Force HTTPS
  1. Add a git remote git remote add clever <Deployment URL>

  2. Push your first deployment git push clever main:master

About

A simple forum built on top of Dream, Caqti, Omd, Preface, Cmdliner and other useful OCaml libraries

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published