diff --git a/charts/incubator/answer/.helmignore b/charts/incubator/answer/.helmignore new file mode 100644 index 00000000000..77ca5567b26 --- /dev/null +++ b/charts/incubator/answer/.helmignore @@ -0,0 +1,30 @@ +# Patterns to ignore when building packages. +# This supports shell glob matching, relative path matching, and +# negation (prefixed with !). Only one pattern per line. +.DS_Store +# Common VCS dirs +.git/ +.gitignore +.bzr/ +.bzrignore +.hg/ +.hgignore +.svn/ +# Common backup files +*.swp +*.bak +*.tmp +*~ +# Various IDEs +.project +.idea/ +*.tmproj +.vscode/ +# OWNERS file for Kubernetes +OWNERS +# helm-docs templates +*.gotmpl +# docs folder +/docs +# icon +icon.png diff --git a/charts/incubator/answer/CHANGELOG.md b/charts/incubator/answer/CHANGELOG.md new file mode 100644 index 00000000000..825c32f0d03 --- /dev/null +++ b/charts/incubator/answer/CHANGELOG.md @@ -0,0 +1 @@ +# Changelog diff --git a/charts/incubator/answer/Chart.yaml b/charts/incubator/answer/Chart.yaml new file mode 100644 index 00000000000..7772f3bb933 --- /dev/null +++ b/charts/incubator/answer/Chart.yaml @@ -0,0 +1,27 @@ +apiVersion: v2 +appVersion: "1.2.0" +dependencies: + - name: common + repository: https://library-charts.truecharts.org + version: 14.2.1 +deprecated: false +description: A Q&A platform software for teams at any scales. +home: https://truecharts.org/charts/incubator/answer +icon: https://truecharts.org/img/hotlink-ok/chart-icons/answer.png +keywords: + - answer + - forum +kubeVersion: ">=1.16.0-0" +maintainers: + - email: info@truecharts.org + name: TrueCharts + url: https://truecharts.org +name: answer +sources: + - https://github.com/truecharts/charts/tree/master/charts/incubator/answer + - https://github.com/answerdev/answer +type: application +version: 0.0.1 +annotations: + truecharts.org/catagories: forum + truecharts.org/SCALE-support: "true" diff --git a/charts/incubator/answer/README.md b/charts/incubator/answer/README.md new file mode 100644 index 00000000000..7e59600739c --- /dev/null +++ b/charts/incubator/answer/README.md @@ -0,0 +1 @@ +# README diff --git a/charts/incubator/answer/icon.png b/charts/incubator/answer/icon.png new file mode 100644 index 00000000000..b99fca21d4d Binary files /dev/null and b/charts/incubator/answer/icon.png differ diff --git a/charts/incubator/answer/questions.yaml b/charts/incubator/answer/questions.yaml new file mode 100644 index 00000000000..9a7d234aaed --- /dev/null +++ b/charts/incubator/answer/questions.yaml @@ -0,0 +1,177 @@ +# Include{groups} +portals: + open: +# Include{portalLink} +questions: +# Include{global} +# Include{workload} +# Include{workloadDeployment} + +# Include{replicas1} +# Include{podSpec} +# Include{containerMain} + + +# Include{containerBasic} +# Include{containerAdvanced} + + - variable: answer + group: App Configuration + label: Answer + schema: + additional_attrs: true + type: dict + attrs: + - variable: app + label: App Configuration + schema: + additional_attrs: true + type: dict + attrs: + - variable: language + label: Language + schema: + type: string + required: true + default: "en-US" + - variable: log_level + label: Log Level + schema: + type: string + required: true + default: DEBUG" + enum: + - value: DEBUG + description: Debug + - value: INFO + description: Info + - value: WARN + description: Warn + - value: ERROR + description: Error + - variable: site + label: Site Configuration + schema: + additional_attrs: true + type: dict + attrs: + - variable: name + label: Name + schema: + type: string + required: true + default: "Answer" + - variable: url + label: Url + schema: + type: string + required: true + default: "http://localhost:9080" + - variable: contact_email + label: Contact Email + schema: + type: string + required: true + default: "" + - variable: admin + label: Admin Configuration + schema: + additional_attrs: true + type: dict + attrs: + - variable: name + label: Admin Name + schema: + type: string + required: true + default: "" + - variable: password + label: Admin Password + schema: + type: string + required: true + private: true + min_length: 8 + default: "" + - variable: email + label: Admin Email + schema: + type: string + required: true + default: "" + +# Include{containerConfig} +# Include{podOptions} +# Include{serviceRoot} +# Include{serviceMain} +# Include{serviceSelectorLoadBalancer} +# Include{serviceSelectorExtras} + - variable: main + label: "Main Service Port Configuration" + schema: + additional_attrs: true + type: dict + attrs: + - variable: port + label: "Port" + description: "This port exposes the container port on the service" + schema: + type: int + default: 9080 + required: true +# Include{serviceExpertRoot} +# Include{serviceExpert} +# Include{serviceList} +# Include{persistenceRoot} + - variable: data + label: App Data Storage + description: Stores the Application Data. + schema: + additional_attrs: true + type: dict + attrs: +# Include{persistenceBasic} +# Include{persistenceList} +# Include{ingressRoot} + - variable: main + label: "Main Ingress" + schema: + additional_attrs: true + type: dict + attrs: +# Include{ingressDefault} +# Include{ingressTLS} +# Include{ingressTraefik} +# Include{ingressAdvanced} +# Include{ingressList} +# Include{securityContextRoot} + + - variable: runAsUser + label: "runAsUser" + description: "The UserID of the user running the application" + schema: + type: int + default: 568 + - variable: runAsGroup + label: "runAsGroup" + description: "The groupID of the user running the application" + schema: + type: int + default: 568 +# Include{securityContextContainer} +# Include{securityContextAdvanced} +# Include{securityContextPod} + - variable: fsGroup + label: "fsGroup" + description: "The group that should own ALL storage." + schema: + type: int + default: 568 + +# Include{resources} +# Include{advanced} +# Include{addons} +# Include{codeserver} +# Include{netshoot} +# Include{vpn} +# Include{documentation} diff --git a/charts/incubator/answer/templates/NOTES.txt b/charts/incubator/answer/templates/NOTES.txt new file mode 100644 index 00000000000..efcb74cb772 --- /dev/null +++ b/charts/incubator/answer/templates/NOTES.txt @@ -0,0 +1 @@ +{{- include "tc.v1.common.lib.chart.notes" $ -}} diff --git a/charts/incubator/answer/templates/common.yaml b/charts/incubator/answer/templates/common.yaml new file mode 100644 index 00000000000..b51394e00a4 --- /dev/null +++ b/charts/incubator/answer/templates/common.yaml @@ -0,0 +1 @@ +{{ include "tc.v1.common.loader.all" . }} diff --git a/charts/incubator/answer/values.yaml b/charts/incubator/answer/values.yaml new file mode 100644 index 00000000000..8bd9c8496a5 --- /dev/null +++ b/charts/incubator/answer/values.yaml @@ -0,0 +1,81 @@ +image: + repository: tccr.io/truecharts/answer + pullPolicy: IfNotPresent + tag: v1.2.0@sha256:70a578170bca4a7a1040d44cb5ff143d5e9c2c2f32f9d48f1ad4519d61c35451 + + +service: + main: + ports: + main: + protocol: http + port: 9080 + +answer: + app: + language: en-US + # DEBUG | INFO | WARN | ERROR + log_level: DEBUG + site: + name: Answer + url: http://localhost:9080 + contact_email: contact@example.com + admin: + name: admin + password: super-secret-password + email: admin@example.com + +workload: + main: + podSpec: + containers: + main: + probes: + liveness: + path: /healthz + readiness: + path: /healthz + startup: + type: tcp + env: + AUTO_INSTALL: true + INSTALL_PORT: "{{ .Values.service.main.ports.main.port }}" + DB_TYPE: postgres + DB_USERNAME: "{{ .Values.cnpg.main.user }}" + DB_PASSWORD: + secretKeyRef: + name: cnpg-main-user + key: password + # Host + port + DB_HOST: '{{ printf "%s:5432" (.Values.cnpg.main.creds.host | trimAll "\"") }}' + DB_NAME: "{{ .Values.cnpg.main.database }}" + # App + LANGUAGE: "{{ .Values.answer.app.language }}" + LOG_LEVEL: "{{ .Values.answer.app.log_level }}" + # Site + SITE_NAME: "{{ .Values.answer.site.name }}" + SITE_URL: "{{ .Values.answer.site.url }}" + CONTACT_EMAIL: "{{ .Values.answer.site.contact_email }}" + # Admin + ADMIN_NAME: "{{ .Values.answer.admin.name }}" + ADMIN_PASSWORD: "{{ .Values.answer.admin.password }}" + ADMIN_EMAIL: "{{ .Values.answer.admin.email }}" + +persistence: + data: + enabled: true + mountPath: /data + +cnpg: + main: + enabled: true + user: answer + database: answer + +portal: + open: + enabled: true + +operator: + verify: + enabled: false