[DO-1572] add msg-files (!89)
Co-authored-by: Rustam Tagaev <rustam.tagaev@avroid.tech> Reviewed-on: https://git.avroid.tech/DevOps/jenkins-pipelines/pulls/89 Reviewed-by: Denis Patrakeev <denis.patrakeev@avroid.team>
This commit is contained in:
92
jobs-dsl/jobs/Cloud/Apps-Backend/msg_files.groovy
Normal file
92
jobs-dsl/jobs/Cloud/Apps-Backend/msg_files.groovy
Normal file
@@ -0,0 +1,92 @@
|
|||||||
|
multibranchPipelineJob('Cloud/Apps-Backend/msg-files') {
|
||||||
|
description('msg-files')
|
||||||
|
displayName('msg-files')
|
||||||
|
factory {
|
||||||
|
remoteJenkinsFileWorkflowBranchProjectFactory {
|
||||||
|
localMarker('')
|
||||||
|
matchBranches(true)
|
||||||
|
fallbackBranch('master')
|
||||||
|
lookupInParameters(false)
|
||||||
|
remoteJenkinsFile('pipelines/Cloud/Apps-Backend/msg-files.groovy')
|
||||||
|
remoteJenkinsFileSCM {
|
||||||
|
gitSCM {
|
||||||
|
userRemoteConfigs {
|
||||||
|
userRemoteConfig {
|
||||||
|
url("${JENKINS_GIT_REPOSITORY_URL}/DevOps/jenkins-pipelines.git")
|
||||||
|
credentialsId("${JENKINS_GIT_CREDENTIALS_HTTP}")
|
||||||
|
name('')
|
||||||
|
refspec('')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
gitTool('')
|
||||||
|
browser {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
branchSources {
|
||||||
|
branchSource {
|
||||||
|
source {
|
||||||
|
giteaSCMSource {
|
||||||
|
serverUrl("${JENKINS_GIT_REPOSITORY_URL}")
|
||||||
|
repoOwner('Apps-Backend')
|
||||||
|
repository('msg-files')
|
||||||
|
credentialsId("${JENKINS_GIT_CREDENTIALS_HTTP}")
|
||||||
|
id('Apps-Backend/msg-files')
|
||||||
|
traits {
|
||||||
|
giteaBranchDiscovery {
|
||||||
|
// 1 Exclude branches that are also filed as PRs
|
||||||
|
// 2 Only branches that are also filed as PRs
|
||||||
|
// 3 Only branches that are also filed as PRs or main
|
||||||
|
// 4 All branches
|
||||||
|
strategyId(1)
|
||||||
|
}
|
||||||
|
|
||||||
|
giteaPullRequestDiscovery {
|
||||||
|
// 1 Merging the pull request with the current target branch revision
|
||||||
|
// 2 The current pull request revision
|
||||||
|
// 3 Both the current pull request revision and the pull request merged with
|
||||||
|
// the current target branch revision
|
||||||
|
strategyId(2)
|
||||||
|
}
|
||||||
|
|
||||||
|
giteaForkDiscovery {
|
||||||
|
// 1 Merging the pull request with the current target branch revision
|
||||||
|
// 2 The current pull request revision
|
||||||
|
// 3 Both the current pull request revision and the pull request merged with
|
||||||
|
// the current target branch revision
|
||||||
|
strategyId(2)
|
||||||
|
trust {
|
||||||
|
giteaTrustContributors()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
giteaTagDiscovery()
|
||||||
|
pruneStaleBranch()
|
||||||
|
pruneStaleTag()
|
||||||
|
|
||||||
|
refSpecs {
|
||||||
|
templates {
|
||||||
|
refSpecTemplate {
|
||||||
|
value('+refs/heads/*:refs/remotes/@{remote}/*')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
orphanedItemStrategy {
|
||||||
|
discardOldItems {
|
||||||
|
numToKeep(20)
|
||||||
|
}
|
||||||
|
|
||||||
|
defaultOrphanedItemStrategy {
|
||||||
|
pruneDeadBranches(true)
|
||||||
|
numToKeepStr('10')
|
||||||
|
daysToKeepStr('10')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
87
jobs-dsl/jobs/Cloud/Deploy/Backend/msg_files_deploy.groovy
Normal file
87
jobs-dsl/jobs/Cloud/Deploy/Backend/msg_files_deploy.groovy
Normal file
@@ -0,0 +1,87 @@
|
|||||||
|
pipelineJob('Cloud/Deploy/Backend/msg-files-deploy') {
|
||||||
|
logRotator {
|
||||||
|
numToKeep(10)
|
||||||
|
artifactNumToKeep(10)
|
||||||
|
}
|
||||||
|
|
||||||
|
parameters {
|
||||||
|
choice {
|
||||||
|
name('ENV')
|
||||||
|
choices(['DEV'])
|
||||||
|
description('Select one of environments')
|
||||||
|
}
|
||||||
|
choiceParameter {
|
||||||
|
name('APP_VERSION')
|
||||||
|
randomName('')
|
||||||
|
filterable(true)
|
||||||
|
filterLength(1)
|
||||||
|
script {
|
||||||
|
groovyScript {
|
||||||
|
fallbackScript {
|
||||||
|
script('')
|
||||||
|
sandbox(false)
|
||||||
|
}
|
||||||
|
script {
|
||||||
|
sandbox(false)
|
||||||
|
script(
|
||||||
|
"""
|
||||||
|
import groovy.json.JsonSlurperClassic
|
||||||
|
import groovy.json.model.*
|
||||||
|
import com.cloudbees.plugins.credentials.CredentialsProvider
|
||||||
|
import com.cloudbees.plugins.credentials.common.StandardUsernamePasswordCredentials
|
||||||
|
import java.util.regex.Pattern
|
||||||
|
|
||||||
|
def createGetHttpClient(String url, String jenkinsCreds) {
|
||||||
|
def jenkinsCredentials = CredentialsProvider.lookupCredentials(StandardUsernamePasswordCredentials.class)
|
||||||
|
def credentials = jenkinsCredentials.findResult { it.id == jenkinsCreds ? it : null }
|
||||||
|
String auth = 'robot' + '\$' + 'ci' + ":" + credentials.password
|
||||||
|
String encodedAuth = Base64.getEncoder().encodeToString(auth.getBytes("utf-8"))
|
||||||
|
String authHeaderValue = "Basic " + encodedAuth
|
||||||
|
def httpClient = new URL(url).openConnection() as HttpURLConnection
|
||||||
|
httpClient.setRequestMethod('GET')
|
||||||
|
httpClient.setRequestProperty("Authorization", authHeaderValue)
|
||||||
|
httpClient.setRequestProperty("Accept", "application/json")
|
||||||
|
return httpClient
|
||||||
|
}
|
||||||
|
|
||||||
|
String harborApiUrl = "https://${JENKINS_DOCKER_REGISTRY}/api/v2.0/projects/cloud/repositories/msg-files/" +
|
||||||
|
"artifacts?page=1&page_size=100&with_tag=true&sort=-push_time"
|
||||||
|
|
||||||
|
def httpClientHarbor = createGetHttpClient(harborApiUrl, "${JENKINS_HARBOR_CREDENTIALS}")
|
||||||
|
httpClientHarbor.connect()
|
||||||
|
|
||||||
|
List imageVersions = []
|
||||||
|
def harborResponse = new JsonSlurperClassic().parseText(httpClientHarbor.inputStream.text)
|
||||||
|
|
||||||
|
harborResponse.each { image ->
|
||||||
|
image.tags.each { tag ->
|
||||||
|
imageVersions.add(tag.name)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return imageVersions
|
||||||
|
"""
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
choiceType('PT_SINGLE_SELECT')
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
definition {
|
||||||
|
cpsScm {
|
||||||
|
scm {
|
||||||
|
git {
|
||||||
|
remote {
|
||||||
|
url("${JENKINS_GIT_REPOSITORY_URL}/DevOps/jenkins-pipelines.git")
|
||||||
|
credentials("${JENKINS_GIT_CREDENTIALS_HTTP}")
|
||||||
|
}
|
||||||
|
branch('master')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
scriptPath('pipelines/Cloud/Deploy/Backend/msg-files-deploy.groovy')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
102
pipelines/Cloud/Apps-Backend/msg-files.groovy
Normal file
102
pipelines/Cloud/Apps-Backend/msg-files.groovy
Normal file
@@ -0,0 +1,102 @@
|
|||||||
|
@Library('shared-lib') _
|
||||||
|
|
||||||
|
import tech.avroid.kube.PodTemplates
|
||||||
|
import tech.avroid.scm.Git
|
||||||
|
|
||||||
|
properties([
|
||||||
|
buildDiscarder(logRotator(daysToKeepStr: '10',
|
||||||
|
numToKeepStr: '10')),
|
||||||
|
disableConcurrentBuilds()
|
||||||
|
])
|
||||||
|
|
||||||
|
Git git = new Git(this, env.JENKINS_GIT_CREDENTIALS_SSH)
|
||||||
|
|
||||||
|
String repoPath = 'Apps-Backend/msg-files.git'
|
||||||
|
|
||||||
|
Map envBranch = [
|
||||||
|
'DEV': 'develop',
|
||||||
|
// 'TEST': 'test'
|
||||||
|
]
|
||||||
|
|
||||||
|
String dockerGroup = 'cloud'
|
||||||
|
String dockerProject = 'msg-files'
|
||||||
|
String projectSettingFile = 'pyproject.toml'
|
||||||
|
Map gitVars = [:]
|
||||||
|
String tag = ''
|
||||||
|
String branch = git.getBranch()
|
||||||
|
String publishBranch = envBranch.find { it.value == branch }?.value
|
||||||
|
|
||||||
|
Map configuration = [
|
||||||
|
vaultUrl: env.JENKINS_VAULT_URL,
|
||||||
|
vaultCredentialId: env.JENKINS_VAULT_TOKEN,
|
||||||
|
engineVersion: 2
|
||||||
|
]
|
||||||
|
|
||||||
|
List dockerCreds = [
|
||||||
|
[path: 'team-devops/services/registry/Harbor/harbor.avroid.tech', engineVersion: 2,
|
||||||
|
secretValues:
|
||||||
|
[
|
||||||
|
[vaultKey: 'service.user.jenkins.ci.login'],
|
||||||
|
[vaultKey: 'service.user.ci.token'],
|
||||||
|
]
|
||||||
|
]
|
||||||
|
]
|
||||||
|
|
||||||
|
slaveTemplates = new PodTemplates(this, env.JENKINS_DOCKER_REGISTRY, ["${env.JENKINS_K8S_HARBOR_SECRET}"])
|
||||||
|
|
||||||
|
slaveTemplates.jnlp {
|
||||||
|
slaveTemplates.poetry {
|
||||||
|
slaveTemplates.docker {
|
||||||
|
node(POD_LABEL){
|
||||||
|
|
||||||
|
stage('Download sources') {
|
||||||
|
gitVars = git.clone([urlRepo: "${env.JENKINS_GIT_REPOSITORY_SSH_URL}/${repoPath}",
|
||||||
|
branch: branch])
|
||||||
|
}
|
||||||
|
|
||||||
|
stage('prepare app'){
|
||||||
|
container('poetry'){
|
||||||
|
sh 'make setup'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
withVault([configuration: configuration, vaultSecrets: dockerCreds]) {
|
||||||
|
String ciUser = getProperty('service.user.jenkins.ci.login')
|
||||||
|
String dockerToken = getProperty('service.user.ci.token')
|
||||||
|
|
||||||
|
container('docker'){
|
||||||
|
Map props = readTOML file: projectSettingFile
|
||||||
|
|
||||||
|
String version = props.tool.poetry.version
|
||||||
|
tag = "${version}-${gitVars.GIT_COMMIT.take(5)}"
|
||||||
|
String imageName = "${env.JENKINS_DOCKER_REGISTRY}/" +
|
||||||
|
"${dockerGroup}/${dockerProject}:${tag}"
|
||||||
|
|
||||||
|
docker.withRegistry("https://${env.JENKINS_DOCKER_REGISTRY}", env.JENKINS_HARBOR_CREDENTIALS) {
|
||||||
|
stage('build image and push'){
|
||||||
|
Object buildImage = docker.build(imageName,
|
||||||
|
"--build-arg PIP_INDEX_URL=${env.JENKINS_PIP_INDEX_URL} -f Dockerfile ."
|
||||||
|
)
|
||||||
|
|
||||||
|
if (publishBranch.contains(branch)) {
|
||||||
|
buildImage.push()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
stage('deploy application'){
|
||||||
|
if (publishBranch.contains(branch)){
|
||||||
|
build job: 'Cloud/Deploy/Backend/msg-messenger-deploy',
|
||||||
|
parameters: [
|
||||||
|
string(name: 'ENV', value: envBranch.find { it.value == branch }?.key ),
|
||||||
|
string(name: 'APP_VERSION', value: tag)
|
||||||
|
],
|
||||||
|
wait: false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
131
pipelines/Cloud/Deploy/Backend/msg-files-deploy.groovy
Normal file
131
pipelines/Cloud/Deploy/Backend/msg-files-deploy.groovy
Normal file
@@ -0,0 +1,131 @@
|
|||||||
|
@Library('shared-lib') _
|
||||||
|
|
||||||
|
import tech.avroid.kube.PodTemplates
|
||||||
|
import tech.avroid.scm.Git
|
||||||
|
import tech.avroid.jenkins.Notifications
|
||||||
|
import tech.avroid.jenkins.Jenkins
|
||||||
|
|
||||||
|
String projectName = 'cloud' // Replace with your Harbor project name
|
||||||
|
String repositoryName = 'msg-files' // Replace with your Harbor repository name
|
||||||
|
String k8sAppName = repositoryName
|
||||||
|
Map envBranch = [
|
||||||
|
'DEV': 'develop',
|
||||||
|
// 'TEST': 'test'
|
||||||
|
]
|
||||||
|
|
||||||
|
String apiUrl = "https://${JENKINS_DOCKER_REGISTRY}/api/v2.0/projects/${projectName}" +
|
||||||
|
"/repositories/${repositoryName}/artifacts"
|
||||||
|
properties([
|
||||||
|
buildDiscarder(logRotator(artifactNumToKeepStr: '10',
|
||||||
|
numToKeepStr: '10')),
|
||||||
|
disableConcurrentBuilds(),
|
||||||
|
parameters([
|
||||||
|
choice(
|
||||||
|
name: 'ENV',
|
||||||
|
choices: envBranch.keySet().toList(),
|
||||||
|
description: 'Select one of environments'
|
||||||
|
),
|
||||||
|
[$class: 'ChoiceParameter',
|
||||||
|
choiceType: 'PT_SINGLE_SELECT',
|
||||||
|
filterLength: 1,
|
||||||
|
filterable: true,
|
||||||
|
name: 'APP_VERSION',
|
||||||
|
script: [$class: 'GroovyScript',
|
||||||
|
script: [sandbox: false, script: """
|
||||||
|
import groovy.json.JsonSlurperClassic
|
||||||
|
import groovy.json.model.*
|
||||||
|
import com.cloudbees.plugins.credentials.CredentialsProvider
|
||||||
|
import com.cloudbees.plugins.credentials.common.StandardUsernamePasswordCredentials
|
||||||
|
import java.util.regex.Pattern
|
||||||
|
|
||||||
|
def createGetHttpClient(String url, String jenkinsCreds) {
|
||||||
|
def jenkinsCredentials = CredentialsProvider.lookupCredentials(StandardUsernamePasswordCredentials.class)
|
||||||
|
def credentials = jenkinsCredentials.findResult { it.id == jenkinsCreds ? it : null }
|
||||||
|
String auth = 'robot' + '\$' + 'ci' + ":" + credentials.password
|
||||||
|
String encodedAuth = Base64.getEncoder().encodeToString(auth.getBytes("utf-8"))
|
||||||
|
String authHeaderValue = "Basic " + encodedAuth
|
||||||
|
def httpClient = new URL(url).openConnection() as HttpURLConnection
|
||||||
|
httpClient.setRequestMethod('GET')
|
||||||
|
httpClient.setRequestProperty("Authorization", authHeaderValue)
|
||||||
|
httpClient.setRequestProperty("Accept", "application/json")
|
||||||
|
return httpClient
|
||||||
|
}
|
||||||
|
|
||||||
|
String harborApiUrl = "https://${JENKINS_DOCKER_REGISTRY}/api/v2.0/projects/cloud/repositories/msg-files/" +
|
||||||
|
"artifacts?page=1&page_size=100&with_tag=true&sort=-push_time"
|
||||||
|
|
||||||
|
def httpClientHarbor = createGetHttpClient(harborApiUrl, "${JENKINS_HARBOR_CREDENTIALS}")
|
||||||
|
httpClientHarbor.connect()
|
||||||
|
|
||||||
|
List imageVersions = []
|
||||||
|
def harborResponse = new JsonSlurperClassic().parseText(httpClientHarbor.inputStream.text)
|
||||||
|
|
||||||
|
harborResponse.each { image ->
|
||||||
|
image.tags.each { tag ->
|
||||||
|
imageVersions.add(tag.name)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return imageVersions
|
||||||
|
"""]],
|
||||||
|
]
|
||||||
|
])
|
||||||
|
|
||||||
|
])
|
||||||
|
String repoPath = 'Apps-Backend/msg-files.git'
|
||||||
|
String branch = envBranch.find { it.key == params.ENV }?.value
|
||||||
|
String valuesPath = ".helm/values.${params.ENV.toLowerCase()}.yaml"
|
||||||
|
String namespace = "tavro-cloud-${params.ENV.toLowerCase()}"
|
||||||
|
|
||||||
|
|
||||||
|
String helmChart = 'msg-files'
|
||||||
|
String helmRepoPath = "avroid/${helmChart}"
|
||||||
|
String helmRepo = "${env.JENKINS_NEXUS_URL}/repository/devops-helm-release"
|
||||||
|
println(branch)
|
||||||
|
Git git = new Git(this, env.JENKINS_GIT_CREDENTIALS_SSH)
|
||||||
|
PodTemplates slaveTemplates = new PodTemplates(this, env.JENKINS_DOCKER_REGISTRY,
|
||||||
|
["${env.JENKINS_K8S_HARBOR_SECRET}"],
|
||||||
|
'avroid-office')
|
||||||
|
|
||||||
|
slaveTemplates.jnlp {
|
||||||
|
slaveTemplates.helm {
|
||||||
|
try {
|
||||||
|
node(POD_LABEL){
|
||||||
|
stage('get repo with values'){
|
||||||
|
gitVars = git.clone([urlRepo: "${env.JENKINS_GIT_REPOSITORY_SSH_URL}/${repoPath}",
|
||||||
|
branch: branch])
|
||||||
|
}
|
||||||
|
container('helm'){
|
||||||
|
stage('deploy'){
|
||||||
|
echo "Deploying version ${env.APP_VERSION} to ${namespace} namespace"
|
||||||
|
sh """#!/bin/sh
|
||||||
|
helm repo add avroid ${helmRepo}
|
||||||
|
helm -n ${namespace} upgrade -f ${valuesPath} \
|
||||||
|
--set image.tag=${env.APP_VERSION} \
|
||||||
|
--install ${k8sAppName} ${helmRepoPath} \
|
||||||
|
--wait
|
||||||
|
"""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch(err) {
|
||||||
|
errorMessage = err.getMessage()
|
||||||
|
|
||||||
|
println 'ERROR: ' + errorMessage
|
||||||
|
|
||||||
|
currentBuild.result = 'FAILURE'
|
||||||
|
|
||||||
|
String currentBuildUser = Jenkins.GetCurrentBuildUser(script: this)
|
||||||
|
String emailSubject = "${currentBuild.currentResult}. " +
|
||||||
|
"Pipeline task: ${currentBuild.fullDisplayName}"
|
||||||
|
|
||||||
|
Notifications.email(
|
||||||
|
script: this,
|
||||||
|
subject: emailSubject,
|
||||||
|
errorString: errorMessage,
|
||||||
|
recipientProviders: [],
|
||||||
|
to: "${currentBuildUser}@avroid.team"
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user