Compare commits

..

97 Commits

Author SHA1 Message Date
31333ea168 Merge pull request 'Removed pull event from build stage' (#106) from test into main
All checks were successful
continuous-integration/drone Build is passing
continuous-integration/drone/promote/staging Build is passing
Reviewed-on: #106
2026-04-04 16:39:53 +02:00
e26c79a9d7 Removed pull event from build stage 2026-04-04 16:39:31 +02:00
200789e832 Merge pull request 'test' (#105) from test into main
Reviewed-on: #105
2026-04-04 16:38:53 +02:00
ae1440fce3 Refactored uat to staging 2026-04-04 16:38:30 +02:00
b58b5777fd Refactored triggers 2026-04-04 16:38:02 +02:00
3e84af9bb5 Merge pull request 'test' (#104) from test into main
Some checks failed
continuous-integration/drone Build was killed
Reviewed-on: #104
2026-04-04 16:36:26 +02:00
83dfdc2cc3 Removed promotion trigger 2026-04-04 16:35:19 +02:00
bbdb27b116 Removed promotion trigger 2026-04-04 16:34:41 +02:00
31f2439033 Merge pull request 'Removed build stage dependency' (#103) from test into main
All checks were successful
continuous-integration/drone Build is passing
continuous-integration/drone/promote/uat Build is passing
Reviewed-on: #103
2026-04-04 16:30:09 +02:00
1da1328870 Removed build stage dependency 2026-04-04 16:29:17 +02:00
15a2ad0b89 Merge pull request 'Removed triggers on build stage' (#102) from test into main
Some checks failed
continuous-integration/drone Build is passing
continuous-integration/drone/promote/uat Build was killed
Reviewed-on: #102
2026-04-04 16:25:35 +02:00
3b5ca4f5b0 Removed triggers on build stage 2026-04-04 16:25:09 +02:00
d179d2d79d Merge pull request 'Light refactor' (#101) from test into main
Reviewed-on: #101
2026-04-04 16:24:35 +02:00
1526648d9a Light refactor 2026-04-04 16:24:12 +02:00
b6813057a4 Merge pull request 'Added pull_request trigger in build stage' (#100) from test into main
Reviewed-on: #100
2026-04-04 16:23:22 +02:00
d1f723c135 Added pull_request trigger in build stage 2026-04-04 16:22:59 +02:00
7882b380b5 Merge pull request 'Removed push trigger from build branch' (#99) from test into main
All checks were successful
continuous-integration/drone Build is passing
Reviewed-on: #99
2026-04-04 16:20:05 +02:00
423281d071 Removed push trigger from build branch 2026-04-04 16:19:44 +02:00
75ecf71370 Merge pull request 'Enhanced triggers' (#98) from test into main
Reviewed-on: #98
2026-04-04 16:18:08 +02:00
44fbc613a3 Enhanced triggers 2026-04-04 16:17:40 +02:00
5fa7d49bcd Merge pull request 'Fixed pipeline stage naming' (#97) from test into main
Reviewed-on: #97
2026-04-04 16:13:32 +02:00
a922531f50 Fixed pipeline stage naming 2026-04-04 16:13:03 +02:00
f356ecdcc0 Merge pull request 'Split deployment from main pipeline' (#96) from test into main
Some checks failed
continuous-integration/drone Build encountered an error
Reviewed-on: #96
2026-04-04 16:11:55 +02:00
9acebb67fe Split deployment from main pipeline 2026-04-04 16:11:17 +02:00
7d32a83af2 Merge pull request 'test' (#95) from test into main
All checks were successful
continuous-integration/drone Build is passing
Reviewed-on: #95
2026-04-04 15:59:25 +02:00
e140319a05 Removed comments 2026-04-04 15:58:58 +02:00
3752da6ebe fixed dotnet step image 2026-04-04 15:58:12 +02:00
a4766c3d48 Merge pull request 'Restored drone image detection' (#94) from test into main
Some checks failed
continuous-integration/drone Build encountered an error
Reviewed-on: #94
2026-04-04 15:57:17 +02:00
1937d2eaa1 Restored drone image detection 2026-04-04 15:56:51 +02:00
14c2205a8d Merge pull request 'removed tags' (#93) from test into main
Some checks failed
continuous-integration/drone Build is failing
Reviewed-on: #93
2026-04-04 15:54:52 +02:00
c2a8b5c797 removed tags 2026-04-04 15:54:19 +02:00
e5b37e9e60 Merge pull request 'Applied nexus to all docker references including docker image' (#92) from test into main
Some checks failed
continuous-integration/drone Build is failing
Reviewed-on: #92
2026-04-04 15:52:22 +02:00
c584d39270 Applied nexus to all docker references including docker image 2026-04-04 15:51:52 +02:00
bdf1c92ab5 Merge pull request 'test' (#91) from test into main
All checks were successful
continuous-integration/drone Build is passing
Reviewed-on: #91
2026-04-04 15:42:19 +02:00
81e93b0e4e Refactored nexus trivy manifest 2026-04-04 15:41:54 +02:00
89f619eefa Pointing to the right .net10 image on nexus 2026-04-04 15:40:55 +02:00
2acbf51413 Merge pull request 'test' (#90) from test into main
Some checks failed
continuous-integration/drone Build encountered an error
Reviewed-on: #90
2026-04-04 15:33:27 +02:00
b46848dd56 Refactored the pipeline to pull the trivy image from nexus as well 2026-04-04 15:33:03 +02:00
30e0bc2b87 Pulling .net docker image from nexus 2026-04-04 15:32:20 +02:00
903c17e7f8 Refactored the pipeline so that docker push happens before the trivy scan 2026-04-04 15:30:56 +02:00
52f10f9181 Merge pull request 'Fixed docker steps to use local nexus properly' (#89) from test into main
Some checks failed
continuous-integration/drone Build is failing
Reviewed-on: #89
2026-04-04 15:24:33 +02:00
bd3cba05cb Fixed docker steps to use local nexus properly 2026-04-04 15:24:06 +02:00
521fa1dbc5 Merge pull request 'Supplied full package source for nuget' (#88) from test into main
Some checks failed
continuous-integration/drone Build is failing
Reviewed-on: #88
2026-04-04 15:13:21 +02:00
007f606bb6 Supplied full package source for nuget 2026-04-04 15:12:55 +02:00
21d2a7981e Merge pull request 'test' (#87) from test into main
Some checks failed
continuous-integration/drone Build is failing
Reviewed-on: #87
2026-04-04 15:10:50 +02:00
ef6262282d Applied specific trivy version 2026-04-04 15:10:28 +02:00
502182a370 Using nexus for dotnet restore 2026-04-04 15:09:05 +02:00
1d4009cc68 Merge pull request 'Added publish step to dotnet' (#86) from test into main
Some checks failed
continuous-integration/drone Build encountered an error
Reviewed-on: #86
2026-04-04 15:07:07 +02:00
c6799a146a Added publish step to dotnet 2026-04-04 15:06:32 +02:00
21e4c3940a Merge pull request 'Ensured donet publish and release are not ignored' (#85) from test into main
Some checks failed
continuous-integration/drone Build is failing
Reviewed-on: #85
2026-04-04 15:02:35 +02:00
6bd60452f2 Ensured donet publish and release are not ignored 2026-04-04 15:02:08 +02:00
0c901d32d8 Merge pull request 'Upgraded packages and refactored the pipeline' (#84) from test into main
Some checks failed
continuous-integration/drone Build is failing
Reviewed-on: #84
2026-04-04 14:54:49 +02:00
52e24bb8f2 Upgraded packages and refactored the pipeline 2026-04-04 14:53:33 +02:00
38cbf5b656 Merge pull request 'Removed dolive stage' (#83) from test into main
All checks were successful
continuous-integration/drone Build is passing
Reviewed-on: #83
2026-03-14 11:50:24 +02:00
a8ad599af2 Removed dolive stage 2026-03-14 11:50:02 +02:00
1263ad8571 Merge pull request 'SImplified prod docker step' (#82) from test into main
Some checks failed
continuous-integration/drone Build is passing
continuous-integration/drone/promote/prod Build is failing
Reviewed-on: #82
2026-03-14 11:41:53 +02:00
5dff86c4fa SImplified prod docker step 2026-03-14 11:41:25 +02:00
8d12af4e10 Merge pull request 'Refactored prod step' (#81) from test into main
All checks were successful
continuous-integration/drone Build is passing
continuous-integration/drone/promote/prod Build is passing
Reviewed-on: #81
2026-03-14 11:34:09 +02:00
6a29032748 Refactored prod step 2026-03-14 11:33:43 +02:00
099bc0c515 Merge pull request 'Unified docker commands' (#80) from test into main
All checks were successful
continuous-integration/drone Build is passing
continuous-integration/drone/promote/prod Build is passing
Reviewed-on: #80
2026-03-14 11:24:14 +02:00
634ad82d2c Unified docker commands 2026-03-14 11:23:44 +02:00
1cb1481ab8 Merge pull request 'Using temporary folder' (#79) from test into main
Some checks failed
continuous-integration/drone Build is passing
continuous-integration/drone/promote/prod Build is failing
Reviewed-on: #79
2026-03-14 11:19:19 +02:00
59c08d2314 Using temporary folder 2026-03-14 11:18:50 +02:00
f6bcbb6674 Merge pull request 'Fixed docker config path error' (#78) from test into main
Some checks failed
continuous-integration/drone Build is passing
continuous-integration/drone/promote/prod Build is failing
Reviewed-on: #78
2026-03-14 11:13:51 +02:00
496e6b653d Fixed docker config path error 2026-03-14 11:13:10 +02:00
6f395f9db7 Merge pull request 'fixed temp directory naming' (#77) from test into main
Some checks failed
continuous-integration/drone Build is passing
continuous-integration/drone/promote/prod Build is failing
Reviewed-on: #77
2026-03-14 11:07:21 +02:00
4c86a810da fixed temp directory naming 2026-03-14 11:07:00 +02:00
080d09fca3 Merge pull request 'Fixed yaml syntax error' (#76) from test into main
Some checks failed
continuous-integration/drone Build is passing
continuous-integration/drone/promote/prod Build is failing
Reviewed-on: #76
2026-03-14 11:01:34 +02:00
1ee31554ce Fixed yaml syntax error 2026-03-14 11:01:07 +02:00
18bc75b687 Merge pull request 'switched to powershell commands on prod step' (#75) from test into main
Some checks failed
continuous-integration/drone Build encountered an error
Reviewed-on: #75
2026-03-14 11:00:31 +02:00
3d1e3f29df switched to powershell commands on prod step 2026-03-14 11:00:11 +02:00
dd5ad891ab Merge pull request 'fixed yaml syntax error' (#74) from test into main
All checks were successful
continuous-integration/drone Build is passing
continuous-integration/drone/promote/prod Build is passing
Reviewed-on: #74
2026-03-14 10:54:38 +02:00
c03dc29446 fixed yaml syntax error 2026-03-14 10:54:16 +02:00
247aa96d19 Merge pull request 'Refactored to fix yaml syntax error' (#73) from test into main
Some checks failed
continuous-integration/drone Build encountered an error
Reviewed-on: #73
2026-03-14 10:53:12 +02:00
24e439558f Refactored to fix yaml syntax error 2026-03-14 10:52:19 +02:00
de0820dcc2 Merge pull request 'Added measures to ignore docker credential store' (#72) from test into main
Some checks failed
continuous-integration/drone Build encountered an error
Reviewed-on: #72
2026-03-14 10:50:26 +02:00
1917a60867 Added measures to ignore docker credential store 2026-03-14 10:50:01 +02:00
7071441d12 Merge pull request 'Added silent removal of existing containers' (#71) from test into main
Some checks failed
continuous-integration/drone Build is passing
continuous-integration/drone/promote/prod Build is failing
Reviewed-on: #71
2026-03-14 10:44:15 +02:00
c43ce20bbe Added silent removal of existing containers 2026-03-14 10:43:50 +02:00
48b884ae72 Merge pull request 'Fixed docker commands on prod step' (#70) from test into main
Some checks failed
continuous-integration/drone Build is failing
Reviewed-on: #70
2026-03-14 10:38:26 +02:00
26c90e1697 Fixed docker commands on prod step 2026-03-14 10:38:05 +02:00
1e66974684 Merge pull request 'test' (#69) from test into main
Some checks failed
continuous-integration/drone Build is passing
continuous-integration/drone/promote/prod Build is failing
Reviewed-on: #69
2026-03-14 10:32:48 +02:00
a6a32817c5 Retrieving host from secrets 2026-03-14 10:32:23 +02:00
03574c720f Refactored container names 2026-03-14 10:31:41 +02:00
b3fa0e5138 Merge pull request 'test' (#68) from test into main
Some checks failed
continuous-integration/drone Build is passing
continuous-integration/drone/promote/prod Build is failing
Reviewed-on: #68
2026-03-14 10:25:50 +02:00
201850a3d4 Removed variable expansion because plugin doesnt support it 2026-03-14 10:25:15 +02:00
c8aef17e95 Added restart conditions 2026-03-14 10:15:35 +02:00
900e72779f Merge pull request 'Refactored prod stage' (#67) from test into main
Some checks failed
continuous-integration/drone Build is passing
continuous-integration/drone/promote/prod Build is failing
Reviewed-on: #67
2026-03-14 10:13:50 +02:00
8c6b400a2d Refactored prod stage 2026-03-14 10:12:55 +02:00
28d02037f8 Merge pull request 'Credential refactor' (#66) from test into main
Some checks failed
continuous-integration/drone Build encountered an error
Reviewed-on: #66
2026-03-10 19:29:17 +02:00
324e25c24b Credential refactor 2026-03-10 19:28:58 +02:00
5e00dd6726 Merge pull request 'Refactored prod stage' (#65) from test into main
Some checks failed
continuous-integration/drone Build is passing
continuous-integration/drone/promote/prod Build is failing
Reviewed-on: #65
2026-03-10 19:23:59 +02:00
cdeae28f27 Refactored prod stage 2026-03-10 19:23:33 +02:00
5ee124790f Merge pull request 'Refactored prod step to target the correct docker folder for user' (#64) from test into main
Reviewed-on: #64
2026-03-10 19:20:09 +02:00
671e8b986f Refactored prod step to target the correct docker folder for user 2026-03-10 19:19:49 +02:00
8b23dfa534 Merge pull request 'Refactored prod step' (#63) from test into main
Some checks failed
continuous-integration/drone Build was killed
continuous-integration/drone/promote/prod Build is failing
Reviewed-on: #63
2026-03-10 19:17:58 +02:00
176fdb2930 Refactored prod step 2026-03-10 19:17:34 +02:00
4 changed files with 50 additions and 122 deletions

View File

@@ -27,4 +27,6 @@ README.md
!.git/config !.git/config
!.git/packed-refs !.git/packed-refs
!.git/refs/heads/** !.git/refs/heads/**
# Ensure the build output is NOT ignored
!**/bin/Release/**/publish/
!**/publish/

View File

@@ -1,143 +1,68 @@
--- ---
kind: pipeline kind: pipeline
type: docker type: docker
name: build name: build-and-package
trigger:
event:
exclude:
- promote
clone:
disable: true
steps: steps:
- name: checkout - name: build-test-publish
image: alpine/git image: nexus.khongisa.co.za/sdk:10.0
commands: commands:
- git clone https://gitea.khongisa.co.za/MngomaLab/webapitest.git . - dotnet restore --source https://nexus.khongisa.co.za/repository/nuget-group/index.json --no-cache
- git checkout ${DRONE_COMMIT} - dotnet build --configuration Release --no-restore
- dotnet test --configuration Release --no-build
- dotnet publish --configuration Release --no-build
- name: dotnet build - name: docker-build-and-push
image: mcr.microsoft.com/dotnet/sdk:10.0 image: plugins/docker
commands: settings:
- dotnet build --configuration Release registry: nexus.khongisa.co.za
repo: nexus.khongisa.co.za/webapitest
tags: [ "${DRONE_BUILD_NUMBER}", "latest" ]
username: { from_secret: docker_username }
password: { from_secret: docker_password }
- name: dotnet test - name: vulnerability-scan
image: mcr.microsoft.com/dotnet/sdk:10.0 image: aquasec/trivy:0.50.1
commands:
- dotnet test --configuration Release
---
x-docker-auth: &docker-auth
DOCKER_AUTH_CONFIG: |
{
"auths": {
"https://index.docker.io/v1/": {
"auth": "a2h3ZXppOlBHM0FRM0VPMFg="
}
}
}
kind: pipeline
type: docker
name: package
depends_on:
- build
trigger:
event:
exclude:
- promote
clone:
disable: true
steps:
- name: checkout
image: alpine/git
commands:
- git clone https://gitea.khongisa.co.za/MngomaLab/webapitest.git .
- git checkout ${DRONE_COMMIT}
- name: dotnet publish
image: mcr.microsoft.com/dotnet/sdk:10.0
commands:
- dotnet publish --configuration Release
- name: build and push
image: gcr.io/kaniko-project/executor:debug
environment: environment:
<<: *docker-auth TRIVY_USERNAME: { from_secret: docker_username }
TRIVY_PASSWORD: { from_secret: docker_password }
commands: commands:
- mkdir -p /kaniko/.docker - trivy image --image-src remote --exit-code 1 --severity CRITICAL nexus.khongisa.co.za/webapitest:${DRONE_BUILD_NUMBER}
- echo "$DOCKER_AUTH_CONFIG" > /kaniko/.docker/config.json
- /kaniko/executor
--verbosity=debug
--context=.
--dockerfile=Dockerfile
--destination=index.docker.io/khwezi/webapitest:latest
--destination=index.docker.io/khwezi/webapitest:${DRONE_BUILD_NUMBER}
- name: volnerability scan
image: aquasec/trivy
commands:
- trivy image --exit-code 1 --timeout 15m --severity CRITICAL khwezi/webapitest:${DRONE_BUILD_NUMBER}
---
kind: pipeline
type: docker
name: deploy
depends_on:
- package
trigger: trigger:
branch:
- main
event: event:
exclude: exclude:
- promote - promote
clone:
disable: true
steps:
- name: uat
image: appleboy/drone-ssh
settings:
host:
from_secret: ssh_host
username:
from_secret: ssh_user
password:
from_secret: ssh_password
script:
- docker pull khwezi/webapitest:latest
- docker stop webapitest || true
- docker rm webapitest || true
- docker run -d --name webapitest -e ASPNETCORE_ENVIRONMENT=Development -p 4000:8081 khwezi/webapitest:latest
--- ---
kind: pipeline kind: pipeline
type: docker type: docker
name: golive name: deploy-to-uat
depends_on:
- deploy
clone: depends_on:
disable: true - build-and-package
steps: steps:
- name: prod - name: uat-deployment
image: appleboy/drone-ssh image: appleboy/drone-ssh
settings: settings:
host: host: { from_secret: ssh_host }
from_secret: ssh_prod_host username: { from_secret: ssh_user }
username: password: { from_secret: ssh_password }
from_secret: ssh_prod_user
password:
from_secret: ssh_prod_password
script: script:
- docker pull khwezi/webapitest:latest - echo $DOCKER_PASSWORD | docker login nexus.khongisa.co.za -u $DOCKER_USERNAME --password-stdin
- docker stop webapi || true - docker pull nexus.khongisa.co.za/webapitest:latest
- docker rm webapi || true - docker stop webapi 2>/dev/null || true
- docker run -d --name webapi -e ASPNETCORE_ENVIRONMENT=Production -p 4001:8081 khwezi/webapitest:latest - docker rm webapi 2>/dev/null || true
when: - docker run -d --name webapi --restart unless-stopped -e ASPNETCORE_ENVIRONMENT=Development -p 4000:8081 nexus.khongisa.co.za/webapitest:latest
event: environment:
- promote DOCKER_USERNAME: { from_secret: docker_username }
target: DOCKER_PASSWORD: { from_secret: docker_password }
- prod
trigger:
event:
- promote
target:
- staging

View File

@@ -1,4 +1,4 @@
FROM mcr.microsoft.com/dotnet/aspnet:10.0 AS final FROM nexus.khongisa.co.za/aspnet:10.0 AS final
WORKDIR /app WORKDIR /app
USER app USER app

View File

@@ -9,8 +9,9 @@
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="Microsoft.VisualStudio.Azure.Containers.Tools.Targets" Version="1.19.6" /> <PackageReference Include="Microsoft.VisualStudio.Azure.Containers.Tools.Targets" Version="1.23.0" />
<PackageReference Include="Swashbuckle.AspNetCore" Version="6.4.0" /> <PackageReference Include="Polly" Version="8.6.6" />
<PackageReference Include="Swashbuckle.AspNetCore" Version="10.1.7" />
</ItemGroup> </ItemGroup>
</Project> </Project>