2018-09-21 16:55:31 +02:00
|
|
|
import static com.sap.piper.Prerequisites.checkScript
|
|
|
|
|
2018-08-09 11:35:33 +02:00
|
|
|
import com.sap.piper.Utils
|
2018-06-20 11:36:41 +02:00
|
|
|
import groovy.transform.Field
|
|
|
|
|
2019-03-28 10:05:54 +01:00
|
|
|
import com.sap.piper.GenerateDocumentation
|
2018-07-06 09:05:26 +02:00
|
|
|
import com.sap.piper.ConfigurationHelper
|
2018-09-25 09:12:07 +02:00
|
|
|
import com.sap.piper.cm.BackendType
|
2018-06-20 11:36:41 +02:00
|
|
|
import com.sap.piper.cm.ChangeManagement
|
|
|
|
import com.sap.piper.cm.ChangeManagementException
|
|
|
|
|
2018-09-28 14:43:51 +02:00
|
|
|
import static com.sap.piper.cm.StepHelpers.getBackendTypeAndLogInfoIfCMIntegrationDisabled
|
2018-06-20 11:36:41 +02:00
|
|
|
|
2018-09-28 15:54:20 +02:00
|
|
|
import static com.sap.piper.cm.StepHelpers.getChangeDocumentId
|
2018-09-28 14:43:51 +02:00
|
|
|
import hudson.AbortException
|
2018-06-20 11:36:41 +02:00
|
|
|
|
2018-11-29 09:54:05 +01:00
|
|
|
@Field def STEP_NAME = getClass().getName()
|
2018-06-20 11:36:41 +02:00
|
|
|
|
2018-10-25 14:15:11 +02:00
|
|
|
@Field GENERAL_CONFIG_KEYS = STEP_CONFIG_KEYS
|
|
|
|
|
|
|
|
@Field Set STEP_CONFIG_KEYS = [
|
2018-07-17 09:21:56 +02:00
|
|
|
'changeManagement',
|
2019-03-28 10:05:54 +01:00
|
|
|
/**
|
|
|
|
* @see checkChangeInDevelopment
|
|
|
|
* @parentConfigKey changeManagement
|
|
|
|
*/
|
|
|
|
'changeDocumentLabel',
|
|
|
|
/**
|
|
|
|
* Defines where the transport request is created, e.g. SAP Solution Manager, ABAP System.
|
|
|
|
* @parentConfigKey changeManagement
|
|
|
|
* @possibleValues `SOLMAN`, `CTS`, `RFC`
|
|
|
|
*/
|
|
|
|
'type',
|
|
|
|
/**
|
|
|
|
* @see checkChangeInDevelopment
|
|
|
|
* @parentConfigKey changeManagement
|
|
|
|
*/
|
|
|
|
'clientOpts',
|
|
|
|
/**
|
|
|
|
* @see checkChangeInDevelopment
|
|
|
|
* @parentConfigKey changeManagement
|
|
|
|
*/
|
|
|
|
'credentialsId',
|
|
|
|
/**
|
|
|
|
* @see checkChangeInDevelopment
|
|
|
|
* @parentConfigKey changeManagement
|
|
|
|
*/
|
|
|
|
'endpoint',
|
|
|
|
/**
|
|
|
|
* @see checkChangeInDevelopment
|
|
|
|
* @parentConfigKey changeManagement
|
|
|
|
*/
|
|
|
|
'git/from',
|
|
|
|
/**
|
|
|
|
* @see checkChangeInDevelopment
|
|
|
|
* @parentConfigKey changeManagement
|
|
|
|
*/
|
|
|
|
'git/to',
|
|
|
|
/**
|
|
|
|
* @see checkChangeInDevelopment
|
|
|
|
* @parentConfigKey changeManagement
|
|
|
|
*/
|
|
|
|
'git/format',
|
|
|
|
/**
|
|
|
|
* AS ABAP instance number. Only for `RFC`.
|
|
|
|
* @parentConfigKey changeManagement
|
|
|
|
*/
|
|
|
|
'rfc/developmentInstance',
|
|
|
|
/**
|
|
|
|
* AS ABAP client number. Only for `RFC`.
|
|
|
|
* @parentConfigKey changeManagement
|
|
|
|
*/
|
|
|
|
'rfc/developmentClient',
|
|
|
|
/**
|
|
|
|
* The logical system id for which the transport request is created.
|
|
|
|
* The format is `<SID>~<TYPE>(/<CLIENT>)?`. For ABAP Systems the `developmentSystemId`
|
|
|
|
* looks like `DEV~ABAP/100`. For non-ABAP systems the `developmentSystemId` looks like
|
|
|
|
* e.g. `L21~EXT_SRV` or `J01~JAVA`. In case the system type is not known (in the examples
|
|
|
|
* provided here: `EXT_SRV` or `JAVA`) the information can be retrieved from the Solution Manager instance.
|
|
|
|
* Only for `SOLMAN`.
|
|
|
|
*/
|
|
|
|
'developmentSystemId',
|
|
|
|
/**
|
|
|
|
* The description of the transport request. Only for `CTS`.
|
|
|
|
*/
|
|
|
|
'description',
|
|
|
|
/**
|
|
|
|
* The system receiving the transport request. Only for `CTS`.
|
|
|
|
*/
|
|
|
|
'targetSystem',
|
|
|
|
/**
|
|
|
|
* Typically `W` (workbench) or `C` customizing. Only for `CTS`.
|
|
|
|
*/
|
|
|
|
'transportType',
|
|
|
|
/**
|
|
|
|
* Provides additional details. Only for `RFC`.
|
|
|
|
*/
|
|
|
|
'verbose'
|
|
|
|
]
|
|
|
|
|
|
|
|
@Field Set PARAMETER_KEYS = STEP_CONFIG_KEYS.plus([
|
|
|
|
/** The id of the change document to that the transport request is bound to.
|
|
|
|
* Typically this value is provided via commit message in the commit history.
|
|
|
|
* Only for `SOLMAN`.
|
|
|
|
*/
|
|
|
|
'changeDocumentId'
|
|
|
|
])
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates
|
|
|
|
*
|
|
|
|
* * a Transport Request for a Change Document on the Solution Manager (type `SOLMAN`) or
|
|
|
|
* * a Transport Request inside an ABAP system (type`CTS`)
|
|
|
|
*
|
2020-09-24 07:41:06 +02:00
|
|
|
* The id of the transport request is available via [commonPipelineEnvironment.getTransportRequestId()](commonPipelineEnvironment.md)
|
2019-03-28 10:05:54 +01:00
|
|
|
*/
|
|
|
|
@GenerateDocumentation
|
2020-08-26 15:32:58 +02:00
|
|
|
void call(Map parameters = [:]) {
|
2018-06-20 11:36:41 +02:00
|
|
|
|
2018-10-11 09:45:13 +02:00
|
|
|
def transportRequestId
|
|
|
|
|
2018-06-20 11:36:41 +02:00
|
|
|
handlePipelineStepErrors (stepName: STEP_NAME, stepParameters: parameters) {
|
|
|
|
|
2018-10-31 08:40:12 +01:00
|
|
|
def script = checkScript(this, parameters) ?: this
|
2020-08-26 15:32:58 +02:00
|
|
|
String stageName = parameters.stageName ?: env.STAGE_NAME
|
2018-06-20 11:36:41 +02:00
|
|
|
|
2018-06-29 09:34:46 +02:00
|
|
|
ChangeManagement cm = parameters.cmUtils ?: new ChangeManagement(script)
|
2018-06-20 11:36:41 +02:00
|
|
|
|
2018-10-17 11:05:20 +02:00
|
|
|
ConfigurationHelper configHelper = ConfigurationHelper.newInstance(this)
|
2019-02-14 12:01:28 +01:00
|
|
|
.collectValidationFailures()
|
2020-08-26 15:32:58 +02:00
|
|
|
.loadStepDefaults([:], stageName)
|
2018-10-25 14:15:11 +02:00
|
|
|
.mixinGeneralConfig(script.commonPipelineEnvironment, GENERAL_CONFIG_KEYS)
|
|
|
|
.mixinStepConfig(script.commonPipelineEnvironment, STEP_CONFIG_KEYS)
|
2020-08-26 15:32:58 +02:00
|
|
|
.mixinStageConfig(script.commonPipelineEnvironment, stageName, STEP_CONFIG_KEYS)
|
2018-10-25 14:15:11 +02:00
|
|
|
.mixin(parameters, PARAMETER_KEYS)
|
2018-07-13 09:28:41 +02:00
|
|
|
|
2018-06-20 11:36:41 +02:00
|
|
|
|
2018-09-28 13:45:26 +02:00
|
|
|
Map configuration = configHelper.use()
|
2018-08-09 11:35:33 +02:00
|
|
|
|
2018-09-28 14:43:51 +02:00
|
|
|
BackendType backendType = getBackendTypeAndLogInfoIfCMIntegrationDisabled(this, configuration)
|
|
|
|
if(backendType == BackendType.NONE) return
|
2018-09-28 13:45:26 +02:00
|
|
|
|
|
|
|
configHelper
|
2018-08-15 10:37:34 +02:00
|
|
|
.withMandatoryProperty('changeManagement/clientOpts')
|
|
|
|
.withMandatoryProperty('changeManagement/credentialsId')
|
|
|
|
.withMandatoryProperty('changeManagement/endpoint')
|
|
|
|
.withMandatoryProperty('changeManagement/git/from')
|
|
|
|
.withMandatoryProperty('changeManagement/git/to')
|
|
|
|
.withMandatoryProperty('changeManagement/git/format')
|
2018-09-28 13:45:26 +02:00
|
|
|
.withMandatoryProperty('transportType', null, { backendType == BackendType.CTS})
|
|
|
|
.withMandatoryProperty('targetSystem', null, { backendType == BackendType.CTS})
|
|
|
|
.withMandatoryProperty('description', null, { backendType == BackendType.CTS})
|
2019-02-07 11:18:32 +01:00
|
|
|
.withMandatoryProperty('changeManagement/rfc/developmentInstance', null, {backendType == BackendType.RFC})
|
2019-02-07 10:11:22 +01:00
|
|
|
.withMandatoryProperty('changeManagement/rfc/developmentClient', null, {backendType == BackendType.RFC})
|
2019-03-05 10:29:23 +01:00
|
|
|
.withMandatoryProperty('verbose', null, {backendType == BackendType.RFC})
|
2018-07-13 09:28:41 +02:00
|
|
|
|
2018-09-25 09:12:07 +02:00
|
|
|
def changeDocumentId = null
|
2018-06-20 11:36:41 +02:00
|
|
|
|
2019-01-21 08:47:34 +01:00
|
|
|
new Utils().pushToSWA([
|
|
|
|
step: STEP_NAME,
|
|
|
|
stepParamKey1: 'scriptMissing',
|
|
|
|
stepParam1: parameters?.script == null
|
|
|
|
], configuration)
|
2018-08-09 11:35:33 +02:00
|
|
|
|
2018-09-25 09:12:07 +02:00
|
|
|
if(backendType == BackendType.SOLMAN) {
|
2018-08-09 11:35:33 +02:00
|
|
|
|
2018-11-08 16:16:42 +01:00
|
|
|
changeDocumentId = getChangeDocumentId(cm, script, configuration)
|
2018-07-10 14:43:15 +02:00
|
|
|
|
2018-09-25 09:12:07 +02:00
|
|
|
configHelper.mixin([changeDocumentId: changeDocumentId?.trim() ?: null], ['changeDocumentId'] as Set)
|
|
|
|
.withMandatoryProperty('developmentSystemId')
|
|
|
|
.withMandatoryProperty('changeDocumentId',
|
2020-09-30 14:29:46 +02:00
|
|
|
"Change document id not provided (parameter: \'changeDocumentId\' provided to the step call or via commit history).")
|
2018-07-10 14:43:15 +02:00
|
|
|
}
|
2018-06-20 11:36:41 +02:00
|
|
|
|
2018-09-25 09:12:07 +02:00
|
|
|
configuration = configHelper.use()
|
2018-06-20 11:36:41 +02:00
|
|
|
|
2018-09-25 09:12:07 +02:00
|
|
|
def creatingMessage = ["[INFO] Creating transport request"]
|
|
|
|
if(backendType == BackendType.SOLMAN) {
|
|
|
|
creatingMessage << " for change document '${configuration.changeDocumentId}' and development system '${configuration.developmentSystemId}'"
|
|
|
|
}
|
|
|
|
creatingMessage << '.'
|
|
|
|
echo creatingMessage.join()
|
2018-06-20 11:36:41 +02:00
|
|
|
|
2019-02-14 12:01:28 +01:00
|
|
|
|
|
|
|
try {
|
2018-09-25 09:12:07 +02:00
|
|
|
if(backendType == BackendType.SOLMAN) {
|
|
|
|
transportRequestId = cm.createTransportRequestSOLMAN(
|
2019-05-16 10:46:13 +02:00
|
|
|
configuration.changeManagement.solman.docker,
|
|
|
|
configuration.changeDocumentId,
|
|
|
|
configuration.developmentSystemId,
|
|
|
|
configuration.changeManagement.endpoint,
|
|
|
|
configuration.changeManagement.credentialsId,
|
|
|
|
configuration.changeManagement.clientOpts
|
|
|
|
)
|
2018-09-25 09:12:07 +02:00
|
|
|
} else if(backendType == BackendType.CTS) {
|
|
|
|
transportRequestId = cm.createTransportRequestCTS(
|
2019-05-16 10:46:13 +02:00
|
|
|
configuration.changeManagement.cts.docker,
|
|
|
|
configuration.transportType,
|
|
|
|
configuration.targetSystem,
|
|
|
|
configuration.description,
|
|
|
|
configuration.changeManagement.endpoint,
|
|
|
|
configuration.changeManagement.credentialsId,
|
|
|
|
configuration.changeManagement.clientOpts
|
|
|
|
)
|
2019-01-18 15:57:52 +01:00
|
|
|
} else if (backendType == BackendType.RFC) {
|
2019-02-11 10:52:47 +01:00
|
|
|
transportRequestId = cm.createTransportRequestRFC(
|
2019-05-16 10:46:13 +02:00
|
|
|
configuration.changeManagement.rfc.docker,
|
|
|
|
configuration.changeManagement.endpoint,
|
|
|
|
configuration.changeManagement.rfc.developmentInstance,
|
|
|
|
configuration.changeManagement.rfc.developmentClient,
|
|
|
|
configuration.changeManagement.credentialsId,
|
|
|
|
configuration.description,
|
|
|
|
configuration.verbose
|
|
|
|
)
|
2018-09-25 09:12:07 +02:00
|
|
|
} else {
|
|
|
|
throw new IllegalArgumentException("Invalid backend type: '${backendType}'.")
|
|
|
|
}
|
2018-06-20 11:36:41 +02:00
|
|
|
} catch(ChangeManagementException ex) {
|
|
|
|
throw new AbortException(ex.getMessage())
|
|
|
|
}
|
2018-07-16 15:41:46 +02:00
|
|
|
|
2018-06-20 11:36:41 +02:00
|
|
|
|
|
|
|
echo "[INFO] Transport Request '$transportRequestId' has been successfully created."
|
2019-04-10 10:56:36 +02:00
|
|
|
script.commonPipelineEnvironment.setValue('transportRequestId', "${transportRequestId}")
|
2018-06-20 11:36:41 +02:00
|
|
|
}
|
|
|
|
}
|