blob: dce74b9f33f2e2685fd8afe22ee85f83a860a13d [file] [log] [blame]
local kube = import "../../../kube/kube.libsonnet";
{
local top = self,
local cfg = self.cfg,
cfg:: {
name: "demo-next",
image: "registry.k0.hswaw.net/radex/next-bruh:v2",
domain: "demo-next.hs.radex.io",
},
ns: kube.Namespace("personal-radex"),
deployment: top.ns.Contain(kube.Deployment(cfg.name)) {
spec+: {
replicas: 1,
template+: {
spec+: {
volumes_: {
data: kube.PersistentVolumeClaimVolume(top.data),
},
containers_: {
default: kube.Container("default") {
image: cfg.image,
resources: {
requests: { cpu: "0.01", memory: "64M" },
limits: { cpu: "1", memory: "256M" },
},
env_: {
DATA_PATH: "/data",
},
ports_: {
http: { containerPort: 3000 },
},
volumeMounts_: {
data: { mountPath: '/data' },
}
},
},
},
},
},
},
data: top.ns.Contain(kube.PersistentVolumeClaim("data")) {
spec+: {
storageClassName: "waw-hdd-redundant-3",
accessModes: [ "ReadWriteOnce" ],
resources: {
requests: {
storage: "1Gi",
},
},
},
},
service: top.ns.Contain(kube.Service(cfg.name)) {
target_pod:: top.deployment.spec.template,
},
ingress: top.ns.Contain(kube.Ingress(cfg.name)) {
metadata+: {
annotations+: {
"kubernetes.io/tls-acme": "true",
"cert-manager.io/cluster-issuer": "letsencrypt-prod",
"nginx.ingress.kubernetes.io/proxy-body-size": "0",
},
},
spec+: {
tls: [ { hosts: [ cfg.domain ], secretName: cfg.name + "-tls" } ],
rules: [
{
host: cfg.domain,
http: {
paths: [
{ path: "/", backend: top.service.name_port },
],
},
},
],
},
}
}