-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathJenkinsfile_parameterized
51 lines (46 loc) · 2.04 KB
/
Jenkinsfile_parameterized
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
#!groovy
@Library("Infrastructure") _
properties([
parameters([
string(name: 'PRODUCT_NAME', defaultValue: 'sscs', description: ''),
string(name: 'APP', defaultValue: 'case-loader', description: ''),
string(name: 'TYPE', defaultValue: 'java', description: ''),
string(name: 'ENVIRONMENT', defaultValue: 'sandbox', description: 'Environment where code should be build and deployed'),
choice(name: 'SUBSCRIPTION', choices: 'sandbox\nnonprod\nprod', description: 'Azure subscriptions available to build in')
]),
[$class: 'GithubProjectProperty', projectUrlStr: 'https://github.com/hmcts/sscs-case-loader.git'],
pipelineTriggers([[$class: 'GitHubPushTrigger']])
])
List<LinkedHashMap<String, Object>> secrets = [
secret('ManagementSecEnabled', 'MANAGEMENT_SECURITY_ENABLED'),
secret('CcdApi', 'CORE_CASE_DATA_API_URL'),
secret('CcdJid', 'CORE_CASE_DATA_JURISDICTION_ID'),
secret('CcdCtid', 'CORE_CASE_DATA_CASE_TYPE_ID'),
secret('CcdDeid', 'CORE_CASE_DATA_EVENT_ID'),
secret('IdamUrl', 'IDAM_URL'),
secret('IdamS2sSecret', 'IDAM_S2S_AUTH_TOTP_SECRET'),
secret('IdamS2sAuth', 'IDAM_S2S_AUTH'),
secret('IdamS2sAuthMicro', 'IDAM_S2S_AUTH_MICROSERVICE'),
secret('IdamSscsUser', 'IDAM_SSCS_SYSTEMUPDATE_USER'),
secret('IdamSscsPass', 'IDAM_SSCS_SYSTEMUPDATE_PASSWORD'),
secret('IdamAuthCid','IDAM_OAUTH2_CLIENT_ID'),
secret('IdamAuthSecret','IDAM_OAUTH2_CLIENT_SECRET'),
secret('IdamAuthUrl','IDAM_OAUTH2_REDIRECT_URL'),
secret('Gaps2Key','GAPS2_KEY_LOCATION'),
secret('Gaps2Host','GAPS2_SFTP_HOST'),
secret('Gaps2Port','GAPS2_SFTP_PORT'),
secret('Gaps2Sftp','GAPS2_SFTP_USER'),
secret('Gaps2Sftp','GAPS2_SFTP_DIR'),
secret('SscsIgnore','IGNORE_CASES_BEFORE_DATE')
]
static LinkedHashMap<String, Object> secret(String secretName, String envVar) {
[ $class: 'AzureKeyVaultSecret',
secretType: 'Secret',
name: secretName,
version: '',
envVariable: envVar
]
}
withParameterizedPipeline(params.TYPE, params.PRODUCT_NAME, params.APP, params.ENVIRONMENT, params.SUBSCRIPTION) {
loadVaultSecrets(secrets)
}