Add cuddle
This commit is contained in:
parent
553b8722de
commit
0575825eda
87
.drone.yml
Normal file
87
.drone.yml
Normal file
@ -0,0 +1,87 @@
|
|||||||
|
kind: pipeline
|
||||||
|
name: default
|
||||||
|
type: docker
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: load_secret
|
||||||
|
image: debian:buster-slim
|
||||||
|
volumes:
|
||||||
|
- name: ssh
|
||||||
|
path: /root/.ssh/
|
||||||
|
environment:
|
||||||
|
SSH_KEY:
|
||||||
|
from_secret: gitea_id_ed25519
|
||||||
|
commands:
|
||||||
|
- mkdir -p $HOME/.ssh/
|
||||||
|
- echo "$SSH_KEY" | base64 -d > $HOME/.ssh/id_ed25519
|
||||||
|
|
||||||
|
- name: build
|
||||||
|
image: kasperhermansen/cuddle:latest
|
||||||
|
pull: always
|
||||||
|
volumes:
|
||||||
|
- name: ssh
|
||||||
|
path: /root/.ssh/
|
||||||
|
- name: dockersock
|
||||||
|
path: /var/run
|
||||||
|
commands:
|
||||||
|
- apk add bash git
|
||||||
|
- git remote set-url origin $DRONE_GIT_SSH_URL
|
||||||
|
- cuddle_cli x setup_ssh
|
||||||
|
- cuddle_cli x start_deployment
|
||||||
|
- cuddle_cli x render_templates
|
||||||
|
- cuddle_cli x build_release
|
||||||
|
- cuddle_cli x push_release
|
||||||
|
- cuddle_cli x deploy_release
|
||||||
|
environment:
|
||||||
|
DOCKER_BUILDKIT: 1
|
||||||
|
DOCKER_USERNAME:
|
||||||
|
from_secret: docker_username
|
||||||
|
DOCKER_PASSWORD:
|
||||||
|
from_secret: docker_password
|
||||||
|
SSH_KEY:
|
||||||
|
from_secret: gitea_id_ed25519
|
||||||
|
depends_on:
|
||||||
|
- "load_secret"
|
||||||
|
|
||||||
|
- name: push_tags
|
||||||
|
image: kasperhermansen/drone-semantic-release:latest
|
||||||
|
pull: always
|
||||||
|
volumes:
|
||||||
|
- name: ssh
|
||||||
|
path: /root/.ssh/
|
||||||
|
- name: dockersock
|
||||||
|
path: /var/run
|
||||||
|
commands:
|
||||||
|
- semantic-release --no-ci
|
||||||
|
environment:
|
||||||
|
DOCKER_BUILDKIT: 1
|
||||||
|
SSH_KEY:
|
||||||
|
from_secret: gitea_id_ed25519
|
||||||
|
depends_on:
|
||||||
|
- build
|
||||||
|
|
||||||
|
- name: send telegram notification
|
||||||
|
image: appleboy/drone-telegram
|
||||||
|
settings:
|
||||||
|
token:
|
||||||
|
from_secret: telegram_token
|
||||||
|
to: 2129601481
|
||||||
|
format: markdown
|
||||||
|
depends_on:
|
||||||
|
- build
|
||||||
|
- push_tags
|
||||||
|
when:
|
||||||
|
status: [failure, success]
|
||||||
|
|
||||||
|
services:
|
||||||
|
- name: docker
|
||||||
|
image: docker:dind
|
||||||
|
privileged: true
|
||||||
|
volumes:
|
||||||
|
- name: dockersock
|
||||||
|
path: /var/run
|
||||||
|
volumes:
|
||||||
|
- name: ssh
|
||||||
|
temp: {}
|
||||||
|
- name: dockersock
|
||||||
|
temp: {}
|
1
.gitignore
vendored
1
.gitignore
vendored
@ -34,3 +34,4 @@ yarn-error.log*
|
|||||||
# typescript
|
# typescript
|
||||||
*.tsbuildinfo
|
*.tsbuildinfo
|
||||||
next-env.d.ts
|
next-env.d.ts
|
||||||
|
.cuddle/
|
||||||
|
8
.releaserc.yml
Normal file
8
.releaserc.yml
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
branches:
|
||||||
|
- "main"
|
||||||
|
|
||||||
|
plugins:
|
||||||
|
- "@semantic-release/commit-analyzer"
|
||||||
|
- "@semantic-release/release-notes-generator"
|
||||||
|
- "@semantic-release/changelog"
|
||||||
|
- "@semantic-release/git"
|
@ -1,10 +0,0 @@
|
|||||||
version: "3"
|
|
||||||
|
|
||||||
services:
|
|
||||||
rawpotion-man:
|
|
||||||
build:
|
|
||||||
context: .
|
|
||||||
dockerfile: scripts/docker/prod.Dockerfile
|
|
||||||
restart: unless-stopped
|
|
||||||
ports:
|
|
||||||
- 3000:3000
|
|
59
scripts/build_release.sh
Executable file
59
scripts/build_release.sh
Executable file
@ -0,0 +1,59 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
base_tag=$REGISTRY/$SERVICE
|
||||||
|
tag="$base_tag:${COMMIT_SHA:0:10}"
|
||||||
|
latest_tag="$base_tag:latest"
|
||||||
|
|
||||||
|
if [[ -n $DEBUG ]]
|
||||||
|
then
|
||||||
|
echo "debug:"
|
||||||
|
echo " REGISTRY: $REGISTRY"
|
||||||
|
echo " SERVICE: $SERVICE"
|
||||||
|
echo " COMMIT_SHA: $COMMIT_SHA"
|
||||||
|
echo " TMP: $TMP"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "docker: logging in"
|
||||||
|
docker login -u $DOCKER_USERNAME -p $DOCKER_PASSWORD
|
||||||
|
|
||||||
|
export DOCKER_BUILDKIT=1
|
||||||
|
|
||||||
|
function pull_target {
|
||||||
|
target=$1
|
||||||
|
echo "pulling $target"
|
||||||
|
latest_target_tag="$base_tag-$target:latest"
|
||||||
|
|
||||||
|
docker pull $latest_target_tag
|
||||||
|
}
|
||||||
|
|
||||||
|
function build_target {
|
||||||
|
target=$1
|
||||||
|
echo "building $target"
|
||||||
|
latest_target_tag="$base_tag-$target:latest"
|
||||||
|
|
||||||
|
docker build \
|
||||||
|
--target "$target" \
|
||||||
|
--tag "$latest_target_tag" \
|
||||||
|
--build-arg BUILDKIT_INLINE_CACHE=1 \
|
||||||
|
--cache-from $latest_target_tag \
|
||||||
|
--file "$TMP/build_release.Dockerfile" .
|
||||||
|
}
|
||||||
|
|
||||||
|
pull_target "deps" &
|
||||||
|
pull_target "builder" &
|
||||||
|
wait
|
||||||
|
|
||||||
|
build_target "deps"
|
||||||
|
build_target "builder"
|
||||||
|
|
||||||
|
docker build \
|
||||||
|
-t "$tag" \
|
||||||
|
--cache-from "$base_tag-deps:latest" \
|
||||||
|
--cache-from "$base_tag-builder:latest" \
|
||||||
|
--build-arg BUILDKIT_INLINE_CACHE=1 \
|
||||||
|
--cache-from $latest_tag \
|
||||||
|
-f "$TMP/build_release.Dockerfile" .
|
||||||
|
docker tag "$tag" "$latest_tag"
|
||||||
|
|
10
scripts/deploy_release.sh
Executable file
10
scripts/deploy_release.sh
Executable file
@ -0,0 +1,10 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
echo "deploying image"
|
||||||
|
deploymentrepo="$TMP/deployments"
|
||||||
|
|
||||||
|
cd $deploymentrepo
|
||||||
|
|
||||||
|
git add . && git commit -m "Added release $SERVICE: ${COMMIT_SHA:0:10}" && git pull && git push
|
@ -1,63 +0,0 @@
|
|||||||
# Step 1. Rebuild the source code only when needed
|
|
||||||
FROM node:18-alpine AS builder
|
|
||||||
|
|
||||||
WORKDIR /app
|
|
||||||
|
|
||||||
# Install dependencies based on the preferred package manager
|
|
||||||
COPY package.json yarn.lock* package-lock.json* pnpm-lock.yaml* ./
|
|
||||||
# Omit --production flag for TypeScript devDependencies
|
|
||||||
RUN \
|
|
||||||
if [ -f yarn.lock ]; then yarn --frozen-lockfile; \
|
|
||||||
elif [ -f package-lock.json ]; then npm ci; \
|
|
||||||
elif [ -f pnpm-lock.yaml ]; then yarn global add pnpm && pnpm i; \
|
|
||||||
else echo "Lockfile not found." && exit 1; \
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
|
||||||
COPY src ./src
|
|
||||||
COPY public ./public
|
|
||||||
COPY posts ./posts
|
|
||||||
COPY next.config.js .
|
|
||||||
COPY tsconfig.json .
|
|
||||||
|
|
||||||
# Environment variables must be present at build time
|
|
||||||
# https://github.com/vercel/next.js/discussions/14030
|
|
||||||
ARG ENV_VARIABLE
|
|
||||||
ENV ENV_VARIABLE=${ENV_VARIABLE}
|
|
||||||
ARG NEXT_PUBLIC_ENV_VARIABLE
|
|
||||||
ENV NEXT_PUBLIC_ENV_VARIABLE=${NEXT_PUBLIC_ENV_VARIABLE}
|
|
||||||
|
|
||||||
# Uncomment the following line to disable telemetry at build time
|
|
||||||
# ENV NEXT_TELEMETRY_DISABLED 1
|
|
||||||
|
|
||||||
RUN yarn build
|
|
||||||
|
|
||||||
# Step 2. Production image, copy all the files and run next
|
|
||||||
FROM node:18-alpine AS runner
|
|
||||||
|
|
||||||
WORKDIR /app
|
|
||||||
|
|
||||||
# Don't run production as root
|
|
||||||
RUN addgroup --system --gid 1001 nodejs
|
|
||||||
RUN adduser --system --uid 1001 nextjs
|
|
||||||
USER nextjs
|
|
||||||
|
|
||||||
COPY --from=builder /app/public ./public
|
|
||||||
|
|
||||||
# Automatically leverage output traces to reduce image size
|
|
||||||
# https://nextjs.org/docs/advanced-features/output-file-tracing
|
|
||||||
COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./
|
|
||||||
COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static
|
|
||||||
COPY --from=builder --chown=nextjs:nodejs /app/posts ./posts
|
|
||||||
|
|
||||||
# Environment variables must be redefined at run time
|
|
||||||
ARG ENV_VARIABLE
|
|
||||||
ENV ENV_VARIABLE=${ENV_VARIABLE}
|
|
||||||
ARG NEXT_PUBLIC_ENV_VARIABLE
|
|
||||||
ENV NEXT_PUBLIC_ENV_VARIABLE=${NEXT_PUBLIC_ENV_VARIABLE}
|
|
||||||
|
|
||||||
# Uncomment the following line to disable telemetry at run time
|
|
||||||
# ENV NEXT_TELEMETRY_DISABLED 1
|
|
||||||
|
|
||||||
CMD node server.js
|
|
||||||
|
|
5
scripts/download.sh
Executable file
5
scripts/download.sh
Executable file
@ -0,0 +1,5 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
pnpm i
|
10
scripts/generate_graphql.sh
Executable file
10
scripts/generate_graphql.sh
Executable file
@ -0,0 +1,10 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
cuddle_cli x download
|
||||||
|
|
||||||
|
pnpm run generate:graphql
|
||||||
|
pnpm run format:graphql
|
||||||
|
|
||||||
|
git diff src/lib/graphql/generated.ts
|
40
scripts/push_release.sh
Executable file
40
scripts/push_release.sh
Executable file
@ -0,0 +1,40 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
base_tag="$REGISTRY/$SERVICE"
|
||||||
|
tag="$base_tag:${COMMIT_SHA:0:10}"
|
||||||
|
latest_tag="$base_tag:latest"
|
||||||
|
|
||||||
|
if [[ -n $DEBUG ]]
|
||||||
|
then
|
||||||
|
echo "debug:"
|
||||||
|
echo " REGISTRY: $REGISTRY"
|
||||||
|
echo " SERVICE: $SERVICE"
|
||||||
|
echo " COMMIT_SHA: $COMMIT_SHA"
|
||||||
|
echo " TMP: $TMP"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "docker: logging in"
|
||||||
|
docker login -u $DOCKER_USERNAME -p $DOCKER_PASSWORD
|
||||||
|
|
||||||
|
export DOCKER_BUILDKIT=1
|
||||||
|
|
||||||
|
function push_target {
|
||||||
|
target=$1
|
||||||
|
echo "pushing $target"
|
||||||
|
latest_target_tag="$base_tag-$target:latest"
|
||||||
|
docker push "$latest_target_tag"
|
||||||
|
}
|
||||||
|
|
||||||
|
function push_main_target {
|
||||||
|
echo "docker: pushing image $tag"
|
||||||
|
docker push "$tag"
|
||||||
|
docker push "$latest_tag"
|
||||||
|
}
|
||||||
|
|
||||||
|
push_target "deps" &
|
||||||
|
push_target "builder" &
|
||||||
|
push_main_target &
|
||||||
|
wait
|
||||||
|
|
11
scripts/render_templates.sh
Executable file
11
scripts/render_templates.sh
Executable file
@ -0,0 +1,11 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
tag="$REGISTRY/$SERVICE:${COMMIT_SHA:0:10}"
|
||||||
|
deploymentrepo="$TMP/deployments"
|
||||||
|
|
||||||
|
CUDDLE_FETCH_POLICY=never cuddle_cli render_template \
|
||||||
|
--template-file "$TMP/docker-compose.deploy_release.yml.tmpl" \
|
||||||
|
--dest "$deploymentrepo/$SERVICE/docker-compose.yml" \
|
||||||
|
--extra-var "image=$tag"
|
24
scripts/setup_ssh.sh
Executable file
24
scripts/setup_ssh.sh
Executable file
@ -0,0 +1,24 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
if [ ! -d ~/.ssh ]; then
|
||||||
|
mkdir -p ~/.ssh
|
||||||
|
chmod 700 ~/.ssh
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -n "$SSH_KEY" ]; then
|
||||||
|
SSH_KEY_ID="$HOME/.ssh/id_ed25519"
|
||||||
|
echo $SSH_KEY | base64 -d > $SSH_KEY_ID
|
||||||
|
|
||||||
|
chmod 600 $SSH_KEY_ID
|
||||||
|
|
||||||
|
cat >$HOME/.ssh/config <<EOL
|
||||||
|
Host git.front.kjuulh.io
|
||||||
|
IdentityFile ${SSH_KEY_ID}
|
||||||
|
IdentitiesOnly yes
|
||||||
|
UserKnownHostsFile=/dev/null
|
||||||
|
StrictHostKeyChecking no
|
||||||
|
EOL
|
||||||
|
|
||||||
|
fi
|
17
scripts/start_deployment.sh
Executable file
17
scripts/start_deployment.sh
Executable file
@ -0,0 +1,17 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
echo "Starting deployment"
|
||||||
|
|
||||||
|
deploymentrepo="$TMP/deployments"
|
||||||
|
|
||||||
|
[ -d $deploymentrepo ] && rm -rf $deploymentrepo
|
||||||
|
|
||||||
|
git clone "$DEPLOYMENTS" $deploymentrepo
|
||||||
|
[ ! -d $deploymentrepo ] && echo "deployments could not be cloned aborting" && exit 1
|
||||||
|
|
||||||
|
echo "$deploymentrepo"
|
||||||
|
|
||||||
|
mkdir -p "$deploymentrepo/$SERVICE"
|
||||||
|
|
56
templates/build_release.Dockerfile
Normal file
56
templates/build_release.Dockerfile
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
# Install dependencies only when needed
|
||||||
|
FROM node:16-alpine AS deps
|
||||||
|
# Check https://github.com/nodejs/docker-node/tree/b4117f9333da4138b03a546ec926ef50a31506c3#nodealpine to understand why libc6-compat might be needed.
|
||||||
|
RUN apk add --no-cache libc6-compat
|
||||||
|
RUN yarn global add pnpm
|
||||||
|
WORKDIR /app
|
||||||
|
|
||||||
|
# Install dependencies based on the preferred package manager
|
||||||
|
COPY package.json pnpm-lock.yaml* ./
|
||||||
|
RUN pnpm i
|
||||||
|
|
||||||
|
|
||||||
|
# Rebuild the source code only when needed
|
||||||
|
FROM node:16-alpine AS builder
|
||||||
|
WORKDIR /app
|
||||||
|
COPY --from=deps /app/node_modules ./node_modules
|
||||||
|
COPY . .
|
||||||
|
|
||||||
|
# Next.js collects completely anonymous telemetry data about general usage.
|
||||||
|
# Learn more here: https://nextjs.org/telemetry
|
||||||
|
# Uncomment the following line in case you want to disable telemetry during the build.
|
||||||
|
# ENV NEXT_TELEMETRY_DISABLED 1
|
||||||
|
|
||||||
|
RUN yarn build
|
||||||
|
|
||||||
|
# If using npm comment out above and use below instead
|
||||||
|
# RUN npm run build
|
||||||
|
|
||||||
|
# Production image, copy all the files and run next
|
||||||
|
FROM node:16-alpine AS runner
|
||||||
|
WORKDIR /app
|
||||||
|
|
||||||
|
ENV NODE_ENV production
|
||||||
|
# Uncomment the following line in case you want to disable telemetry during runtime.
|
||||||
|
# ENV NEXT_TELEMETRY_DISABLED 1
|
||||||
|
|
||||||
|
RUN addgroup --system --gid 1001 nodejs
|
||||||
|
RUN adduser --system --uid 1001 nextjs
|
||||||
|
|
||||||
|
# You only need to copy next.config.js if you are NOT using the default configuration
|
||||||
|
# COPY --from=builder /app/next.config.js ./
|
||||||
|
COPY --from=builder /app/public ./public
|
||||||
|
COPY --from=builder /app/package.json ./package.json
|
||||||
|
|
||||||
|
# Automatically leverage output traces to reduce image size
|
||||||
|
# https://nextjs.org/docs/advanced-features/output-file-tracing
|
||||||
|
COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./
|
||||||
|
COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static
|
||||||
|
|
||||||
|
USER nextjs
|
||||||
|
|
||||||
|
EXPOSE 3000
|
||||||
|
|
||||||
|
ENV PORT 3000
|
||||||
|
|
||||||
|
CMD ["node", "server.js"]
|
7
templates/build_release.Dockerfile.dockerignore
Normal file
7
templates/build_release.Dockerfile.dockerignore
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
.next/
|
||||||
|
.git/
|
||||||
|
.cuddle/
|
||||||
|
node_modules/
|
||||||
|
scripts/
|
||||||
|
.drone.yml
|
||||||
|
.releaserc.yml
|
9
templates/docker-compose.deploy_release.yml.tmpl
Normal file
9
templates/docker-compose.deploy_release.yml.tmpl
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
version: '3.7'
|
||||||
|
|
||||||
|
services:
|
||||||
|
{{ service }}:
|
||||||
|
image: {{ image }}
|
||||||
|
ports:
|
||||||
|
- {{ port }}
|
||||||
|
env_file: ".env"
|
||||||
|
restart: always
|
Loading…
Reference in New Issue
Block a user