diff --git a/Makefile b/Makefile index e89c834a3..d4eddb47a 100644 --- a/Makefile +++ b/Makefile @@ -263,8 +263,23 @@ gen-values-schema: @yq r api/crds/installer.stash.appscode.com_stashpostgreses.yaml spec.validation.openAPIV3Schema.properties.spec > /tmp/stash-postgres-values.openapiv3_schema.yaml @yq d /tmp/stash-postgres-values.openapiv3_schema.yaml description > charts/stash-postgres/values.openapiv3_schema.yaml +.PHONY: gen-chart-doc +gen-chart-doc: gen-chart-doc-stash-postgres + +gen-chart-doc-%: + @echo "Generate $* chart docs" + @docker run --rm \ + -u $$(id -u):$$(id -g) \ + -v /tmp:/.cache \ + -v $$(pwd):$(DOCKER_REPO_ROOT) \ + -w $(DOCKER_REPO_ROOT) \ + --env HTTP_PROXY=$(HTTP_PROXY) \ + --env HTTPS_PROXY=$(HTTPS_PROXY) \ + $(BUILD_IMAGE) \ + chart-doc-gen -d ./charts/$*/doc.yaml -v ./charts/$*/values.yaml > ./charts/$*/README.md + .PHONY: manifests -manifests: gen-crds patch-crds label-crds gen-bindata gen-values-schema +manifests: gen-crds patch-crds label-crds gen-bindata gen-values-schema gen-chart-doc .PHONY: gen gen: clientset gen-crd-protos manifests openapi diff --git a/charts/stash-postgres/README.md b/charts/stash-postgres/README.md index 29def639d..ff15edf3c 100644 --- a/charts/stash-postgres/README.md +++ b/charts/stash-postgres/README.md @@ -1,18 +1,18 @@ # stash-postgres -[stash-postgres](https://github.com/stashed/stash-postgres) - PostgreSQL database backup/restore plugin for [Stash by AppsCode](https://appscode.com/products/stash/). +[stash-postgres](https://github.com/stashed/postgres) - PostgreSQL database backup/restore plugin for [Stash by AppsCode](https://stash.run) ## TL;DR; ```console -helm repo add appscode https://charts.appscode.com/stable/ -helm repo update -helm install stash-postgres-11.1 appscode/stash-postgres -n kube-system --version=11.1 +$ helm repo add appscode https://charts.appscode.com/stable/ +$ helm repo update +$ helm install stash-postgres-11.1 appscode/stash-postgres -n kube-system --version=11.1 ``` ## Introduction -This chart installs necessary `Function` and `Task` definition to backup or restore PostgreSQL database 11.1 using Stash. +This chart deploys necessary `Function` and `Task` definition to backup or restore PostgreSQL database 11.1 using Stash on a [Kubernetes](http://kubernetes.io) cluster using the [Helm](https://helm.sh) package manager. ## Prerequisites @@ -20,32 +20,22 @@ This chart installs necessary `Function` and `Task` definition to backup or rest ## Installing the Chart -- Add AppsCode chart repository to your helm repository list, +To install the chart with the release name `stash-postgres-11.1`: ```console -helm repo add appscode https://charts.appscode.com/stable/ +$ helm install stash-postgres-11.1 appscode/stash-postgres -n kube-system --version=11.1 ``` -- Update helm repositories to fetch latest charts from the remove repository, +The command deploys necessary `Function` and `Task` definition to backup or restore PostgreSQL database 11.1 using Stash on the Kubernetes cluster in the default configuration. The [configuration](#configuration) section lists the parameters that can be configured during installation. -```console -helm repo update -``` - -- Install the chart with the release name `stash-postgres-11.1` run the following command, - -```console -helm install stash-postgres-11.1 appscode/stash-postgres -n kube-system --version=11.1 -``` - -The above commands installs `Functions` and `Task` crds that are necessary to backup PostgreSQL database 11.1 using Stash. +> **Tip**: List all releases using `helm list` ## Uninstalling the Chart -To uninstall/delete the `stash-postgres-11.1` run the following command, +To uninstall/delete the `stash-postgres-11.1`: ```console -helm uninstall stash-postgres-11.1 -n kube-system +$ helm delete stash-postgres-11.1 -n kube-system ``` The command removes all the Kubernetes components associated with the chart and deletes the release. @@ -54,18 +44,26 @@ The command removes all the Kubernetes components associated with the chart and The following table lists the configurable parameters of the `stash-postgres` chart and their default values. -| Parameter | Description | Default | -| ----------------- | -------------------------------------------------------------------------------------------------------------------------------- | ---------------- | -| `docker.registry` | Docker registry used to pull respective images | `stashed` | -| `docker.image` | Docker image used to backup/restore PosegreSQL database | `stash-postgres` | -| `docker.tag` | Tag of the image that is used to backup/restore PostgreSQL database. This is usually same as the database version it can backup. | `11.1` | -| `backup.args` | Optional arguments to pass to `pgdump` command during bakcup process | | -| `restore.args` | Optional arguments to pass to `psql` command during restore process | | +| Parameter | Description | Default | +|------------------|----------------------------------------------------------------------------------------------------------------------------------|------------------| +| nameOverride | Overrides name template | `""` | +| fullnameOverride | Overrides fullname template | `""` | +| image.registry | Docker registry used to pull Postgres addon image | `stashed` | +| image.repository | Docker image used to backup/restore PosegreSQL database | `stash-postgres` | +| image.tag | Tag of the image that is used to backup/restore PostgreSQL database. This is usually same as the database version it can backup. | `"11.1"` | +| backup.args | Arguments to pass to `pgdump` command during bakcup process | `""` | +| restore.args | Arguments to pass to `psql` command during restore process | `""` | + + +Specify each parameter using the `--set key=value[,key=value]` argument to `helm install`. For example: -Specify each parameter using the `--set key=value[,key=value]` argument to `helm install`. +```console +$ helm install stash-postgres-11.1 appscode/stash-postgres -n kube-system --version=11.1 --set image.registry=stashed +``` -For example: +Alternatively, a YAML file that specifies the values for the parameters can be provided while +installing the chart. For example: ```console -helm install stash-postgres-11.1 appscode/stash-postgres -n kube-system --set docker.registry=my-registry +$ helm install stash-postgres-11.1 appscode/stash-postgres -n kube-system --version=11.1 --values values.yaml ``` diff --git a/charts/stash-postgres/doc.yaml b/charts/stash-postgres/doc.yaml new file mode 100644 index 000000000..24acc665d --- /dev/null +++ b/charts/stash-postgres/doc.yaml @@ -0,0 +1,19 @@ +project: + name: stash-postgres + shortName: stash-postgres + url: https://github.com/stashed/postgres + description: "PostgreSQL database backup/restore plugin for [Stash by AppsCode](https://stash.run)" + app: "necessary `Function` and `Task` definition to backup or restore PostgreSQL database 11.1 using Stash" +repository: + url: https://charts.appscode.com/stable/ + name: appscode +chart: + name: stash-postgres + version: "11.1" + values: "-- generate from values file --" + valuesExample: "-- generate from values file --" +prerequisites: +- Kubernetes 1.11+ +release: + name: stash-postgres-11.1 + namespace: kube-system diff --git a/charts/stash-postgres/values.yaml b/charts/stash-postgres/values.yaml index b1d1724fb..117fb45d2 100644 --- a/charts/stash-postgres/values.yaml +++ b/charts/stash-postgres/values.yaml @@ -2,16 +2,23 @@ # This is a YAML-formatted file. # Declare variables to be passed into your templates. +# Overrides name template nameOverride: "" +# Overrides fullname template fullnameOverride: "" image: + # Docker registry used to pull Postgres addon image registry: stashed + # Docker image used to backup/restore PosegreSQL database repository: stash-postgres + # Tag of the image that is used to backup/restore PostgreSQL database. + # This is usually same as the database version it can backup. tag: "11.1" -# optional argument to send pgdump or psql command backup: + # Arguments to pass to `pgdump` command during bakcup process args: "" restore: + # Arguments to pass to `psql` command during restore process args: ""