summaryrefslogtreecommitdiffstats
path: root/setup/projects/services
diff options
context:
space:
mode:
Diffstat (limited to 'setup/projects/services')
-rw-r--r--setup/projects/services/templates/01-mysql-secret.yml.j228
-rw-r--r--setup/projects/services/vars/apps.yml1
-rw-r--r--setup/projects/services/vars/mysql.yml21
-rw-r--r--setup/projects/services/vars/script.yml2
-rw-r--r--setup/projects/services/vars/volumes.yml12
5 files changed, 59 insertions, 5 deletions
diff --git a/setup/projects/services/templates/01-mysql-secret.yml.j2 b/setup/projects/services/templates/01-mysql-secret.yml.j2
new file mode 100644
index 0000000..22412bc
--- /dev/null
+++ b/setup/projects/services/templates/01-mysql-secret.yml.j2
@@ -0,0 +1,28 @@
+apiVersion: v1
+kind: Template
+metadata:
+ name: mysql-secret
+ labels:
+ app: mysql
+ annotations:
+ descriptions: "MySQL Secrets"
+objects:
+- apiVersion: v1
+ kind: Secret
+ metadata:
+ annotations:
+ template.openshift.io/expose-ipe_password: '{.data[''ipe-password'']}'
+ template.openshift.io/expose-root_password: '{.data[''root-password'']}'
+ template.openshift.io/expose-pma_password: '{.data[''pma-password'']}'
+ name: mysql
+ stringData:
+ ipe-password: "{{ ands_secrets.ipepdv }}"
+ root-password: "{{ ands_secrets.ipepdv }}"
+ pma-password: "${PMA_PASSWORD}"
+parameters:
+- description: Password for the PMA connection user.
+ displayName: PMA Connection Password
+ from: '[a-zA-Z0-9]{16}'
+ generate: expression
+ name: PMA_PASSWORD
+ required: true
diff --git a/setup/projects/services/vars/apps.yml b/setup/projects/services/vars/apps.yml
index 3532941..a5216e2 100644
--- a/setup/projects/services/vars/apps.yml
+++ b/setup/projects/services/vars/apps.yml
@@ -1,3 +1,4 @@
apps:
davmail: { provision: true, instantiate: true }
gogs: { provision: true, instantiate: true }
+ mysql: { provision: true, instantiate: true }
diff --git a/setup/projects/services/vars/mysql.yml b/setup/projects/services/vars/mysql.yml
new file mode 100644
index 0000000..c174b61
--- /dev/null
+++ b/setup/projects/services/vars/mysql.yml
@@ -0,0 +1,21 @@
+mysql:
+ pods:
+ mysql:
+ service: { ports: [ 3306 ] }
+ groups: [ "services_mysql" ]
+ images:
+ - stream: "openshift/mysql:5.7"
+ env:
+ - { name: "MYSQL_USER", value: "ipe" }
+ - { name: "MYSQL_PASSWORD", value: "secret@mysql/ipe-password" }
+ - { name: "MYSQL_ROOT_PASSWORD", value: "secret@mysql/root-password" }
+ - { name: "MYSQL_DATABASE", value: "test" }
+ - { name: "MYSQL_PMA_PASSWORD", value: "secret@mysql/pma-password" }
+ - { name: "MYSQL_MAX_CONNECTIONS", value: "500" }
+ mappings:
+ - { name: "db", path: "mysql", mount: "/var/lib/mysql/data" }
+ resources: { request: { cpu: 500m, mem: 1Gi }, limit: { cpu: 2000m, mem: 4Gi } }
+ probes:
+ - { port: 3306 }
+# - { type: "liveness", port: 3306 }
+# - { type: "readiness", command: [/bin/sh, -i, -c, MYSQL_PWD="$MYSQL_PASSWORD" mysql -h 127.0.0.1 -u $MYSQL_USER -D $MYSQL_DATABASE, -e 'SELECT 1'] }
diff --git a/setup/projects/services/vars/script.yml b/setup/projects/services/vars/script.yml
index f5d9378..6b306a8 100644
--- a/setup/projects/services/vars/script.yml
+++ b/setup/projects/services/vars/script.yml
@@ -1,6 +1,6 @@
oc:
- storage: ".*"
- - templates: "gogs*"
+ - templates: "*"
- apps: ".*"
- oc: "expose svc/davmail --type LoadBalancer --protocol TCP --generator service/v1 --name davmail-ingress"
resource: "svc/davmail-ingress"
diff --git a/setup/projects/services/vars/volumes.yml b/setup/projects/services/vars/volumes.yml
index 192f572..0f7dbd4 100644
--- a/setup/projects/services/vars/volumes.yml
+++ b/setup/projects/services/vars/volumes.yml
@@ -1,8 +1,12 @@
gids:
- services: { id: 9000 }
+ services: { id: 9000 }
services_gogs: { id: 9001, users: [ 'csa', 'kopmann' ] }
+ services_sds: { id: 9002, users: [ 'csa', 'jalal' ] }
+ services_mysql: { id: 9005, users: [ 'csa', 'kopmann', 'jalal' ] }
files:
- - { osv: "data", path: "gogs", state: "directory", group: "services_gogs", mode: "02770" }
- - { osv: "data/gogs", path: "gogs", state: "directory", group: "services_gogs", mode: "02770" }
-
+ - { osv: "data", path: "gogs", state: "directory", group: "services_gogs", mode: "02770" }
+ - { osv: "db", path: "mysql", state: "directory", group: "services_mysql", mode: "02770" }
+# - { osv: "data/gogs", path: "gogs", state: "directory", group: "services_gogs", mode: "02770" }
+# - { osv: "etc", path: "sds", state: "directory", group: "services_sds", mode: "02770" }
+# - { osv: "db", path: "sds", state: "directory", group: "services_sds", mode: "02770" }