Migration
This page describes how to update Valtimo from the previous version to the current.
MySQL 5.7 end of life
Scope: Backend
Now that the extended support for MySQL 5.7 is ending, it is recommended to upgrade any MySQL database to MySQL 8 or higher. More information here.
Java 17
Scope: Backend
In order to run Valtimo a Java 17 environment must be used. The way to configure this is different per implementation. For example, the Java version used when gradle with gradle can be set like this:
Also make sure that when building to a docker container a base image is used that supports Java 17.
View configurator
Scope: Backend
The view configurator module has been removed. This module has not been supported by the front-end since Valtimo 5 and any implementation that has this on the classpath can remove this module. Any implementation that has had this module on the classpath can run this database script for MySQL or PostgreSQL to clean up the database.
Process data object relation
Scope: Backend
Process data object relations have been removed. Any implementation that has entities that extend the
IProcessDataObject
class are to remove this interface and store the data in their document definition instead. This data can be the entity or a reference to the entity, and has to be migrated before upgrading to this version of Valtimo.Additionally, the following database script should be used for MySQL or PostgreSQL to clean up the database.
Angular upgrade
Scope: Frontend
In order to use the new front-end libraries based on Angular version 14 in an implementation, run the following command in the root of the implementation project:
ng update @angular/core@14 @angular/cli@14
Dependency upgrades
Scope: Frontend
In order to use the front-end libraries with upgraded dependencies, make sure to first upgrade your implementation to Angular 14 by following the steps mentioned on this page.
Redundant stylesheets
Next, you might have to delete the following lines from the
styles
array inangular.json
in the root of your implementation:"node_modules/dmn-js/dist/assets/dmn-font/css/animation.css"
"node_modules/dmn-js/dist/assets/dmn-font/css/dmn-ie7.css"
"node_modules/dmn-js/dist/assets/dmn-font/css/dmn-ie7-codes.css"
New required dependency
Scope: Front-end
ngx-translate-multi-http-loader
requires a new dependency. Run the following command in the root of the implementation project:npm i deepmerge-ts
.Matching dependencies
Then, make sure the following dependencies in
package.json
in the root of your implementation have the following versions:package.json
Note: if your implementation has any dependencies not included in the above example, and installing dependencies or building your application causes errors, make sure the versions of these dependencies match the versions in this release of
valtimo-frontend-libraries
.Translate loader upgrade
ngx-translate-multi-http-loader
has been upgraded from version 7 to version 9. This upgrade requires adjustments in implementations of Valtimo:HttpClient
needs to be replaced byHttpBackend
in thedeps
of theloader
ofTranslateModule
.app.module.ts.ts
If your implementation uses custom translation resources, these need to be adjusted in the environment file of your implementation. The environment property
translationResources
no longer accepts an array ofITranslationResource
, but an array of strings. The propertiesprefix
andsuffix
are now redundant. For example, if the previous value in your environment file was[{prefix: 'src/assets/translation', suffix: 'json'}]
, it should now be['src/assets/translation']
.Migrating from
Protractor
toCypress
Support for
Protractor
(an end-to-end testing framework) in the Angular CLI will be discontinued. Either removeProtractor
from your implementation, or migrate to Cypress by following this guide. The latter is recommended.REST API versioning
Scope: Front-end and back-end
Versioning has been introduced for every REST endpoint exposed by Valtimo. If your implementation manually makes calls to currently existing Valtimo endpoints, these will have to be changed, e.g.
/api/document
becomes/api/v1/document
.Auth0 removed as authentication provider
Scope: Front-end
As of major version 10, Auth0 is no longer supported as an authentication provider. In order to adjust your implementation remove the dependencies
@auth0/angular-jwt
and@valtimo/auth0
. Also, remove the filesauth0-config.dev.ts
,auth0-config.prod.ts
andauth0-config.test.ts
fromsrc/environments/auth
if they exist. Lastly, make sure none of the environment files in your implementation use Auth0 under the keyauthentication
.Removed deprecated code
Scope: Back-end
The following table shows the methods that were removed, and which methods should be used instead:
ValtimoUser
ValtimoUser(String, String, String, String, String, String, String, boolean, String, boolean, boolean, List<String>)
-
Use ValtimoUserBuilder
instead
QueryDialectHelper
getJsonValueExpression(CriteriaBuilder, Path, String)
getJsonValueExpression(CriteriaBuilder, Path, String, Class)
Classes that implement this method have also had this method removed.
FormFieldDataResolver
supports(ExternalFormFieldType)
supports(String)
Classes that implement this method have also had this method removed.
AuthorityCreatedEvent
AuthorityCreatedEvent(UUID, String, LocalDateTime, String, String, Boolean, Money)
AuthorityCreatedEvent(UUID, String, LocalDateTime, String, String, Boolean)
Hourly rates were removed.
AuthorityDeletedEvent
AuthorityDeletedEvent(UUID, String, LocalDateTime, String, String, Boolean, Money)
AuthorityDeletedEvent(UUID, String, LocalDateTime, String, String, Boolean)
Hourly rates were removed.
AuthorityEvent
AuthorityEvent(UUID, String, LocalDateTime, String, String, Boolean, Money)
AuthorityEvent(UUID, String, LocalDateTime, String, String, Boolean)
Hourly rates were removed.
AuthorityNameChangedEvent
AuthorityNameChangedEvent(UUID, String, LocalDateTime, String, String, Boolean, Money, String)
AuthorityNameChangedEvent(UUID, String, LocalDateTime, String, String, Boolean, String)
Hourly rates were removed.
Authority
Authority(String, BigDecimal, boolean)
Authority(String, boolean)
Hourly rates were removed.
AuthorityRequest
AuthorityRequest(String, BigDecimal)
AuthorityRequest(String)
Hourly rates were removed.
FormFileResource
uploadFile(String, MultipartFile)
uploadFile(String, String, MultipartFile)
-
FormAssociationService
getPreFilledFormDefinitionByFormLinkId(Document.Id, String, String, String)
getPreFilledFormDefinitionByFormLinkId(String, String, Optional<Document.Id>, Optional<String>)
-
BlacklistRepository
findByEmailAddress(String)
existsById(String)
-
BlacklistService
blacklist(EmailAddress, String)
blacklist(String, LocalDateTime, String)
-
DocumentenService
createObjectInformatieObject(URI, UUID, String)
createObjectInformatieObject(URI, UUID)
-
DocumentDefinitionProcessLinkService
getDocumentDefinitionProcess(String)
getDocumentDefinitionProcessList(String)
-
DocumentDefinitionProcessLinkService
getDocumentDefinitionProcessLink(String)
getDocumentDefinitionProcessLink(String, String)
-
In addition to this, the following classes were removed. No replacements were added as these should not be used.
AuthorityHourlyRateChangedEvent
Hourly rates were removed.
ExternalFormFieldType
Enum was removed to increase extendability. See here for a list of external form fields.
Carbon design system
Scope: Front-end
The user interface of Valtimo will now use the Carbon design system. In order to make this work in your implementation, first make sure the
@valtimo/*
dependencies inpackage.json
are version 10 or higher and runnpm install
. Yournode_modules
folder should now include the packages@carbon/icons
,carbon-components
andcarbon-components-angular
.Next, add the follow entries to the end of the
styles
array inangular.json
in your project root:"node_modules/@valtimo/components/assets/css/carbon.scss"
and"node_modules/@valtimo/components/assets/css/carbon-beagle-compatibility.scss"
.The environment files (of type
ValtimoConfig
) now support an entryapplicationTitle
. This can be left empty and defaults to Valtimo. If another value is specified, the page titles, tab titles and breadcrumbs will make use of this new title.The logos of implementations are now specified through a Base64 string in the environment file, either under the key
logoSvgBase64
orlogoPngBase64
, which means the logo can either be in the.png
format or the.svg
format, encoded in Base64.To use your own logo, first make sure to resize it to an optimal resolution if it's a
.png
file (a height of about 30px is recommended). If it is a.svg
image, you might want to make use of an optimization tool to reduce its file size and complexity.Next, create a file in the same folder as your environment files:
logo.ts
. From this file, export a string containing your base64 encoded logo. Use this page to encode.svg
to a Base64 string. Use this page to encode.png
to Base64. Make sure the option 'Plain text -- just the Base64' value is selected. The resulting Base64 string should not be prefixed withdata:
.Finally, import this string value containing a Base64 image in your environment file and specify it under the key
logoSvgBase64
for.svg
images, or under the keylogoPngBase64
for.png
images.The functionality to highlight the active menu item in the Carbon sidebar depends on the
sequence
numbers of the menu items undermenu.menuItems
in your environment file(s). Make sure the sequence numbers of menu items, and child menu items, are consecutive. No menu items on the same level should have the same sequence numbers
Last updated