forked from helm/charts
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: Christian Ingenhaag <christian.ingenhaag@googlemail.com>
- Loading branch information
1 parent
11fa809
commit f4bb1a9
Showing
16 changed files
with
717 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
# 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 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
name: nextcloud | ||
version: 1.0.0 | ||
appVersion: 15.0.2 | ||
description: A file sharing server that puts the control and security of your own data back into your hands. | ||
keywords: | ||
- nextcloud | ||
- storage | ||
- http | ||
- web | ||
- php | ||
home: https://nextcloud.com/ | ||
icon: https://cdn.rawgit.com/docker-library/docs/defa5ffc7123177acd60ddef6e16bddf694cc35f/nextcloud/logo.svg | ||
sources: | ||
- https://github.com/nextcloud/docker | ||
maintainers: | ||
- name: chrisingenhaag | ||
email: christian.ingenhaag@googlemail.com |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,119 @@ | ||
# nextcloud | ||
|
||
[nextcloud](https://nextcloud.com/) is a file sharing server that puts the control and security of your own data back into your hands. | ||
|
||
## TL;DR; | ||
|
||
```console | ||
$ helm install stable/nextcloud | ||
``` | ||
|
||
## Introduction | ||
|
||
This chart bootstraps an [nextcloud](https://hub.docker.com/_/nextcloud/) deployment on a [Kubernetes](http://kubernetes.io) cluster using the [Helm](https://helm.sh) package manager. | ||
|
||
It also packages the [Bitnami MariaDB chart](https://github.com/kubernetes/charts/tree/master/stable/mariadb) which is required for bootstrapping a MariaDB deployment for the database requirements of the nextcloud application. | ||
|
||
## Prerequisites | ||
|
||
- Kubernetes 1.9+ with Beta APIs enabled | ||
- PV provisioner support in the underlying infrastructure | ||
|
||
## Installing the Chart | ||
|
||
To install the chart with the release name `my-release`: | ||
|
||
```console | ||
$ helm install --name my-release stable/nextcloud | ||
``` | ||
|
||
The command deploys nextcloud on the Kubernetes cluster in the default configuration. The [configuration](#configuration) section lists the parameters that can be configured during installation. | ||
|
||
> **Tip**: List all releases using `helm list` | ||
## Uninstalling the Chart | ||
|
||
To uninstall/delete the `my-release` deployment: | ||
|
||
```console | ||
$ helm delete my-release | ||
``` | ||
|
||
The command removes all the Kubernetes components associated with the chart and deletes the release. | ||
|
||
## Configuration | ||
|
||
The following table lists the configurable parameters of the nextcloud chart and their default values. | ||
|
||
| Parameter | Description | Default | | ||
|-------------------------------------|-------------------------------------------|-------------------------------------------------------- | | ||
| `image.repository` | nextcloud Image name | `nextcloud` | | ||
| `image.tag` | nextcloud Image tag | `{VERSION}` | | ||
| `image.pullPolicy` | Image pull policy | `Always` if `imageTag` is `latest`, else `IfNotPresent` | | ||
| `image.pullSecrets` | Specify image pull secrets | `nil` | | ||
| `ingress.enabled` | Enable use of ingress controllers | `false` | | ||
| `ingress.servicePort` | Ingress' backend servicePort | `http` | | ||
| `ingress.annotations` | An array of service annotations | `nil` | | ||
| `ingress.tls` | Ingress TLS configuration | `[]` | | ||
| `nextcloud.host` | nextcloud host to create application URLs | `nextcloud.kube.home` | | ||
| `nextcloud.username` | User of the application | `admin` | | ||
| `nextcloud.password` | Application password | `changeme` | | ||
| `internalDatabase.enabled` | Whether to use internal sqlite database | `true` | | ||
| `internalDatabase.database` | Name of the existing database | `nextcloud` | | ||
| `externalDatabase.enabled` | Whether to use external database | `false` | | ||
| `externalDatabase.host` | Host of the external database | `nil` | | ||
| `externalDatabase.database` | Name of the existing database | `nextcloud` | | ||
| `externalDatabase.user` | Existing username in the external db | `nextcloud` | | ||
| `externalDatabase.password` | Password for the above username | `nil` | | ||
| `mariadb.enabled` | Whether to use the MariaDB chart | `false` | | ||
| `mariadb.db.name` | Database name to create | `nextcloud` | | ||
| `mariadb.db.password` | Password for the database | `changeme` | | ||
| `mariadb.db.user` | Database user to create | `nextcloud` | | ||
| `mariadb.rootUser.password` | MariaDB admin password | `nil` | | ||
| `service.type` | Kubernetes Service type | `ClusterIp` | | ||
| `service.loadBalancerIP` | LoadBalancerIp for service type LoadBalancer | `nil` | | ||
| `persistence.enabled` | Enable persistence using PVC | `true` | | ||
| `persistence.storageClass` | PVC Storage Class for nextcloud volume | `nil` (uses alpha storage class annotation) | | ||
| `persistence.existingClaim`| An Existing PVC name for nextcloud volume | `nil` (uses alpha storage class annotation) | | ||
| `persistence.accessMode` | PVC Access Mode for nextcloud volume | `ReadWriteOnce` | | ||
| `persistence.size` | PVC Storage Request for nextcloud volume | `8Gi` | | ||
| `resources` | CPU/Memory resource requests/limits | `{}` | | ||
|
||
> **Note**: | ||
> | ||
> For nextcloud to function correctly, you should specify the `nextcloud.host` parameter to specify the FQDN (recommended) or the public IP address of the nextcloud service. | ||
> | ||
> Optionally, you can specify the `service.loadBalancerIP` parameter to assign a reserved IP address to the nextcloud service of the chart. However please note that this feature is only available on a few cloud providers (f.e. GKE). | ||
> | ||
> To reserve a public IP address on GKE: | ||
> | ||
> ```bash | ||
> $ gcloud compute addresses create nextcloud-public-ip | ||
> ``` | ||
> | ||
> The reserved IP address can be associated to the nextcloud service by specifying it as the value of the `service.loadBalancerIP` parameter while installing the chart. | ||
Specify each parameter using the `--set key=value[,key=value]` argument to `helm install`. For example, | ||
```console | ||
$ helm install --name my-release \ | ||
--set nextcloud.username=admin,nextcloud.password=password,mariadb.rootUser.password=secretpassword \ | ||
stable/nextcloud | ||
``` | ||
The above command sets the nextcloud administrator account username and password to `admin` and `password` respectively. Additionally, it sets the MariaDB `root` user password to `secretpassword`. | ||
Alternatively, a YAML file that specifies the values for the above parameters can be provided while installing the chart. For example, | ||
```console | ||
$ helm install --name my-release -f values.yaml stable/nextcloud | ||
``` | ||
> **Tip**: You can use the default [values.yaml](values.yaml) | ||
## Persistence | ||
The [Nextcloud](https://hub.docker.com/_/nextcloud/) image stores the nextcloud data and configurations at the `/var/www/html` paths of the container. | ||
Persistent Volume Claims are used to keep the data across deployments. This is known to work in GCE, AWS, and minikube. | ||
See the [Configuration](#configuration) section to configure the PVC or to disable persistence. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
dependencies: | ||
- name: mariadb | ||
repository: https://kubernetes-charts.storage.googleapis.com/ | ||
version: 5.5.0 | ||
digest: sha256:66e8bec50806f6576f4954c145d45b44a55975cad4f10b3bdd6cc4e208055bca | ||
generated: 2019-01-26T18:57:18.847326+01:00 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
dependencies: | ||
- name: mariadb | ||
version: ~5.5.0 | ||
repository: https://kubernetes-charts.storage.googleapis.com/ | ||
condition: mariadb.enabled |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,93 @@ | ||
{{- if or .Values.mariadb.enabled .Values.externalDatabase.host -}} | ||
|
||
{{- if empty (include "nextcloud.host" .) -}} | ||
############################################################################### | ||
### ERROR: You did not provide an external host in your 'helm install' call ### | ||
############################################################################### | ||
|
||
This deployment will be incomplete until you configure nextcloud with a resolvable | ||
host. To configure nextcloud with the URL of your service: | ||
|
||
1. Get the nextcloud URL by running: | ||
|
||
{{- if contains "NodePort" .Values.service.type }} | ||
|
||
export APP_PORT=$(kubectl get svc --namespace {{ .Release.Namespace }} {{ template "nextcloud.fullname" . }} -o jsonpath="{.spec.ports[0].nodePort}") | ||
export APP_HOST=$(kubectl get nodes --namespace {{ .Release.Namespace }} -o jsonpath="{.items[0].status.addresses[0].address}") | ||
|
||
{{- else if contains "LoadBalancer" .Values.service.type }} | ||
|
||
NOTE: It may take a few minutes for the LoadBalancer IP to be available. | ||
Watch the status with: 'kubectl get svc --namespace {{ .Release.Namespace }} -w {{ template "nextcloud.fullname" . }}' | ||
|
||
export APP_HOST=$(kubectl get svc --namespace {{ .Release.Namespace }} {{ template "nextcloud.fullname" . }} --template "{{ "{{ range (index .status.loadBalancer.ingress 0) }}{{ . }}{{ end }}" }}") | ||
export APP_PASSWORD=$(kubectl get secret --namespace {{ .Release.Namespace }} {{ template "nextcloud.fullname" . }} -o jsonpath="{.data.nextcloud-password}" | base64 --decode) | ||
{{- if .Values.mariadb.db.password }} | ||
export APP_DATABASE_PASSWORD=$(kubectl get secret --namespace {{ .Release.Namespace }} {{ template "nextcloud.mariadb.fullname" . }} -o jsonpath="{.data.mariadb-password}" | base64 --decode) | ||
{{- end }} | ||
{{- end }} | ||
|
||
2. Complete your nextcloud deployment by running: | ||
|
||
{{- if .Values.mariadb.enabled }} | ||
|
||
helm upgrade {{ .Release.Name }} stable/nextcloud \ | ||
--set nextcloud.host=$APP_HOST,nextcloud.password=$APP_PASSWORD{{ if .Values.mariadb.db.password }},mariadb.db.password=$APP_DATABASE_PASSWORD{{ end }} | ||
{{- else }} | ||
|
||
## PLEASE UPDATE THE EXTERNAL DATABASE CONNECTION PARAMETERS IN THE FOLLOWING COMMAND AS NEEDED ## | ||
|
||
helm upgrade {{ .Release.Name }} stable/nextcloud \ | ||
--set nextcloud.password=$APP_PASSWORD,nextcloud.host=$APP_HOST,service.type={{ .Values.service.type }},mariadb.enabled=false{{- if not (empty .Values.externalDatabase.host) }},externalDatabase.host={{ .Values.externalDatabase.host }}{{- end }}{{- if not (empty .Values.externalDatabase.user) }},externalDatabase.user={{ .Values.externalDatabase.user }}{{- end }}{{- if not (empty .Values.externalDatabase.password) }},externalDatabase.password={{ .Values.externalDatabase.password }}{{- end }}{{- if not (empty .Values.externalDatabase.database) }},externalDatabase.database={{ .Values.externalDatabase.database }}{{- end }} | ||
{{- end }} | ||
|
||
{{- else -}} | ||
1. Get the nextcloud URL by running: | ||
|
||
{{- if eq .Values.service.type "ClusterIP" }} | ||
|
||
export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app={{ template "nextcloud.fullname" . }}" -o jsonpath="{.items[0].metadata.name}") | ||
echo http://127.0.0.1:8080/ | ||
kubectl port-forward $POD_NAME 8080:8080 | ||
{{- else }} | ||
|
||
echo http://{{ include "nextcloud.host" . }}{{ if .Values.nextcloudPort }}:{{ .Values.nextcloudPort }}{{ end }}/ | ||
{{- end }} | ||
|
||
2. Get your nextcloud login credentials by running: | ||
|
||
echo User: {{ .Values.nextcloud.username }} | ||
echo Password: $(kubectl get secret --namespace {{ .Release.Namespace }} {{ template "nextcloud.fullname" . }} -o jsonpath="{.data.nextcloud-password}" | base64 --decode) | ||
{{- end }} | ||
|
||
{{- else -}} | ||
|
||
######################################################################################## | ||
### ERROR: You did not provide an external database host in your 'helm install' call ### | ||
######################################################################################## | ||
|
||
This deployment will be incomplete until you configure nextcloud with a resolvable database | ||
host. To configure nextcloud to use and external database host: | ||
|
||
|
||
1. Complete your nextcloud deployment by running: | ||
|
||
{{- if contains "NodePort" .Values.service.type }} | ||
export APP_HOST=$(kubectl get nodes --namespace {{ .Release.Namespace }} -o jsonpath="{.items[0].status.addresses[0].address}") | ||
{{- else if contains "LoadBalancer" .Values.service.type }} | ||
|
||
NOTE: It may take a few minutes for the LoadBalancer IP to be available. | ||
Watch the status with: 'kubectl get svc --namespace {{ .Release.Namespace }} -w {{ template "nextcloud.fullname" . }}' | ||
|
||
export APP_HOST=$(kubectl get svc --namespace {{ .Release.Namespace }} {{ template "nextcloud.fullname" . }} --template "{{ "{{ range (index .status.loadBalancer.ingress 0) }}{{ . }}{{ end }}" }}") | ||
{{- else }} | ||
|
||
export APP_HOST=127.0.0.1 | ||
{{- end }} | ||
export APP_PASSWORD=$(kubectl get secret --namespace {{ .Release.Namespace }} {{ template "nextcloud.fullname" . }} -o jsonpath="{.data.nextcloud-password}" | base64 --decode) | ||
|
||
## PLEASE UPDATE THE EXTERNAL DATABASE CONNECTION PARAMETERS IN THE FOLLOWING COMMAND AS NEEDED ## | ||
|
||
helm upgrade {{ .Release.Name }} stable/nextcloud \ | ||
--set nextcloud.password=$APP_PASSWORD,nextcloud.host=$APP_HOST,service.type={{ .Values.service.type }},mariadb.enabled=false{{- if not (empty .Values.externalDatabase.user) }},externalDatabase.user={{ .Values.externalDatabase.user }}{{- end }}{{- if not (empty .Values.externalDatabase.password) }},externalDatabase.password={{ .Values.externalDatabase.password }}{{- end }}{{- if not (empty .Values.externalDatabase.database) }},externalDatabase.database={{ .Values.externalDatabase.database }}{{- end }},externalDatabase.host=YOUR_EXTERNAL_DATABASE_HOST | ||
{{- end }} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
{{/* vim: set filetype=mustache: */}} | ||
{{/* | ||
Expand the name of the chart. | ||
*/}} | ||
{{- define "nextcloud.name" -}} | ||
{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" -}} | ||
{{- end -}} | ||
|
||
{{/* | ||
Create a default fully qualified app name. | ||
We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). | ||
*/}} | ||
{{- define "nextcloud.fullname" -}} | ||
{{- $name := default .Chart.Name .Values.nameOverride -}} | ||
{{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" -}} | ||
{{- end -}} | ||
|
||
{{/* | ||
Create a default fully qualified app name. | ||
We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). | ||
*/}} | ||
{{- define "nextcloud.mariadb.fullname" -}} | ||
{{- printf "%s-%s" .Release.Name "mariadb" | trunc 63 | trimSuffix "-" -}} | ||
{{- end -}} | ||
|
||
{{/* | ||
Get the user defined LoadBalancerIP for this release. | ||
Note, returns 127.0.0.1 if using ClusterIP. | ||
*/}} | ||
{{- define "nextcloud.serviceIP" -}} | ||
{{- if eq .Values.service.type "ClusterIP" -}} | ||
127.0.0.1 | ||
{{- else -}} | ||
{{- index .Values (printf "%sLoadBalancerIP" .Chart.Name) | default "" -}} | ||
{{- end -}} | ||
{{- end -}} | ||
|
||
{{/* | ||
Gets the host to be used for this application. | ||
If not using ClusterIP, or if a host or LoadBalancerIP is not defined, the value will be empty. | ||
*/}} | ||
{{- define "nextcloud.host" -}} | ||
{{- $host := index .Values (printf "%sHost" .Chart.Name) | default "" -}} | ||
{{- default (include "nextcloud.serviceIP" .) $host -}} | ||
{{- end -}} | ||
|
||
{{/* | ||
Create chart name and version as used by the chart label. | ||
*/}} | ||
{{- define "nextcloud.chart" -}} | ||
{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" -}} | ||
{{- end -}} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
{{- if .Values.mariadb.enabled }} | ||
apiVersion: v1 | ||
kind: Secret | ||
metadata: | ||
name: {{ printf "%s-%s" .Release.Name "db" }} | ||
labels: | ||
app.kubernetes.io/name: {{ include "nextcloud.name" . }} | ||
helm.sh/chart: {{ include "nextcloud.chart" . }} | ||
app.kubernetes.io/instance: {{ .Release.Name }} | ||
app.kubernetes.io/managed-by: {{ .Release.Service }} | ||
type: Opaque | ||
data: | ||
db-password: {{ default "" .Values.mariadb.db.password | b64enc | quote }} | ||
db-username: {{ default "" .Values.mariadb.db.user | b64enc | quote }} | ||
{{- end }} |
Oops, something went wrong.