blob: b5cf34d65591a81850a45fbe6d222e579c0eeec4 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
### CRIMSON --- A simple PHP framework.
### Copyright © 2024 Freya Murphy <contact@freyacat.org>
###
### This file is part of CRIMSON.
###
### CRIMSON is free software; you can redistribute it and/or modify it
### under the terms of the GNU General Public License as published by
### the Free Software Foundation; either version 3 of the License, or (at
### your option) any later version.
###
### CRIMSON is distributed in the hope that it will be useful, but
### WITHOUT ANY WARRANTY; without even the implied warranty of
### MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
### GNU General Public License for more details.
###
### You should have received a copy of the GNU General Public License
### along with CRIMSON. If not, see <http://www.gnu.org/licenses/>.
services:
# `docker-compose-db.yml`
# This compose file creates the `postgres`, and `db-init` containers.
# Crimson uses prostgres for its database and uses db-init to initalize the
# baseline required for all crimson components.
#
# This service stack is only enabled when API_ENABLED=true.
postgres:
build: ${CRIMSON_ROOT}/build/postgres
restart: unless-stopped
env_file: DOCKER_ENV_FILES
environment:
- POSTGRES_INITDB_ARGS=--encoding=UTF-8 --lc-collate=C --lc-ctype=C
volumes:
- ${PROJECT_DATA}/schemas:/var/lib/postgresql/data
- ${PROJECT_SOURCE}/db:/db:ro
healthcheck:
test: pg_isready -U ${POSTGRES_USER} -d ${POSTGRES_DB}
interval: 1s
timeout: 3s
retries: 10
start_period: 3s
db-init:
# => Guarantees the required crimson baseline in the database.
# i.e. sys schema used for storing migration meta data and other small
# things.
# => Runs all database migrations for you. All that is needed
# is that the migration file convention is followed.
# => If the API is enabled, also loads in the api schema for postgrest.
#
# Once db-init finishes, it will create a `db-ready` file in
# /var/run/crimson to tell crimson's php code its to further route requests.
#
# For information on databse conventions and layouts, see
# `build/db-init/README.md`.
build: ${CRIMSON_ROOT}/build/db-init
restart: no
env_file: DOCKER_ENV_FILES
volumes:
- ${PROJECT_SOURCE}/db:/db:ro
- ${PROJECT_DATA}/crimson:/var/run/crimson
depends_on:
postgres:
condition: service_healthy
php:
# Crimson supports calling the postgres database inside php though the
# database library. Thus is in added dependency. Crimson does not need to
# depend on db-init since db-init has a ready file that crimons uses
# instead.
depends_on:
postgres:
condition: service_healthy
|