Skip to main content

Upgrading

Before upgrading

Before upgrading, make sure you have backed up your configuration, trusted certificates and data to be able to restore the platform in case of any issues.

Never downgrade the platform version, as it may cause data loss or other issues. Be sure that you are upgrading to higher version of the Helm chart.

Upgrade vs Install

Platform can be installed from scratch anytime when you have a backup of your database and configuration. New installation through the Helm chart will deploy new environment connecting to the same database. You can install multiple instances of the platform in different clusters and infrastructures with the same database.

The following contains important information and instructions about upgrading Helm charts.

Upgrading Helm chart is done by running the helm upgrade command. The command upgrades the platform to the specified version. The command can be used to upgrade the platform to the same version with changed parameters.

To 2.14.0

Breaking changes

This version introduced breaking changes in the configuration of OAuth2 providers and logging that need your attention.

OAuth2 provider configuration

The platform now supports multiple configurations of OAuth2 providers. If you are using the internal Keycloak for authentication (global.keycloak.enabled=true), a different approach must be applied depending on whether you are deploying the platform for the first time or upgrading from a previous version:

DeploymentConfiguration
Fresh installationThe OAuth2 internal provider is automatically configured. No manual changes are required.
Upgrade from previous versionThe OAuth2 internal provider is automatically configured. However, changes to the OAuth2 Keycloak client configuration must be applied manually. For a convenient upgrade, use the provided Python script update_realm_from_2.7.0_to_2.14.0.py. The script will prompt you for the required parameters and update the Keycloak client configuration. It also serves as a guide and documentation for the necessary changes.

Logging configuration

The logging was updated to support structured records and better integration with the logging infrastructure. The previous implementation of audit logs was removed and replaced with the new implementation.

Audit logs

It is recommended to create a backup or export of all audit logs you want to keep before upgrading to this version. The audit logs are reset during the upgrade.

The logging.audit.enabled parameter was removed. The audit logs are now configured in the platform. For more information on logging and how to configure it, see the Logging section in the documentation.

Changed parameters

The following parameters were changed or removed. Please update your configuration accordingly:

  • Configuration of header names and OIDC for API gateway is removed in favor of the new OAuth2 provider configuration. Particularly, the auth, oidc, and hostAliases parameters were removed from the apiGateway section and are not supported anymore.
  • The certification authentication header name was changed from default X-APP-CERTIFICATE to ssl-client-cert in the auth.header.certificate parameter. Be sure to update your configuration if you are using the certificate-based authentication and terminate the SSL connection outside the platform.

To 2.13.1

Added support for custom command and args for the containers. The following parameters were added to the umbrella chart and all sub-charts:

# custom command and args
command: []
args: []

Removed deprecated sub-charts

Deprecated sub-charts were removed:

  • MS ADCS Connector
  • API Gateway HAProxy

You can remove the deprecated dependencies from the umbrella chart, if they are still used (they will not be applied anymore):

msAdcsConnector:
nameOverride: ms-adcs-connector
enabled: false

To 2.13.0

Additional connector sub-charts

The following sub-charts were added to support additional connectors as optional components:

  • CT Logs Discovery Provider

When you enable new connector during upgrade, you need to register the connector manually in the platform:

ctLogsDiscoveryProvider:
enabled: false

To 2.11.0-1

Additional connector sub-charts

The following sub-charts were added to support additional connectors as optional components:

  • HashiCorp Vault Connector

When you enable new connector during upgrade, you need to register the connector manually in the platform:

hashicorpVaultConnector:
enabled: false

See the CZERTAINLY Helm chart 2.11.0-1 release notes for more information.

To 2.11.0

New PyADCS connector

To resolve compatibility issues and improve performance of the ADCS certificate related operations and authentication, the new ADCS connector was introduced based on Python technology. MS ADCS connector is considered from this version as deprecated and will be removed in the future.

When you enable PyADCS connector during upgrade, you need to register the connector manually in the platform:

pyAdcsConnector:
enabled: true

See the CZERTAINLY Helm chart 2.11.0 release notes for more information.

To 2.9.0

Persistent volume provisioner

This version introduced requirement for the persistent volume provisioner support in the underlying infrastructure. The StorageClass is required to be available in the cluster. The volumes are dynamically provisioned by default, but it can be changed by setting existing persistent volume claim or disabling persistence (which will use emptyDir volume).

The list of components that need persistence can be found in the Overview - Persistence section.

Persistent volume claim

The provisioner of the persistent volume must be properly configured to upgrade the platform, in case the dynamic storage should be created. In case the dynamic provisioning is not enabled, the persistent volume claim must be created manually before upgrading the platform. Form more information see Dynamic Volume Provisioning.

Container image configuration and repository

To support multiple container registries, including better support for privately managed registries, where there are different naming conventions and images are organized in projects, we have split image repository property to repository and name.

This allows to control the repository name using the global configuration, providing better support for private repositories with different organization of images and repositories. For example the following values:

global:
image:
registry: myregistry.com
repository: czertainly/project

image:
# default registry name
registry: docker.io
repository: 3keycompany
name: czertainly-core
tag: 2.9.0

will result in the following image name: myregistry.com/czertainly/project/czertainly-core:2.9.0.

Customization of the deployment

The deployment of the platform can be customized using the following parameters:

initContainers: []
sidecarContainers: []
additionalVolumes: []
additionalVolumeMounts: []
additionalPorts: []
additionalEnv:
variables: []
configMaps: []
secrets: []

When the parameters are set globally, they are applied to all charts and sub-charts. When the parameters are set for specific chart or sub-chart, they are applied only to the sub-chart. If they global and local parameters are defined, they are merged together.

To 2.8.0

Using NodePort to access the platform should be configured on API Gateway level, not for the Core service (as a service in czertainly chart). The nodePort parameter is included for both admin and consumer service in api-gateway-kong sub-chart. The proper way to configure NodePort is:

ingress:
# disable ingress as we are going to use direct access to the platform
enabled: false

apiGateway:
service:
# use NodePort to access the platform
type: "NodePort"
consumer:
port: 8000
nodePort: 30080
admin:
port: 8001
nodePort: 30081

See the CZERTAINLY Helm chart 2.8.0 release notes for more information.

To 2.7.1

Enabling Utils Service

Enabling parameter of Utils Service was moved from the utilsService.enabled to global parameters:

global:
utils:
enabled: false

See the CZERTAINLY Helm chart 2.7.1 release notes for more information.

To 2.7.0

Cleanup of the global parameters

The global parameters were cleaned up and reorganized.

The following default parameters were removed. They must be explicitly set now in the values, if you want to use them. Check your current configuration and update it accordingly:

global:
database:
type: ""
host: ""
port: ""
name: ""
username: ""
password: ""
trusted:
certificates: ""

Hostname was introduced as a global parameter that can be shared across the deployment. The main reason is optional implementation of the internal Keycloak service that requires to know the hostname of the platform to properly set URLs:

global:
hostName: ""

Administrator registration information is introduced as global parameters. This allows to share for example the same data with internal Keycloak, if enabled. If you want to keep the client certificate-based authentication for administrator, configure certificate in the registerAdmin.admin.certificate parameter:

global:
admin:
username: ""
password: ""
name: ""
surname: ""
email: ""

Be aware that you can always enable auto-provisioning of the users with JSON ID using the following parameter:

authService:
createUnknownUsers: "true"
createUnknownRoles: "true"

Hardening of the deployment

The deployment was hardened to be more secure and stable. The following changes were made for every container:

  • running as non-root user
  • running with read-only root filesystem
  • specified default securityContext
  • added configuration and default values for livenessProbe, readinessProbe and startupProbe
  • added configuration for resource limits and requests

Optional services

New optional services were added to the umbrella chart:

  • Keycloak internal service
  • Utils service

Keycloak internal service is disabled by default and can be enabled by setting the following values:

global:
keycloak:
enabled: true
# client secret must be set if keycloak is enabled
clientSecret: ""

Utils service is disabled by default and can be enabled by setting the following values:

utilsService:
enabled: false

See the CZERTAINLY Helm chart 2.7.0 release notes for more information.

To 2.6.0

ACME endpoint and trusted IPs

The API gateway sub-chart was updated to support ACME endpoint and trusted IPs. Trusted IP addresses defines blocks that are known to send correct X-Forwarded-* headers which is important to generate correct URLs for the clients communicating with the platform behind gateway and proxy.

Trusted IP addresses can be configured in the API gateway dependency for the umbrella:

apiGateway:
trustedIps: ""

Additional connector sub-charts

The Software Cryptography Provider connector was added as sub-chart to the umbrella chart.

When you enable new connector during upgrade, you need to register the connector manually in the platform:

softwareCryptographyProvider:
enabled: false

See the CZERTAINLY Helm chart 2.6.0 release notes for more information.

To 2.5.2

Container image configuration

Configuration of container registry has changed. The new configuration is more flexible and allows to use multiple container registries, including configuration of registry globally.

Every image that is supported in the umbrella chart or sub-charts now has the following structure:

image:
# default registry name
registry: docker.io
# default repository name
repository: 3keycompany/czertainly-core
# default image tag
tag: "2.5.2"
# the digest to be used instead of the tag, will override tag if specified
digest: ""
# default image pull policy
pullPolicy: IfNotPresent
# array of image pull secrets
pullSecrets: []

Container registry and image pull secrets can be also configured globally for the umbrella chart and all of its sub-charts using global parameters, for example:

global:
image:
# registry name
registry: "harbor.czertainly.online"
# array of secret names
pullSecrets:
- harbor-registry-credentials
- dockerhub-registry-credentials

Additional connector sub-charts

The following sub-charts were added to support additional connectors as optional components:

  • Cryptosense Discovery Provider
  • Network Discovery Provider
  • Keystore Entity Provider

When you enable new connector during upgrade, you need to register the connector manually in the platform:

cryptosenseDiscoveryProvider:
enabled: false

networkDiscoveryProvider:
enabled: false

keystoreEntityProvider:
enabled: false

See the CZERTAINLY Helm chart 2.5.2 release notes for more information.