Compare commits

..

1 Commits

Author SHA1 Message Date
90e5624576 chore: set up commitlint and git hooks
Some checks failed
Commit Message Check / conventional-commits (pull_request) Failing after 1m53s
Deploy monie-backend to dev (kaniko) / build-and-deploy (pull_request) Successful in 0s
Deploy monie-backend (kaniko) / build-and-deploy (pull_request) Successful in 0s
2026-04-04 23:00:37 +03:00
7 changed files with 89 additions and 4 deletions

View File

@@ -8,3 +8,4 @@ coverage
.env .env
.env.* .env.*
README.md README.md
.codex

View File

@@ -0,0 +1,50 @@
name: Commit Message Check
on:
push:
branches: [ main, develop ]
pull_request:
jobs:
conventional-commits:
runs-on: [self-hosted, linux]
steps:
- name: Checkout
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: 22
cache: npm
- name: Install dependencies
run: npm ci --ignore-scripts
- name: Validate commit messages with commitlint
env:
EVENT_NAME: ${{ github.event_name }}
BEFORE_SHA: ${{ github.event.before }}
PR_BASE_SHA: ${{ github.event.pull_request.base.sha }}
HEAD_SHA: ${{ github.sha }}
run: |
set -euo pipefail
BASE_SHA=""
if [ "${EVENT_NAME}" = "pull_request" ] && [ -n "${PR_BASE_SHA:-}" ]; then
BASE_SHA="${PR_BASE_SHA}"
elif [ -n "${BEFORE_SHA:-}" ] && [ "${BEFORE_SHA}" != "0000000000000000000000000000000000000000" ]; then
BASE_SHA="${BEFORE_SHA}"
elif git rev-parse "${HEAD_SHA}^" >/dev/null 2>&1; then
BASE_SHA="$(git rev-parse "${HEAD_SHA}^")"
fi
if [ -n "${BASE_SHA}" ] && [ "${BASE_SHA}" != "${HEAD_SHA}" ]; then
npx --no -- commitlint --from "${BASE_SHA}" --to "${HEAD_SHA}" --verbose
else
git log -1 --format=%s "${HEAD_SHA}" | npx --no -- commitlint --verbose
fi

View File

@@ -3,6 +3,7 @@ name: Deploy monie-backend to dev (kaniko)
on: on:
push: push:
branches: [ develop ] branches: [ develop ]
pull_request:
jobs: jobs:
build-and-deploy: build-and-deploy:
@@ -26,7 +27,12 @@ jobs:
REPO_PATH: monie/monie-backend.git REPO_PATH: monie/monie-backend.git
steps: steps:
- name: Skip deploy for pull requests
if: github.event_name == 'pull_request'
run: echo "Pull request check passed. Deploy runs only on push to develop."
- name: Debug - name: Debug
if: github.event_name == 'push'
run: | run: |
set -eu set -eu
echo "sha=${{ github.sha }}" echo "sha=${{ github.sha }}"
@@ -35,6 +41,7 @@ jobs:
microk8s kubectl version --client=true microk8s kubectl version --client=true
- name: Build & push with Kaniko (K8s Job) - name: Build & push with Kaniko (K8s Job)
if: github.event_name == 'push'
env: env:
SHA: ${{ github.sha }} SHA: ${{ github.sha }}
REF: ${{ github.ref_name }} REF: ${{ github.ref_name }}
@@ -131,6 +138,7 @@ jobs:
fi fi
- name: Deploy to dev - name: Deploy to dev
if: github.event_name == 'push'
env: env:
SHA: ${{ github.sha }} SHA: ${{ github.sha }}
run: | run: |

View File

@@ -1,9 +1,9 @@
# .gitea/workflows/deploy-prod.yml
name: Deploy monie-backend (kaniko) name: Deploy monie-backend (kaniko)
on: on:
push: push:
branches: [ main ] branches: [ main ]
pull_request:
jobs: jobs:
build-and-deploy: build-and-deploy:
@@ -27,7 +27,12 @@ jobs:
REPO_PATH: monie/monie-backend.git REPO_PATH: monie/monie-backend.git
steps: steps:
- name: Skip deploy for pull requests
if: github.event_name == 'pull_request'
run: echo "Pull request check passed. Deploy runs only on push to main."
- name: Build & push image with Kaniko (K8s Job) - name: Build & push image with Kaniko (K8s Job)
if: github.event_name == 'push'
env: env:
SHA: ${{ github.sha }} SHA: ${{ github.sha }}
REF: ${{ github.ref_name }} REF: ${{ github.ref_name }}
@@ -120,6 +125,7 @@ jobs:
fi fi
- name: Deploy to prod - name: Deploy to prod
if: github.event_name == 'push'
env: env:
SHA: ${{ github.sha }} SHA: ${{ github.sha }}
run: | run: |

1
.gitignore vendored
View File

@@ -34,6 +34,7 @@ lerna-debug.log*
!.vscode/tasks.json !.vscode/tasks.json
!.vscode/launch.json !.vscode/launch.json
!.vscode/extensions.json !.vscode/extensions.json
.codex
# dotenv environment variable files # dotenv environment variable files
.env .env

19
.husky/pre-push Executable file
View File

@@ -0,0 +1,19 @@
#!/usr/bin/env sh
branch="$(git rev-parse --abbrev-ref HEAD)"
case "$branch" in
main|develop)
echo "Direct pushes to $branch are not allowed."
echo "Please create a feature/... or bugfix/... branch and open a PR/MR."
exit 1
;;
feature/*|bugfix/*|hotfix/*|chore/*)
exit 0
;;
*)
echo "Invalid branch name: $branch"
echo "Allowed branch prefixes: feature/*, bugfix/*, hotfix/*, chore/*"
exit 1
;;
esac

View File

@@ -1,15 +1,15 @@
FROM node:22-bookworm-slim AS deps FROM node:24-bookworm-slim AS deps
WORKDIR /app WORKDIR /app
COPY package*.json ./ COPY package*.json ./
RUN npm ci RUN npm ci
FROM node:22-bookworm-slim AS build FROM node:24-bookworm-slim AS build
WORKDIR /app WORKDIR /app
COPY --from=deps /app/node_modules ./node_modules COPY --from=deps /app/node_modules ./node_modules
COPY . . COPY . .
RUN npm run build && npm prune --omit=dev RUN npm run build && npm prune --omit=dev
FROM node:22-bookworm-slim AS runner FROM node:24-bookworm-slim AS runner
WORKDIR /app WORKDIR /app
ENV NODE_ENV=production ENV NODE_ENV=production
COPY package*.json ./ COPY package*.json ./