# Mongo Express

[Mongo Express](https://github.com/mongo-express/mongo-express) is a web-based MongoDB admin interface, written with Node.js and express.

**DISCLAIMER**: This is an unofficial chart not supported by Mongo Express authors.

## TL;DR;

```bash
$ helm repo add cowboysysop https://cowboysysop.github.io/charts/
$ helm install my-release cowboysysop/mongo-express
```

## Introduction

This chart bootstraps a Mongo Express deployment on a [Kubernetes](http://kubernetes.io) cluster using the [Helm](https://helm.sh) package manager.

## Prerequisites

- Kubernetes >= 1.24
- Helm >= 3.9

## Installing

Install the chart using:

```bash
$ helm repo add cowboysysop https://cowboysysop.github.io/charts/
$ helm install my-release cowboysysop/mongo-express
```

These commands deploy Mongo Express on the Kubernetes cluster in the default configuration and with the release name `my-release`. The deployment configuration can be customized by specifying the customization parameters with the `helm install` command using the `--values` or `--set` arguments. Find more information in the [configuration section](#configuration) of this document.

## Upgrading

Upgrade the chart deployment using:

```bash
$ helm upgrade my-release cowboysysop/mongo-express
```

The command upgrades the existing `my-release` deployment with the most latest release of the chart.

**TIP**: Use `helm repo update` to update information on available charts in the chart repositories.

### Upgrading to version 5.0.0

The chart is now tested with Kubernetes >= 1.24 and Helm >= 3.9.

Future upgrades may introduce undetected breaking changes if you continue to use older versions.

### Upgrading to version 4.0.0

Some parameters related to port management have been modified:

- Parameter `service.port` has been renamed `service.ports.http`.
- Parameter `service.nodePort` has been renamed `service.nodePorts.http`.

### Upgrading to version 3.0.0

Some parameters related to image management have been modified:

- Registry prefix in `image.repository` parameters is now configured in `image.registry`.
- Parameter `imagePullSecrets` has been renamed `global.imagePullSecrets`.

### Upgrading to version 2.0.0

The chart is no more compatible with Helm 2.

Refer to the [Helm documentation](https://helm.sh/docs/topics/v2_v3_migration/) for more information.

## Uninstalling

Uninstall the `my-release` deployment using:

```bash
$ helm uninstall my-release
```

The command deletes the release named `my-release` and frees all the kubernetes resources associated with the release.

**TIP**: Specify the `--purge` argument to the above command to remove the release from the store and make its name free for later use.

## Configuration

### Global parameters

| Name                      | Description                                     | Default |
| ------------------------- | ----------------------------------------------- | ------- |
| `global.imageRegistry`    | Global Docker image registry                    | `""`    |
| `global.imagePullSecrets` | Global Docker registry secret names as an array | `[]`    |

### Common parameters

| Name                | Description                                                                                        | Default |
| ------------------- | -------------------------------------------------------------------------------------------------- | ------- |
| `kubeVersion`       | Override Kubernetes version                                                                        | `""`    |
| `nameOverride`      | Partially override `mongo-express.fullname` template with a string (will prepend the release name) | `""`    |
| `fullnameOverride`  | Fully override `mongo-express.fullname` template with a string                                     | `""`    |
| `commonAnnotations` | Annotations to add to all deployed objects                                                         | `{}`    |
| `commonLabels`      | Labels to add to all deployed objects                                                              | `{}`    |
| `extraDeploy`       | Array of extra objects to deploy with the release                                                  | `[]`    |

### Parameters

| Name                                 | Description                                                                                               | Default                  |
| ------------------------------------ | --------------------------------------------------------------------------------------------------------- | ------------------------ |
| `replicaCount`                       | Number of replicas                                                                                        | `1`                      |
| `image.registry`                     | Image registry                                                                                            | `docker.io`              |
| `image.repository`                   | Image repository                                                                                          | `mongo-express`          |
| `image.tag`                          | Image tag                                                                                                 | `1.0.2`                  |
| `image.digest`                       | Image digest                                                                                              | `""`                     |
| `image.pullPolicy`                   | Image pull policy                                                                                         | `IfNotPresent`           |
| `pdb.create`                         | Specifies whether a pod disruption budget should be created                                               | `false`                  |
| `pdb.minAvailable`                   | Minimum number/percentage of pods that should remain scheduled                                            | `1`                      |
| `pdb.maxUnavailable`                 | Maximum number/percentage of pods that may be made unavailable                                            | `nil`                    |
| `serviceAccount.create`              | Specifies whether a service account should be created                                                     | `true`                   |
| `serviceAccount.annotations`         | Service account annotations                                                                               | `{}`                     |
| `serviceAccount.name`                | The name of the service account to use (Generated using the `mongo-express.fullname` template if not set) | `nil`                    |
| `deploymentAnnotations`              | Additional deployment annotations                                                                         | `{}`                     |
| `podAnnotations`                     | Additional pod annotations                                                                                | `{}`                     |
| `podLabels`                          | Additional pod labels                                                                                     | `{}`                     |
| `podSecurityContext`                 | Pod security context                                                                                      | `{}`                     |
| `priorityClassName`                  | Priority class name                                                                                       | `nil`                    |
| `runtimeClassName`                   | Runtime class name                                                                                        | `""`                     |
| `topologySpreadConstraints`          | Topology Spread Constraints for pod assignment                                                            | `[]`                     |
| `securityContext`                    | Container security context                                                                                | `{}`                     |
| `containerPorts.http`                | Container port for HTTP                                                                                   | `8081`                   |
| `livenessProbe.enabled`              | Enable liveness probe                                                                                     | `true`                   |
| `livenessProbe.initialDelaySeconds`  | Delay before the liveness probe is initiated                                                              | `0`                      |
| `livenessProbe.periodSeconds`        | How often to perform the liveness probe                                                                   | `10`                     |
| `livenessProbe.timeoutSeconds`       | When the liveness probe times out                                                                         | `1`                      |
| `livenessProbe.failureThreshold`     | Minimum consecutive failures for the liveness probe to be considered failed after having succeeded        | `3`                      |
| `livenessProbe.successThreshold`     | Minimum consecutive successes for the liveness probe to be considered successful after having failed      | `1`                      |
| `readinessProbe.enabled`             | Enable readiness probe                                                                                    | `true`                   |
| `readinessProbe.initialDelaySeconds` | Delay before the readiness probe is initiated                                                             | `0`                      |
| `readinessProbe.periodSeconds`       | How often to perform the readiness probe                                                                  | `10`                     |
| `readinessProbe.timeoutSeconds`      | When the readiness probe times out                                                                        | `1`                      |
| `readinessProbe.failureThreshold`    | Minimum consecutive failures for the readiness probe to be considered failed after having succeeded       | `3`                      |
| `readinessProbe.successThreshold`    | Minimum consecutive successes for the readiness probe to be considered successful after having failed     | `1`                      |
| `startupProbe.enabled`               | Enable startup probe                                                                                      | `false`                  |
| `startupProbe.initialDelaySeconds`   | Delay before the startup probe is initiated                                                               | `0`                      |
| `startupProbe.periodSeconds`         | How often to perform the startup probe                                                                    | `10`                     |
| `startupProbe.timeoutSeconds`        | When the startup probe times out                                                                          | `1`                      |
| `startupProbe.failureThreshold`      | Minimum consecutive failures for the startup probe to be considered failed after having succeeded         | `3`                      |
| `startupProbe.successThreshold`      | Minimum consecutive successes for the startup probe to be considered successful after having failed       | `1`                      |
| `service.annotations`                | Service annotations                                                                                       | `{}`                     |
| `service.type`                       | Service type                                                                                              | `ClusterIP`              |
| `service.clusterIP`                  | Static cluster IP address or None for headless service when service type is ClusterIP                     | `nil`                    |
| `service.loadBalancerIP`             | Static load balancer IP address when service type is LoadBalancer                                         | `nil`                    |
| `service.loadBalancerSourceRanges`   | Source IP address ranges when service type is LoadBalancer                                                | `nil`                    |
| `service.externalTrafficPolicy`      | External traffic routing policy when service type is LoadBalancer or NodePort                             | `Cluster`                |
| `service.ports.http`                 | Service port for HTTP                                                                                     | `8081`                   |
| `service.nodePorts.http`             | Service node port for HTTP when service type is LoadBalancer or NodePort                                  | `nil`                    |
| `ingress.enabled`                    | Enable ingress controller resource                                                                        | `false`                  |
| `ingress.ingressClassName`           | IngressClass that will be be used to implement the Ingress                                                | `""`                     |
| `ingress.pathType`                   | Ingress path type                                                                                         | `ImplementationSpecific` |
| `ingress.annotations`                | Ingress annotations                                                                                       | `{}`                     |
| `ingress.hosts[0].host`              | Hostname to your Mongo Express installation                                                               | `mongo-express.local`    |
| `ingress.hosts[0].paths`             | Paths within the url structure                                                                            | `["/"]`                  |
| `ingress.tls`                        | TLS configuration                                                                                         | `[]`                     |
| `resources`                          | CPU/Memory resource requests/limits                                                                       | `{}`                     |
| `nodeSelector`                       | Node labels for pod assignment                                                                            | `{}`                     |
| `tolerations`                        | Tolerations for pod assignment                                                                            | `[]`                     |
| `affinity`                           | Map of node/pod affinities                                                                                | `{}`                     |
| `extraArgs`                          | Additional container arguments                                                                            | `{}`                     |
| `extraEnvVars`                       | Additional container environment variables                                                                | `[]`                     |
| `extraEnvVarsCM`                     | Name of existing ConfigMap containing additional container environment variables                          | `nil`                    |
| `extraEnvVarsSecret`                 | Name of existing Secret containing additional container environment variables                             | `nil`                    |

### Config parameters

| Name                                    | Description                                                                                                                       | Default                  |
| --------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------- | ------------------------ |
| `mongodbServer`                         | MongoDB host name or IP address                                                                                                   | `mongodb`                |
| `mongodbPort`                           | MongoDB port                                                                                                                      | `27017`                  |
| `mongodbEnableAdmin`                    | Enable administrator access                                                                                                       | `false`                  |
| `mongodbAdminUsername`                  | Administrator username                                                                                                            | `root`                   |
| `mongodbAdminPassword`                  | Administrator password                                                                                                            | `""`                     |
| `mongodbAuthUsername`                   | Database username (only needed if `mongodbEnableAdmin` is `false`)                                                                | `""`                     |
| `mongodbAuthPassword`                   | Database password (only needed if `mongodbEnableAdmin` is `false`)                                                                | `""`                     |
| `mongodbAuthDatabase`                   | Database name (only needed if `mongodbEnableAdmin` is `false`)                                                                    | `""`                     |
| `siteBaseUrl`                           | Set the express baseUrl to ease mounting at a subdirectory                                                                        | `/`                      |
| `siteCookieSecret`                      | String used by cookie-parser middleware to sign cookies (Random 32 character long alphanumeric string if not set)                 | `""`                     |
| `siteSessionSecret`                     | String used to sign the session ID cookie by express-session middleware (Random 32 character long alphanumeric string if not set) | `""`                     |
| `basicAuthUsername`                     | Mongo Express web login name                                                                                                      | `""`                     |
| `basicAuthPassword`                     | Mongo Express web login password                                                                                                  | `""`                     |
| `existingSecret`                        | Name of existing Secret to use                                                                                                    | `""`                     |
| `existingSecretKeyMongodbAdminPassword` | Key in existing Secret that contains administrator password                                                                       | `mongodb-admin-password` |
| `existingSecretKeyMongodbAuthPassword`  | Key in existing Secret that contains database password                                                                            | `mongodb-auth-password`  |
| `existingSecretKeySiteCookieSecret`     | Key in existing Secret that contains string used by cookie-parser middleware to sign cookies                                      | `site-cookie-secret`     |
| `existingSecretKeySiteSessionSecret`    | Key in existing Secret that contains string used to sign the session ID cookie by express-session middleware                      | `site-session-secret`    |
| `existingSecretKeyBasicAuthPassword`    | Key in existing Secret that contains Mongo Express web login password                                                             | `basic-auth-password`    |

### MongoDB parameters

| Name              | Description                                                  | Default |
| ----------------- | ------------------------------------------------------------ | ------- |
| `mongodb.enabled` | Whether to use the MongoDB chart (for testing purposes only) | `false` |

### Tests parameters

| Name                     | Description       | Default              |
| ------------------------ | ----------------- | -------------------- |
| `tests.image.registry`   | Image registry    | `ghcr.io`            |
| `tests.image.repository` | Image repository  | `cowboysysop/pytest` |
| `tests.image.tag`        | Image tag         | `1.0.41`             |
| `tests.image.digest`     | Image digest      | `""`                 |
| `tests.image.pullPolicy` | Image pull policy | `IfNotPresent`       |

## Setting parameters

Specify the parameters you which to customize using the `--set` argument to the `helm install` command. For instance,

```bash
$ helm install my-release \
    --set nameOverride=my-name cowboysysop/mongo-express
```

The above command sets the `nameOverride` to `my-name`.

Alternatively, a YAML file that specifies the values for the above parameters can be provided while installing the chart. For example,

```bash
$ helm install my-release \
    --values values.yaml cowboysysop/mongo-express
```

**TIP**: You can use the default [values.yaml](values.yaml).