# ${docGenStepName} ## ${docGenDescription} ## Prerequisites * **[Change Management Client 2.0.0 or compatible version](http://central.maven.org/maven2/com/sap/devops/cmclient/dist.cli/)** - available for download on Maven Central. **Note:** This is only required if you don't use a Docker-based environment. * Solution Manager version `ST720 SP08` or newer. ## ${docGenParameters} ## ${docGenConfiguration} ## ${docJenkinsPluginDependencies} The step is configured using a customer configuration file provided as resource in an custom shared library. ```groovy @Library('piper-lib-os@master') _ // the shared lib containing the additional configuration // needs to be configured in Jenkins @Library('foo@master') __ // inside the shared lib denoted by 'foo' the additional configuration file // needs to be located under 'resources' ('resoures/myConfig.yml') prepareDefaultValues script: this, customDefaults: 'myConfig.yml' ``` Example content of `'resources/myConfig.yml'` in branch `'master'` of the repository denoted by `'foo'`: ```yaml general: changeManagement: changeDocumentLabel: 'ChangeDocument\s?:' cmClientOpts: '-Djavax.net.ssl.trustStore=' credentialsId: 'CM' type: 'SOLMAN' endpoint: 'https://example.org/cm' git: from: 'HEAD~1' to: 'HEAD' format: '%b' ``` The properties configured in section `'general/changeManagement'` are shared between all change managment related steps. The properties can also be configured on a per-step basis: ```yaml [...] steps: transportRequestCreate: changeManagement: type: 'SOLMAN' endpoint: 'https://example.org/cm' [...] ``` The parameters can also be provided when the step is invoked. For examples see below. ## Return value none ## Exceptions * `AbortException`: * If the creation of the transport request fails. * `IllegalStateException`: * If the change id is not provided. ## Example ```groovy // SOLMAN def transportRequestId = transportRequestCreate script:this, changeDocumentId: '001,' changeManagement: [ type: 'SOLMAN' endpoint: 'https://example.org/cm' ] // CTS def transportRequestId = transportRequestCreate script:this, transportType: 'W', targetSystem: 'XYZ', description: 'the description', changeManagement: [ type: 'CTS' endpoint: 'https://example.org/cm' ] ```