feat/add-postgres-database #20

Merged
kjuulh merged 2 commits from feat/add-postgres-database into main 2024-11-29 09:05:50 +01:00
21 changed files with 60 additions and 35 deletions
Showing only changes of commit 8d97ebd6d3 - Show all commits

View File

@ -89,14 +89,14 @@ impl Component for PostgresDatabase {
format!("{}.yaml", self.name().replace("/", "-")),
r#"
{%- if environment == "dev" %}
{% set port = 5433 %}
{% else %}
{% set port = 5432 %}
{%- endif%}
{%- set port = 5433 %}
{%- else %}
{%- set port = 5432 %}
{%- endif %}
apiVersion: v1
kind: ConfigMap
metadata:
name: {{ vars.cuddle_crdb.file_name(vars.cuddle_vars.service) }}
name: {{ vars.cuddle_postgres.file_name(vars.cuddle_vars.service) }}
namespace: {{ vars.cluster_vars.namespace }}
data:
DATABASE_TYPE: postgresql
@ -104,7 +104,8 @@ data:
DATABASE_PORT: {{ port }}
DATABASE_USER: {{ vars.cuddle_vars.service | replace("_", "-") }}
DATABASE_DB: {{ vars.cuddle_vars.service | replace("_", "-") }}
"#
"#
.into(),
)));
}

View File

@ -354,6 +354,12 @@ async fn process_render_template(
vars => variables
})?;
let rendered = if rendered.is_empty() || rendered.ends_with("\n") {
rendered
} else {
format!("{rendered}\n")
};
dest_file.write_all(rendered.as_bytes()).await?;
Ok(())

View File

@ -3,4 +3,4 @@
some = {
thing = "some"
}
}
}

View File

@ -1 +1 @@
env: dev
env: dev

View File

@ -1 +1 @@
env: prod
env: prod

View File

@ -1 +1 @@
some_file: 4
some_file: 4

View File

@ -1 +1 @@
service
service

View File

@ -6,4 +6,4 @@ metadata:
namespace: dev
data:
DATABASE_URL: postgresql://root@dev-cluster:26257/service

View File

@ -36,4 +36,4 @@ spec:
- containerPort: 3001
name: internal-http
- containerPort: 3002
name: internal-grpc
name: internal-grpc

View File

@ -118,4 +118,4 @@ spec:
tls:
- hosts:
- grpc.service.dev.internal.kjuulh.app
secretName: tls-service-kjuulh-app-internal-grpc-ingress-dns
secretName: tls-service-kjuulh-app-internal-grpc-ingress-dns

View File

@ -27,4 +27,4 @@ spec:
- containerPort: 3001
name: internal-http
- containerPort: 3002
name: internal-grpc
name: internal-grpc

View File

@ -118,4 +118,4 @@ spec:
tls:
- hosts:
- grpc.service.prod.internal.kjuulh.app
secretName: tls-service-kjuulh-app-internal-grpc-ingress-dns
secretName: tls-service-kjuulh-app-internal-grpc-ingress-dns

View File

@ -27,4 +27,4 @@ spec:
- containerPort: 3001
name: internal-http
- containerPort: 3002
name: internal-grpc
name: internal-grpc

View File

@ -0,0 +1,12 @@
apiVersion: v1
kind: ConfigMap
metadata:
name: service-cuddle-postgres
namespace: dev
data:
DATABASE_TYPE: postgresql
DATABASE_HOST: dev.postgresql.kjuulh.app
DATABASE_PORT: 5433
DATABASE_USER: service
DATABASE_DB: service

View File

@ -1,9 +0,0 @@
apiVersion: v1
kind: ConfigMap
metadata:
name: service-cuddle-crdb
namespace: dev
data:
DATABASE_URL: postgresql://root@dev-cluster:26257/service

View File

@ -25,15 +25,30 @@ spec:
- configMapRef:
name: service-config
env:
- name: DATABASE_URL
- name: DATABASE_HOST
valueFrom:
secretKeyRef:
name: service-cuddle-crdb
key: DATABASE_URL
name: service-cuddle-postgres
key: DATABASE_HOST
- name: DATABASE_PORT
valueFrom:
secretKeyRef:
name: service-cuddle-postgres
key: DATABASE_PORT
- name: DATABASE_USER
valueFrom:
secretKeyRef:
name: service-cuddle-postgres
key: DATABASE_USER
- name: DATABASE_DB
valueFrom:
secretKeyRef:
name: service-cuddle-postgres
key: DATABASE_DB
ports:
- containerPort: 3000
name: external-http
- containerPort: 3001
name: internal-http
- containerPort: 3002
name: internal-grpc
name: internal-grpc

View File

@ -26,7 +26,7 @@ spec:
envFrom:
- configMapRef:
name: {{service_name}}-config
{%- if vars.vault_secret.has_values or vars.cuddle_crdb.has_values %}
{%- if vars.vault_secret.has_values or vars.cuddle_postgres.has_values %}
env:
{%- if vars.vault_secret.has_values %}
{%- for secret in vars.vault_secret.secrets %}

View File

@ -36,4 +36,4 @@ spec:
- containerPort: 3001
name: internal-http
- containerPort: 3002
name: internal-grpc
name: internal-grpc

View File

@ -10,4 +10,4 @@ spec:
mount: kvv2
path: service/dev
refreshAfter: 30s
type: kv-v2
type: kv-v2