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.
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
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:
Deployment | Configuration |
---|---|
Fresh installation | The OAuth2 internal provider is automatically configured. No manual changes are required. |
Upgrade from previous version | The 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.
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
, andhostAliases
parameters were removed from theapiGateway
section and are not supported anymore. - The certification authentication header name was changed from default
X-APP-CERTIFICATE
tossl-client-cert
in theauth.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.
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
andstartupProbe
- 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.