Compare commits

...

315 Commits

Author SHA1 Message Date
renovate-bot 256b7b9539 Update Helm release kube-prometheus-stack to v85.4.0
renovate/stability-days Updates have met minimum release age requirement
2026-06-09 15:26:11 +00:00
mrtz c7b3201573 catalyst: Disable on hel1 2026-06-09 17:19:52 +02:00
mrtz 8d00b94329 Merge pull request 'Update kubernetes-ingress Docker tag to v1.49.0' (#206) from renovate/kubernetes-ingress-1.x into main
Reviewed-on: #206
2026-06-09 15:18:23 +00:00
mrtz ac1116d2bc Merge pull request 'Update registry.k8s.io/kueue/charts/kueue Docker tag to v0.17.3' (#203) from renovate/registry.k8s.io-kueue-charts-kueue-0.x into main
Reviewed-on: #203
2026-06-09 15:12:09 +00:00
mrtz 95b752eb80 Merge pull request 'Update Helm release argo-cd to v9.5.17' (#218) from renovate/argo-cd-9.x into main
Reviewed-on: #218
2026-06-09 15:11:39 +00:00
mrtz 9b04866e53 niks3: Bump to 1.6.1 2026-06-09 17:06:06 +02:00
mrtz 1b4a34de92 niks3: Fix multipart uploads 2026-06-09 16:29:32 +02:00
mrtz a90381545d niks: Add gc and correct s3 url 2026-06-09 15:01:12 +02:00
Gitea Actions 65a31e835d ci(staging): deploy docs cdfdc59d-debug 2026-06-09 12:35:17 +00:00
Gitea Actions 30cc6d70dd ci(staging): deploy docs 6579df12-debug 2026-06-09 12:19:32 +00:00
mrtz 85c81ec4c0 headscale: Add niks3 magicdns and haavahak@ntnu.no 2026-06-09 13:45:58 +02:00
mrtz ac99938a79 niks3: Move to sys 2026-06-09 13:40:41 +02:00
mrtz d0aa57fa13 argo: Allow niks3 in sys project 2026-06-09 13:39:11 +02:00
mrtz 2aed9ead11 niks3: Add nix binary cache 2026-06-09 13:28:14 +02:00
Gitea Actions 5df05acd46 ci(prod): deploy atlantis v2.11.0 2026-06-09 11:06:12 +00:00
Gitea Actions 4625fc0550 ci(staging): deploy atlantis acc3745a-debug 2026-06-09 11:05:43 +00:00
Gitea Actions 796d7e033a ci(prod): deploy codex v2.11.0 2026-06-09 11:05:31 +00:00
Gitea Actions 13800aa8a8 ci(staging): deploy codex acc3745a-debug 2026-06-09 11:04:53 +00:00
Gitea Actions 6228922b62 ci(prod): deploy sorcerer v2.11.0 2026-06-09 11:04:07 +00:00
Gitea Actions 7a4d2f9f74 ci(prod): deploy atlantis v2.10.4 2026-06-09 09:07:52 +00:00
Gitea Actions ea0adc2295 ci(prod): deploy codex v2.10.4 2026-06-09 09:07:21 +00:00
Gitea Actions 0560d3a7f9 ci(staging): deploy atlantis 7b82c201-debug 2026-06-09 09:07:15 +00:00
Gitea Actions 5a3a023d1e ci(prod): deploy sorcerer v2.10.4 2026-06-09 09:06:05 +00:00
Gitea Actions 538549d949 ci(prod): deploy atlantis v2.10.3 2026-06-09 08:13:23 +00:00
Gitea Actions a7a29aadd7 ci(prod): deploy codex v2.10.3 2026-06-09 08:12:45 +00:00
Gitea Actions 7e5a98cc3e ci(prod): deploy sorcerer v2.10.3 2026-06-09 08:11:41 +00:00
Gitea Actions d786f1bab8 ci(staging): deploy atlantis 83a6ac96-debug 2026-06-09 08:10:13 +00:00
Gitea Actions 3c35fbd0d4 ci(prod): deploy atlantis v2.10.2 2026-06-08 15:35:57 +00:00
Gitea Actions e55afeb707 ci(prod): deploy codex v2.10.2 2026-06-08 15:35:17 +00:00
Gitea Actions 14733e1742 ci(prod): deploy sorcerer v2.10.2 2026-06-08 15:34:14 +00:00
Gitea Actions 9bd1ea9464 ci(staging): deploy atlantis a26b0ee5-debug 2026-06-08 15:32:43 +00:00
Gitea Actions fa5d18f97f ci(staging): deploy docs 0e803743-debug 2026-06-08 14:58:08 +00:00
Gitea Actions 026c8a7221 ci(staging): deploy makai e49d3f4f-debug 2026-06-08 09:13:39 +00:00
Gitea Actions 3a34bc0234 ci(prod): deploy atlantis v2.10.1 2026-06-08 07:31:33 +00:00
Gitea Actions 730e7181d5 ci(staging): deploy atlantis 463b423e-debug 2026-06-08 07:31:26 +00:00
Gitea Actions 2b72960e86 ci(prod): deploy codex v2.10.1 2026-06-08 07:30:36 +00:00
Gitea Actions e509b85cd9 ci(prod): deploy sorcerer v2.10.1 2026-06-08 07:29:34 +00:00
mrtz 9aa6b67b3f Increase gitea resources and add ha-proxy logging 2026-06-07 14:01:03 +02:00
mrtz f6a592a266 Merge pull request 'Update Helm release argo-rollouts to v2.40.10' (#219) from renovate/argo-rollouts-2.x into main
Reviewed-on: #219
2026-06-07 09:01:49 +00:00
renovate-bot acc87c79ff Update Helm release argo-rollouts to v2.40.10
renovate/stability-days Updates have met minimum release age requirement
2026-06-07 00:03:36 +00:00
renovate-bot a9374c5934 Update Helm release argo-cd to v9.5.17
renovate/stability-days Updates have met minimum release age requirement
2026-06-07 00:03:13 +00:00
mrtz 50f9f2d638 poseidon: Release Beta 2.10.0 2026-06-06 15:51:34 +02:00
Gitea Actions ce440ae3ea ci(staging): deploy atlantis 74963f78-debug 2026-06-06 13:49:39 +00:00
mrtz b103d37178 gitea: Correct eviction flag 2026-06-06 15:38:59 +02:00
mrtz dc0b889f3a gitea: Increase limits to 1GB and lru caching 2026-06-06 15:36:18 +02:00
Gitea Actions dd0cad06ca ci(staging): deploy atlantis 5db33158-debug 2026-06-06 07:30:57 +00:00
Gitea Actions 33236d642b ci(prod): deploy atlantis v2.10.0 2026-06-06 06:54:07 +00:00
Gitea Actions 53253af69f ci(prod): deploy codex v2.10.0 2026-06-06 06:53:27 +00:00
Gitea Actions 2eaa21e13c ci(staging): deploy atlantis 95b1e01a-debug 2026-06-06 06:53:10 +00:00
Gitea Actions 1febbd87c8 ci(prod): deploy sorcerer v2.10.0 2026-06-06 06:52:11 +00:00
Gitea Actions faddbffd47 ci(staging): deploy sorcerer 5db33158-debug 2026-06-05 09:01:13 +00:00
simkir 3468b8e58d Bump prod atlantis v1.42.24 -> v1.42.25 2026-06-05 01:48:22 +02:00
simkir a80d43aa54 Bump prod sorcerer v1.42.24 -> v1.42.25 2026-06-05 01:47:16 +02:00
simkir 4a74a20c79 Bump beta v2.8.0 -> v2.9.4 2026-06-05 01:33:40 +02:00
Gitea Actions 9c7e09c84a ci(prod): deploy atlantis v2.9.4 2026-06-04 23:22:44 +00:00
Gitea Actions dcde964e25 ci(prod): deploy codex v2.9.4 2026-06-04 23:22:06 +00:00
Gitea Actions 7182148418 ci(staging): deploy codex 32f66b86-debug 2026-06-04 23:21:20 +00:00
Gitea Actions 7564c69aa7 ci(prod): deploy sorcerer v2.9.4 2026-06-04 23:20:56 +00:00
Gitea Actions 72783901b7 ci(prod): deploy atlantis v2.9.3 2026-06-04 22:48:04 +00:00
Gitea Actions a34519f639 ci(staging): deploy atlantis d7525aed-debug 2026-06-04 22:47:43 +00:00
Gitea Actions b2444da71f ci(prod): deploy codex v2.9.3 2026-06-04 22:47:29 +00:00
Gitea Actions ea18a86299 ci(staging): deploy codex d7525aed-debug 2026-06-04 22:46:50 +00:00
Gitea Actions cea3993a00 ci(prod): deploy sorcerer v2.9.3 2026-06-04 22:46:03 +00:00
Gitea Actions 2a5a5d0141 ci(staging): deploy sorcerer d7525aed-debug 2026-06-04 22:45:27 +00:00
Gitea Actions aec98546a0 ci(prod): deploy codex v1.42.25 2026-06-04 22:02:27 +00:00
Gitea Actions ca5ab55995 ci(prod): deploy atlantis v1.42.25 2026-06-04 22:02:21 +00:00
Gitea Actions f3886de47d ci(prod): deploy sorcerer v1.42.25 2026-06-04 22:01:07 +00:00
Gitea Actions 774bcd2d23 ci(prod): deploy sorcerer v2.9.0 2026-06-04 21:43:18 +00:00
Gitea Actions a0e0c74c9c ci(prod): deploy atlantis v2.8.7 2026-06-04 15:35:55 +00:00
Gitea Actions ff851dfdb4 ci(prod): deploy codex v2.8.7 2026-06-04 15:35:25 +00:00
Gitea Actions af8e3d935c ci(staging): deploy atlantis 401fdac1-debug 2026-06-04 15:35:17 +00:00
Gitea Actions 919b75ef9f ci(prod): deploy sorcerer v2.8.7 2026-06-04 15:34:07 +00:00
Gitea Actions f2ed4b8921 ci(prod): deploy atlantis v2.8.6 2026-06-04 15:28:29 +00:00
Gitea Actions 701fed343a ci(prod): deploy codex v2.8.6 2026-06-04 15:27:58 +00:00
Gitea Actions 0365fb84bc ci(staging): deploy atlantis 379762aa-debug 2026-06-04 15:27:51 +00:00
Gitea Actions 069f257895 ci(prod): deploy sorcerer v2.8.6 2026-06-04 15:26:32 +00:00
Gitea Actions 0e828a452f ci(prod): deploy codex v2.8.5 2026-06-04 13:29:05 +00:00
Gitea Actions 7971b2eaa0 ci(prod): deploy atlantis v2.8.5 2026-06-04 13:29:02 +00:00
Gitea Actions 7b7c606473 ci(prod): deploy sorcerer v2.8.5 2026-06-04 13:28:21 +00:00
Gitea Actions c3a16d72cc ci(prod): deploy codex v1.42.24 2026-06-04 09:07:05 +00:00
Gitea Actions 7da86d0bb8 ci(prod): deploy atlantis v1.42.24 2026-06-04 09:06:37 +00:00
Gitea Actions 8cd2318259 ci(prod): deploy sorcerer v1.42.24 2026-06-04 09:05:46 +00:00
Gitea Actions 6bb3bbfdff ci(prod): deploy atlantis v2.8.4 2026-06-04 06:44:31 +00:00
Gitea Actions 5e0cc2c25d ci(prod): deploy codex v2.8.4 2026-06-04 06:44:02 +00:00
Gitea Actions 1649745cad ci(prod): deploy sorcerer v2.8.4 2026-06-04 06:42:53 +00:00
Gitea Actions e8a318d65f ci(staging): deploy atlantis 543ea627-debug 2026-06-04 06:41:52 +00:00
Gitea Actions 9c2497e3ec ci(staging): deploy sorcerer 543ea627-debug 2026-06-04 06:41:47 +00:00
Gitea Actions 5df1cbfabc ci(staging): deploy codex 543ea627-debug 2026-06-04 06:41:41 +00:00
Gitea Actions 39f9b408d5 ci(prod): deploy atlantis v2.8.3 2026-06-03 08:08:48 +00:00
Gitea Actions b128ccc1ee ci(prod): deploy codex v2.8.3 2026-06-03 08:08:15 +00:00
Gitea Actions 5a963f7320 ci(prod): deploy sorcerer v2.8.3 2026-06-03 08:07:08 +00:00
Gitea Actions 8392219980 ci(staging): deploy codex 29336121-debug 2026-06-02 16:42:16 +00:00
Gitea Actions 1395e92744 ci(staging): deploy atlantis 29336121-debug 2026-06-02 16:42:10 +00:00
Gitea Actions af87bc73cb ci(staging): deploy sorcerer 29336121-debug 2026-06-02 16:42:07 +00:00
mrtz 89ad3fe9b8 chore: Bump katamari in staging to 1.4.0 2026-06-02 17:43:17 +02:00
Gitea Actions 713f476f01 ci(staging): deploy atlantis 9bf32638-debug 2026-06-02 12:56:30 +00:00
Gitea Actions 19a11f93c3 ci(staging): deploy codex 9bf32638-debug 2026-06-02 12:55:54 +00:00
Gitea Actions ab24193a2c ci(prod): deploy atlantis v2.8.2 2026-06-02 12:52:04 +00:00
Gitea Actions 720836da5c ci(prod): deploy codex v2.8.2 2026-06-02 12:51:30 +00:00
Gitea Actions 754714f497 ci(prod): deploy sorcerer v2.8.2 2026-06-02 12:50:23 +00:00
Gitea Actions 4a6b1d106b ci(staging): deploy atlantis 866feb1d-debug 2026-06-02 12:49:07 +00:00
Gitea Actions 0e2ace7d40 ci(staging): deploy sorcerer 866feb1d-debug 2026-06-02 12:49:01 +00:00
Gitea Actions b2efdb889c ci(staging): deploy docs 1c160398-debug 2026-06-02 11:29:24 +00:00
Gitea Actions 8251e3da80 ci(staging): deploy docs 879a097a-debug 2026-06-02 11:09:14 +00:00
Gitea Actions 411ce7171e ci(staging): deploy docs 6bfe22ca-debug 2026-06-02 11:07:27 +00:00
Gitea Actions 1cebd72992 ci(staging): deploy docs 79035c8c-debug 2026-06-02 09:30:12 +00:00
mrtz d5c6013376 fix: Bump Gitea after runner 2026-06-02 11:24:52 +02:00
mrtz ac3f6a58f2 fix: Downgrade gitea because of runner incompat. 2026-05-31 21:49:11 +02:00
Gitea Actions 5810099689 ci(staging): deploy docs a530bd5f-debug 2026-05-31 19:21:26 +00:00
mrtz 1681c9843c chore: Bump gitea to 1.26.2 2026-05-31 18:46:47 +02:00
mrtz d511388401 Merge pull request 'Update Helm release x509-certificate-exporter to v4' (#217) from renovate/x509-certificate-exporter-4.x into main
Reviewed-on: #217
2026-05-31 08:43:33 +00:00
mrtz 695f43f5bf fix(x509): Move to oci reg 2026-05-31 10:41:22 +02:00
renovate-bot 3980f61f44 Update Helm release x509-certificate-exporter to v4
renovate/stability-days Updates have met minimum release age requirement
2026-05-31 08:13:10 +00:00
mrtz 102c6263a3 Merge pull request 'Update Helm release kube-prometheus-stack to v85' (#216) from renovate/kube-prometheus-stack-85.x into main
Reviewed-on: #216
2026-05-31 08:09:51 +00:00
mrtz 3e05a29191 Merge pull request 'Update Helm release umami to v7.9.4' (#214) from renovate/umami-7.x into main
Reviewed-on: #214
2026-05-31 08:07:15 +00:00
mrtz e76d33715f Merge pull request 'Update twinproduction/gatus Docker tag to v5.36.0' (#215) from renovate/twinproduction-gatus-5.x into main
Reviewed-on: #215
2026-05-31 08:07:02 +00:00
renovate-bot 2959b0a03d Update Helm release kube-prometheus-stack to v85
renovate/stability-days Updates have met minimum release age requirement
2026-05-31 08:06:12 +00:00
renovate-bot 9cc35893c9 Update twinproduction/gatus Docker tag to v5.36.0
renovate/stability-days Updates have met minimum release age requirement
2026-05-31 08:06:07 +00:00
mrtz f2505960d7 Merge pull request 'Update Helm release openfga to v0.3.5' (#212) from renovate/openfga-0.x into main
Reviewed-on: #212
2026-05-31 08:05:56 +00:00
mrtz 65ea4cfe6c Merge pull request 'Update Helm release opentelemetry-collector to v0.156.2' (#213) from renovate/opentelemetry-collector-0.x into main
Reviewed-on: #213
2026-05-31 08:05:41 +00:00
renovate-bot f3f76d6f34 Update Helm release umami to v7.9.4
renovate/stability-days Updates have met minimum release age requirement
2026-05-31 08:05:29 +00:00
renovate-bot e441293f47 Update Helm release opentelemetry-collector to v0.156.2
renovate/stability-days Updates have met minimum release age requirement
2026-05-31 08:05:12 +00:00
renovate-bot 886d5f266d Update Helm release openfga to v0.3.5
renovate/stability-days Updates have met minimum release age requirement
2026-05-31 08:05:06 +00:00
mrtz 5d86515bbd Merge pull request 'Update Helm release argo-cd to v9.5.15' (#210) from renovate/argo-cd-9.x into main
Reviewed-on: #210
2026-05-31 07:37:28 +00:00
mrtz 0350a29e61 Merge pull request 'Update Helm release cloudnative-pg to v0.28.2' (#209) from renovate/cloudnative-pg-0.x into main
Reviewed-on: #209
2026-05-31 07:30:26 +00:00
mrtz 23041a7cb1 Merge pull request 'Update Helm release kyverno to v3.8.1' (#211) from renovate/kyverno-3.x into main
Reviewed-on: #211
2026-05-31 07:26:41 +00:00
renovate-bot 574daf43be Update Helm release kyverno to v3.8.1
renovate/stability-days Updates have met minimum release age requirement
2026-05-31 00:04:34 +00:00
renovate-bot adc5e75b07 Update Helm release argo-cd to v9.5.15
renovate/stability-days Updates have met minimum release age requirement
2026-05-31 00:04:10 +00:00
Gitea Actions 79d9fded3b ci(prod): deploy codex v1.42.23 2026-05-29 16:26:22 +00:00
Gitea Actions 72652cde2e ci(prod): deploy atlantis v1.42.23 2026-05-29 16:26:01 +00:00
Gitea Actions c3e7968a45 ci(prod): deploy sorcerer v1.42.23 2026-05-29 16:24:45 +00:00
Gitea Actions 2b7e2ce9a3 ci(prod): deploy atlantis v2.8.1 2026-05-29 16:22:37 +00:00
Gitea Actions 307e165af9 ci(prod): deploy codex v2.8.1 2026-05-29 16:22:10 +00:00
Gitea Actions b8366e0009 ci(staging): deploy atlantis d46af365-debug 2026-05-29 16:21:27 +00:00
Gitea Actions b174b1d27d ci(prod): deploy sorcerer v2.8.1 2026-05-29 16:20:42 +00:00
oletytlandsvik d146365fff bump beta to 2.8.0 2026-05-29 10:42:07 +02:00
Gitea Actions 64bfeee043 ci(prod): deploy atlantis v2.8.0 2026-05-29 08:17:14 +00:00
Gitea Actions 9ff1530bdf ci(prod): deploy codex v2.8.0 2026-05-29 08:16:44 +00:00
Gitea Actions 968e96c3a5 ci(prod): deploy sorcerer v2.8.0 2026-05-29 08:15:34 +00:00
Gitea Actions d4699dbf9b ci(staging): deploy atlantis 4258e2f6-debug 2026-05-29 08:14:04 +00:00
oletytlandsvik e52edaca66 Update values/atlantis/values/values-beta.yaml.gotmpl 2026-05-27 10:24:25 +00:00
Gitea Actions 7238bbd720 ci(prod): deploy atlantis v2.7.6 2026-05-27 09:07:11 +00:00
Gitea Actions 5620e05e94 ci(prod): deploy codex v2.7.6 2026-05-27 09:06:52 +00:00
Gitea Actions 75e76f6e37 ci(prod): deploy sorcerer v2.7.6 2026-05-27 09:05:39 +00:00
Gitea Actions 8e20ff37da ci(staging): deploy atlantis c88a3f4d-debug 2026-05-27 08:54:18 +00:00
simkir cda142b3d1 Update umami sql queries 2026-05-26 16:52:01 +02:00
Gitea Actions f0eb28a627 ci(staging): deploy docs 4147901d-debug 2026-05-26 13:37:27 +00:00
Gitea Actions 30f0b45618 ci(prod): deploy atlantis v2.7.5 2026-05-26 07:25:50 +00:00
Gitea Actions e480c57b74 ci(prod): deploy codex v2.7.5 2026-05-26 07:25:13 +00:00
Gitea Actions c09f883ca7 ci(staging): deploy sorcerer f583579d-debug 2026-05-26 07:24:14 +00:00
Gitea Actions fb06a92d75 ci(prod): deploy sorcerer v2.7.5 2026-05-26 07:24:07 +00:00
mrtz d94b0ec137 Merge pull request 'Update Helm release argocd-apps to v2.0.5' (#208) from renovate/argocd-apps-2.x into main
Reviewed-on: #208
2026-05-24 18:25:36 +00:00
renovate-bot 5646300ad7 Update Helm release cloudnative-pg to v0.28.2
renovate/stability-days Updates have met minimum release age requirement
2026-05-24 18:22:29 +00:00
renovate-bot cd8d699c4c Update Helm release argocd-apps to v2.0.5
renovate/stability-days Updates have met minimum release age requirement
2026-05-24 18:22:07 +00:00
mrtz 1529885797 Merge pull request 'Update Helm release argo-cd to v9.5.14' (#207) from renovate/argo-cd-9.x into main
Reviewed-on: #207
2026-05-24 08:18:34 +00:00
mrtz aecd8fd868 Merge pull request 'Update Helm release opentelemetry-collector to v0.156.0' (#204) from renovate/opentelemetry-collector-0.x into main
Reviewed-on: #204
2026-05-24 08:07:09 +00:00
mrtz 3562eb6ba2 Merge pull request 'Update Helm release openfga to v0.3.4' (#202) from renovate/openfga-0.x into main
Reviewed-on: #202
2026-05-24 06:58:09 +00:00
mrtz 6ea4a80bfe Merge pull request 'Update Helm release argo-workflows to v1.0.14' (#201) from renovate/argo-workflows-1.x into main
Reviewed-on: #201
2026-05-24 06:57:27 +00:00
renovate-bot d6096121e5 Update Helm release argo-cd to v9.5.14
renovate/stability-days Updates have met minimum release age requirement
2026-05-24 00:06:53 +00:00
Gitea Actions fd934482e0 ci(prod): deploy atlantis v2.7.4 2026-05-22 14:32:43 +00:00
Gitea Actions 85deb2014b ci(prod): deploy codex v2.7.4 2026-05-22 14:32:12 +00:00
Gitea Actions ba51eda94f ci(prod): deploy sorcerer v2.7.4 2026-05-22 14:31:01 +00:00
Gitea Actions 28def55aa6 ci(staging): deploy atlantis 088703ad-debug 2026-05-22 14:29:28 +00:00
Gitea Actions 3acdcbeed3 ci(prod): deploy atlantis v2.7.3 2026-05-22 13:59:19 +00:00
Gitea Actions 37eccee222 ci(prod): deploy codex v2.7.3 2026-05-22 13:36:29 +00:00
Gitea Actions 67772a7ce2 ci(prod): deploy sorcerer v2.7.3 2026-05-22 13:35:25 +00:00
Gitea Actions 1861e7d3e6 ci(staging): deploy docs 845d0278-debug 2026-05-22 13:34:28 +00:00
Gitea Actions 366745a475 ci(staging): deploy atlantis dbc41b39-debug 2026-05-22 13:33:30 +00:00
Gitea Actions 329ff86ff0 ci(prod): deploy atlantis v2.7.2 2026-05-22 13:28:28 +00:00
Gitea Actions cb3c75bfdb ci(prod): deploy codex v2.7.2 2026-05-22 13:27:57 +00:00
Gitea Actions c7bf676b76 ci(staging): deploy atlantis 8dfb5011-debug 2026-05-22 13:27:52 +00:00
Gitea Actions 4891080aa6 ci(prod): deploy sorcerer v2.7.2 2026-05-22 13:26:32 +00:00
Gitea Actions 9c8c07809f ci(prod): deploy sorcerer v2.7.1 2026-05-22 12:54:13 +00:00
Gitea Actions 06506b0ba9 ci(staging): deploy docs 634ba26f-debug 2026-05-22 09:16:34 +00:00
Gitea Actions d51ab8d65e ci(staging): deploy docs aa150679-debug 2026-05-22 09:16:07 +00:00
Gitea Actions af66872de7 ci(staging): deploy docs d6b8514c-debug 2026-05-22 08:40:08 +00:00
Gitea Actions b6b71fc37d ci(prod): deploy atlantis v2.7.0 2026-05-22 08:00:36 +00:00
Gitea Actions 89a81a4ba0 ci(prod): deploy codex v2.7.0 2026-05-22 08:00:02 +00:00
Gitea Actions 8d1fc597bd ci(prod): deploy sorcerer v2.7.0 2026-05-22 07:58:57 +00:00
Gitea Actions a44ebbcb19 ci(staging): deploy codex 10c7cef3-debug 2026-05-22 07:57:16 +00:00
Gitea Actions 0bb0173009 ci(staging): deploy docs 2fc14b80-debug 2026-05-21 11:40:35 +00:00
Gitea Actions a4e52b258e ci(staging): deploy docs 28a430a3-debug 2026-05-21 11:16:19 +00:00
Gitea Actions cb671b92ce ci(staging): deploy docs 8bc73259-debug 2026-05-21 06:52:11 +00:00
Gitea Actions 470ac2420f ci(staging): deploy docs e39ba23a-debug 2026-05-20 08:12:46 +00:00
Gitea Actions 16273bb3c9 ci(staging): deploy docs 705c1513-debug 2026-05-19 23:51:50 +00:00
Gitea Actions e91ce2974f ci(staging): deploy docs 7e030126-debug 2026-05-19 13:44:26 +00:00
Gitea Actions 0528eb2009 ci(staging): deploy docs b6a4e6b2-debug 2026-05-19 13:28:10 +00:00
Gitea Actions 54d2aec413 ci(prod): deploy atlantis v2.6.8 2026-05-19 12:56:49 +00:00
mrtz 38fb1d778f chore(poseidon): Bump beta to 2.6.8 2026-05-19 14:54:18 +02:00
Gitea Actions b99af34324 ci(prod): deploy codex v2.6.8 2026-05-19 12:19:12 +00:00
Gitea Actions 3b9d698660 ci(staging): deploy atlantis d0d2ea8b-debug 2026-05-19 12:19:04 +00:00
Gitea Actions dc14e0b75b ci(prod): deploy sorcerer v2.6.8 2026-05-19 12:17:49 +00:00
mrtz 5aad5318e8 chore: Bump beta to 2.6.7 2026-05-18 16:12:08 +02:00
Gitea Actions ce79c19ebd ci(prod): deploy atlantis v2.6.7 2026-05-18 13:38:37 +00:00
Gitea Actions 4aac07170a ci(staging): deploy atlantis a4cb9dbe-debug 2026-05-18 13:38:29 +00:00
Gitea Actions b09e90304c ci(prod): deploy codex v2.6.7 2026-05-18 13:37:47 +00:00
Gitea Actions fe3dd36245 ci(prod): deploy sorcerer v2.6.7 2026-05-18 13:36:56 +00:00
mrtz c77eae155f chore(atlantis): Bump xtract and plume 2026-05-18 14:53:48 +02:00
mrtz f975b70e59 fix: Add pvc to prod-queue ns 2026-05-18 11:29:08 +02:00
mrtz ba51468d97 fix(sorcerer): Use correct pvc 2026-05-18 11:20:17 +02:00
mrtz 95bc09d93e fix(atlantis): Add ns to actor config 2026-05-18 11:03:28 +02:00
mrtz c84da247c3 fix(sorcerer): Remove dupe 2026-05-18 10:53:08 +02:00
mrtz 3146b30696 fix(sorcerer): Use the correct ns for jobs 2026-05-18 10:49:38 +02:00
mrtz f5f877f6e0 chore(sorcerer): Bump xtract and plume 2026-05-18 10:25:06 +02:00
mrtz 88ca10e3d4 Merge pull request 'Update Helm release kube-prometheus-stack to v82.18.0' (#175) from renovate/kube-prometheus-stack-82.x into main
Reviewed-on: #175
2026-05-17 07:38:57 +00:00
mrtz 2580a8915d Merge pull request 'Update Helm release argo-cd to v9.5.13' (#200) from renovate/argo-cd-9.x into main
Reviewed-on: #200
2026-05-17 07:38:46 +00:00
renovate-bot 78339c3f30 Update kubernetes-ingress Docker tag to v1.49.0
renovate/stability-days Updates have not met minimum release age requirement
2026-05-17 00:06:09 +00:00
renovate-bot 00970855f9 Update Helm release opentelemetry-collector to v0.156.0
renovate/stability-days Updates have met minimum release age requirement
2026-05-17 00:05:47 +00:00
renovate-bot 8796206315 Update registry.k8s.io/kueue/charts/kueue Docker tag to v0.17.3
renovate/stability-days Updates have not met minimum release age requirement
2026-05-17 00:04:59 +00:00
renovate-bot 1dd9ff51cf Update Helm release openfga to v0.3.4
renovate/stability-days Updates have met minimum release age requirement
2026-05-17 00:04:53 +00:00
renovate-bot 4b4dce1175 Update Helm release argo-workflows to v1.0.14
renovate/stability-days Updates have met minimum release age requirement
2026-05-17 00:04:50 +00:00
renovate-bot d8fb77a2b6 Update Helm release argo-cd to v9.5.13
renovate/stability-days Updates have met minimum release age requirement
2026-05-17 00:04:28 +00:00
mrtz 64532535cc fix(sorcerer/atlantis): Release 2.6.6 to Beta 2026-05-16 20:54:07 +02:00
Gitea Actions 0029f598cb ci(prod): deploy atlantis v2.6.6 2026-05-16 18:41:46 +00:00
Gitea Actions 2641a76b96 ci(prod): deploy codex v2.6.6 2026-05-16 18:41:13 +00:00
Gitea Actions cd6132a846 ci(staging): deploy atlantis 0042495a-debug 2026-05-16 18:40:16 +00:00
Gitea Actions f6b9f011de ci(prod): deploy sorcerer v2.6.6 2026-05-16 18:40:10 +00:00
Gitea Actions 766d8a7939 ci(staging): deploy sorcerer 0042495a-debug 2026-05-16 18:38:32 +00:00
Gitea Actions 95a555753b ci(staging): deploy codex 0042495a-debug 2026-05-16 18:38:26 +00:00
mrtz 1d0f30aac3 chore:(gitea): Bump to .ini fix 2026-05-16 11:12:48 +02:00
mrtz 51c172fbeb Merge pull request 'Update Helm release argo-cd to v9.5.12' (#198) from renovate/argo-cd-9.x into main
Reviewed-on: #198
2026-05-15 09:55:55 +00:00
mrtz bb427a2b39 Merge pull request 'Update Helm release umami to v7.9.1' (#199) from renovate/umami-7.x into main
Reviewed-on: #199
2026-05-15 09:55:09 +00:00
renovate-bot 4e9763657a Update Helm release umami to v7.9.1
renovate/stability-days Updates have met minimum release age requirement
2026-05-15 08:14:31 +00:00
renovate-bot ea79e359b0 Update Helm release argo-cd to v9.5.12
renovate/stability-days Updates have met minimum release age requirement
2026-05-15 08:13:15 +00:00
simkir ceec770fd6 Bump atlantis beta v2.6.4 -> v2.6.5 2026-05-13 16:09:59 +02:00
Gitea Actions 75a12df69c ci(prod): deploy atlantis v2.6.5 2026-05-13 13:29:51 +00:00
Gitea Actions ffe896fdf2 ci(prod): deploy codex v2.6.5 2026-05-13 13:29:17 +00:00
Gitea Actions c7a7c776ba ci(staging): deploy atlantis 184c18a8-debug 2026-05-13 13:29:01 +00:00
Gitea Actions f6e9288a50 ci(prod): deploy sorcerer v2.6.5 2026-05-13 13:28:01 +00:00
simkir e31e72b3d7 Bump Atlantis Beta v2.6.3 -> v2.6.4 2026-05-13 15:07:55 +02:00
simkir 51d1c056ba Set Atlantis Beta app env to preprod
So to use new drifters v7
2026-05-13 15:05:31 +02:00
Gitea Actions 37aff0737a ci(prod): deploy atlantis v2.6.4 2026-05-13 10:21:24 +00:00
Gitea Actions 9886b7e754 ci(prod): deploy codex v2.6.4 2026-05-13 10:20:48 +00:00
Gitea Actions 2c718ed7c9 ci(staging): deploy atlantis 94d0278b-debug 2026-05-13 10:20:31 +00:00
Gitea Actions d13a7df980 ci(prod): deploy sorcerer v2.6.4 2026-05-13 10:19:37 +00:00
Gitea Actions ea53f34c87 ci(staging): deploy makai fd47bfc5-debug 2026-05-13 04:00:47 +00:00
simkir a15c26fdf4 Bump Atlantis beta v2.6.1 -> v2.6.3 2026-05-12 17:50:45 +02:00
Gitea Actions 4e1677a77f ci(prod): deploy atlantis v2.6.3 2026-05-12 15:49:02 +00:00
Gitea Actions ee9f6997fc ci(prod): deploy codex v2.6.3 2026-05-12 15:48:28 +00:00
Gitea Actions 3c1edae36f ci(staging): deploy atlantis a99df174-debug 2026-05-12 15:48:02 +00:00
Gitea Actions b576255404 ci(prod): deploy sorcerer v2.6.3 2026-05-12 15:47:10 +00:00
Gitea Actions 67be13a7e8 ci(prod): deploy atlantis v2.6.2 2026-05-12 15:28:24 +00:00
Gitea Actions 9b5beb3113 ci(prod): deploy codex v2.6.2 2026-05-12 15:27:52 +00:00
Gitea Actions 46b6f647dd ci(staging): deploy atlantis 85c3b852-debug 2026-05-12 15:27:39 +00:00
Gitea Actions 8673ea9d3d ci(prod): deploy sorcerer v2.6.2 2026-05-12 15:26:35 +00:00
simkir 3ffd39e73f Bump beta v1.48.1 -> v2.6.1 2026-05-12 16:26:42 +02:00
Gitea Actions 2427e2a04b ci(prod): deploy atlantis v2.6.1 2026-05-12 14:13:04 +00:00
Gitea Actions 15d2138791 ci(prod): deploy codex v2.6.1 2026-05-12 14:12:30 +00:00
Gitea Actions 2b6bda727f ci(staging): deploy atlantis 0001a0fc-debug 2026-05-12 14:12:16 +00:00
Gitea Actions 0063635012 ci(prod): deploy sorcerer v2.6.1 2026-05-12 14:11:19 +00:00
Gitea Actions 96cf9e8857 ci(prod): deploy atlantis v2.6.0 2026-05-12 14:02:20 +00:00
Gitea Actions 22da3c2c97 ci(prod): deploy codex v2.6.0 2026-05-12 14:01:44 +00:00
Gitea Actions d4064a5669 ci(staging): deploy atlantis ade08af1-debug 2026-05-12 14:01:28 +00:00
Gitea Actions 30648f2168 ci(prod): deploy sorcerer v2.6.0 2026-05-12 14:00:29 +00:00
Gitea Actions 7fb93d0348 ci(staging): deploy sorcerer ade08af1-debug 2026-05-12 13:59:21 +00:00
Gitea Actions fa56ff9b78 ci(staging): deploy docs 5e339995-debug 2026-05-12 10:53:23 +00:00
Gitea Actions 46efc9e580 ci(prod): deploy atlantis v2.5.7 2026-05-11 13:21:32 +00:00
Gitea Actions 7afdee783c ci(prod): deploy atlantis v1.42.22 2026-05-11 11:49:22 +00:00
Gitea Actions c80e9f84cb ci(prod): deploy codex v1.42.22 2026-05-11 11:49:17 +00:00
Gitea Actions d0a4f0d9b5 ci(prod): deploy sorcerer v1.42.22 2026-05-11 11:47:28 +00:00
Gitea Actions 467e1a47f0 ci(prod): deploy codex v2.5.7 2026-05-11 11:27:40 +00:00
Gitea Actions caad872e88 ci(prod): deploy sorcerer v2.5.7 2026-05-11 11:26:25 +00:00
mrtz 0eb5ab4011 Merge pull request 'Update Helm release kyverno to v3.8.0' (#196) from renovate/kyverno-3.x into main
Reviewed-on: #196
2026-05-10 06:49:05 +00:00
mrtz 9705af52b0 Merge pull request 'Update Helm release opentelemetry-collector to v0.153.0' (#197) from renovate/opentelemetry-collector-0.x into main
Reviewed-on: #197
2026-05-10 06:48:55 +00:00
renovate-bot 3324005d0d Update Helm release opentelemetry-collector to v0.153.0
renovate/stability-days Updates have met minimum release age requirement
2026-05-10 00:04:29 +00:00
renovate-bot 55e496c5db Update Helm release kyverno to v3.8.0
renovate/stability-days Updates have met minimum release age requirement
2026-05-10 00:04:17 +00:00
mrtz ce5a488dd0 Merge pull request 'Update Helm release argo-cd to v9.5.11' (#193) from renovate/argo-cd-9.x into main
Reviewed-on: #193
2026-05-09 19:49:49 +00:00
mrtz 95dfa4ffe2 Merge pull request 'Update Helm release openfga to v0.3.3' (#194) from renovate/openfga-0.x into main
Reviewed-on: #194
2026-05-09 19:49:22 +00:00
renovate-bot 21c39c9612 Update Helm release velero to v12.0.1
renovate/stability-days Updates have met minimum release age requirement
2026-05-09 16:39:35 +00:00
renovate-bot 7ae0a2ac41 Update Helm release openfga to v0.3.3
renovate/stability-days Updates have met minimum release age requirement
2026-05-09 16:39:29 +00:00
renovate-bot 624252a373 Update Helm release argo-cd to v9.5.11
renovate/stability-days Updates have met minimum release age requirement
2026-05-09 16:39:08 +00:00
Gitea Actions 527a5812e1 ci(staging): deploy docs b3997895-debug 2026-05-08 11:29:50 +00:00
Gitea Actions ab843a0b86 ci(prod): deploy atlantis v1.42.21 2026-05-08 11:28:15 +00:00
Gitea Actions 8d80a0ea7d ci(prod): deploy codex v1.42.21 2026-05-08 11:28:09 +00:00
Gitea Actions 9a2931f3ec ci(staging): deploy atlantis 1060001f-debug 2026-05-08 11:25:25 +00:00
mrtz 9a5f2b8fea feat: Initial fap(r) stubs with for prod/staging 2026-05-08 09:13:30 +02:00
mrtz f50851c775 chore(gitea): Bump to 1.26.1 2026-05-07 16:52:36 +02:00
mrtz d1a1421e2d fix(cilium): Remove lb2 2026-05-07 16:50:31 +02:00
mrtz cbd0775a47 fix: No http in lb 2026-05-07 16:39:19 +02:00
Gitea Actions ec16ae1085 ci(staging): deploy docs 1a870c15-debug 2026-05-07 12:29:28 +00:00
Gitea Actions 074e3d4dbd ci(prod): deploy atlantis v2.5.5 2026-05-07 12:15:48 +00:00
Gitea Actions 029ce12b89 ci(prod): deploy codex v2.5.5 2026-05-07 12:15:18 +00:00
Gitea Actions b11b663ecb ci(staging): deploy atlantis c5fa4c44-debug 2026-05-07 12:14:56 +00:00
Gitea Actions ef06d7e045 ci(prod): deploy sorcerer v2.5.5 2026-05-07 12:14:02 +00:00
Gitea Actions 7031317fb8 ci(prod): deploy atlantis v2.5.4 2026-05-06 13:57:46 +00:00
Gitea Actions a0fc2b3254 ci(prod): deploy codex v2.5.4 2026-05-06 13:57:13 +00:00
Gitea Actions 8f51b96bcc ci(staging): deploy atlantis 0201daa1-debug 2026-05-06 13:56:21 +00:00
Gitea Actions 9edf45c01e ci(prod): deploy sorcerer v2.5.4 2026-05-06 13:56:03 +00:00
mrtz 7a91dae2f8 fix(haproxy): Use default secret 2026-05-06 14:26:18 +02:00
mrtz de8e6c9853 fix(haproxy): Quicless 2026-05-06 14:22:54 +02:00
mrtz bfc617f958 fix(argo): Allow haproxy in sys 2026-05-06 11:15:25 +02:00
mrtz e23af34c66 Merge pull request 'major(ingress): Migrate hel1 to ha-proxy controller' (#192) from mrtz/ha into main
Reviewed-on: #192
2026-05-06 09:12:11 +00:00
mrtz 0b73242b65 major(ingress): Migrate hel1 to ha-proxy controller
Most ingresses annotations should be work with small changes.
2026-05-06 11:10:18 +02:00
mrtz 464280cdc4 fix: Plume and Xtractor with files 2026-05-05 16:25:32 +02:00
mrtz a12c718072 Merge pull request 'Update Helm release loki to v7' (#191) from renovate/loki-7.x into main
Reviewed-on: #191
2026-05-05 12:36:04 +00:00
Gitea Actions d7fc7db846 ci(prod): deploy atlantis v2.5.3 2026-05-05 08:51:06 +00:00
Gitea Actions 3837105590 ci(prod): deploy codex v2.5.3 2026-05-05 08:50:41 +00:00
Gitea Actions 4d4ed402ee ci(staging): deploy atlantis ea26ac41-debug 2026-05-05 08:50:05 +00:00
Gitea Actions 631e8c2d16 ci(prod): deploy sorcerer v2.5.3 2026-05-05 08:49:25 +00:00
Gitea Actions 506614a5c9 ci(staging): deploy makai 1c9c91a9-debug 2026-05-05 06:13:21 +00:00
mrtz b34ae49feb Merge pull request 'Update Helm release argo-cd to v9.5.4' (#184) from renovate/argo-cd-9.x into main
Reviewed-on: #184
2026-05-04 09:43:48 +00:00
Gitea Actions 5a177eb96b ci(staging): deploy docs f040ed60-debug 2026-05-04 08:01:15 +00:00
mrtz f3acad98da Merge pull request 'Update Helm release kyverno to v3.7.2' (#186) from renovate/kyverno-3.x into main
Reviewed-on: #186
2026-05-03 06:29:53 +00:00
mrtz a895b98de1 Merge pull request 'Update Helm release x509-certificate-exporter to v3.21.0' (#189) from renovate/x509-certificate-exporter-3.x into main
Reviewed-on: #189
2026-05-03 06:28:03 +00:00
mrtz 22990310db Merge pull request 'Update Helm release umami to v7.8.2' (#188) from renovate/umami-7.x into main
Reviewed-on: #188
2026-05-03 06:27:01 +00:00
mrtz 307d31faa3 Merge pull request 'Update Helm release opentelemetry-collector to v0.152.0' (#187) from renovate/opentelemetry-collector-0.x into main
Reviewed-on: #187
2026-05-03 06:26:54 +00:00
mrtz 1192b0392c Merge pull request 'Update Helm release argo-workflows to v1.0.13' (#185) from renovate/argo-workflows-1.x into main
Reviewed-on: #185
2026-05-03 06:26:45 +00:00
renovate-bot 2fb1c1980a Update Helm release loki to v7
renovate/stability-days Updates have met minimum release age requirement
2026-05-03 00:06:18 +00:00
renovate-bot 55a62aceca Update Helm release x509-certificate-exporter to v3.21.0
renovate/stability-days Updates have met minimum release age requirement
2026-05-03 00:06:09 +00:00
renovate-bot 6a344e3c36 Update Helm release umami to v7.8.2
renovate/stability-days Updates have met minimum release age requirement
2026-05-03 00:05:32 +00:00
renovate-bot a9f5278fc6 Update Helm release opentelemetry-collector to v0.152.0
renovate/stability-days Updates have met minimum release age requirement
2026-05-03 00:05:16 +00:00
renovate-bot 10e444dcea Update Helm release kyverno to v3.7.2
renovate/stability-days Updates have met minimum release age requirement
2026-05-03 00:04:17 +00:00
renovate-bot b37456adba Update Helm release argo-workflows to v1.0.13
renovate/stability-days Updates have met minimum release age requirement
2026-05-03 00:04:14 +00:00
renovate-bot f5a47b6132 Update Helm release argo-cd to v9.5.4
renovate/stability-days Updates have met minimum release age requirement
2026-05-03 00:03:54 +00:00
renovate-bot 8d6c8b62aa Update Helm release kube-prometheus-stack to v82.18.0
renovate/stability-days Updates have met minimum release age requirement
2026-04-18 12:15:44 +00:00
101 changed files with 1425 additions and 443 deletions
+2 -2
View File
@@ -4,10 +4,10 @@ description: Atlantis map and simulation service
type: application
# This is the chart version. This version number should be incremented each time you make changes
# to the chart and its templates, including the app version.
version: v2.5.2
version: v2.11.0
# This is the version number of the application being deployed. This version number should be
# incremented each time you make changes to the application.
appVersion: v2.5.2
appVersion: v2.11.0
dependencies:
- name: diagrid-dashboard
version: "0.1.0"
+1 -1
View File
@@ -4,7 +4,7 @@
replicaCount: 1
image:
repository: git.oceanbox.io/oceanbox/poseidon/atlantis
tag: v2.5.2
tag: v2.11.0
pullPolicy: IfNotPresent
init:
enabled: false
+2 -2
View File
@@ -13,9 +13,9 @@ type: application
# This is the chart version. This version number should be incremented each time you make changes
# to the chart and its templates, including the app version.
# Versions are expected to follow Semantic Versioning (https://semver.org/)
version: v2.5.2
version: v2.11.0
# This is the version number of the application being deployed. This version number should be
# incremented each time you make changes to the application. Versions are not expected to
# follow Semantic Versioning. They should reflect the version the application is using.
# It is recommended to use it with quotes.
appVersion: "v2.5.2"
appVersion: "v2.11.0"
+1 -1
View File
@@ -10,7 +10,7 @@ image:
# This sets the pull policy for images.
pullPolicy: IfNotPresent
# Overrides the image tag whose default is the chart appVersion.
tag: v2.5.2
tag: v2.11.0
# This is for the secrets for pulling an image from a private repository more information can be found here: https://kubernetes.io/docs/tasks/configure-pod-container/pull-image-private-registry/
imagePullSecrets:
- name: gitlab-pull-secret
+1 -1
View File
@@ -47,7 +47,7 @@ service:
port: 8080
ingress:
enabled: true
className: nginx
className: haproxy
persistence:
enabled: false
size: 1G
+6
View File
@@ -0,0 +1,6 @@
apiVersion: v2
name: fapr
description: A Helm chart for Fapr (F# Dapr workflow orchestrator)
type: application
version: v0.1.0
appVersion: v0.1.0
+61
View File
@@ -0,0 +1,61 @@
{{/* vim: set filetype=mustache: */}}
{{/*
Expand the name of the chart.
*/}}
{{- define "fapr.name" -}}
{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" }}
{{- end }}
{{/*
Create a default fully qualified app name.
*/}}
{{- define "fapr.fullname" -}}
{{- if .Values.fullnameOverride }}
{{- .Values.fullnameOverride | trunc 63 | trimSuffix "-" }}
{{- else }}
{{- $name := default .Chart.Name .Values.nameOverride }}
{{- if contains $name .Release.Name }}
{{- .Release.Name | trunc 63 | trimSuffix "-" }}
{{- else }}
{{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" }}
{{- end }}
{{- end }}
{{- end }}
{{/*
Create chart name and version as used by the chart label.
*/}}
{{- define "fapr.chart" -}}
{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" }}
{{- end }}
{{/*
Common labels
*/}}
{{- define "fapr.labels" -}}
helm.sh/chart: {{ include "fapr.chart" . }}
{{ include "fapr.selectorLabels" . }}
{{- if .Chart.AppVersion }}
app.kubernetes.io/version: {{ .Chart.AppVersion | quote }}
{{- end }}
app.kubernetes.io/managed-by: {{ .Release.Service }}
{{- end }}
{{/*
Selector labels
*/}}
{{- define "fapr.selectorLabels" -}}
app.kubernetes.io/name: {{ include "fapr.name" . }}
app.kubernetes.io/instance: {{ .Release.Name }}
{{- end }}
{{/*
Create the name of the service account to use
*/}}
{{- define "fapr.serviceAccountName" -}}
{{- if .Values.serviceAccount.create -}}
{{ default (include "fapr.fullname" .) .Values.serviceAccount.name }}
{{- else -}}
{{ default "default" .Values.serviceAccount.name }}
{{- end -}}
{{- end -}}
+85
View File
@@ -0,0 +1,85 @@
apiVersion: apps/v1
kind: Deployment
metadata:
name: {{ include "fapr.fullname" . }}
labels:
{{- include "fapr.labels" . | nindent 4 }}
spec:
{{- if not .Values.autoscaling.enabled }}
replicas: {{ .Values.replicaCount }}
{{- end }}
selector:
matchLabels:
{{- include "fapr.selectorLabels" . | nindent 6 }}
template:
metadata:
{{- with .Values.podAnnotations }}
annotations:
{{- toYaml . | nindent 8 }}
{{- end }}
labels:
{{- include "fapr.selectorLabels" . | nindent 8 }}
spec:
{{- with .Values.imagePullSecrets }}
imagePullSecrets:
{{- toYaml . | nindent 8 }}
{{- end }}
serviceAccountName: {{ include "fapr.serviceAccountName" . }}
securityContext:
{{- toYaml .Values.podSecurityContext | nindent 8 }}
containers:
- name: {{ .Chart.Name }}
securityContext:
{{- toYaml .Values.securityContext | nindent 12 }}
image: "{{ .Values.image.repository }}:{{ .Values.image.tag | default .Chart.AppVersion }}"
imagePullPolicy: {{ .Values.image.pullPolicy }}
ports:
- name: http
containerPort: {{ .Values.service.port }}
protocol: TCP
env:
{{- toYaml .Values.env | nindent 12 }}
livenessProbe:
httpGet:
path: /healthz
port: http
initialDelaySeconds: 5
periodSeconds: 15
readinessProbe:
httpGet:
path: /healthz
port: http
initialDelaySeconds: 3
periodSeconds: 10
resources:
{{- toYaml .Values.resources | nindent 12 }}
volumeMounts:
- name: data
mountPath: /data
- name: appsettings
mountPath: /app/appsettings.json
subPath: appsettings.json
readOnly: true
volumes:
- name: data
{{- if .Values.persistence.enabled }}
persistentVolumeClaim:
claimName: {{ .Values.persistence.existingClaim | default (include "fapr.fullname" .) }}
{{- else }}
emptyDir: {}
{{- end }}
- name: appsettings
configMap:
name: {{ include "fapr.fullname" . }}-appsettings
{{- with .Values.nodeSelector }}
nodeSelector:
{{- toYaml . | nindent 8 }}
{{- end }}
{{- with .Values.affinity }}
affinity:
{{- toYaml . | nindent 8 }}
{{- end }}
{{- with .Values.tolerations }}
tolerations:
{{- toYaml . | nindent 8 }}
{{- end }}
+21
View File
@@ -0,0 +1,21 @@
{{- if and .Values.persistence.enabled (not .Values.persistence.existingClaim) }}
kind: PersistentVolumeClaim
apiVersion: v1
metadata:
name: {{ include "fapr.fullname" . }}
labels:
{{ include "fapr.labels" . | indent 4 }}
spec:
accessModes:
- {{ .Values.persistence.accessMode | quote }}
resources:
requests:
storage: {{ .Values.persistence.size | quote }}
{{- if .Values.persistence.storageClass }}
{{- if (eq "-" .Values.persistence.storageClass) }}
storageClassName: ""
{{- else }}
storageClassName: "{{ .Values.persistence.storageClass }}"
{{- end }}
{{- end }}
{{- end }}
+49
View File
@@ -0,0 +1,49 @@
{{- if .Values.redis.enabled -}}
apiVersion: dragonflydb.io/v1alpha1
kind: Dragonfly
metadata:
name: {{ include "fapr.fullname" . }}-redis
namespace: {{ .Release.Namespace }}
annotations:
linkerd.io/inject: disabled
labels:
app.kubernetes.io/created-by: dragonfly-operator
{{- include "fapr.labels" . | nindent 4 }}
spec:
args:
- --dbfilename=dump
- --maxmemory=$(MAX_MEMORY)Mi
- --proactor_threads=1
- --logtostderr
- --save_schedule=
env:
- name: MAX_MEMORY
valueFrom:
resourceFieldRef:
resource: limits.memory
divisor: 1Mi
replicas: {{ .Values.redis.replicas | default "1" }}
resources:
requests:
cpu: {{ .Values.redis.resources.cpu | default "100m" }}
memory: {{ .Values.redis.resources.memory | default "128Mi" }}
limits:
memory: {{ .Values.redis.resources.memory | default "128Mi" }}
authentication:
passwordFromSecret:
name: {{ .Values.redis.secret.name | default (printf "%s-redis" (include "fapr.fullname" .)) | quote }}
key: {{ .Values.redis.secret.key | quote }}
{{- if .Values.redis.backup.enabled }}
snapshot:
dir: /data
cron: "0 3 * * *"
enableOnMasterOnly: false
persistentVolumeClaimSpec:
storageClassName: {{ .Values.redis.storageClass | default "managed-nfs-storage" }}
accessModes:
- ReadWriteOnce
resources:
requests:
storage: {{ .Values.redis.size | default "1Gi" }}
{{- end }}
{{- end }}
+15
View File
@@ -0,0 +1,15 @@
apiVersion: v1
kind: Service
metadata:
name: {{ include "fapr.fullname" . }}
labels:
{{- include "fapr.labels" . | nindent 4 }}
spec:
type: {{ .Values.service.type }}
ports:
- port: {{ .Values.service.port }}
targetPort: http
protocol: TCP
name: http
selector:
{{- include "fapr.selectorLabels" . | nindent 4 }}
+12
View File
@@ -0,0 +1,12 @@
{{- if .Values.serviceAccount.create -}}
apiVersion: v1
kind: ServiceAccount
metadata:
name: {{ include "fapr.serviceAccountName" . }}
labels:
{{- include "fapr.labels" . | nindent 4 }}
{{- with .Values.serviceAccount.annotations }}
annotations:
{{- toYaml . | nindent 4 }}
{{- end }}
{{- end }}
+67
View File
@@ -0,0 +1,67 @@
# Default values for fapr.
replicaCount: 1
image:
repository: git.oceanbox.io/oceanbox/fapr/fapr
tag: v0.1.0
pullPolicy: IfNotPresent
env:
- name: APP_NAME
valueFrom:
fieldRef:
fieldPath: metadata.name
- name: APP_NAMESPACE
valueFrom:
fieldRef:
fieldPath: metadata.namespace
imagePullSecrets:
- name: gitlab-pull-secret
nameOverride: ""
fullnameOverride: ""
serviceAccount:
create: true
annotations: {}
name: ""
podAnnotations: {}
podSecurityContext:
fsGroup: 0
securityContext:
capabilities:
drop:
- ALL
readOnlyRootFilesystem: false
runAsNonRoot: false
runAsUser: 0
service:
type: ClusterIP
port: 8080
persistence:
enabled: true
existingClaim: ""
size: 1Gi
storageClass: "ceph-rbd"
accessMode: ReadWriteMany
redis:
enabled: true
replicas: 1
backup:
enabled: false
size: 1Gi
storageClass: "ceph-rbd"
secret:
name: ""
key: "redis-password"
resources:
cpu: 100m
memory: 128Mi
resources: {}
autoscaling:
enabled: false
minReplicas: 1
maxReplicas: 3
targetCPUUtilizationPercentage: 80
serviceMonitor:
enabled: false
nodeSelector: {}
tolerations: []
affinity: {}
+1 -1
View File
@@ -47,7 +47,7 @@ service:
port: 8080
ingress:
enabled: true
className: nginx
className: haproxy
persistence:
enabled: false
size: 1G
+2 -2
View File
@@ -4,10 +4,10 @@ description: A Helm chart for Kubernetes
type: application
# This is the chart version. This version number should be incremented each time you make changes
# to the chart and its templates, including the app version.
version: v2.5.2
version: v2.11.0
# This is the version number of the application being deployed. This version number should be
# incremented each time you make changes to the application.
appVersion: v2.5.2
appVersion: v2.11.0
dependencies:
- name: diagrid-dashboard
version: "0.1.0"
+1 -1
View File
@@ -5,7 +5,7 @@
replicaCount: 1
image:
repository: git.oceanbox.io/oceanbox/poseidon/sorcerer
tag: v2.5.2
tag: v2.11.0
pullPolicy: IfNotPresent
init:
enabled: false
+4 -4
View File
@@ -15,7 +15,7 @@ releases:
- name: argocd
namespace: argocd
chart: argo/argo-cd
version: 9.5.2
version: 9.5.17
condition: argo.enabled
values:
- ../values/argo/values/argocd.yaml.gotmpl
@@ -27,7 +27,7 @@ releases:
- name: argocd-apps
namespace: argocd
chart: argo/argocd-apps
version: 2.0.4
version: 2.0.5
condition: argo.apps.enabled
values:
- ../values/argo/values/apps.yaml.gotmpl
@@ -35,7 +35,7 @@ releases:
- name: argo-rollouts
namespace: argocd
chart: argo/argo-rollouts
version: 2.40.9
version: 2.40.10
condition: argo.rollouts.enabled
values:
- ../values/argo/values/rollouts.yaml.gotmpl
@@ -43,7 +43,7 @@ releases:
- name: argo-workflows
namespace: argocd
chart: argo/argo-workflows
version: 1.0.10
version: 1.0.14
condition: argo.workflows.enabled
missingFileHandler: Info
- name: manifests
+39
View File
@@ -0,0 +1,39 @@
bases:
- ../envs/environments.yaml.gotmpl
commonLabels:
tier: oceanbox
releases:
- name: {{ .Environment.Name }}-fapr
namespace: {{ .Environment.Name }}-fapr
chart: ../charts/fapr
condition: fapr.enabled
values:
- ../values/fapr/values/values.yaml
- ../values/fapr/values/values-{{ .Environment.Name }}.yaml
- ../values/fapr/values/values-{{ .Environment.Name }}-{{ requiredEnv "ARGOCD_ENV_CLUSTER_NAME" }}.yaml
postRenderer: ../bin/kustomizer
postRendererArgs:
- ../values/fapr/kustomize/{{ .Environment.Name }}-{{ requiredEnv "ARGOCD_ENV_CLUSTER_NAME" }}
missingFileHandler: Info
- name: manifests
namespace: {{ .Environment.Name }}-fapr
chart: manifests
condition: fapr.enabled
missingFileHandler: Info
values:
- ../values/env.yaml
- ../values/env-{{ requiredEnv "ARGOCD_ENV_CLUSTER_NAME" }}.yaml
- ../values/fapr/env.yaml.gotmpl
- ../values/fapr/env-{{ requiredEnv "ARGOCD_ENV_CLUSTER_NAME" }}.yaml.gotmpl
hooks:
- events: [ prepare, cleanup ]
showlogs: true
command: ../bin/helmify
args:
- '{{`{{ if eq .Event.Name "prepare" }}build{{ else }}clean{{ end }}`}}'
- '{{`{{ .Release.Chart }}`}}'
- '{{`{{ .Environment.Name }}`}}'
- ../values/fapr/manifests
- manifests
+1 -1
View File
@@ -13,7 +13,7 @@ releases:
- name: gitea
namespace: gitea
chart: gitea/gitea
version: 12.5.3
version: 12.6.0
condition: gitea.enabled
values:
- ../values/gitea/values/values.yaml
+44
View File
@@ -0,0 +1,44 @@
bases:
- ../envs/environments.yaml.gotmpl
repositories:
- name: haproxytech
oci: true
url: 'ghcr.io/haproxytech/helm-charts'
commonLabels:
tier: system
releases:
- name: ingress-haproxy
namespace: ingress-haproxy
chart: haproxytech/kubernetes-ingress
version: 1.49.0
condition: haproxy.enabled
values:
- ../values/ingress-haproxy/values/ingress-haproxy.yaml.gotmpl
- ../values/ingress-haproxy/values/ingress-haproxy-{{ .Environment.Name }}.yaml.gotmpl
postRenderer: ../bin/kustomizer
postRendererArgs:
- ../values/ingress-haproxy/kustomize/{{ .Environment.Name }}
missingFileHandler: Info
- name: manifests
namespace: ingress-haproxy
chart: manifests
condition: haproxy.enabled
missingFileHandler: Info
values:
- ../values/env.yaml
- ../values/env-{{ requiredEnv "ARGOCD_ENV_CLUSTER_NAME" }}.yaml
- ../values/ingress-haproxy/env.yaml.gotmpl
- ../values/ingress-haproxy/env-{{ requiredEnv "ARGOCD_ENV_CLUSTER_NAME" }}.yaml.gotmpl
hooks:
- events: [ prepare, cleanup ]
showlogs: true
command: ../bin/helmify
args:
- '{{`{{ if eq .Event.Name "prepare" }}build{{ else }}clean{{ end }}`}}'
- '{{`{{ .Release.Chart }}`}}'
- '{{`{{ .Environment.Name }}`}}'
- ../values/ingress-haproxy/manifests
- manifests
+1 -1
View File
@@ -8,7 +8,7 @@ releases:
- name: kueue
namespace: kueue-system
chart: oci://registry.k8s.io/kueue/charts/kueue
version: 0.17.1
version: 0.17.3
condition: kueue.enabled
values:
- ../values/kueue/values/values.yaml
+1 -1
View File
@@ -15,7 +15,7 @@ releases:
- name: kyverno
namespace: kyverno
chart: kyverno/kyverno
version: 3.7.1
version: 3.8.1
condition: kyverno.enabled
values:
- ../values/kyverno/values/kyverno.yaml.gotmpl
+1 -1
View File
@@ -12,7 +12,7 @@ releases:
- name: loki
namespace: loki
chart: loki/loki
version: 6.55.0
version: 7.0.0
condition: loki.enabled
values:
- ../values/loki/values/loki.yaml.gotmpl
+27
View File
@@ -0,0 +1,27 @@
bases:
- ../envs/environments.yaml.gotmpl
commonLabels:
tier: system
releases:
- name: manifests
namespace: niks3
chart: manifests
condition: niks3.enabled
missingFileHandler: Info
values:
- ../values/env.yaml
- ../values/env-{{ requiredEnv "ARGOCD_ENV_CLUSTER_NAME" }}.yaml
- ../values/niks3/env.yaml.gotmpl
- ../values/niks3/env-{{ requiredEnv "ARGOCD_ENV_CLUSTER_NAME" }}.yaml.gotmpl
hooks:
- events: [ prepare, cleanup ]
showlogs: true
command: ../bin/helmify
args:
- '{{`{{ if eq .Event.Name "prepare" }}build{{ else }}clean{{ end }}`}}'
- '{{`{{ .Release.Chart }}`}}'
- '{{`{{ .Environment.Name }}`}}'
- ../values/niks3/manifests
- manifests
+1 -1
View File
@@ -16,7 +16,7 @@ releases:
namespace: {{ .Environment.Name }}-openfga
{{- end }}
chart: openfga/openfga
version: 0.3.2
version: 0.3.5
condition: openfga.enabled
values:
- ../values/openfga/values/values.yaml
@@ -12,7 +12,7 @@ releases:
- name: opentelemetry-collector
namespace: otel
chart: open-telemetry/opentelemetry-collector
version: 0.150.1
version: 0.156.2
condition: otel.enabled
values:
- ../values/opentelemetry-collector/values/values.yaml
+1 -1
View File
@@ -15,7 +15,7 @@ releases:
- name: postgres-operator
namespace: cnpg
chart: cloudnative-pg/cloudnative-pg
version: 0.28.0
version: 0.28.2
condition: postgres_operator.enabled
values:
- ../values/postgres-operator/values/postgres-operator.yaml.gotmpl
+1 -1
View File
@@ -15,7 +15,7 @@ releases:
- name: prometheus
namespace: prometheus
chart: prometheus/kube-prometheus-stack
version: 82.15.1
version: 85.4.0
condition: prometheus.enabled
values:
- ../values/prometheus/values/prometheus.yaml.gotmpl
+1 -1
View File
@@ -14,7 +14,7 @@ releases:
- name: umami
namespace: analytics
chart: umami/umami
version: 7.7.20
version: 7.9.4
condition: umami.enabled
values:
- ../values/umami/values/values.yaml
+1 -1
View File
@@ -15,7 +15,7 @@ releases:
- name: velero
namespace: velero
chart: velero/velero
version: 12.0.0
version: 12.0.1
condition: velero.enabled
values:
- ../values/velero/values/velero.yaml.gotmpl
+3 -2
View File
@@ -3,7 +3,8 @@ bases:
repositories:
- name: x509-exporter
url: 'https://charts.enix.io'
oci: true
url: 'quay.io/enix/charts'
commonLabels:
tier: sys
@@ -12,7 +13,7 @@ releases:
- name: x509-exporter
namespace: x509-exporter
chart: x509-exporter/x509-certificate-exporter
version: 3.20.1
version: 4.1.0
condition: x509_exporter.enabled
values:
- ../values/x509-exporter/values/x509-exporter.yaml.gotmpl
+6
View File
@@ -94,12 +94,16 @@ spec:
server: https://kubernetes.default.svc
- namespace: jobset-system
server: https://kubernetes.default.svc
- namespace: ingress-haproxy
server: https://kubernetes.default.svc
- namespace: dex
server: https://kubernetes.default.svc
- namespace: cra-agent
server: https://kubernetes.default.svc
- namespace: catalyst
server: https://kubernetes.default.svc
- namespace: niks3
server: https://kubernetes.default.svc
sourceRepos:
- https://argoproj.github.io/argo-helm
- https://kubernetes-sigs.github.io/metrics-server/
@@ -139,6 +143,7 @@ spec:
- ghcr.io/spegel-org/helm-charts
- quay.io/cilium/charts
- quay.io/jetstack/charts
- quay.io/enix/charts
- registry.k8s.io/jobset/charts/jobset
- ghcr.io/dragonflydb/dragonfly-operator/helm/dragonfly-operator
- docker.gitea.com
@@ -148,3 +153,4 @@ spec:
- https://twin.github.io/helm-charts
- https://charts.dexidp.io
- public.ecr.aws/diagrid/catalyst
- ghcr.io/haproxytech/helm-charts
@@ -3,7 +3,8 @@ kind: ConfigMap
metadata:
name: beta-atlantis-actor-config
data:
XTRACT_IMAGE: "git.oceanbox.io/oceanbox/katamari/excavator:v1.2.8"
KUEUE_NAMESPACE: "prod-queue"
XTRACT_IMAGE: "git.oceanbox.io/oceanbox/katamari/excavator:v1.2.14"
XTRACT_QUEUE: "prod-queue"
PLUME_IMAGE: "git.oceanbox.io/oceanbox/katamari/plume:v1.2.8"
PLUME_IMAGE: "git.oceanbox.io/oceanbox/katamari/plume:v1.2.14"
PLUME_QUEUE: "prod-queue"
@@ -76,7 +76,7 @@
"https://maps.beta.oceanbox.io"
],
"appName": "atlantis",
"appEnv": "prod",
"appEnv": "preprod",
"appNamespace": "atlantis",
"appVersion": "2.95.1",
"otelCollector": "http://opentelemetry-collector.otel.svc:4317",
@@ -3,6 +3,7 @@ kind: ConfigMap
metadata:
name: prod-atlantis-actor-config
data:
KUEUE_NAMESPACE: "prod-queue"
XTRACT_IMAGE: "git.oceanbox.io/oceanbox/katamari/excavator:v1.2.8"
XTRACT_QUEUE: "prod-queue"
PLUME_IMAGE: "git.oceanbox.io/oceanbox/katamari/plume:v1.2.8"
@@ -3,7 +3,7 @@ kind: ConfigMap
metadata:
name: staging-atlantis-actor-config
data:
XTRACT_IMAGE: "git.oceanbox.io/oceanbox/katamari/excavator:v1.2.8"
XTRACT_IMAGE: "git.oceanbox.io/oceanbox/katamari/excavator:v1.4.0"
XTRACT_QUEUE: "dev-queue"
PLUME_IMAGE: "git.oceanbox.io/oceanbox/katamari/plume:v1.2.8"
PLUME_IMAGE: "git.oceanbox.io/oceanbox/katamari/plume:v1.4.0"
PLUME_QUEUE: "dev-queue"
@@ -2,7 +2,7 @@ replicaCount: 1
image:
repository: git.oceanbox.io/oceanbox/poseidon/atlantis
tag: v1.48.1
tag: v2.10.0
podAnnotations:
dapr.io/app-id: "beta-atlantis"
@@ -11,7 +11,7 @@ env:
- name: APP_NAMESPACE
value: beta-atlantis
- name: APP_VERSION
value: "2.97.4-beta"
value: "2.10.0-beta"
- name: LOG_LEVEL
value: "1"
- name: ANALYTICS_WEB_ID
@@ -1,7 +1,7 @@
replicaCount: 1
image:
repository: git.oceanbox.io/oceanbox/poseidon/atlantis
tag: 5d810716-debug
tag: acc3745a-debug
podAnnotations:
dapr.io/app-id: "staging-atlantis"
env:
-2
View File
@@ -1,2 +0,0 @@
attic:
enabled: false
-27
View File
@@ -1,27 +0,0 @@
apiVersion: argoproj.io/v1alpha1
kind: Application
metadata:
name: attic
namespace: argocd
finalizers:
- resources-finalizer.argocd.argoproj.io
spec:
destination:
namespace: attic
server: "https://kubernetes.default.svc"
sources:
- repoURL: https://git.oceanbox.io/oceanbox/manifests.git
targetRevision: HEAD
path: values/attic/manifests
project: aux
syncPolicy:
managedNamespaceMetadata:
labels:
component: aux
syncOptions:
- CreateNamespace=true
- ApplyOutOfSyncOnly=true
# - ServerSideApply=true
automated:
prune: true
# selfHeal: false
-167
View File
@@ -1,167 +0,0 @@
apiVersion: v1
kind: ConfigMap
metadata:
labels:
app.kubernetes.io/name: attic
name: attic-config
namespace: attic
data:
config.toml: |
# src: https://github.com/zhaofengli/attic/blob/main/server/src/config-template.toml
# Socket address to listen on
listen = "[::]:8080"
# Allowed `Host` headers
#
# This _must_ be configured for production use. If unconfigured or the
# list is empty, all `Host` headers are allowed.
allowed-hosts = []
# The canonical API endpoint of this server
#
# This is the endpoint exposed to clients in `cache-config` responses.
#
# This _must_ be configured for production use. If not configured, the
# API endpoint is synthesized from the client's `Host` header which may
# be insecure.
#
# The API endpoint _must_ end with a slash (e.g., `https://domain.tld/attic/`
# not `https://domain.tld/attic`).
api-endpoint = "https://attic.srv.oceanbox.io/"
# Whether to soft-delete caches
#
# If this is enabled, caches are soft-deleted instead of actually
# removed from the database. Note that soft-deleted caches cannot
# have their names reused as long as the original database records
# are there.
#soft-delete-caches = false
# Whether to require fully uploading a NAR if it exists in the global cache.
#
# If set to false, simply knowing the NAR hash is enough for
# an uploader to gain access to an existing NAR in the global
# cache.
#require-proof-of-possession = true
# Database connection
[database]
# Connection URL
#
# For production use it's recommended to use PostgreSQL.
url = "postgresql://app:mZP1BnmnpDU33B7UZvomYKOSS1laRJ4bvUR7jNDZ1AJqPdNxH2rLXykghczg7Bgy@attic-db-rw:5432/app"
# Whether to enable sending on periodic heartbeat queries
#
# If enabled, a heartbeat query will be sent every minute
#heartbeat = false
# File storage configuration
[storage]
# Storage type
#
# Can be "local" or "s3".
type = "local"
# ## Local storage
# The directory to store all files under
path = "/attic"
# ## S3 Storage (set type to "s3" and uncomment below)
# The AWS region
#region = "us-east-1"
# The name of the bucket
#bucket = "some-bucket"
# Custom S3 endpoint
#
# Set this if you are using an S3-compatible object storage (e.g., Minio).
#endpoint = "https://xxx.r2.cloudflarestorage.com"
# Credentials
#
# If unset, the credentials are read from the `AWS_ACCESS_KEY_ID` and
# `AWS_SECRET_ACCESS_KEY` environment variables.
#[storage.credentials]
# access_key_id = ""
# secret_access_key = ""
# Data chunking
#
# Warning: If you change any of the values here, it will be
# difficult to reuse existing chunks for newly-uploaded NARs
# since the cutpoints will be different. As a result, the
# deduplication ratio will suffer for a while after the change.
[chunking]
# The minimum NAR size to trigger chunking
#
# If 0, chunking is disabled entirely for newly-uploaded NARs.
# If 1, all NARs are chunked.
nar-size-threshold = 65536 # chunk files that are 64 KiB or larger
# The preferred minimum size of a chunk, in bytes
min-size = 16384 # 16 KiB
# The preferred average size of a chunk, in bytes
avg-size = 65536 # 64 KiB
# The preferred maximum size of a chunk, in bytes
max-size = 262144 # 256 KiB
# Compression
[compression]
# Compression type
#
# Can be "none", "brotli", "zstd", or "xz"
type = "zstd"
# Compression level
#level = 8
# Garbage collection
[garbage-collection]
# The frequency to run garbage collection at
#
# By default it's 12 hours. You can use natural language
# to specify the interval, like "1 day".
#
# If zero, automatic garbage collection is disabled, but
# it can still be run manually with `atticd --mode garbage-collector-once`.
interval = "1 week"
# Default retention period
#
# Zero (default) means time-based garbage-collection is
# disabled by default. You can enable it on a per-cache basis.
default-retention-period = "6 months"
[jwt]
# WARNING: Changing _anything_ in this section will break any existing
# tokens. If you need to regenerate them, ensure that you use the the
# correct secret and include the `iss` and `aud` claims.
# JWT `iss` claim
#
# Set this to the JWT issuer that you want to validate.
# If this is set, all received JWTs will validate that the `iss` claim
# matches this value.
#token-bound-issuer = "some-issuer"
# JWT `aud` claim
#
# Set this to the JWT audience(s) that you want to validate.
# If this is set, all received JWTs will validate that the `aud` claim
# contains at least one of these values.
#token-bound-audiences = ["some-audience1", "some-audience2"]
[jwt.signing]
# JWT RS256 secret key
#
# Set this to the base64-encoded private half of an RSA PEM PKCS1 key.
# You can also set it via the `ATTIC_SERVER_TOKEN_RS256_SECRET_BASE64`
# environment variable.
token-rs256-secret-base64 = "LS0tLS1CRUdJTiBSU0EgUFJJVkFURSBLRVktLS0tLQpNSUlKS2dJQkFBS0NBZ0VBdlZrMHQyZUtvdjhpV3prVFFtQzJtRklvd0gxc2liNlVpUFhUaGVwcURiWHMyaERFCnFYa1pKUXRjTnY0T2RtcldmZ2tsbjVyblJNQk5yL1B5dE05OFFMVVJnbzFSU2VTeUVjcmxSU1N4MElVRlhkM3YKV0U0aTJJTktsSzgxblJoY0o4czRUM09iYUpvSUQweEpqS2IzMkhxZmpOSU1vcVdBRk1ES2YyMUM5OWxQeTRXSgpVUUVnYTRzbHo5RzZHVi8wZW5qbFNMa2RRNjEvdEwyRE1ISHgvV2VRUEtpWkF4c2Fwczd3ZVJiNVBrS3J0MVlGClRxa1lJSjY3eDFiNDR1N0NmdWdVbHhMM2JCQ1lqVXVXNnoxdGU3T2ZQUUhoM1FPU2lFZTczQ3I4dU1lSkplV0wKN2VKc1hWSG9uVzBMZWl0aDk5WmJTUTF3YlhieDVPZzNTQ3ZWYnkyZE90Y3Rud2Y2aDN5YlJ3SUNoc24xbk4zMwowRkMyOXlFY0ExQ2VFVzRsMVVHNmxoMGw5cEpiWEhRNlFJS1paempaTlgxZTRGRW5TdytGNGhXd3R1Z2JtKzZnCnVPdEE5QVJxYndJOTFLeEtoT204Q0RJQlRwWThSZG1SaElicWUrc3czT3p3dGk0eTVkU3FMREsrT3Y5b05ucngKQW9TN21TaXNQeDVJS3JwaFhMT3JvVmI2L1puSmNOK3ljaExuenptMDY2Zk5RaTBLNHhzaitvWkphaXVjZnBacAphSElHZGpaY1U3aE5FUzdJNVliVEFqUDdkaDRzdXJnMk1xTUtxbUxsa2ZPcGFoRTlMQTZVVFZRZHZLVFVGNWZwCkdYSnhaT1RKWlpiOGNQTFYxZFdXbnBMaEZNV2h2OUZQTCtDVGZQVUFvQmtmOTE3TzFLdkE3bGsvcTJzQ0F3RUEKQVFLQ0FnQU9WZ3k1dmlzdkFDWTN4ZkNCWEJVM0h6RmFzYVJnSVgvWmh0TkhGbUtGT3pyOW43dGtJWGtYNXU1SwpjNTNndFdJY0ZORTJibUlJUUk4aFBWVW8vM1NtNlk2ejFjTkwxdmJzaGZJcDlBZEtoR2ZOblpvYmszN3I2YlRoCjRRb3NKTVlGZFV1RUtIcWh4dGZKWUx0STNQTnkvb1hLQWJWWE16U3BYWmQzWW14cG01aUJEbEZCUXRhVGpldUUKK3BvZWhiZGE5b0JWcXo1ZCsycnA0bGRtZVpvYTE1YUNJVG5FbEc3R0puRHFtaVN3NUJkZ1FERVNyWmJZRVd5aQpRU0dDL1JUWXl2V1VJcWw5RXh5WnhobGRJaitCMkMyOFRzSXRHN0lpZzF2ajVaVlE0RHF3RmRzc1hiSmF0bkxvClNITlFBcXplT09xY2Mxb0p6N0dzNVRBYVZNZEtEQXZCZm1JMFBMcDNqNmVFOFFIYlduMHk2NzVYbnlqWllLUUcKaWx5R0pUNVRzMWZHWHlPSXBrNG4yQjM1V3dHcjIyTkxnYUd5cnZjRkgxN3JoZGVnaGlrZFJRd1FOcXRsZjBIZApMWDVRQWVwcUt3SE9uR1BGVy9XU2xGU0lEdkt1VFZSVGtvQmFSMTA3OFpiS2JXckZBbEdqYTFvbnNXQUh1YW5UClh5dFE4dWoxUEFFeWFMZUJEaUJxRVJ2am1VVFQ1ZktCOTdaVnRJenVBZ0lyWWZ6YjIyVEk2VFJ6OVZiQ2VyWG8KdTc0cnoxMjM2TXMrbmg5Y2xYd3VtQlBOU1d1eE9OdldOWEZ6VWdIOURzdlFRMWRsMFRJWEFQMGhFYkRHRkNBQwowUlg2M0lpcXFzUG1ZZUZNTGR5K2tVWjViNzI1TlhXWFRHbDRnQ1Y3NFVRU01ya0xrUUtDQVFFQStobXIwYjdnClVYcWRKaGtLRXVsa29IVzVuYzZ4QmhobCtuTkFucVFSTm5tQWpiaDlCeDVpLzQ2WUwxcHFYQUY5cTNIRlowSDIKZEJRZXN2Q0pxbmtSTHVwTi95VE1KSlo0ZE5kMHZqRzZ0UGhMUjZuRmRabHU0TFBRMXRKcU5XZkhZeCtwQ3N2SQo4Wkx3VG8rRGFxSjArZDk3WWF0b0dWNUZHOWtUSjhBYWFXb0Q1R1AyOGtOd0djKzI0b2VNYnJtU0ppQ2I2UlJoCjA5WWJaMGpXdkFHaXJyMzFOTW5nR0dtVmRPMThoOXVMUStLNzFUQWt1eFEzZEhpUzh6UVd6YythRnM1THgyUnIKeXppcEJhR3VySmFJQ05XNklFQm5ndFcvZEZaYXpMbjhQcDVrQlJzQ1NyN1JpQkNFSFZmeHBYVFNoS3cwVWp4NQo2a0gwc01YZnFoOFpMUUtDQVFFQXdkQ3BPUXBRa1RhK0t6Z0VrWGdMVnk2QmZJKzRWdC9BYjRtK2pFSm85aUIzCnN4dEtKNU5tNXltNldXcmFWS25zekxNZy85Mi9vSVZreUlNSklrOWNYdEpuaEU5ak1aVzc2ZjhYbW5CUnJIMnAKVHVmNWtYWWdVUHZLQ2g1U1g5Q2w0UHJENHNSb3cwNHJjbHVxSE1MT2g1MncxUmJPalRrb05tNXBHWlFoVkhxeApaUzh3aVk3bzhLNFZJQXZOVlZOdGlIZFNOY2Y0cDMxL0F6SU5aQjJWdlczeWJHTWNIdDByekQ5TkpZLzhTekc3CktEME5mRTgzeng2OWxHTlhUcURGSnBTV2ZNVlFwSGVCM0FTRTV1YVhVM1c5S3EwN2NDOEJWSHRaK3B5a1B0RTYKOHgrZE9NYWh6UElaMjRqbkIzZkVsaWc0Rk5zd01LZm9aeDdKYUJLRjl3S0NBUUVBdWJUTUgwOWpVenovYVdXWQpWRmlYVG9wN3pGRElvNlVFUEFiT1NiMjd4ajVNRlcrUzd2RkNRMDZIZEVubnhlK1pkKzlmeS85djE5dUV2QXZkCnZRWnVtdTZDQWQwNTlFVUNwb2ZCZU9TR0paQmtuWTdUUHpJeDRZbkRuVy9hUzFPRyt2UnNXY2JkcTNzWEVzNS8KbjNPSDltNWFPRGpGY0dqT1doSkNwZlovNWh4QlRacG9xSlVvclJIT1U4Q2dweXNGK1dlblBWZlVHQzdZWkVYeQpwT0YyQWRpdE5ZaGM3T09oaFpRK0xzYjNUdTRSMlFnSmpoeEIzU3NXdXAzSC9RU1UvekFwbHFIYlpLZnE0WEtmCnVDbUNVMFVZRXBDZ0M4ZFpoVElGOUJSNTE2bFd6Vyt6c1BxbHJTbk9YOWVJWi9vcHd6ZjNGY1V3SmFEWjUxVFcKY29UcTlRS0NBUUVBckhtVTdpYkl0Y0Zpa0RGa2wxT2R1L0t0MW54TFRqd0dFdndnYnM3MmV2ay9yRXEvdmVKRgpzN2NGbDJjb2JpbGRpbmhxQ0doOGpFdkkrVXJxeVBhWXUrVS9xNVcrTHpVUnFkV1JXcVZUZVUzR2FtcXpSQWc4CkQvVlJ3WmxrTXRJSm0rRnNpcFBBcXZVWVlzZEI1aUJTREl0Ky90SXg4NmtHcVJHdVE4MzNyeWNVVUhnakdIYnQKd3FrWU1aRnZJOXgvWCs3WFlQYll4Nnc5YUVtVmN4K0V6ck5XQmJCWktQb25iTFowWDlYM2JhOE8zMnNkWWg5WgpDZDlRVkFubmV4aEUrZVZHMmpmNVlMTGRCRCtkU2FHd3p0dTdBSXh5bFkydkFGQlpMVlZTTUhpZm5oWG5Jc3hZCjFub29HcDZGQWJkS1lWbmZObWdzUlZCVzE5V2s1QkYvMXdLQ0FRRUFqVnR1RXdYZzU5NERIaVN4UjlWbGRBaHYKcXF5dlpieVhPT2pnNHNKZjFLUlpxZkkzV28yL05IQWN0MlZlREE1bnlEM001YndHWEwrdVZGaUlMVk1ZMUp0WQp6MmlHWHgwZVdlbFJya2tRZHFncTI1TE9BQ2dxYTFMNW9tQS9tMGcwQWljWVdYa1FYSXpXRkhwb0ZqcU9KZHpTCnZ0MHhLV2lpWHUxVk5YeDJibFR1dXBCa1JUZUlQNTVxdWdyOUh0ZmY1MHc5MHhwTllaMFR3d0lDMG1neVVMMWEKRkdVdHlPUTlqVFBUUUdGM3h6REJCQ2U2MW5uZUV0TThRMEJ1MXh3Rm90aWFYSE9NaGhiMFBndVkzNHhiekNHYgpHcTlsWjVaN2lRVXByUWNNYjhrUzZ1WFk3VHBDTmUzaDBiTTM5dVlKeHNYNXUzcmVNRWsyZlBNT3dnTlFjdz09Ci0tLS0tRU5EIFJTQSBQUklWQVRFIEtFWS0tLS0tCg=="
-63
View File
@@ -1,63 +0,0 @@
apiVersion: apps/v1
kind: Deployment
metadata:
name: attic
spec:
selector:
matchLabels:
app: attic
strategy:
type: Recreate
template:
metadata:
labels:
app: attic
spec:
containers:
- name: attic
image: ghcr.io/zhaofengli/attic:latest
args:
- -f
- /config.toml
ports:
- name: http
containerPort: 8080
protocol: TCP
livenessProbe:
httpGet:
path: /
port: http
readinessProbe:
httpGet:
path: /
port: http
env:
- name: ATTIC_SERVER_TOKEN_HS256_SECRET_BASE64
value: "LS0tLS1CRUdJTiBSU0EgUFJJVkFURSBLRVktLS0tLQpNSUlKS2dJQkFBS0NBZ0VBdlZrMHQyZUtvdjhpV3prVFFtQzJtRklvd0gxc2liNlVpUFhUaGVwcURiWHMyaERFCnFYa1pKUXRjTnY0T2RtcldmZ2tsbjVyblJNQk5yL1B5dE05OFFMVVJnbzFSU2VTeUVjcmxSU1N4MElVRlhkM3YKV0U0aTJJTktsSzgxblJoY0o4czRUM09iYUpvSUQweEpqS2IzMkhxZmpOSU1vcVdBRk1ES2YyMUM5OWxQeTRXSgpVUUVnYTRzbHo5RzZHVi8wZW5qbFNMa2RRNjEvdEwyRE1ISHgvV2VRUEtpWkF4c2Fwczd3ZVJiNVBrS3J0MVlGClRxa1lJSjY3eDFiNDR1N0NmdWdVbHhMM2JCQ1lqVXVXNnoxdGU3T2ZQUUhoM1FPU2lFZTczQ3I4dU1lSkplV0wKN2VKc1hWSG9uVzBMZWl0aDk5WmJTUTF3YlhieDVPZzNTQ3ZWYnkyZE90Y3Rud2Y2aDN5YlJ3SUNoc24xbk4zMwowRkMyOXlFY0ExQ2VFVzRsMVVHNmxoMGw5cEpiWEhRNlFJS1paempaTlgxZTRGRW5TdytGNGhXd3R1Z2JtKzZnCnVPdEE5QVJxYndJOTFLeEtoT204Q0RJQlRwWThSZG1SaElicWUrc3czT3p3dGk0eTVkU3FMREsrT3Y5b05ucngKQW9TN21TaXNQeDVJS3JwaFhMT3JvVmI2L1puSmNOK3ljaExuenptMDY2Zk5RaTBLNHhzaitvWkphaXVjZnBacAphSElHZGpaY1U3aE5FUzdJNVliVEFqUDdkaDRzdXJnMk1xTUtxbUxsa2ZPcGFoRTlMQTZVVFZRZHZLVFVGNWZwCkdYSnhaT1RKWlpiOGNQTFYxZFdXbnBMaEZNV2h2OUZQTCtDVGZQVUFvQmtmOTE3TzFLdkE3bGsvcTJzQ0F3RUEKQVFLQ0FnQU9WZ3k1dmlzdkFDWTN4ZkNCWEJVM0h6RmFzYVJnSVgvWmh0TkhGbUtGT3pyOW43dGtJWGtYNXU1SwpjNTNndFdJY0ZORTJibUlJUUk4aFBWVW8vM1NtNlk2ejFjTkwxdmJzaGZJcDlBZEtoR2ZOblpvYmszN3I2YlRoCjRRb3NKTVlGZFV1RUtIcWh4dGZKWUx0STNQTnkvb1hLQWJWWE16U3BYWmQzWW14cG01aUJEbEZCUXRhVGpldUUKK3BvZWhiZGE5b0JWcXo1ZCsycnA0bGRtZVpvYTE1YUNJVG5FbEc3R0puRHFtaVN3NUJkZ1FERVNyWmJZRVd5aQpRU0dDL1JUWXl2V1VJcWw5RXh5WnhobGRJaitCMkMyOFRzSXRHN0lpZzF2ajVaVlE0RHF3RmRzc1hiSmF0bkxvClNITlFBcXplT09xY2Mxb0p6N0dzNVRBYVZNZEtEQXZCZm1JMFBMcDNqNmVFOFFIYlduMHk2NzVYbnlqWllLUUcKaWx5R0pUNVRzMWZHWHlPSXBrNG4yQjM1V3dHcjIyTkxnYUd5cnZjRkgxN3JoZGVnaGlrZFJRd1FOcXRsZjBIZApMWDVRQWVwcUt3SE9uR1BGVy9XU2xGU0lEdkt1VFZSVGtvQmFSMTA3OFpiS2JXckZBbEdqYTFvbnNXQUh1YW5UClh5dFE4dWoxUEFFeWFMZUJEaUJxRVJ2am1VVFQ1ZktCOTdaVnRJenVBZ0lyWWZ6YjIyVEk2VFJ6OVZiQ2VyWG8KdTc0cnoxMjM2TXMrbmg5Y2xYd3VtQlBOU1d1eE9OdldOWEZ6VWdIOURzdlFRMWRsMFRJWEFQMGhFYkRHRkNBQwowUlg2M0lpcXFzUG1ZZUZNTGR5K2tVWjViNzI1TlhXWFRHbDRnQ1Y3NFVRU01ya0xrUUtDQVFFQStobXIwYjdnClVYcWRKaGtLRXVsa29IVzVuYzZ4QmhobCtuTkFucVFSTm5tQWpiaDlCeDVpLzQ2WUwxcHFYQUY5cTNIRlowSDIKZEJRZXN2Q0pxbmtSTHVwTi95VE1KSlo0ZE5kMHZqRzZ0UGhMUjZuRmRabHU0TFBRMXRKcU5XZkhZeCtwQ3N2SQo4Wkx3VG8rRGFxSjArZDk3WWF0b0dWNUZHOWtUSjhBYWFXb0Q1R1AyOGtOd0djKzI0b2VNYnJtU0ppQ2I2UlJoCjA5WWJaMGpXdkFHaXJyMzFOTW5nR0dtVmRPMThoOXVMUStLNzFUQWt1eFEzZEhpUzh6UVd6YythRnM1THgyUnIKeXppcEJhR3VySmFJQ05XNklFQm5ndFcvZEZaYXpMbjhQcDVrQlJzQ1NyN1JpQkNFSFZmeHBYVFNoS3cwVWp4NQo2a0gwc01YZnFoOFpMUUtDQVFFQXdkQ3BPUXBRa1RhK0t6Z0VrWGdMVnk2QmZJKzRWdC9BYjRtK2pFSm85aUIzCnN4dEtKNU5tNXltNldXcmFWS25zekxNZy85Mi9vSVZreUlNSklrOWNYdEpuaEU5ak1aVzc2ZjhYbW5CUnJIMnAKVHVmNWtYWWdVUHZLQ2g1U1g5Q2w0UHJENHNSb3cwNHJjbHVxSE1MT2g1MncxUmJPalRrb05tNXBHWlFoVkhxeApaUzh3aVk3bzhLNFZJQXZOVlZOdGlIZFNOY2Y0cDMxL0F6SU5aQjJWdlczeWJHTWNIdDByekQ5TkpZLzhTekc3CktEME5mRTgzeng2OWxHTlhUcURGSnBTV2ZNVlFwSGVCM0FTRTV1YVhVM1c5S3EwN2NDOEJWSHRaK3B5a1B0RTYKOHgrZE9NYWh6UElaMjRqbkIzZkVsaWc0Rk5zd01LZm9aeDdKYUJLRjl3S0NBUUVBdWJUTUgwOWpVenovYVdXWQpWRmlYVG9wN3pGRElvNlVFUEFiT1NiMjd4ajVNRlcrUzd2RkNRMDZIZEVubnhlK1pkKzlmeS85djE5dUV2QXZkCnZRWnVtdTZDQWQwNTlFVUNwb2ZCZU9TR0paQmtuWTdUUHpJeDRZbkRuVy9hUzFPRyt2UnNXY2JkcTNzWEVzNS8KbjNPSDltNWFPRGpGY0dqT1doSkNwZlovNWh4QlRacG9xSlVvclJIT1U4Q2dweXNGK1dlblBWZlVHQzdZWkVYeQpwT0YyQWRpdE5ZaGM3T09oaFpRK0xzYjNUdTRSMlFnSmpoeEIzU3NXdXAzSC9RU1UvekFwbHFIYlpLZnE0WEtmCnVDbUNVMFVZRXBDZ0M4ZFpoVElGOUJSNTE2bFd6Vyt6c1BxbHJTbk9YOWVJWi9vcHd6ZjNGY1V3SmFEWjUxVFcKY29UcTlRS0NBUUVBckhtVTdpYkl0Y0Zpa0RGa2wxT2R1L0t0MW54TFRqd0dFdndnYnM3MmV2ay9yRXEvdmVKRgpzN2NGbDJjb2JpbGRpbmhxQ0doOGpFdkkrVXJxeVBhWXUrVS9xNVcrTHpVUnFkV1JXcVZUZVUzR2FtcXpSQWc4CkQvVlJ3WmxrTXRJSm0rRnNpcFBBcXZVWVlzZEI1aUJTREl0Ky90SXg4NmtHcVJHdVE4MzNyeWNVVUhnakdIYnQKd3FrWU1aRnZJOXgvWCs3WFlQYll4Nnc5YUVtVmN4K0V6ck5XQmJCWktQb25iTFowWDlYM2JhOE8zMnNkWWg5WgpDZDlRVkFubmV4aEUrZVZHMmpmNVlMTGRCRCtkU2FHd3p0dTdBSXh5bFkydkFGQlpMVlZTTUhpZm5oWG5Jc3hZCjFub29HcDZGQWJkS1lWbmZObWdzUlZCVzE5V2s1QkYvMXdLQ0FRRUFqVnR1RXdYZzU5NERIaVN4UjlWbGRBaHYKcXF5dlpieVhPT2pnNHNKZjFLUlpxZkkzV28yL05IQWN0MlZlREE1bnlEM001YndHWEwrdVZGaUlMVk1ZMUp0WQp6MmlHWHgwZVdlbFJya2tRZHFncTI1TE9BQ2dxYTFMNW9tQS9tMGcwQWljWVdYa1FYSXpXRkhwb0ZqcU9KZHpTCnZ0MHhLV2lpWHUxVk5YeDJibFR1dXBCa1JUZUlQNTVxdWdyOUh0ZmY1MHc5MHhwTllaMFR3d0lDMG1neVVMMWEKRkdVdHlPUTlqVFBUUUdGM3h6REJCQ2U2MW5uZUV0TThRMEJ1MXh3Rm90aWFYSE9NaGhiMFBndVkzNHhiekNHYgpHcTlsWjVaN2lRVXByUWNNYjhrUzZ1WFk3VHBDTmUzaDBiTTM5dVlKeHNYNXUzcmVNRWsyZlBNT3dnTlFjdz09Ci0tLS0tRU5EIFJTQSBQUklWQVRFIEtFWS0tLS0tCg=="
# valueFrom:
# secretKeyRef:
# name: server
# key: token
- name: ATTIC_SERVER_DATABASE_URL
value: "postgresql://app:mZP1BnmnpDU33B7UZvomYKOSS1laRJ4bvUR7jNDZ1AJqPdNxH2rLXykghczg7Bgy@attic-db-rw:5432/app"
# valueFrom:
# secretKeyRef:
# name: database
# key: url
volumeMounts:
- name: data
mountPath: /attic
- name: attic-config
mountPath: /config.toml
subPath: config.toml
volumes:
- name: server
secret:
secretName: server
- name: attic-config
configMap:
defaultMode: 420
name: attic-config
- name: data
persistentVolumeClaim:
claimName: attic
-31
View File
@@ -1,31 +0,0 @@
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
annotations:
cert-manager.io/cluster-issuer: letsencrypt-production
nginx.ingress.kubernetes.io/backend-protocol: HTTP
nginx.ingress.kubernetes.io/proxy-body-size: "0"
nginx.ingress.kubernetes.io/proxy-read-timeout: "600"
nginx.ingress.kubernetes.io/proxy-send-timeout: "600"
nginx.ingress.kubernetes.io/ssl-redirect: "true"
labels:
app.kubernetes.io/component: attic
name: attic
namespace: attic
spec:
ingressClassName: nginx
rules:
- host: attic.srv.oceanbox.io
http:
paths:
- backend:
service:
name: attic
port:
name: http
path: /
pathType: Prefix
tls:
- hosts:
- attic.srv.oceanbox.io
secretName: attic.srv.oceanbox.io-tls
@@ -1,13 +0,0 @@
apiVersion: cilium.io/v2
kind: CiliumNetworkPolicy
metadata:
name: allow-cache-nixos
namespace: ncps
spec:
egress:
- toFQDNs:
- matchPattern: 'cache.nixos.org'
- matchPattern: 'nix-community.cachix.org'
endpointSelector:
matchLabels:
app: nix-cache
-12
View File
@@ -1,12 +0,0 @@
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: attic
labels:
app: attic
spec:
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 20Gi
-6
View File
@@ -1,6 +0,0 @@
apiVersion: v1
kind: Secret
metadata:
name: server
stringData:
token: "ref+sops://secrets.yml#attic/jwtToken"
+1 -1
View File
@@ -1,3 +1,3 @@
catalyst:
enabled: true
enabled: false
autosync: false
@@ -9,14 +9,6 @@ metadata:
name: shared-gateway
namespace: kube-system
spec:
infrastructure:
annotations:
load-balancer.hetzner.cloud/location: hel1
load-balancer.hetzner.cloud/type: lb11
load-balancer.hetzner.cloud/name: load-balancer-2
load-balancer.hetzner.cloud/use-private-ip: "true"
load-balancer.hetzner.cloud/uses-proxyprotocol: "true"
load-balancer.hetzner.cloud/http-redirect-https: "false"
gatewayClassName: cilium
listeners:
- name: http
+1 -1
View File
@@ -38,4 +38,4 @@ volumeMounts:
readOnly: true
subPath: appsettings.json
image:
tag: 651291bd-debug
tag: acc3745a-debug
+4 -6
View File
@@ -1,6 +1,6 @@
replicaCount: 1
image:
tag: "ea8cf7dc-debug"
tag: "cdfdc59d-debug"
env:
- name: APP_VERSION
value: "0.0.0"
@@ -8,13 +8,11 @@ env:
value: "1"
ingress:
enabled: true
className: "nginx"
className: "haproxy"
annotations:
cert-manager.io/cluster-issuer: letsencrypt-production
nginx.ingress.kubernetes.io/backend-protocol: HTTP
nginx.ingress.kubernetes.io/enable-cors: "true"
nginx.ingress.kubernetes.io/proxy-buffer-size: 128k
nginx.ingress.kubernetes.io/ssl-redirect: "true"
haproxy.org/backend-protocol: h1
haproxy.org/cors-enable: "true"
oceanbox.io/expose: internal
hosts:
- host: docs.oceanbox.io
+2
View File
@@ -0,0 +1,2 @@
fapr:
enabled: true
+4
View File
@@ -0,0 +1,4 @@
fapr:
enabled: true
autosync: {{ if or (eq .Environment.Name "prod") (eq .Environment.Name "beta") }}false{{ else }}true{{ end }}
env: {{ .Environment.Name }}
@@ -0,0 +1,4 @@
apiVersion: kustomize.config.k8s.io/v1beta1
kind: Kustomization
resources:
- _manifest.yaml
@@ -0,0 +1,20 @@
{
"appName": "fapr",
"appEnv": "prod",
"logLevel": "Information",
"aromeOutputDir": "/data/hdd/data/AROME",
"aromeStartDate": "2026-04-24",
"nveOutputDir": "/data/hdd/data/river-data/Data",
"nveNdays": 5000,
"nveApiUrl": "https://chartserver.nve.no/ShowData.aspx?req=getchart&ver=1.0",
"riverrunBinary": "/app/riverrun",
"norshelfOutputDir": "/data/hdd/data/norshelf/sea_norshelf_files",
"norshelfStartDate": "2026-03-01",
"nemoOutputDir": "/data/hdd/data/NEMO",
"copernicusmarineBinary": "/usr/local/bin/copernicusmarine",
"copernicusUsername": "",
"copernicusPassword": "",
"murOutputDir": "/data/hdd/data/river-data/MUR/MUR_SST_nc",
"netrcPath": "/root/.netrc",
"norkystOutputDir": "/data/hdd/data/norkyst"
}
@@ -0,0 +1,77 @@
apiVersion: dapr.io/v1alpha1
kind: Component
metadata:
name: cron-arome
spec:
type: bindings.cron
version: v1
metadata:
- name: schedule
value: "0 6 * * *"
scopes:
- prod-fapr
---
apiVersion: dapr.io/v1alpha1
kind: Component
metadata:
name: cron-nve
spec:
type: bindings.cron
version: v1
metadata:
- name: schedule
value: "0 8 * * *"
scopes:
- prod-fapr
---
apiVersion: dapr.io/v1alpha1
kind: Component
metadata:
name: cron-norshelf
spec:
type: bindings.cron
version: v1
metadata:
- name: schedule
value: "0 13 * * *"
scopes:
- prod-fapr
---
apiVersion: dapr.io/v1alpha1
kind: Component
metadata:
name: cron-nemo
spec:
type: bindings.cron
version: v1
metadata:
- name: schedule
value: "0 13 * * *"
scopes:
- prod-fapr
---
apiVersion: dapr.io/v1alpha1
kind: Component
metadata:
name: cron-mur
spec:
type: bindings.cron
version: v1
metadata:
- name: schedule
value: "0 6 * * *"
scopes:
- prod-fapr
---
apiVersion: dapr.io/v1alpha1
kind: Component
metadata:
name: cron-norkyst
spec:
type: bindings.cron
version: v1
metadata:
- name: schedule
value: "0 13 * * *"
scopes:
- prod-fapr
@@ -0,0 +1,3 @@
- op: add
path: /spec/template/spec/containers/0/envFrom
value: []
@@ -0,0 +1,21 @@
generatorOptions:
disableNameSuffixHash: true
configMapGenerator:
- name: prod-fapr-appsettings
files:
- appsettings.json
patches:
- target:
group: apps
version: v1
kind: Deployment
path: deployment_patch.yaml
resources:
- ../base
- pv.yaml
- pvc.yaml
- secrets.yaml
- secretstore.yaml
- statestore.yaml
- tracing.yaml
- cron-bindings.yaml
+22
View File
@@ -0,0 +1,22 @@
apiVersion: v1
kind: PersistentVolume
metadata:
name: pv-prod-fapr-ceph-data
spec:
accessModes:
- ReadWriteMany
capacity:
storage: 1Gi
csi:
driver: rook-ceph.cephfs.csi.ceph.com
nodeStageSecretRef:
name: rook-csi-cephfs-node
namespace: rook-ceph
volumeAttributes:
clusterID: rook-ceph
fsName: data
rootPath: /
staticVolume: "true"
volumeHandle: pv-prod-fapr-ceph-data
persistentVolumeReclaimPolicy: Retain
volumeMode: Filesystem
+13
View File
@@ -0,0 +1,13 @@
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: prod-fapr-ceph-data
spec:
accessModes:
- ReadWriteMany
resources:
requests:
storage: 1Gi
storageClassName: ""
volumeMode: Filesystem
volumeName: pv-prod-fapr-ceph-data
@@ -0,0 +1,6 @@
apiVersion: v1
kind: Secret
metadata:
name: prod-fapr-redis
type: Opaque
data:
@@ -0,0 +1,12 @@
apiVersion: dapr.io/v1alpha1
kind: Component
metadata:
name: secretstore
spec:
type: secretstores.kubernetes
version: v1
metadata:
- name: defaultNamespace
value: prod-fapr
scopes:
- prod-fapr
@@ -0,0 +1,22 @@
apiVersion: dapr.io/v1alpha1
kind: Component
metadata:
name: statestore
spec:
type: state.redis
version: v1
metadata:
- name: redisHost
value: prod-fapr-redis:6379
- name: redisUsername
value: default
- name: redisPassword
secretKeyRef:
name: prod-fapr-redis
key: redis-password
- name: actorStateStore
value: "true"
- name: redisDB
value: "0"
scopes:
- prod-fapr
@@ -0,0 +1,11 @@
apiVersion: dapr.io/v1alpha1
kind: Configuration
metadata:
name: tracing
spec:
tracing:
samplingRate: "1"
otel:
endpointAddress: "10.255.241.12:4317"
protocol: grpc
isSecure: false
+42
View File
@@ -0,0 +1,42 @@
{{ if .Values.clusterConfig.argo.enabled }}
apiVersion: argoproj.io/v1alpha1
kind: Application
metadata:
name: {{ .Values.fapr.env }}-fapr
namespace: argocd
annotations:
argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
argocd.argoproj.io/compare-options: ServerSideDiff=true
finalizers:
- resources-finalizer.argocd.argoproj.io
spec:
destination:
namespace: {{ .Values.fapr.env }}-fapr
server: https://kubernetes.default.svc
project: atlantis
sources:
- repoURL: {{ .Values.clusterConfig.manifests }}
targetRevision: HEAD
path: helmfile.d
plugin:
name: helmfile-cmp
env:
- name: CLUSTER_NAME
value: {{ .Values.clusterConfig.cluster }}
- name: HELMFILE_ENVIRONMENT
value: {{ .Values.fapr.env }}
- name: HELMFILE_FILE_PATH
value: fapr.yaml.gotmpl
- repoURL: https://git.oceanbox.io/platform/manifests.git
targetRevision: main
ref: values
syncPolicy:
syncOptions:
- CreateNamespace=true
- ApplyOutOfSyncOnly=true
{{- if .Values.fapr.autosync }}
automated:
prune: true
selfHeal: false
{{- end }}
{{- end }}
+55
View File
@@ -0,0 +1,55 @@
replicaCount: 1
podAnnotations:
dapr.io/enabled: "true"
dapr.io/app-id: "prod-fapr"
dapr.io/app-port: "8080"
dapr.io/api-token-secret: "dapr-api-token"
dapr.io/config: "tracing"
dapr.io/app-protocol: "http"
dapr.io/log-as-json: "true"
dapr.io/sidecar-cpu-request: "10m"
dapr.io/sidecar-memory-request: "50Mi"
env:
- name: APP_NAME
valueFrom:
fieldRef:
fieldPath: metadata.name
- name: APP_NAMESPACE
valueFrom:
fieldRef:
fieldPath: metadata.namespace
- name: DAPR_API_TOKEN
valueFrom:
secretKeyRef:
name: dapr-api-token
key: token
persistence:
enabled: true
existingClaim: prod-fapr-ceph-data
redis:
enabled: true
replicas: 1
backup:
enabled: true
size: 2Gi
storageClass: "ceph-rbd"
secret:
name: "prod-fapr-redis"
key: "redis-password"
resources:
cpu: 100m
memory: 128Mi
affinity:
nodeAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
nodeSelectorTerms:
- matchExpressions:
- key: "topology.kubernetes.io/group"
operator: In
values:
- srv
+1
View File
@@ -0,0 +1 @@
# Base values for fapr - overridden per environment
+5 -7
View File
@@ -3,17 +3,15 @@ kind: Ingress
metadata:
annotations:
cert-manager.io/cluster-issuer: ca-issuer
nginx.ingress.kubernetes.io/backend-protocol: HTTP
nginx.ingress.kubernetes.io/cors-allow-headers: Content-Type, x-gatus-cache
nginx.ingress.kubernetes.io/enable-cors: "true"
nginx.ingress.kubernetes.io/proxy-buffer-size: 128k
nginx.ingress.kubernetes.io/ssl-redirect: "true"
haproxy.org/backend-protocol: h1
haproxy.org/cors-allow-headers: Content-Type, x-gatus-cache
haproxy.org/cors-enable: "true"
labels:
app.kubernetes.io/name: gatus
name: gatus
namespace: uptime
spec:
ingressClassName: nginx
ingressClassName: haproxy
rules:
- host: uptime.adm.hel1.obx
http:
@@ -24,7 +22,7 @@ spec:
port:
number: 80
path: /
pathType: ImplementationSpecific
pathType: Prefix
tls:
- hosts:
- uptime.adm.hel1.obx
+1 -1
View File
@@ -1,6 +1,6 @@
image:
repository: twinproduction/gatus
tag: v5.35.0
tag: v5.36.0
# Does envFrom secret named gatus
secrets: true
+5 -10
View File
@@ -8,18 +8,13 @@ spec:
resources:
requests:
cpu: 150m
memory: 256Mi
memory: 1Gi
limits:
memory: 256Mi
memory: 1Gi
args:
- --dbfilename=dump # Static filename prevents disk exhaustion
- --maxmemory=$(MAX_MEMORY)Mi # Graceful memory management (90% of limit)
- --dbfilename=dump # Static filename prevents disk exhaustion
- --maxmemory=920Mi # ~90% of the 1Gi limit, leaving headroom
- --cache_mode=true # evict near maxmemory instead of rejecting writes (graceful degradation)
- --proactor_threads=1 # Auto-detect CPU cores (optimal threading)
- --cluster_mode=emulated
- --logtostderr
env:
- name: MAX_MEMORY
valueFrom:
resourceFieldRef:
resource: limits.memory
divisor: 1Mi
+8 -9
View File
@@ -3,11 +3,11 @@ replicaCount: 1
image:
registry: "docker.gitea.com"
repository: gitea
tag: "1.26.0"
tag: "1.26.2"
resources:
requests:
cpu: 200m
cpu: 500m
memory: 512Mi
strategy:
@@ -82,6 +82,8 @@ gitea:
database:
DB_TYPE: postgres
MAX_OPEN_CONNS: 90
MAX_IDLE_CONNS: 20
CONN_MAX_LIFETIME: 3h
openid:
ENABLE_OPENID_SIGNIN: false
ENABLE_OPENID_SIGNUP: false
@@ -135,15 +137,12 @@ gitea:
ingress:
enabled: true
className: nginx
className: haproxy
annotations:
cert-manager.io/cluster-issuer: letsencrypt-production
nginx.ingress.kubernetes.io/ssl-redirect: "true"
nginx.ingress.kubernetes.io/backend-protocol: HTTP
nginx.ingress.kubernetes.io/proxy-body-size: "0"
nginx.ingress.kubernetes.io/proxy-read-timeout: "600"
nginx.ingress.kubernetes.io/proxy-send-timeout: "600"
nginx.ingress.kubernetes.io/whitelist-source-range: 10.0.0.0/8,172.16.0.0/12,192.168.0.0/16,172.19.255.0/24,100.64.0.0/12,185.125.160.4/32,37.27.203.38/32
haproxy.org/backend-protocol: h1
haproxy.org/timeout-server: 600s
haproxy.org/allow-list: 10.0.0.0/8,172.16.0.0/12,192.168.0.0/16,172.19.255.0/24,100.64.0.0/12,185.125.160.4/32,37.27.203.38/32
hosts:
- host: git.oceanbox.io
paths:
+2
View File
@@ -129,6 +129,7 @@ configMaps:
"group:dev": [],
"group:intern": [
"haavahak@stud.ntnu.no",
"haavahak@ntnu.no",
],
"group:ceph": [
"jonas.juselius@oceanbox.io",
@@ -309,6 +310,7 @@ configMaps:
{ "name": "yolo-registry.dev.oceanbox.io", "type": "A", "value": "10.255.241.11" },
{ "name": "argocd.ekman.oceanbox.io", "type": "A", "value": "10.255.241.99" },
{ "name": "cache.ekman.oceanbox.io", "type": "A", "value": "10.255.241.99" },
{ "name": "prometheus.ekman.oceanbox.io", "type": "A", "value": "10.255.241.99" },
{ "name": "alertmanager.ekman.oceanbox.io", "type": "A", "value": "10.255.241.99" },
{ "name": "grafana.ekman.oceanbox.io", "type": "A", "value": "10.255.241.99" },
@@ -0,0 +1,14 @@
haproxy:
enabled: true
autosync: true
pdb:
minAvailable: 1
resources:
controller:
cpu: "100m"
memory: "100Mi"
annotations:
load-balancer.hetzner.cloud/location: hel1
load-balancer.hetzner.cloud/name: load-balancer-1
load-balancer.hetzner.cloud/type: lb11
load-balancer.hetzner.cloud/use-private-ip: "true"
+10
View File
@@ -0,0 +1,10 @@
haproxy:
enabled: false
autosync: true
pdb:
minAvailable: 1
resources:
controller:
cpu: "100m"
memory: "100Mi"
annotations: []
@@ -0,0 +1,40 @@
{{- if .Values.clusterConfig.argo.enabled }}
apiVersion: argoproj.io/v1alpha1
kind: Application
metadata:
name: ingress-haproxy
namespace: argocd
annotations:
argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
spec:
destination:
namespace: ingress-haproxy
server: 'https://kubernetes.default.svc'
sources:
- repoURL: {{ .Values.clusterConfig.manifests }}
targetRevision: HEAD
path: helmfile.d
plugin:
name: helmfile-cmp
env:
- name: CLUSTER_NAME
value: {{ .Values.clusterConfig.cluster }}
- name: HELMFILE_ENVIRONMENT
value: default
- name: HELMFILE_FILE_PATH
value: ingress-haproxy.yaml.gotmpl
project: sys
syncPolicy:
managedNamespaceMetadata:
labels:
component: sys
syncOptions:
- CreateNamespace=true
- ApplyOutOfSyncOnly=true
- ServerSideApply=true
{{- if .Values.haproxy.autosync }}
automated:
prune: true
# selfHeal: false
{{- end }}
{{- end }}
@@ -0,0 +1,16 @@
{{- if .Values.clusterConfig.cilium.enabled }}
apiVersion: cilium.io/v2
kind: CiliumNetworkPolicy
metadata:
name: allow-host-traffic
namespace: ingress-haproxy
spec:
egress:
- toEntities:
- kube-apiserver
- host
endpointSelector:
matchLabels:
app.kubernetes.io/name: kubernetes-ingress
app.kubernetes.io/instance: ingress-haproxy
{{- end }}
@@ -0,0 +1,16 @@
{{- if .Values.clusterConfig.cilium.enabled }}
apiVersion: cilium.io/v2
kind: CiliumNetworkPolicy
metadata:
name: allow-hubble-traffic
namespace: ingress-haproxy
spec:
egress:
- toFQDNs:
- matchPattern: hubble.*.*.*
- matchPattern: hubble.*.*.*.*
endpointSelector:
matchLabels:
app.kubernetes.io/name: kubernetes-ingress
app.kubernetes.io/instance: ingress-haproxy
{{- end }}
@@ -0,0 +1,19 @@
{{- if .Values.clusterConfig.cilium.enabled }}
apiVersion: cilium.io/v2
kind: CiliumNetworkPolicy
metadata:
name: allow-prometheus-metrics
namespace: ingress-haproxy
spec:
endpointSelector:
matchLabels:
app.kubernetes.io/instance: ingress-haproxy
ingress:
- fromEndpoints:
- matchLabels:
io.kubernetes.pod.namespace: prometheus
- toPorts:
- ports:
- port: "1024"
protocol: TCP
{{- end }}
@@ -0,0 +1,21 @@
{{- if .Values.clusterConfig.cilium.enabled }}
apiVersion: cilium.io/v2
kind: CiliumNetworkPolicy
metadata:
name: allow-world-to-ingress-haproxy
namespace: ingress-haproxy
spec:
endpointSelector:
matchLabels:
app.kubernetes.io/name: kubernetes-ingress
app.kubernetes.io/instance: ingress-haproxy
ingress:
- fromEntities:
- world
- toPorts:
- ports:
- port: "80"
protocol: TCP
- port: "443"
protocol: TCP
{{- end }}
@@ -0,0 +1,114 @@
## HAProxy Kubernetes Ingress Controller configuration
## Ref: https://www.haproxy.com/documentation/kubernetes-ingress/
##
controller:
resources:
requests:
cpu: {{ .Values.haproxy.resources.controller.cpu }}
memory: {{ .Values.haproxy.resources.controller.memory }}
ingressClass: haproxy
ingressClassResource:
name: haproxy
default: true
config:
body-size: "0"
tune.bufsize: "131072"
ssl-redirect: "true"
forwarded-for: "true"
# NOTE: Emit HAProxy access logs (real client IP + request line)
# to the controller's stdout so `kubectl logs` can see them.
syslog-server: "address:stdout, format: raw, facility: daemon"
# Disable QUIC ar Hetzner LB doesn't support UDP
quic-enabled: "false"
# Proxy protocol
proxy-protocol: "10.0.0.0/8"
use-proxy-protocol: "true"
tolerations:
- key: unschedulable
operator: Exists
effect: NoSchedule
- key: node-role.kubernetes.io/control-plane
operator: Exists
effect: NoSchedule
affinity:
nodeAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
nodeSelectorTerms:
- matchExpressions:
- key: kubernetes.io/hostname
operator: In
values: {{ .Values.clusterConfig.ingress_nodes }}
podAntiAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
- labelSelector:
matchExpressions:
- key: app.kubernetes.io/instance
operator: In
values:
- ingress-haproxy
- key: app.kubernetes.io/name
operator: In
values:
- kubernetes-ingress
topologyKey: "kubernetes.io/hostname"
replicaCount: {{ .Values.clusterConfig.ingress_replica_count }}
PodDisruptionBudget:
enable: true
minAvailable: {{ .Values.haproxy.pdb.minAvailable }}
service:
{{- if .Values.clusterConfig.ingress_loadbalancer }}
type: LoadBalancer
{{- if .Values.clusterConfig.ingress_nodeport }}
nodePorts:
http: 30080
https: 30443
{{- end }}
{{- else if .Values.clusterConfig.ingress_nodeport }}
type: NodePort
externalTrafficPolicy: Local
nodePorts:
http: 30080
https: 30443
{{- else }}
type: ClusterIP
{{- end }}
annotations:
{{- with .Values.haproxy.annotations }}
{{ toYaml . | nindent 8 }}
{{- end }}
hostNetwork: {{ .Values.clusterConfig.ingress_hostnetwork }}
hostPorts:
enable: {{ .Values.clusterConfig.ingress_hostport }}
http: 80
https: 443
stats:
enabled: true
prometheus:
enabled: true
port: 1024
service:
annotations:
prometheus.io/scrape: "true"
prometheus.io/port: "1024"
serviceMonitor:
enabled: true
extraArgs:
- --disable-quic
+1 -1
View File
@@ -1,5 +1,5 @@
nginx:
enabled: true
enabled: false
autosync: true
pdb:
minAvailable: 1
@@ -1,3 +1,42 @@
---
apiVersion: v1
kind: PersistentVolume
metadata:
name: pv-prod-queue-ceph-archives
spec:
accessModes:
- ReadWriteMany
capacity:
storage: 1Gi
csi:
driver: rook-ceph.cephfs.csi.ceph.com
nodeStageSecretRef:
name: rook-csi-cephfs-node
namespace: rook-ceph
volumeAttributes:
clusterID: rook-ceph
fsName: data
rootPath: /
staticVolume: "true"
volumeHandle: pv-prod-queue-ceph-archives
persistentVolumeReclaimPolicy: Retain
volumeMode: Filesystem
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: prod-queue-ceph-archives
namespace: prod-queue
spec:
accessModes:
- ReadWriteMany
resources:
requests:
storage: 1Gi
storageClassName: ""
volumeMode: Filesystem
volumeName: pv-prod-queue-ceph-archives
---
# Cross-namespace RBAC: allow sorcerer ServiceAccounts to manage JobSets in dev-queue
apiVersion: rbac.authorization.k8s.io/v1
kind: Role
+4 -6
View File
@@ -1,6 +1,6 @@
replicaCount: 1
image:
tag: "ad49e745-debug"
tag: "e49d3f4f-debug"
env:
- name: APP_VERSION
value: "0.0.0"
@@ -8,13 +8,11 @@ env:
value: "1"
ingress:
enabled: true
className: "nginx"
className: "haproxy"
annotations:
cert-manager.io/cluster-issuer: letsencrypt-production
nginx.ingress.kubernetes.io/backend-protocol: HTTP
nginx.ingress.kubernetes.io/enable-cors: "true"
nginx.ingress.kubernetes.io/proxy-buffer-size: 128k
nginx.ingress.kubernetes.io/ssl-redirect: "true"
haproxy.org/backend-protocol: h1
haproxy.org/cors-enable: "true"
oceanbox.io/expose: internal
hosts:
- host: makai.oceanbox.io
+2
View File
@@ -0,0 +1,2 @@
niks3:
enabled: true
@@ -1,3 +1,3 @@
attic:
niks3:
enabled: false
autosync: false
@@ -1,10 +1,10 @@
apiVersion: postgresql.cnpg.io/v1
kind: Cluster
metadata:
name: attic-db
namespace: attic
name: niks3-db
namespace: niks3
labels:
app: attic-db
app: niks3-db
spec:
instances: 1
primaryUpdateStrategy: unsupervised
+73
View File
@@ -0,0 +1,73 @@
apiVersion: apps/v1
kind: Deployment
metadata:
name: niks3
spec:
selector:
matchLabels:
app: niks3
strategy:
type: Recreate
template:
metadata:
labels:
app: niks3
spec:
containers:
- name: niks3
image: ghcr.io/mic92/niks3:v1.6.1
ports:
- name: http
containerPort: 5751
protocol: TCP
livenessProbe:
httpGet:
path: /
port: http
readinessProbe:
httpGet:
path: /
port: http
env:
- name: NIKS3_DB
valueFrom:
secretKeyRef:
name: niks3-db-app
key: uri
- name: NIKS3_API_TOKEN
valueFrom:
secretKeyRef:
name: server
key: api-token
- name: NIKS3_S3_ENDPOINT
value: "10.255.241.30:30080"
- name: NIKS3_S3_BUCKET
value: "niks3"
- name: NIKS3_S3_REGION
value: "default"
- name: NIKS3_S3_USE_SSL
value: "false"
- name: NIKS3_S3_ACCESS_KEY
valueFrom:
secretKeyRef:
name: server
key: s3-access-key
- name: NIKS3_S3_SECRET_KEY
valueFrom:
secretKeyRef:
name: server
key: s3-secret-key
- name: NIKS3_ENABLE_READ_PROXY
value: "true"
- name: NIKS3_CACHE_URL
value: "https://cache.ekman.oceanbox.io"
- name: NIKS3_SIGN_KEY_PATHS
value: "/secrets/sign-key"
volumeMounts:
- name: server
mountPath: /secrets
readOnly: true
volumes:
- name: server
secret:
secretName: server
+49
View File
@@ -0,0 +1,49 @@
apiVersion: batch/v1
kind: CronJob
metadata:
name: niks3-gc
namespace: niks3
labels:
app: niks3-gc
spec:
# Daily at 03:00. niks3 gc asks the server to drop closures older than
# --older-than and clean up stale failed uploads; the server performs the
# actual S3 deletions, so this job only needs to reach the in-cluster API.
schedule: "0 3 * * *"
concurrencyPolicy: Forbid
successfulJobsHistoryLimit: 3
failedJobsHistoryLimit: 3
jobTemplate:
spec:
backoffLimit: 2
template:
metadata:
# NOT app: niks3 — that label is the Service selector and would route
# cache traffic to this job. Its egress is governed by allow-gc-egress.
labels:
app: niks3-gc
spec:
restartPolicy: Never
containers:
- name: gc
image: ghcr.io/mic92/niks3:v1.6.1
# Image entrypoint is /bin/niks3-server; override with the client.
command: ["/bin/niks3", "gc"]
args:
- --server-url=http://niks3:5751
- --auth-token-path=/secrets/api-token
- --older-than=720h
volumeMounts:
- name: server
mountPath: /secrets
readOnly: true
resources:
requests:
cpu: 10m
memory: 32Mi
limits:
memory: 128Mi
volumes:
- name: server
secret:
secretName: server
+28
View File
@@ -0,0 +1,28 @@
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
annotations:
cert-manager.io/cluster-issuer: letsencrypt-production
nginx.ingress.kubernetes.io/proxy-read-timeout: "600"
oceanbox.io/expose: internal
labels:
app.kubernetes.io/component: niks3
name: niks3
namespace: niks3
spec:
ingressClassName: nginx
rules:
- host: cache.ekman.oceanbox.io
http:
paths:
- backend:
service:
name: niks3
port:
name: http
path: /
pathType: Prefix
tls:
- hosts:
- cache.ekman.oceanbox.io
secretName: cache.ekman.oceanbox.io-tls
+39
View File
@@ -0,0 +1,39 @@
{{- if .Values.clusterConfig.argo.enabled }}
apiVersion: argoproj.io/v1alpha1
kind: Application
metadata:
name: niks3
namespace: argocd
annotations:
argocd.argoproj.io/sync-options: SkipDryRunOnMissingResource=true
finalizers:
- resources-finalizer.argocd.argoproj.io
spec:
destination:
namespace: niks3
server: https://kubernetes.default.svc
project: sys
sources:
- repoURL: {{ .Values.clusterConfig.manifests }}
targetRevision: HEAD
path: helmfile.d
plugin:
name: helmfile-cmp
env:
- name: CLUSTER_NAME
value: {{ .Values.clusterConfig.cluster }}
- name: HELMFILE_ENVIRONMENT
value: default
- name: HELMFILE_FILE_PATH
value: niks3.yaml.gotmpl
syncPolicy:
syncOptions:
- CreateNamespace=true
- ApplyOutOfSyncOnly=true
# - ServerSideApply=true
{{- if .Values.niks3.autosync }}
automated:
prune: true
# selfHeal: false
{{- end }}
{{- end }}
@@ -0,0 +1,47 @@
{{- if .Values.clusterConfig.cilium.enabled }}
apiVersion: cilium.io/v2
kind: CiliumNetworkPolicy
metadata:
name: allow-egress
namespace: niks3
spec:
# ekman has no cluster-wide allow-namespace-traffic baseline (unlike hel1/oceanbox),
# so once niks3 is selected by an egress rule it is default-deny for egress and every
# destination must be listed explicitly: RGW (S3), in-namespace PostgreSQL, and DNS.
description: niks3 egress to Ceph RGW (S3), in-namespace PostgreSQL, and kube-dns
endpointSelector:
matchLabels:
app: niks3
egress:
# Ceph RadosGW (S3 object storage backend) via NodePort
- toCIDR:
- 10.255.241.30/32
- 10.255.241.31/32
- 10.255.241.32/32
toPorts:
- ports:
- port: "30080"
protocol: TCP
# PostgreSQL (CNPG niks3-db cluster, same namespace)
- toEndpoints:
- matchLabels:
io.kubernetes.pod.namespace: niks3
toPorts:
- ports:
- port: "5432"
protocol: TCP
# DNS resolution
- toEndpoints:
- matchLabels:
io.kubernetes.pod.namespace: kube-system
k8s-app: kube-dns
toPorts:
- ports:
- port: "53"
protocol: UDP
- port: "53"
protocol: TCP
rules:
dns:
- matchPattern: "*"
{{- end }}
@@ -0,0 +1,35 @@
{{- if .Values.clusterConfig.cilium.enabled }}
apiVersion: cilium.io/v2
kind: CiliumNetworkPolicy
metadata:
name: allow-gc-egress
namespace: niks3
spec:
description: niks3-gc job egress to the in-namespace niks3 server and kube-dns
endpointSelector:
matchLabels:
app: niks3-gc
egress:
# niks3 server HTTP API (same namespace)
- toEndpoints:
- matchLabels:
io.kubernetes.pod.namespace: niks3
toPorts:
- ports:
- port: "5751"
protocol: TCP
# DNS resolution
- toEndpoints:
- matchLabels:
io.kubernetes.pod.namespace: kube-system
k8s-app: kube-dns
toPorts:
- ports:
- port: "53"
protocol: UDP
- port: "53"
protocol: TCP
rules:
dns:
- matchPattern: "*"
{{- end }}
@@ -1,14 +1,14 @@
apiVersion: v1
kind: Service
metadata:
name: attic
name: niks3
labels:
app: attic
app: niks3
spec:
type: ClusterIP
selector:
app: attic
app: niks3
ports:
- name: http
port: 8080
port: 5751
targetPort: http
@@ -21,7 +21,7 @@
path: /spec/template/spec/containers/0/envFrom/-
value:
secretRef:
name: prod-sorcerer-env
name: beta-sorcerer-env
- op: add
path: /spec/template/spec/containers/0/envFrom/-
value:
@@ -2,7 +2,7 @@ replicaCount: 1
image:
repository: git.oceanbox.io/oceanbox/poseidon/sorcerer
tag: v1.48.1
tag: v2.10.0
podAnnotations:
dapr.io/enabled: "true"
@@ -19,7 +19,7 @@ podAnnotations:
env:
- name: APP_VERSION
value: "4.16.3-beta"
value: "2.10.0-beta"
- name: LOG_LEVEL
value: "1"
- name: REDIS_USER
+1 -1
View File
@@ -1,7 +1,7 @@
replicaCount: 1
image:
repository: git.oceanbox.io/oceanbox/poseidon/sorcerer
tag: 651291bd-debug
tag: 5db33158-debug
podAnnotations:
dapr.io/enabled: "true"
dapr.io/app-id: "staging-sorcerer"
+2 -6
View File
@@ -2,13 +2,11 @@ apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
annotations:
nginx.ingress.kubernetes.io/auth-signin: https://$host/oauth2/start?rd=$escaped_request_uri
nginx.ingress.kubernetes.io/auth-url: https://$host/oauth2/auth
oceanbox.io/expose: internal
name: hubble-ui
namespace: kube-system
spec:
ingressClassName: nginx
ingressClassName: haproxy
rules:
- host: hubble.hel1.oceanbox.io
http:
@@ -26,13 +24,11 @@ kind: Ingress
metadata:
annotations:
cert-manager.io/cluster-issuer: letsencrypt-production
nginx.ingress.kubernetes.io/proxy-buffer-size: 8k
nginx.ingress.kubernetes.io/proxy-busy-buffers-size: 16k
oceanbox.io/expose: internal
name: hubble-ui-oauth2-proxy
namespace: kube-system
spec:
ingressClassName: nginx
ingressClassName: haproxy
rules:
- host: hubble.hel1.oceanbox.io
http:
@@ -14,9 +14,8 @@ metadata:
whitelist to the already existing ones
spec:
mutateExistingOnPolicyUpdate: false
#precondition: has whitelist annotation or
rules:
- name: ensure-nginx-whitelist-exists
- name: ensure-haproxy-allowlist-exists
skipBackgroundRequests: true
match:
resources:
@@ -28,8 +27,8 @@ spec:
patchStrategicMerge:
metadata:
annotations:
+(nginx.ingress.kubernetes.io/whitelist-source-range): ""
- name: append-existing-whitelist
+(haproxy.org/allow-list): ""
- name: append-existing-haproxy-allowlist
skipBackgroundRequests: true
match:
resources:
@@ -39,7 +38,7 @@ spec:
oceanbox.io/expose: internal
preconditions:
any:
- key: "{{`{{request.object.metadata.annotations.\"nginx.ingress.kubernetes.io/whitelist-source-range\"}}`}}"
- key: "{{`{{request.object.metadata.annotations.\"haproxy.org/allow-list\"}}`}}"
operator: NotEquals
value: ""
mutate:
@@ -47,9 +46,9 @@ spec:
metadata:
annotations:
{{- with .Values.clusterConfig.ingress_whitelist }}
nginx.ingress.kubernetes.io/whitelist-source-range: "{{`{{ @ }}`}},{{ join "," . }}"
haproxy.org/allow-list: "{{`{{ @ }}`}},{{ join "," . }}"
{{- end }}
- name: add-nginx-whitelist
- name: add-haproxy-allowlist
skipBackgroundRequests: true
match:
resources:
@@ -59,7 +58,7 @@ spec:
oceanbox.io/expose: internal
preconditions:
any:
- key: "{{`{{request.object.metadata.annotations.\"nginx.ingress.kubernetes.io/whitelist-source-range\"}}`}}"
- key: "{{`{{request.object.metadata.annotations.\"haproxy.org/allow-list\"}}`}}"
operator: Equals
value: ""
mutate:
@@ -67,7 +66,6 @@ spec:
metadata:
annotations:
{{- with .Values.clusterConfig.ingress_whitelist }}
nginx.ingress.kubernetes.io/whitelist-source-range: "{{ join "," . }}"
haproxy.org/allow-list: "{{ join "," . }}"
{{- end }}
{{- end }}
@@ -23,8 +23,8 @@ SELECT
*
FROM
crosstab(
'SELECT "group", sim_type, count::text FROM weekly_sim_submit_count_v2 ORDER BY 1, 2',
'SELECT DISTINCT sim_type FROM weekly_sim_submit_count_v2 ORDER BY 1'
'SELECT "group", sim_type, count::text FROM weekly_sim_submit_count WHERE sim_type <> ''lice-network'' AND sim_type <> ''lice-delousing'' ORDER BY 1, 2',
'SELECT DISTINCT sim_type FROM weekly_sim_submit_count WHERE sim_type <> ''lice-network'' AND sim_type <> ''lice-delousing'' ORDER BY 1'
) AS ct (
group_name text,
lice bigint,
@@ -33,3 +33,9 @@ FROM
virus bigint,
watercontact bigint
)
WHERE
(lice + sedimentation + transport + virus + watercontact) <> 0
AND "group" <> '@oceanbox.io'
ORDER BY
(lice + sedimentation + transport + virus + watercontact) DESC
;
+12 -7
View File
@@ -9,9 +9,11 @@ WITH base AS (
WHERE
w.website_id = '16e7d807-4db5-45fd-92a9-27393445a153'
AND w.event_type = 1
AND w.created_at BETWEEN '2025-10-13' AND '2025-10-19'
-- NOTE: This is only available in grafana
-- AND $__timeFilter(w.created_at)
AND w.created_at BETWEEN current_timestamp - '7 days'::interval and current_timestamp
AND s.distinct_id IS NOT NULL
-- AND substring(s.distinct_id SIMILAR '%#"@%#"' ESCAPE '#') IN ('@leroyseafood.com')
-- AND substring(s.distinct_id SIMILAR '%#"@%#"' ESCAPE '#') IN ($groups)
),
unique_totals AS (
SELECT
@@ -28,9 +30,12 @@ unique_users AS (
GROUP BY "Group"
)
SELECT
SUM("Users in range")
FROM
unique_totals
t."Group",
t."Users in range" AS "Weekly users"
FROM unique_totals t
LEFT JOIN
unique_users u USING ("Group")
WHERE
LOWER("Group") NOT IN ('@oceanbox.io')
;
t."Group" <> '@oceanbox.io'
ORDER BY
"Users in range" DESC;

Some files were not shown because too many files have changed in this diff Show More