From b17f7e338b78622397413e3775936523b66f64c4 Mon Sep 17 00:00:00 2001 From: Stavros Kois <47820033+stavros-k@users.noreply.github.com> Date: Fri, 15 Oct 2021 00:37:08 +0300 Subject: [PATCH] (feat) Add Uptime-kuma (#1144) * Add maintainer to OO * Add uptime-kuma --- charts/incubator/uptime-kuma/.helmignore | 24 + charts/incubator/uptime-kuma/Chart.yaml | 26 + charts/incubator/uptime-kuma/SCALE/item.yaml | 3 + .../uptime-kuma/SCALE/ix_values.yaml | 15 + .../uptime-kuma/SCALE/questions.yaml | 456 ++++++++++++++++++ .../uptime-kuma/templates/common.yaml | 1 + charts/incubator/uptime-kuma/values.yaml | 28 ++ .../onlyoffice-document-server/Chart.yaml | 3 + docs/apps/app-requests.md | 2 +- docs/manual/default-ports.md | 1 + 10 files changed, 558 insertions(+), 1 deletion(-) create mode 100644 charts/incubator/uptime-kuma/.helmignore create mode 100644 charts/incubator/uptime-kuma/Chart.yaml create mode 100644 charts/incubator/uptime-kuma/SCALE/item.yaml create mode 100644 charts/incubator/uptime-kuma/SCALE/ix_values.yaml create mode 100644 charts/incubator/uptime-kuma/SCALE/questions.yaml create mode 100644 charts/incubator/uptime-kuma/templates/common.yaml create mode 100644 charts/incubator/uptime-kuma/values.yaml diff --git a/charts/incubator/uptime-kuma/.helmignore b/charts/incubator/uptime-kuma/.helmignore new file mode 100644 index 00000000000..e559de0a012 --- /dev/null +++ b/charts/incubator/uptime-kuma/.helmignore @@ -0,0 +1,24 @@ +# 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 diff --git a/charts/incubator/uptime-kuma/Chart.yaml b/charts/incubator/uptime-kuma/Chart.yaml new file mode 100644 index 00000000000..af389c118ba --- /dev/null +++ b/charts/incubator/uptime-kuma/Chart.yaml @@ -0,0 +1,26 @@ +apiVersion: v2 +appVersion: "1.8.0-alpine" +dependencies: +- name: common + repository: https://truecharts.org + version: 8.3.6 +deprecated: false +description: A fancy self-hosted monitoring tool +home: https://github.com/louislam/uptime-kuma +icon: https://raw.githubusercontent.com/louislam/uptime-kuma/master/public/icon.png +keywords: +- monitoring +- uptime +kubeVersion: '>=1.16.0-0' +maintainers: +- email: info@truecharts.org + name: TrueCharts + url: truecharts.org +- email: stavros-k@users.noreply.github.com + name: stavros-k + url: truecharts.org +name: uptime-kuma +sources: +- https://github.com/louislam/uptime-kuma +type: application +version: 0.0.1 diff --git a/charts/incubator/uptime-kuma/SCALE/item.yaml b/charts/incubator/uptime-kuma/SCALE/item.yaml new file mode 100644 index 00000000000..463fb109713 --- /dev/null +++ b/charts/incubator/uptime-kuma/SCALE/item.yaml @@ -0,0 +1,3 @@ +categories: + - monitoring +icon_url: https://raw.githubusercontent.com/louislam/uptime-kuma/master/public/icon.png diff --git a/charts/incubator/uptime-kuma/SCALE/ix_values.yaml b/charts/incubator/uptime-kuma/SCALE/ix_values.yaml new file mode 100644 index 00000000000..8dcfac890c2 --- /dev/null +++ b/charts/incubator/uptime-kuma/SCALE/ix_values.yaml @@ -0,0 +1,15 @@ +## +# This file contains Values.yaml content that gets added to the output of questions.yaml +# It's ONLY meant for content that the user is NOT expected to change. +# Example: Everything under "image" is not included in questions.yaml but is included here. +## + +image: + repository: louislam/uptime-kuma + pullPolicy: IfNotPresent + tag: 1.8.0-debian@sha256:c775044689c432e282df0adc2fb6f0706513e87d6ff73fcafe0149a729a5e383 + +## +# Most other defaults are set in questions.yaml +# For other options please refer to the wiki, default_values.yaml or the common library chart +## diff --git a/charts/incubator/uptime-kuma/SCALE/questions.yaml b/charts/incubator/uptime-kuma/SCALE/questions.yaml new file mode 100644 index 00000000000..3b3dca443e4 --- /dev/null +++ b/charts/incubator/uptime-kuma/SCALE/questions.yaml @@ -0,0 +1,456 @@ +# Include{groups} +portals: + web_portal: + protocols: + - "$kubernetes-resource_configmap_portal_protocol" + host: + - "$kubernetes-resource_configmap_portal_host" + ports: + - "$kubernetes-resource_configmap_portal_port" +questions: + - variable: portal + group: "Container Image" + label: "Configure Portal Button" + schema: + type: dict + hidden: true + attrs: + - variable: enabled + label: "Enable" + description: "enable the portal button" + schema: + hidden: true + editable: false + type: boolean + default: true + - variable: controller + group: "Controller" + label: "" + schema: + type: dict + attrs: + - variable: type + description: "Please specify type of workload to deploy" + label: "(Advanced) Controller Type" + schema: + type: string + default: "deployment" + required: true + enum: + - value: "deployment" + description: "Deployment" + - value: "statefulset" + description: "Statefulset" + - value: "daemonset" + description: "Daemonset" + - variable: replicas + description: "Number of desired pod replicas" + label: "Desired Replicas" + schema: + type: int + default: 1 + required: true + - variable: strategy + description: "Please specify type of workload to deploy" + label: "(Advanced) Update Strategy" + schema: + type: string + default: "Recreate" + required: true + enum: + - value: "Recreate" + description: "Recreate: Kill existing pods before creating new ones" + - value: "RollingUpdate" + description: "RollingUpdate: Create new pods and then kill old ones" + - value: "OnDelete" + description: "(Legacy) OnDelete: ignore .spec.template changes" +# Include{controllerExpert} + + - variable: env + group: "Container Configuration" + label: "Image Environment" + schema: + type: dict + attrs: +# Include{fixedEnv} + +# Include{containerConfig} + + - variable: service + group: "Networking and Services" + label: "Configure Service(s)" + schema: + type: dict + attrs: + - variable: main + label: "Main Service" + description: "The Primary service on which the healthcheck runs, often the webUI" + schema: + type: dict + attrs: + - variable: enabled + label: "Enable the service" + schema: + type: boolean + default: true + hidden: true + - variable: type + label: "Service Type" + description: "ClusterIP's are only internally available, nodePorts expose the container to the host node System, Loadbalancer exposes the service using the system loadbalancer" + schema: + type: string + default: "NodePort" + enum: + - value: "NodePort" + description: "NodePort" + - value: "ClusterIP" + description: "ClusterIP" + - value: "LoadBalancer" + description: "LoadBalancer" + - variable: loadBalancerIP + label: "LoadBalancer IP" + description: "LoadBalancerIP" + schema: + show_if: [["type", "=", "LoadBalancer"]] + type: string + default: "" + - variable: externalIPs + label: "External IP's" + description: "External IP's" + schema: + show_if: [["type", "=", "LoadBalancer"]] + type: list + default: [] + items: + - variable: externalIP + label: "External IP" + schema: + type: string + - variable: ports + label: "Service's Port(s) Configuration" + schema: + type: dict + attrs: + - variable: main + label: "Main Service Port Configuration" + schema: + type: dict + attrs: + - variable: enabled + label: "Enable the port" + schema: + type: boolean + default: true + hidden: true + - variable: protocol + label: "Port Type" + schema: + type: string + default: "HTTP" + enum: + - value: HTTP + description: "HTTP" + - value: "HTTPS" + description: "HTTPS" + - value: TCP + description: "TCP" + - value: "UDP" + description: "UDP" + - variable: targetPort + label: "Target Port" + description: "This port exposes the container port on the service" + schema: + type: int + default: 3001 + editable: false + hidden: true + - variable: port + label: "Container Port" + schema: + type: int + default: 3001 + editable: true + required: true + - variable: nodePort + label: "Node Port (Optional)" + description: "This port gets exposed to the node. Only considered when service type is NodePort" + schema: + type: int + min: 9000 + max: 65535 + default: 36149 + + - variable: serviceexpert + group: "Networking and Services" + label: "Show Expert Config" + schema: + type: boolean + default: false + show_subquestions_if: true + subquestions: + - variable: hostNetwork + group: "Networking and Services" + label: "Host-Networking (Complicated)" + schema: + type: boolean + default: false + +# Include{serviceExpert} + +# Include{serviceList} + + - variable: persistence + label: "Integrated Persistent Storage" + group: "Storage and Persistence" + schema: + type: dict + attrs: + - variable: config + label: "App Config Storage" + description: "Stores the Application Configuration." + schema: + type: dict + attrs: + - variable: enabled + label: "Enable the storage" + schema: + type: boolean + default: true + - variable: type + label: "(Advanced) Type of Storage" + description: "Sets the persistence type" + schema: + type: string + default: "pvc" + enum: + - value: "pvc" + description: "pvc" + - value: "emptyDir" + description: "emptyDir" + - value: "hostPath" + description: "hostPath" + - variable: storageClass + label: "(Advanced) storageClass" + description: " Warning: Anything other than SCALE-ZFS will break rollback!" + schema: + show_if: [["type", "=", "pvc"]] + type: string + default: "SCALE-ZFS" + - variable: labelsList + label: "Labels" + schema: + type: list + default: [] + items: + - variable: labelItem + label: "Label" + schema: + type: dict + attrs: + - variable: name + label: "Name" + schema: + type: string + - variable: value + label: "Value" + schema: + type: string + - variable: annotationsList + label: "Annotations" + schema: + type: list + default: [] + items: + - variable: annotationItem + label: "Label" + schema: + type: dict + attrs: + - variable: name + label: "Name" + schema: + type: string + - variable: value + label: "Value" + schema: + type: string + - variable: setPermissions + label: "Automatic Permissions" + description: "Automatically set permissions on install" + schema: + show_if: [["type", "=", "hostPath"]] + type: boolean + default: true + - variable: readOnly + label: "readOnly" + schema: + type: boolean + default: false + - variable: hostPath + label: "hostPath" + description: "Path inside the container the storage is mounted" + schema: + show_if: [["type", "=", "hostPath"]] + type: hostpath + - variable: hostPathType + label: "hostPath Type" + schema: + show_if: [["type", "=", "hostPath"]] + type: string + default: "" + enum: + - value: "" + description: "Default" + - value: "DirectoryOrCreate" + description: "DirectoryOrCreate" + - value: "Directory" + description: "Directory" + - value: "FileOrCreate" + description: "FileOrCreate" + - value: "File" + description: "File" + - value: "Socket" + description: "Socket" + - value: "CharDevice" + description: "CharDevice" + - value: "BlockDevice" + description: "BlockDevice" + - variable: mountPath + label: "mountPath" + description: "Path inside the container the storage is mounted" + schema: + type: string + default: "/app/data" + hidden: true + - variable: medium + label: "EmptyDir Medium" + schema: + show_if: [["type", "=", "emptyDir"]] + type: string + default: "" + enum: + - value: "" + description: "Default" + - value: "Memory" + description: "Memory" + - variable: accessMode + label: "Access Mode (Advanced)" + description: "Allow or disallow multiple PVC's writhing to the same PV" + schema: + show_if: [["type", "=", "pvc"]] + type: string + default: "ReadWriteOnce" + enum: + - value: "ReadWriteOnce" + description: "ReadWriteOnce" + - value: "ReadOnlyMany" + description: "ReadOnlyMany" + - value: "ReadWriteMany" + description: "ReadWriteMany" + - variable: size + label: "Size quotum of storage" + schema: + show_if: [["type", "=", "pvc"]] + type: string + default: "100Gi" +# Include{persistenceList} + + - variable: ingress + label: "" + group: "Ingress" + schema: + type: dict + attrs: + - variable: main + label: "Main Ingress" + schema: + type: dict + attrs: + +# Include{ingressDefault} + +# Include{ingressTLS} + +# Include{ingressTraefik} + +# Include{ingressExpert} + +# Include{ingressList} + + - variable: securityContext + group: "Security and Permissions" + label: "Security Context" + schema: + type: dict + attrs: + - variable: privileged + label: "Privileged mode" + schema: + type: boolean + default: false + - variable: readOnlyRootFilesystem + label: "ReadOnly Root Filesystem" + schema: + type: boolean + default: true + - variable: allowPrivilegeEscalation + label: "Allow Privilege Escalation" + schema: + type: boolean + default: false + - variable: runAsNonRoot + label: "runAsNonRoot" + schema: + type: boolean + default: true + + - variable: podSecurityContext + group: "Security and Permissions" + label: "Pod Security Context" + schema: + type: dict + attrs: + - 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 this App of the user running the application" + schema: + type: int + default: 568 + - variable: fsGroup + label: "fsGroup" + description: "The group that should own ALL storage." + schema: + type: int + default: 568 + - variable: supplementalGroups + label: "supplemental Groups" + schema: + type: list + default: [] + items: + - variable: supplementalGroupsEntry + label: "supplemental Group" + schema: + type: int + - variable: fsGroupChangePolicy + label: "When should we take ownership?" + schema: + type: string + default: "OnRootMismatch" + enum: + - value: "OnRootMismatch" + description: "OnRootMismatch" + - value: "Always" + description: "Always" + +# Include{resources} + +# Include{advanced} + +# Include{addons} diff --git a/charts/incubator/uptime-kuma/templates/common.yaml b/charts/incubator/uptime-kuma/templates/common.yaml new file mode 100644 index 00000000000..a6613c2ce21 --- /dev/null +++ b/charts/incubator/uptime-kuma/templates/common.yaml @@ -0,0 +1 @@ +{{ include "common.all" . }} diff --git a/charts/incubator/uptime-kuma/values.yaml b/charts/incubator/uptime-kuma/values.yaml new file mode 100644 index 00000000000..1292d870f8e --- /dev/null +++ b/charts/incubator/uptime-kuma/values.yaml @@ -0,0 +1,28 @@ +# Default values for Uptime Kuma. + +image: + repository: louislam/uptime-kuma + pullPolicy: IfNotPresent + tag: 1.8.0-debian@sha256:c775044689c432e282df0adc2fb6f0706513e87d6ff73fcafe0149a729a5e383 + +securityContext: + runAsNonRoot: false + +podSecurityContext: + runAsUser: 0 + runAsGroup: 0 + +service: + main: + enabled: true + ports: + main: + port: 3001 + +persistence: + config: + enabled: true + mountPath: "/app/data" + type: pvc + accessMode: ReadWriteOnce + size: "100Gi" diff --git a/charts/stable/onlyoffice-document-server/Chart.yaml b/charts/stable/onlyoffice-document-server/Chart.yaml index 543d267f8e7..650e670c00f 100644 --- a/charts/stable/onlyoffice-document-server/Chart.yaml +++ b/charts/stable/onlyoffice-document-server/Chart.yaml @@ -14,6 +14,9 @@ maintainers: - email: info@truecharts.org name: TrueCharts url: truecharts.org +- email: stavros-k@users.noreply.github.com + name: stavros-k + url: truecharts.org name: onlyoffice-document-server sources: - https://github.com/ONLYOFFICE/DocumentServer diff --git a/docs/apps/app-requests.md b/docs/apps/app-requests.md index 293b9a733c7..ce2da1ab701 100644 --- a/docs/apps/app-requests.md +++ b/docs/apps/app-requests.md @@ -63,7 +63,6 @@ _This list is to track `App Requests` from one place._ - [ ] oauth2-proxy - [ ] DokuWiki #1115 - [ ] Storj Node #1086 -- [ ] Uptime Kuma #1097 - [ ] PiGallery2 #1116 ##### TODO: Requires Postgresql customisation @@ -356,3 +355,4 @@ _These Apps have specific requirements or need specific customisation and care_ - [x] wiki - [x] zigbee2mqtt - [x] podgrab +- [x] Uptime Kuma #1097 diff --git a/docs/manual/default-ports.md b/docs/manual/default-ports.md index f0f7492ef8c..cf068fc9349 100644 --- a/docs/manual/default-ports.md +++ b/docs/manual/default-ports.md @@ -168,5 +168,6 @@ These defaults can ofcoarse be changed, but as we guarantee "sane, working defau | Cryptfolio | main | 36145 | | | | Valheim | main | 36146 | | | | Valheim | supervisor | 36147 | | | +| Uptime-Kuma | main | 36149 | | | ##### Note: TCP and UPD ports that are the same in each App, are not by mistake.