diff --git a/.idea/inspectionProfiles/Project_Default.xml b/.idea/inspectionProfiles/Project_Default.xml
new file mode 100644
index 0000000..efae37f
--- /dev/null
+++ b/.idea/inspectionProfiles/Project_Default.xml
@@ -0,0 +1,10 @@
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/test-ci-cd.iml b/.idea/test-ci-cd.iml
new file mode 100644
index 0000000..7ee078d
--- /dev/null
+++ b/.idea/test-ci-cd.iml
@@ -0,0 +1,4 @@
+
+
+
+
\ No newline at end of file
diff --git a/.idea/vcs.xml b/.idea/vcs.xml
new file mode 100644
index 0000000..35eb1dd
--- /dev/null
+++ b/.idea/vcs.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/Jenkinsfile b/Jenkinsfile
index e69de29..94bd441 100644
--- a/Jenkinsfile
+++ b/Jenkinsfile
@@ -0,0 +1,116 @@
+def notify(
+ String context,
+ String giteaUser,
+ String giteaPass,
+ String repositoryUrl,
+ String repositoryName,
+ String commitHash,
+ String buildStatus
+) {
+ def status = buildStatus == 'success' ? 'success' : 'failure'
+ def description = buildStatus == 'success' ? 'Build succeeded' : 'Build failed'
+
+ sh """
+ curl -X POST \
+ -u "${giteaUser}:${giteaPass}" \
+ -H "Content-Type: application/json" \
+ -d '{"context":"${context}","state": "${status}", "description": "${description}"}' \
+ ${repositoryUrl}deployer3000/${repositoryName}/statuses/${commitHash}
+ """
+}
+
+pipeline {
+ agent any
+ parameters {
+ string(name: 'PROJECT_VERSION', defaultValue: '1.0.0', description: 'SemVer version (e.g., 1.0.0)')
+ }
+ environment {
+ REGISTRY_NAME = 'registry.entcor/trust-module'
+ IMAGE_NAME = "trust-module-backend"
+ GITEA_REPOSITORY_URL = "http://git.entcor/api/v1/repos/"
+ }
+ stages {
+ stage ('Initialize variables') {
+ steps {
+ script {
+ // Читаем текущую версию из параметров
+ def (major, minor, patch) = params.PROJECT_VERSION.tokenize('.')
+
+ // Увеличиваем патч (1.0.0 → 1.0.1)
+ patch = (patch as Integer) + 1
+ env.IMAGE_TAG = "${major}.${minor}.${patch}"
+
+ // Опционально: сохраняем новую версию в параметры через API (см. ниже)
+ echo "New version: ${env.IMAGE_TAG}"
+ }
+ }
+ }
+ stage ('Build docker image') {
+ when {
+ expression { env.CHANGE_BRANCH?.startsWith('rc') }
+ }
+ steps {
+ script {
+ def image = docker.build("${env.IMAGE_NAME}:${env.IMAGE_TAG}")
+ sh "docker tag ${env.IMAGE_NAME}:${env.IMAGE_TAG} ${env.REGISTRY_NAME}/${env.IMAGE_NAME}:${env.IMAGE_TAG}"
+ }
+ }
+ }
+ stage ('Push docker image to registry') {
+ when {
+ expression { env.CHANGE_BRANCH?.startsWith('rc') }
+ }
+ steps {
+ script {
+ docker.withRegistry('https://registry.entcor/harbor/', 'harbor-credentials-id') {
+ docker.image("${env.REGISTRY_NAME}/${env.IMAGE_NAME}:${env.IMAGE_TAG}").push()
+ }
+ }
+ }
+ }
+ }
+ post {
+ always {
+ script {
+ echo "Cleaning up workspace..."
+ sh "rm -rf ${env.WORKSPACE}/rc/ || true"
+ }
+ }
+ success {
+ script {
+ if (env.CHANGE_BRANCH?.startsWith('rc')) {
+ echo "Attempting to merge PR ${env.CHANGE_ID} into master..."
+ withCredentials([usernamePassword(credentialsId: 'gitea_creds', usernameVariable: 'GITEA_USER', passwordVariable: 'GITEA_PASS')]) {
+ def prId = env.CHANGE_ID
+ sh """
+ curl -X POST \
+ -u "${GITEA_USER}:${GITEA_PASS}" \
+ -H "Content-Type: application/json" \
+ -d '{"do":"merge"}' \
+ http://git.entcor/api/v1/repos/deployer3000/trust-module-backend/pulls/${prId}/merge
+ """
+ echo "PR ${prId} merged successfully into main!"
+ def context = "test-org/trust-module-backend/pipeline/pr-${env.CHANGE_TARGET}"
+ def commitHash = sh(script: "git rev-parse HEAD~1", returnStdout: true).trim()
+ notify(context, GITEA_USER, GITEA_PASS, env.GITEA_REPOSITORY_URL, "trust-module-backend", commitHash, "success")
+
+ // Обновляем параметр PROJECT_VERSION через API (если нужно)
+ def newVersion = env.IMAGE_TAG
+ sh """
+ curl -X POST -u ${GITEA_USER}:${GITEA_PASS} \
+ "http://192.168.2.55:8080/job/${env.JOB_NAME}/buildWithParameters?PROJECT_VERSION=${newVersion}"
+ """
+ }
+ }
+ }
+ }
+ failure {
+ echo "Pipeline failed. Check the logs for details."
+ }
+ aborted {
+ echo "Pipeline was aborted."
+ }
+ }
+}
+
+//TODO: дженкинс entcor убрать