Upgrading from 4.0.x to 4.0.5
How to upgrade
Compared to previous versions, IBM Industry Solutions Workbench provides now a schema registry integration for managing event payloads. After upgrading from 4.0.x to 4.1.0, you have the chance to migrate your existing projects, to use schemas in event payloads as well.
System requirements and third-party components
IBM Industry Solutions Workbench 4.0.5 supports OpenShift 4.12. We strongly recommend to upgrade your OpenShift cluster to that version before upgrading IBM Industry Solutions Workbench.
Additionally, a running instance of Red Hat Integration - Service Registry is required now. You can check the updated
system requirements here. We also provide
an installation manual. After installing the Service Registry, you need to
configure the k5-schema-registry-binding
to connect it to IBM Industry Solutions Workbench. All information for configuring can be
found here. Additionally the Schema Registry must be configured
for you k5projects here.
Adjust your existing deployment targets
In order to setup the schema registry integration properly for your deployment targets, make sure the secrets k5-schema-registry-binding
and k5-schema-registry-oauth-secret
are defined as described in k5-project configuration
Java pro-code
Dependency update
Java pro-code uses several functionalities provided by the dependency "cp-framework-sdk", which has been updated to include new fixes, and versions of underlying used dependencies.
All existing Java pro-code projects have to download this new version and migrate to this new version.
Migration steps
Open the Solution Envoy dashboard (you can find the link in Solution Designer on the CI/CD page after you have set up at least one deploy pipeline or inside Solution Hub after selecting a k5-project and opening the tab "Service Deployments")
Navigate to the Infrastructure page and download all the dependencies listed under Maven Dependencies (Java)
Install dependencies in the local maven repository. Below is an example how the dependencies can be installed via maven
mvn install:install-file -Dfile=cp-framework-sdk-autoconfiguration-4.0.219.jar -DpomFile=cp-framework-sdk-autoconfiguration-4.0.219.pom mvn install:install-file -Dfile=cp-framework-sdk-parent-4.0.219.pom -DpomFile=cp-framework-sdk-parent-4.0.219.pom
Clone / Open your pro-code service project
Navigate to pom.xml file
Search for the parent attribute and change it to match the new "cp-framework-sdk" version, see the following snippet example:
<parent> <groupId>de.knowis.cp.sdk</groupId> <artifactId>cp-framework-sdk-parent</artifactId> <version>4.0.219</version> <relativePath> ./.framework/repo/de/knowis/cp/sdk/cp-framework-sdk-parent/4.0.219/cp-framework-sdk-parent-4.0.219.pom </relativePath> </parent>
NOTE Current latest version of "cp-framework-sdk" that is shipped with the IBM Industry Solutions Workbench 4.1.0 is 4.0.219.
Push your adjustment and run your pipeline(s) to make sure your projects deploy successfully
Adjust your Java low-code projects created with previous versions
Dependency Update
Java low-code uses several functionalities provided by the dependency "cp-framework-sdk", which has been updated to include new fixes, and versions of underlying used dependencies.
All existing Java low-code are required to migrate to this new version.
Migration steps
Clone (
k5 clone
) or update (k5 pull
) your low-code service projectOpen your low-code service project
Navigate to pom.xml file
Search for the parent attribute and change it to match the new "cp-framework-sdk" version, see the following snippet example:
<parent> <groupId>de.knowis.cp.sdk</groupId> <artifactId>cp-framework-managed-sdk-parent</artifactId> <version>4.0.219</version> <relativePath> ./.framework/repo/de/knowis/cp/sdk/cp-framework-managed-sdk-parent/4.0.219/cp-framework-managed-sdk-parent-4.0.219.pom </relativePath> </parent>
NOTE Current latest version of "cp-framework-sdk" that is shipped with the IBM Industry Solutions Workbench 4.1.0 is 4.0.219.
Push your adjustment and run your pipeline(s) to make sure your projects deploy successfully
Adding necessary dependencies and configurations
Open your project in your IDE
Navigate to the pom.xml
Add the dependencies apicurio-registry-serdes-jsonschema-serde which handles the integration with the schema registry, and json-schema-validator which does the json schema validation
<dependency> <groupId>io.apicurio</groupId> <artifactId>apicurio-registry-serdes-jsonschema-serde</artifactId> <version>2.4.1.Final</version> <exclusions> <exclusion> <artifactId>slf4j-jboss-logmanager</artifactId> <groupId>org.jboss.slf4j</groupId> </exclusion> </exclusions> </dependency> <dependency> <groupId>com.networknt</groupId> <artifactId>json-schema-validator</artifactId> <version>1.0.77</version> </dependency>
Add generated-resources to build in your pom.xml so resources inside build should look like:
<resources> <resource> <directory>src/main/filtered</directory> <filtering>true</filtering> </resource> <resource> <directory>src/main/resources</directory> <filtering>false</filtering> </resource> <resource> <directory>src/main/generated-resources</directory> <filtering>false</filtering> </resource> </resources>
Add the jsonschema2pojo plugin to your pom.xml. Please replace yourPackageName and yourProjectAcronym according to your project meta data:
<plugin> <groupId>org.jsonschema2pojo</groupId> <artifactId>jsonschema2pojo-maven-plugin</artifactId> <version>1.1.2</version> <configuration> <sourceDirectory>${basedir}/src/main/generated-resources/schemas</sourceDirectory> <targetPackage>yourPackageName.yourProjectAcronym.sdk.domain.schemas</targetPackage> <outputDirectory>${basedir}/src/main/generated</outputDirectory> </configuration> <executions> <execution> <goals> <goal>generate</goal> </goals> </execution> </executions> </plugin>
Note: After adding the plugin to your pom.xml you have to trigger the code generation using the new plugin. Please execute k5 pull for this or push your changes and clone the project again.For local development using schema registry, please refer to Setup Java local profile
Push the changes and run the pipeline to ensure that the project deploys successfully
Migrate existing low-code projects to use schemas in event payloads
If you have used events in your services, it is possible to migrate your existing events to the new events using schemas.The migration of the events can be processed one by one and you are not forced to do it directly after the installation of 4.0.5. However, it is recommended to do it rather soon as the old event way is deprecated. Please checkout our other documentation articles to learn more about Schemas, Events and Event support 1.0 vs 2.0.
To migrate events in your low-code projects to use schemas instead of entities, please follow the below described procedure.
Create new schema
Open the Schema page in the Solution Designer
Create a new schema containing all the properties needed for the event
Adjust event in producing service
Create a new event for your the use case you want to migrate
Choose a new topic for it (one topic per event is suggested and recommended)
Add your schema as payload of the event
Keep the old event to still support the old behavior
Commit and push changes in Solution Designer
Clone/Pull your project
Implement new publishing logic
Deploy/Release your service by triggering a pipeline
After these steps, your service will now publish the old and the new event.
Adjust agent in the consuming service
Adjust existing event:
Remove the entity payload from the event
Adjust topic binding of the event to use the same one as in the consuming service
Select the new schema as payload for the event
Commit and push changes in Solution Designer
Clone/Pull your project
Adjust agent implementation to deal with the new event payload
Deploy/Release your service by triggering a pipeline
Create a new event:
Create a new event using the same topic binding as in the consuming service
Select the new schema as payload for the event
Create a new agent using the event as trigger event
Delete old event
Commit and push changes in Solution Designer
Clone/Pull your project
Implement agent implementation of the new agent
Cleanup agent implementation of the old agent
Deploy/Release your service by triggering a pipeline
After these steps, your service will now use the new event and no longer the old event.
Cleanup producing service
After you ensured, that all consuming services use the new event, you can delete the old event and deploy your service again.
Keycloak roles
New Keycloak roles sr-admin
, sr-developer
and sr-readonly
were added for managing access to the schema registry.
Users should be granted one of these roles, otherwise schema registry can not be accessed if role-based-authorization is
enabled. See the Configure Users page for a full description of the roles.