Compare commits
31 Commits
Author | SHA1 | Date |
---|---|---|
Danny Bessems | 2538247718 | |
Danny Bessems | 361a85592e | |
Danny Bessems | e83b98e116 | |
Danny Bessems | a4ced9e4b4 | |
Danny Bessems | cde06aae36 | |
Danny Bessems | f4ee0617cc | |
Danny Bessems | dce6d7fb1c | |
Danny Bessems | f09dfc99d2 | |
Danny Bessems | 396e2fe9b3 | |
Danny Bessems | 3501cd51f3 | |
Danny Bessems | 78cb46795f | |
Danny Bessems | 48e8b21c30 | |
Danny Bessems | b19a3f7391 | |
Danny Bessems | cde425809f | |
Danny Bessems | 6170a12b19 | |
Danny Bessems | a12ce0a9e9 | |
Danny Bessems | 2c749e2077 | |
Danny Bessems | 1f2081f05c | |
Danny Bessems | 1d791a3820 | |
Danny Bessems | 7f5242eedc | |
Danny Bessems | ec276c088d | |
Danny Bessems | 1ab1c10f37 | |
Danny Bessems | 4deac9ab13 | |
Danny Bessems | 2f6c7f7f91 | |
Danny Bessems | d24792b8c3 | |
Danny Bessems | 55afb79de5 | |
Danny Bessems | 0fa80669cd | |
Danny Bessems | 38eb4e9faa | |
Danny Bessems | c6815721df | |
Danny Bessems | ff42784426 | |
Danny Bessems | d6e01f3c23 |
185
.drone.yml
185
.drone.yml
|
@ -1,55 +1,152 @@
|
|||
kind: pipeline
|
||||
type: kubernetes
|
||||
name: Container image
|
||||
name: Container & Helm chart
|
||||
|
||||
trigger:
|
||||
event:
|
||||
exclude:
|
||||
- tag
|
||||
|
||||
steps:
|
||||
- name: Build & publish (Harbor)
|
||||
depends_on:
|
||||
- clone
|
||||
image: plugins/docker
|
||||
context: .
|
||||
settings:
|
||||
repo: bv11-cr01.bessems.eu/library/json-server
|
||||
registry: bv11-cr01.bessems.eu
|
||||
tags: latest
|
||||
mtu: 1450
|
||||
username:
|
||||
from_secret: harbor_username
|
||||
password:
|
||||
from_secret: harbor_password
|
||||
- name: Build & publish (Dockerhub)
|
||||
depends_on:
|
||||
- clone
|
||||
image: plugins/docker
|
||||
context: .
|
||||
settings:
|
||||
repo: djpbessems/json-server
|
||||
tags: latest
|
||||
mtu: 1450
|
||||
username:
|
||||
from_secret: docker_username
|
||||
password:
|
||||
from_secret: docker_password
|
||||
|
||||
---
|
||||
kind: pipeline
|
||||
type: kubernetes
|
||||
name: Helm chart (Gitea)
|
||||
|
||||
steps:
|
||||
- name: Package & publish
|
||||
image: bv11-cr01.bessems.eu/proxy/alpine/helm
|
||||
- name: Semantic Release (Dry-run)
|
||||
image: bv11-cr01.bessems.eu/proxy/library/node:20-slim
|
||||
pull: always
|
||||
commands:
|
||||
- |
|
||||
apk add yq
|
||||
apt-get update
|
||||
- |
|
||||
helm package ./charts/json-server
|
||||
apt-get install -y --no-install-recommends \
|
||||
git-core \
|
||||
ca-certificates
|
||||
- |
|
||||
CHART_VERSION=$(cat ./charts/json-server/Chart.yaml | yq '.version')
|
||||
curl \
|
||||
--header "Authorization: token $GIT_APIKEY" \
|
||||
--upload-file json-server-$CHART_VERSION.tgz \
|
||||
https://code.spamasaurus.com/api/packages/$GIT_USERNAME/helm/api/charts
|
||||
npm install \
|
||||
semantic-release \
|
||||
@semantic-release/commit-analyzer \
|
||||
@semantic-release/exec \
|
||||
- |
|
||||
export GIT_CREDENTIALS=$${GIT_USERNAME}:$${GIT_APIKEY}
|
||||
- |
|
||||
npx semantic-release \
|
||||
--package @semantic-release/exec \
|
||||
--package semantic-release \
|
||||
--branches ${DRONE_BRANCH} \
|
||||
--tag-format "v\$${version}" \
|
||||
--dry-run \
|
||||
--plugins @semantic-release/commit-analyzer,@semantic-release/exec \
|
||||
--analyzeCommits @semantic-release/commit-analyzer \
|
||||
--verifyRelease @semantic-release/exec \
|
||||
--verifyReleaseCmd 'echo "$${nextRelease.version}" > .version'
|
||||
environment:
|
||||
GIT_APIKEY:
|
||||
from_secret: git_apikey
|
||||
GIT_USERNAME: djpbessems
|
||||
|
||||
- name: Container image (Harbor)
|
||||
depends_on:
|
||||
- Semantic Release (Dry-run)
|
||||
image: gcr.io/kaniko-project/executor:debug
|
||||
pull: always
|
||||
commands:
|
||||
- |
|
||||
wget https://github.com/jqlang/jq/releases/download/jq-1.6/jq-linux64 -qO /bin/jq
|
||||
chmod +x /bin/jq
|
||||
- |
|
||||
/bin/jq '.auths["https://bv11-cr01.bessems.eu/v2/"].auth="'"$(echo -n $HARBOR_USERNAME':'$HARBOR_PASSWORD | base64)"'"' --null-input > /kaniko/.docker/config.json
|
||||
- |
|
||||
export IMAGE_TAG=$(cat .version)
|
||||
- |
|
||||
/kaniko/executor \
|
||||
--dockerfile=Dockerfile \
|
||||
--context=dir://. \
|
||||
--destination=bv11-cr01.bessems.eu/library/json-server:latest \
|
||||
--destination=bv11-cr01.bessems.eu/library/json-server:$IMAGE_TAG
|
||||
environment:
|
||||
HARBOR_USERNAME:
|
||||
from_secret: harbor_username
|
||||
HARBOR_PASSWORD:
|
||||
from_secret: harbor_password
|
||||
|
||||
- name: Container image (docker.io)
|
||||
depends_on:
|
||||
- Semantic Release (Dry-run)
|
||||
image: gcr.io/kaniko-project/executor:debug
|
||||
pull: always
|
||||
commands:
|
||||
- |
|
||||
wget https://github.com/jqlang/jq/releases/download/jq-1.6/jq-linux64 -qO /bin/jq
|
||||
chmod +x /bin/jq
|
||||
- |
|
||||
export IMAGE_TAG=$(cat .version)
|
||||
- |
|
||||
/bin/jq '.auths["https://index.docker.io/v1/"].auth="'"$(echo -n $DOCKER_USERNAME':'$DOCKER_PASSWORD | base64)"'"' --null-input > /kaniko/.docker/config.json
|
||||
- |
|
||||
/kaniko/executor \
|
||||
--dockerfile=Dockerfile \
|
||||
--context=dir://. \
|
||||
--destination=docker.io/djpbessems/json-server:latest \
|
||||
--destination=docker.io/djpbessems/json-server:$IMAGE_TAG
|
||||
environment:
|
||||
DOCKER_USERNAME:
|
||||
from_secret: docker_username
|
||||
DOCKER_PASSWORD:
|
||||
from_secret: docker_password
|
||||
|
||||
- name: Helm chart (Gitea)
|
||||
depends_on:
|
||||
- Semantic Release (Dry-run)
|
||||
image: bv11-cr01.bessems.eu/proxy/alpine/helm
|
||||
pull: always
|
||||
commands:
|
||||
- |
|
||||
export CHART_VERSION=$(cat .version)
|
||||
sed -i 's/{{ chart_version }}/'$CHART_VERSION'/g' charts/json-server/Chart.yaml
|
||||
sed -i 's/tag: latest/tag: '$CHART_VERSION'/g' charts/json-server/values.yaml
|
||||
- |
|
||||
helm package ./charts/json-server
|
||||
- |
|
||||
helm plugin install https://github.com/chartmuseum/helm-push
|
||||
- |
|
||||
helm repo add \
|
||||
--username $GIT_USERNAME \
|
||||
--password $GIT_APIKEY \
|
||||
spamasaurus \
|
||||
https://code.spamasaurus.com/api/packages/$GIT_USERNAME/helm
|
||||
- |
|
||||
helm cm-push \
|
||||
json-server-*.tgz \
|
||||
spamasaurus
|
||||
environment:
|
||||
GIT_APIKEY:
|
||||
from_secret: git_apikey
|
||||
GIT_USERNAME: djpbessems
|
||||
|
||||
- name: Semantic Release
|
||||
depends_on:
|
||||
- Container image (Harbor)
|
||||
- Container image (docker.io)
|
||||
- Helm chart (Gitea)
|
||||
image: bv11-cr01.bessems.eu/proxy/library/node:20-slim
|
||||
pull: always
|
||||
commands:
|
||||
- |
|
||||
apt-get update
|
||||
- |
|
||||
apt-get install -y --no-install-recommends \
|
||||
git-core \
|
||||
ca-certificates
|
||||
- |
|
||||
npm install \
|
||||
semantic-release \
|
||||
@semantic-release/commit-analyzer \
|
||||
@semantic-release/git \
|
||||
@semantic-release/release-notes-generator
|
||||
- |
|
||||
export GIT_CREDENTIALS=$${GIT_USERNAME}:$${GIT_APIKEY}
|
||||
- |
|
||||
npx semantic-release \
|
||||
--branches ${DRONE_BRANCH} \
|
||||
--tag-format "v\$${version}" \
|
||||
--plugins @semantic-release/commit-analyzer,@semantic-release/release-notes-generator,@semantic-release/git
|
||||
environment:
|
||||
GIT_APIKEY:
|
||||
from_secret: git_apikey
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
FROM node:latest
|
||||
FROM node:lts-slim AS build
|
||||
|
||||
RUN npm install -g --no-optional --omit=dev \
|
||||
RUN npm install -g --omit=optional --omit=dev \
|
||||
json-server && \
|
||||
npm cache clean --force
|
||||
|
||||
|
|
|
@ -6,10 +6,10 @@ type: application
|
|||
# This is the chart version. This version number should be incremented each time you make changes
|
||||
# to the chart and its templates, including the app version.
|
||||
# Versions are expected to follow Semantic Versioning (https://semver.org/)
|
||||
version: v0.5.3
|
||||
version: v{{ chart_version }}
|
||||
|
||||
# This is the version number of the application being deployed. This version number should be
|
||||
# incremented each time you make changes to the application. Versions are not expected to
|
||||
# follow Semantic Versioning. They should reflect the version the application is using.
|
||||
# It is recommended to use it with quotes.
|
||||
appVersion: "v0.5.3"
|
||||
appVersion: "v{{ chart_version }}"
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,9 @@
|
|||
{
|
||||
"dependencies": {
|
||||
"@semantic-release/commit-analyzer": "^10.0.1",
|
||||
"@semantic-release/exec": "^6.0.3",
|
||||
"@semantic-release/git": "^10.0.1",
|
||||
"@semantic-release/release-notes-generator": "^11.0.4",
|
||||
"semantic-release": "^21.0.7"
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue