Skip to content

Commit

Permalink
docs: add outline docs
Browse files Browse the repository at this point in the history
  • Loading branch information
SilasPeters committed Aug 8, 2024
1 parent 5947520 commit d8f70e3
Show file tree
Hide file tree
Showing 4 changed files with 53 additions and 7 deletions.
19 changes: 14 additions & 5 deletions ansible/roles/docker/tasks/compose-up.yml
Original file line number Diff line number Diff line change
@@ -1,12 +1,21 @@
---
# NOTE These tasks expect the 'project_source' variable to be set

- name: "Gather service facts"
ansible.builtin.service_facts:
- name: "Check if 'project_source' is defined"
ansible.builtin.fail:
msg: "You forgot to specify the path to the docker compose project"
when: "project_source is undefined"

- name: "Assert that Docker daemon is active, but do not start it"
ansible.builtin.assert:
that: "ansible_facts.services['docker'].state == 'running'"
ansible.builtin.systemd_service:
name: "docker"
state: "started"
check_mode: true
register: "docker_status"

- name: "Exit if docker is not running"
fail:
msg: "Docker deamon is not running"
when: "docker_status.status.ActiveState != 'active'"

- name: "Tear down existing services"
community.docker.docker_compose_v2:
Expand Down
8 changes: 7 additions & 1 deletion ansible/roles/outline/tasks/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
- name: "Ensure Postgres role exists"
community.postgresql.postgresql_user:
name: "outline"
password: "{{ secret_outline.postgresql_password }}" # Sadly seems required to make authentication over localhost work, for peer authentication fails somehow
password: "{{ secret_outline.postgresql_password }}" # TODO Sadly seems required to make authentication over localhost work, for peer authentication fails somehow. Perhaps docker networks can make this easier.
state: "present"

- name: "Ensure database exists"
Expand All @@ -31,6 +31,12 @@
owner: "outline"
state: "present"

# TODO this task assumes the database has already been migrated by Outline to
# have the correct scheme. See `docs/outline.md` for more info.
# Later on, when the database will be hosted in another docker service, this
# migration should be done as well here (but be careful for data loss.
# Backups?).

- name: "Create outline 'docker-compose.yml' file"
ansible.builtin.template:
src: "docker-compose.yml.j2"
Expand Down
2 changes: 1 addition & 1 deletion ansible/roles/outline/templates/docker-compose.yml.j2
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
services:

outline:
image: outlinewiki/outline:0.78.0
image: outlinewiki/outline:0.78.0 # NOTE when bumping this, see `docs/outline.md#Updating to a newer version`. Basically, backup before updating, for a migration will happen automatically upon updating.
env_file: ./docker.env
# ports:
# - "4568:3000"
Expand Down
31 changes: 31 additions & 0 deletions docs/outline.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
# Outline configuration

The `docker.env` file contains many configurations, but some configurations must
be done through the website itself - the settings page. These settings are
stored in the database, and thus not expressed through the `docker.env` file.

When creating a new database, the following settings must be set through the
website:

- Arbitrary members should be viewers, and admins (board members and such) should
be editors. Whilst it does not fully match this logic, the default role for
new members must be set to `viewer` and not `editor`.
- Logging in should only be done through our OAuth provider. Thus, logging in
through email should be disabled.

## Creating a new database and/or migrating

Outline databases are maintained (and created?) using migrations. When updating
the outline version, one _must_ create a backup beforehand, for the
documentation states that the database will automatically be migrated once the
service starts.

When no database exists yet, this can be created by migrating/seeding.

For both scenarios, I would like to refer you to [the official documentation](https://docs.getoutline.com/s/hosting/doc/docker-7pfeLP5a8t).

## Updating to a newer version

When updating outline to the latest version, please make a backup beforehand!
As explained in the section above, the next time outline starts, a database
migration will automatically occur.

0 comments on commit d8f70e3

Please sign in to comment.