{
	"kind": "Template",
	"apiVersion": "template.openshift.io/v1",
	"metadata": {
		"name": "mariadb-persistent",
		"creationTimestamp": null,
		"annotations": {
			"description": "MariaDB database service, with persistent storage. For more information about using this template, including OpenShift considerations, see https://github.com/sclorg/mariadb-container/blob/master/10.3/root/usr/share/container-scripts/mysql/README.md.\n\nNOTE: Scaling to more than one replica is not supported. You must have persistent volumes available in your cluster to use this template.",
			"iconClass": "icon-mariadb",
			"openshift.io/display-name": "MariaDB",
			"openshift.io/documentation-url": "https://github.com/sclorg/mariadb-container/blob/master/10.3/root/usr/share/container-scripts/mysql/README.md",
			"openshift.io/long-description": "This template provides a standalone MariaDB server with a database created.  The database is stored on persistent storage.  The database name, username, and password are chosen via parameters when provisioning this service.",
			"openshift.io/provider-display-name": "Red Hat, Inc.",
			"openshift.io/support-url": "https://access.redhat.com",
			"tags": "database,mariadb"
		}
	},
	"message": "The following service(s) have been created in your project: ${DATABASE_SERVICE_NAME}.\n\n       Username: ${MYSQL_USER}\n       Password: ${MYSQL_PASSWORD}\n  Database Name: ${MYSQL_DATABASE}\n Connection URL: mysql://${DATABASE_SERVICE_NAME}:3306/\n\nFor more information about using this template, including OpenShift considerations, see https://github.com/sclorg/mariadb-container/blob/master/10.3/root/usr/share/container-scripts/mysql/README.md.",
	"objects": [
		{
			"apiVersion": "v1",
			"kind": "Secret",
			"metadata": {
				"annotations": {
					"template.openshift.io/expose-database_name": "{.data['database-name']}",
					"template.openshift.io/expose-password": "{.data['database-password']}",
					"template.openshift.io/expose-root_password": "{.data['database-root-password']}",
					"template.openshift.io/expose-username": "{.data['database-user']}"
				},
				"name": "${DATABASE_SERVICE_NAME}"
			},
			"stringData": {
				"database-name": "${MYSQL_DATABASE}",
				"database-password": "${MYSQL_PASSWORD}",
				"database-root-password": "${MYSQL_ROOT_PASSWORD}",
				"database-user": "${MYSQL_USER}"
			}
		},
		{
			"apiVersion": "v1",
			"kind": "Service",
			"metadata": {
				"annotations": {
					"template.openshift.io/expose-uri": "mysql://{.spec.clusterIP}:{.spec.ports[?(.name==\"mariadb\")].port}"
				},
				"name": "${DATABASE_SERVICE_NAME}"
			},
			"spec": {
				"ports": [
					{
						"name": "mariadb",
						"port": 3306
					}
				],
				"selector": {
					"name": "${DATABASE_SERVICE_NAME}"
				}
			}
		},
		{
			"apiVersion": "v1",
			"kind": "PersistentVolumeClaim",
			"metadata": {
				"name": "${DATABASE_SERVICE_NAME}"
			},
			"spec": {
				"accessModes": [
					"ReadWriteOnce"
				],
				"resources": {
					"requests": {
						"storage": "${VOLUME_CAPACITY}"
					}
				}
			}
		},
		{
			"apiVersion": "apps/v1",
			"kind": "Deployment",
			"metadata": {
				"annotations": {
					"image.openshift.io/triggers": "[{\"from\":{\"kind\":\"ImageStreamTag\",\"name\":\"mariadb:${MARIADB_VERSION}\"},\"fieldPath\": \"spec.template.spec.containers[0].image\"}]",
					"template.alpha.openshift.io/wait-for-ready": "true"
				},
				"name": "${DATABASE_SERVICE_NAME}"
			},
			"spec": {
				"replicas": 1,
				"selector": {
					"matchLabels": {
						"name": "${DATABASE_SERVICE_NAME}"
					}
				},
				"strategy": {
					"type": "Recreate"
				},
				"template": {
					"metadata": {
						"labels": {
							"name": "${DATABASE_SERVICE_NAME}"
						}
					},
					"spec": {
						"containers": [
							{
								"env": [
									{
										"name": "MYSQL_USER",
										"valueFrom": {
											"secretKeyRef": {
												"key": "database-user",
												"name": "${DATABASE_SERVICE_NAME}"
											}
										}
									},
									{
										"name": "MYSQL_PASSWORD",
										"valueFrom": {
											"secretKeyRef": {
												"key": "database-password",
												"name": "${DATABASE_SERVICE_NAME}"
											}
										}
									},
									{
										"name": "MYSQL_ROOT_PASSWORD",
										"valueFrom": {
											"secretKeyRef": {
												"key": "database-root-password",
												"name": "${DATABASE_SERVICE_NAME}"
											}
										}
									},
									{
										"name": "MYSQL_DATABASE",
										"valueFrom": {
											"secretKeyRef": {
												"key": "database-name",
												"name": "${DATABASE_SERVICE_NAME}"
											}
										}
									}
								],
								"image": " ",
								"imagePullPolicy": "IfNotPresent",
								"livenessProbe": {
									"exec": {
										"command": [
											"/bin/sh",
											"-i",
											"-c",
											"MYSQL_PWD=\"$MYSQL_PASSWORD\" mysqladmin -u $MYSQL_USER ping"
										]
									},
									"initialDelaySeconds": 30,
									"timeoutSeconds": 1
								},
								"name": "mariadb",
								"ports": [
									{
										"containerPort": 3306
									}
								],
								"readinessProbe": {
									"exec": {
										"command": [
											"/bin/sh",
											"-i",
											"-c",
											"MYSQL_PWD=\"$MYSQL_PASSWORD\" mysqladmin -u $MYSQL_USER ping"
										]
									},
									"initialDelaySeconds": 5,
									"timeoutSeconds": 1
								},
								"resources": {
									"limits": {
										"memory": "${MEMORY_LIMIT}"
									}
								},
								"volumeMounts": [
									{
										"mountPath": "/var/lib/mysql/data",
										"name": "${DATABASE_SERVICE_NAME}-data"
									}
								]
							}
						],
						"volumes": [
							{
								"name": "${DATABASE_SERVICE_NAME}-data",
								"persistentVolumeClaim": {
									"claimName": "${DATABASE_SERVICE_NAME}"
								}
							}
						]
					}
				}
			}
		}
	],
	"parameters": [
		{
			"name": "MEMORY_LIMIT",
			"displayName": "Memory Limit",
			"description": "Maximum amount of memory the container can use.",
			"value": "512Mi",
			"required": true
		},
		{
			"name": "NAMESPACE",
			"displayName": "Namespace",
			"description": "The OpenShift Namespace where the ImageStream resides.",
			"value": "openshift"
		},
		{
			"name": "DATABASE_SERVICE_NAME",
			"displayName": "Database Service Name",
			"description": "The name of the OpenShift Service exposed for the database.",
			"value": "mariadb",
			"required": true
		},
		{
			"name": "MYSQL_USER",
			"displayName": "MariaDB Connection Username",
			"description": "Username for MariaDB user that will be used for accessing the database.",
			"generate": "expression",
			"from": "user[A-Z0-9]{3}",
			"required": true
		},
		{
			"name": "MYSQL_PASSWORD",
			"displayName": "MariaDB Connection Password",
			"description": "Password for the MariaDB connection user.",
			"generate": "expression",
			"from": "[a-zA-Z0-9]{16}",
			"required": true
		},
		{
			"name": "MYSQL_ROOT_PASSWORD",
			"displayName": "MariaDB root Password",
			"description": "Password for the MariaDB root user.",
			"generate": "expression",
			"from": "[a-zA-Z0-9]{16}",
			"required": true
		},
		{
			"name": "MYSQL_DATABASE",
			"displayName": "MariaDB Database Name",
			"description": "Name of the MariaDB database accessed.",
			"value": "sampledb",
			"required": true
		},
		{
			"name": "MARIADB_VERSION",
			"displayName": "Version of MariaDB Image",
			"description": "Version of MariaDB image to be used (10.3-el7, 10.3-el8, or latest).",
			"value": "10.3-el8",
			"required": true
		},
		{
			"name": "VOLUME_CAPACITY",
			"displayName": "Volume Capacity",
			"description": "Volume space available for data, e.g. 512Mi, 2Gi.",
			"value": "1Gi",
			"required": true
		}
	],
	"labels": {
		"app.openshift.io/runtime": "mariadb",
		"template": "mariadb-persistent-template"
	}
}