2021-07-09 14:21:17 +00:00
|
|
|
(ns dda.c4k-common.postgres
|
|
|
|
(:require
|
|
|
|
[clojure.spec.alpha :as s]
|
2021-07-09 14:53:38 +00:00
|
|
|
#?(:cljs [shadow.resource :as rc])
|
2021-11-05 14:16:04 +00:00
|
|
|
#?(:clj [orchestra.core :refer [defn-spec]]
|
|
|
|
:cljs [orchestra.core :refer-macros [defn-spec]])
|
2021-07-09 14:21:17 +00:00
|
|
|
[dda.c4k-common.yaml :as yaml]
|
|
|
|
[dda.c4k-common.base64 :as b64]
|
2021-11-05 13:11:20 +00:00
|
|
|
[dda.c4k-common.predicate :as cp]
|
2021-09-14 12:45:32 +00:00
|
|
|
[dda.c4k-common.common :as cm]))
|
2021-07-09 14:21:17 +00:00
|
|
|
|
2021-09-13 07:05:08 +00:00
|
|
|
(defn postgres-size?
|
|
|
|
[input]
|
|
|
|
(contains? #{:2gb :4gb :8gb :16gb} input))
|
|
|
|
|
2021-11-05 15:18:37 +00:00
|
|
|
(defn postgres-image?
|
|
|
|
[input]
|
2024-02-17 13:39:31 +00:00
|
|
|
(contains? #{"postgres:13" "postgres:14" "postgres:15" "postgres:16"} input))
|
2021-11-05 15:18:37 +00:00
|
|
|
|
2021-09-14 12:45:32 +00:00
|
|
|
(s/def ::postgres-db-user cp/bash-env-string?)
|
|
|
|
(s/def ::postgres-db-password cp/bash-env-string?)
|
2021-07-09 14:21:17 +00:00
|
|
|
(s/def ::postgres-data-volume-path string?)
|
2021-09-13 07:05:08 +00:00
|
|
|
(s/def ::postgres-size postgres-size?)
|
2021-10-01 13:46:06 +00:00
|
|
|
(s/def ::db-name cp/bash-env-string?)
|
2022-02-12 17:28:35 +00:00
|
|
|
(s/def ::pvc-storage-class-name cp/pvc-storage-class-name?)
|
|
|
|
(s/def ::pv-storage-size-gb pos?)
|
2023-01-27 09:32:47 +00:00
|
|
|
|
|
|
|
(def pg-config?
|
|
|
|
(s/keys :opt-un [::postgres-size ::db-name ::postgres-data-volume-path
|
2022-02-12 17:28:35 +00:00
|
|
|
::pvc-storage-class-name ::pv-storage-size-gb]))
|
2023-01-27 09:32:47 +00:00
|
|
|
(def pg-auth?
|
2021-11-05 18:35:16 +00:00
|
|
|
(s/keys :opt-un [::postgres-db-user ::postgres-db-password]))
|
2021-07-09 14:21:17 +00:00
|
|
|
|
2021-11-05 14:16:04 +00:00
|
|
|
(def postgres-function (s/keys :opt-un [::deserializer ::optional]))
|
|
|
|
|
2021-07-09 14:53:38 +00:00
|
|
|
#?(:cljs
|
|
|
|
(defmethod yaml/load-resource :postgres [resource-name]
|
2024-02-20 11:08:49 +00:00
|
|
|
(get (inline-resources "postgres") resource-name)))
|
2021-07-09 14:53:38 +00:00
|
|
|
|
2021-11-05 15:18:37 +00:00
|
|
|
(defn-spec generate-config cp/map-or-seq?
|
2021-11-05 18:35:16 +00:00
|
|
|
[& config (s/? pg-config?)]
|
2021-09-14 17:38:57 +00:00
|
|
|
(let [{:keys [postgres-size db-name]
|
|
|
|
:or {postgres-size :2gb
|
2021-11-05 18:35:16 +00:00
|
|
|
db-name "postgres"}} (first config)]
|
2021-09-14 17:38:57 +00:00
|
|
|
(->
|
2021-11-05 18:35:16 +00:00
|
|
|
(yaml/from-string (yaml/load-resource
|
|
|
|
(str "postgres/config-" (name postgres-size) ".yaml")))
|
2021-09-14 17:38:57 +00:00
|
|
|
(assoc-in [:data :postgres-db] db-name))))
|
2021-07-09 14:21:17 +00:00
|
|
|
|
2021-11-05 15:18:37 +00:00
|
|
|
(defn-spec generate-deployment cp/map-or-seq?
|
2021-11-05 18:35:16 +00:00
|
|
|
[& config (s/? pg-config?)]
|
2021-10-08 09:56:42 +00:00
|
|
|
(let [{:keys [postgres-image]
|
2021-11-05 18:35:16 +00:00
|
|
|
:or {postgres-image "postgres:13"}} (first config)]
|
2021-10-08 09:56:42 +00:00
|
|
|
(->
|
|
|
|
(yaml/from-string (yaml/load-resource "postgres/deployment.yaml"))
|
|
|
|
(assoc-in [:spec :template :spec :containers 0 :image] postgres-image))))
|
2021-07-09 14:21:17 +00:00
|
|
|
|
2021-11-05 14:16:04 +00:00
|
|
|
(defn-spec generate-persistent-volume cp/map-or-seq?
|
2021-11-05 15:18:37 +00:00
|
|
|
[config pg-config?]
|
2022-02-12 17:28:35 +00:00
|
|
|
(let [{:keys [postgres-data-volume-path pv-storage-size-gb]
|
|
|
|
:or {postgres-data-volume-path "/var/postgres"
|
|
|
|
pv-storage-size-gb 10}} config]
|
2021-07-09 14:21:17 +00:00
|
|
|
(->
|
|
|
|
(yaml/from-string (yaml/load-resource "postgres/persistent-volume.yaml"))
|
2022-02-12 17:28:35 +00:00
|
|
|
(assoc-in [:spec :hostPath :path] postgres-data-volume-path)
|
|
|
|
(assoc-in [:spec :capacity :storage] (str pv-storage-size-gb "Gi")))))
|
2021-07-09 14:21:17 +00:00
|
|
|
|
2021-11-05 15:18:37 +00:00
|
|
|
(defn-spec generate-pvc cp/map-or-seq?
|
2022-02-12 17:28:35 +00:00
|
|
|
[config pg-config?]
|
|
|
|
(let [{:keys [pv-storage-size-gb pvc-storage-class-name]
|
|
|
|
:or {pv-storage-size-gb 10
|
2023-01-27 11:24:22 +00:00
|
|
|
pvc-storage-class-name "manual"}} config]
|
2022-02-12 17:28:35 +00:00
|
|
|
(->
|
|
|
|
(yaml/from-string (yaml/load-resource "postgres/pvc.yaml"))
|
|
|
|
(assoc-in [:spec :resources :requests :storage] (str pv-storage-size-gb "Gi"))
|
|
|
|
(assoc-in [:spec :storageClassName] (name pvc-storage-class-name)))))
|
2021-07-09 14:21:17 +00:00
|
|
|
|
2021-11-05 14:16:04 +00:00
|
|
|
(defn-spec generate-secret cp/map-or-seq?
|
2021-11-05 18:35:16 +00:00
|
|
|
[my-auth any?]
|
2021-07-09 14:21:17 +00:00
|
|
|
(let [{:keys [postgres-db-user postgres-db-password]} my-auth]
|
|
|
|
(->
|
|
|
|
(yaml/from-string (yaml/load-resource "postgres/secret.yaml"))
|
|
|
|
(cm/replace-key-value :postgres-user (b64/encode postgres-db-user))
|
|
|
|
(cm/replace-key-value :postgres-password (b64/encode postgres-db-password)))))
|
|
|
|
|
2021-11-05 15:18:37 +00:00
|
|
|
(defn-spec generate-service cp/map-or-seq?
|
|
|
|
[]
|
2021-07-09 14:21:17 +00:00
|
|
|
(yaml/from-string (yaml/load-resource "postgres/service.yaml")))
|