From aef55bafd67f64cc6e497d0333b89617a8b01db3 Mon Sep 17 00:00:00 2001 From: David Jeffers Date: Sun, 23 Mar 2025 03:14:29 +0000 Subject: [PATCH] Initial commit --- .drone.yml | 83 +++++++++++++++++++++++++++++++++++ README.md | 12 +++++ clusterprism_helm_values.yaml | 62 ++++++++++++++++++++++++++ 3 files changed, 157 insertions(+) create mode 100644 .drone.yml create mode 100644 README.md create mode 100644 clusterprism_helm_values.yaml diff --git a/.drone.yml b/.drone.yml new file mode 100644 index 0000000..da4764b --- /dev/null +++ b/.drone.yml @@ -0,0 +1,83 @@ +--- +kind: pipeline +type: docker +name: default +service_account_name: dronesome-app + +steps: + - name: lint + image: python:3 + commands: + - pip3 install yamllint==1.29.0 + - yamllint . + + # yamllint disable rule:line-length + # - name: deploy + # image: alpine/k8s:1.31.2 + # environment: + # CACRT: + # from_secret: clusterprism_some-app_kubernetes_ca_cert + # TOKEN: + # from_secret: clusterprism_some-app_kubernetes_token + # # yamllint disable rule:line-length + # commands: + # - kubectl config set-cluster clusterprism --server=https://192.168.1.201:6443 + # - kubectl config set-credentials drone-some-app --token=$TOKEN + # - kubectl config set-context clusterprism --user=drone-some-app --cluster=clusterprism + # - kubectl config use-context clusterprism + # - echo $CACRT > cacert.pem + # - kubectl config set-context clusterprism --certificate-authority=cacert.pem + # - kubectl config set clusters.clusterprism.insecure-skip-tls-verify true + # - helm repo add bjw-s https://bjw-s.github.io/helm-charts + # - helm upgrade some-app --install bjw-s/app-template -n localassist -f clusterprism_some-app_values.yaml --version 3.6.1 + # # yamllint enable rule:line-length + # when: + # branch: + # - main + # yamllint enable rule:line-length + + + # yamllint disable rule:line-length + # - name: rawkubectl + # image: alpine/k8s:1.31.2 + # environment: + # CACRT: + # from_secret: clusterprism_some-app_ca_cert + # TOKEN: + # from_secret: clusterprism_some-app_kubernetes_token + # commands: + # - 'kubectl config set-cluster clusterprism + # --server=https://192.168.1.201:6443' + # - kubectl config set-credentials dronesome-app --token=$TOKEN + # - 'kubectl config set-context clusterprism + # --user=dronesome-app --cluster=clusterprism' + # - kubectl config use-context clusterprism + # - echo $CACRT > cacert.pem + # - 'kubectl config set-context clusterprism + # --certificate-authority=cacert.pem' + # - kubectl config set clusters.clusterprism.insecure-skip-tls-verify true + # - kubectl apply -f raw_kubectl/manifest.yml + # when: + # branch: + # - main + # yamllint enable rule:line-length- name: rawkubectl + + - name: notify + image: plugins/webhook + settings: + urls: + from_secret: mattermost_webhook + content_type: application/json + # yamllint disable rule:line-length + template: | + { + "channel": "drone-notifications", + "username": "Drone Build Bot", + "icon_url": "", + "text": "**{{repo.name}}** - {{#success build.status}}✅ Build success for build [{{build.number}}](https://drone.sadmin.pro/{{repo.owner}}/{{repo.name}}/{{build.number}}){{else}}❌ Build failure for build [{{build.number}}](https://drone.sadmin.pro/{{repo.owner}}/{{repo.name}}/{{build.number}}){{/success}}\n**Branch**: [{{build.branch}}](https://git.sadmin.pro/{{repo.owner}}/{{repo.name}}/src/branch/{{build.branch}})\n**Commit**: [{{build.commit}}](https://git.sadmin.pro/{{repo.owner}}/{{repo.name}}/commit/{{build.commit}})" + } + # yamllint enable rule:line-length + when: + status: + - failure + - success diff --git a/README.md b/README.md new file mode 100644 index 0000000..a99134a --- /dev/null +++ b/README.md @@ -0,0 +1,12 @@ +# helm-helpers + +Helm override values for any given Helm chart, along with any other meta needed for it. + +[![Build Status](https://drone.sadmin.pro/api/badges/DaJeffers/helm-helpers/status.svg)](https://drone.sadmin.pro/DaJeffers/helm-helpers) + +1. Add service account to Ansible variables. +1. Rename `cluster_helm_values.yaml` to whatever and update `.drone.yml`. +1. `drone repo sync` +1. `drone repo enable DaJeffers/some-app-helpers` +1. `drone secret add DaJeffers/some-app-helpers --name clusterprism_some-app_kubernetes_token --data $(kubectl get secrets -n some-app drone-some-app-token --template={{.data.token}} | base64 -d -w 0)` +1. `drone secret add DaJeffers/some-app-helpers --name clusterprism_some-app_kubernetes_ca_cert --data $(kubectl get -n some-app secrets drone-some-app-token --template="{{index .data \"ca.crt\" | base64decode}}")` \ No newline at end of file diff --git a/clusterprism_helm_values.yaml b/clusterprism_helm_values.yaml new file mode 100644 index 0000000..3399f1f --- /dev/null +++ b/clusterprism_helm_values.yaml @@ -0,0 +1,62 @@ +--- +controllers: + some-app: + containers: + app: + securityContext: + privileged: false + allowPrivilegeEscalation: false + readOnlyRootFilesystem: false + capabilities: + drop: + - ALL + seccompProfile: + type: "RuntimeDefault" + image: + repository: some/image + tag: latest + args: + - some + - argument + env: + TZ: America/New_York + probes: &probes + liveness: + enabled: true + readiness: + enabled: true + startup: + enabled: true + spec: + failureThreshold: 30 + periodSeconds: 5 + resources: + limits: + memory: 3Gi + requests: + cpu: 100m + memory: 500Mi + pod: + securityContext: + runAsUser: 568 + runAsGroup: 568 + fsGroup: 568 + fsGroupChangePolicy: "OnRootMismatch" + runAsNonRoot: true + +service: + app: + controller: some-app + ports: + http: + port: 42069 + protocol: TCP + +# -- Configure persistence settings for the chart under this key. +persistence: + config: + type: persistentVolumeClaim + accessMode: ReadWriteOnce + size: 1Gi + globalMounts: + - path: /data