Compare commits
15 Commits
Author | SHA1 | Date | |
---|---|---|---|
f04c1ec1b9
|
|||
ca72a0c8f9
|
|||
7219caa4ff
|
|||
2cd46e37ef
|
|||
7c8bfad01f
|
|||
4821316ee9
|
|||
798cd355b2
|
|||
eab152e928
|
|||
60e7136bcd
|
|||
99b5401c38
|
|||
b6c133bb54
|
|||
58a1a8ee2f
|
|||
bbeebda027
|
|||
267ec22c6f
|
|||
a95bf7a43e
|
@@ -11,60 +11,29 @@ permissions:
|
|||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
runs-on: ubuntu-latest
|
name: Build image
|
||||||
services:
|
runs-on: ubuntu-22.04
|
||||||
docker:
|
container: catthehacker/ubuntu:act-latest
|
||||||
image: docker:dind
|
|
||||||
env:
|
|
||||||
DOCKER_TLS_CERTDIR: ""
|
|
||||||
container:
|
|
||||||
image: docker:24-git
|
|
||||||
env:
|
|
||||||
DOCKER_HOST: tcp://docker:2375
|
|
||||||
DOCKER_TLS_CERTDIR: ""
|
|
||||||
env:
|
env:
|
||||||
REGISTRY: hub.realmanual.ru
|
REGISTRY: git.realmanual.ru
|
||||||
IMAGE_NAME: pub/sqlite-backup/backup
|
IMAGE_NAME: ${{ gitea.repository }}
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout (git)
|
- name: Checkout repository
|
||||||
shell: sh
|
uses: actions/checkout@v4
|
||||||
env:
|
|
||||||
TOKEN: ${{ secrets.GITEA_TOKEN }}
|
|
||||||
run: |
|
|
||||||
set -eu
|
|
||||||
: "${GITHUB_SERVER_URL:?}"
|
|
||||||
: "${GITHUB_REPOSITORY:?}"
|
|
||||||
: "${GITHUB_SHA:?}"
|
|
||||||
git init .
|
|
||||||
git remote add origin "${GITHUB_SERVER_URL}/${GITHUB_REPOSITORY}.git"
|
|
||||||
git -c http.extraHeader="Authorization: Bearer ${TOKEN}" fetch --no-tags --depth=1 origin "${GITHUB_SHA}"
|
|
||||||
git checkout --detach "${GITHUB_SHA}"
|
|
||||||
|
|
||||||
- name: Extract tag
|
- name: Log in to the Container registry
|
||||||
id: vars
|
uses: docker/login-action@v3
|
||||||
shell: sh
|
with:
|
||||||
run: |
|
registry: ${{ env.REGISTRY }}
|
||||||
TAG_REF="${GITHUB_REF#refs/tags/}"
|
username: ${{ gitea.actor }}
|
||||||
echo "tag=$TAG_REF" >> "$GITHUB_OUTPUT"
|
password: ${{ secrets.PUSH_TOKEN }}
|
||||||
|
|
||||||
- name: Docker login
|
- name: Build and push Docker image
|
||||||
shell: sh
|
id: push
|
||||||
run: |
|
uses: docker/build-push-action@v6
|
||||||
set -eu
|
with:
|
||||||
echo "${{ secrets.GITEA_TOKEN }}" | docker login "${{ env.REGISTRY }}" --username "${{ github.actor }}" --password-stdin
|
context: .
|
||||||
|
push: true
|
||||||
- name: Build image
|
tags: |
|
||||||
shell: sh
|
${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ gitea.ref_name }}
|
||||||
run: |
|
${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:latest
|
||||||
set -eu
|
|
||||||
docker build \
|
|
||||||
-t "${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ steps.vars.outputs.tag }}" \
|
|
||||||
-t "${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:latest" \
|
|
||||||
.
|
|
||||||
|
|
||||||
- name: Push images
|
|
||||||
shell: sh
|
|
||||||
run: |
|
|
||||||
set -eu
|
|
||||||
docker push "${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ steps.vars.outputs.tag }}"
|
|
||||||
docker push "${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:latest"
|
|
||||||
|
@@ -3,7 +3,7 @@
|
|||||||
```yaml
|
```yaml
|
||||||
services:
|
services:
|
||||||
sqlite_backup:
|
sqlite_backup:
|
||||||
image: hub.realmanual.ru/pub/sqlite-backup/backup:latest
|
image: git.realmanual.ru/pub/sqlite-backup-s3
|
||||||
container_name: sqlite_backup
|
container_name: sqlite_backup
|
||||||
restart: always
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
services:
|
services:
|
||||||
sqlite_backup:
|
sqlite_backup:
|
||||||
image: hub.realmanual.ru/pub/sqlite-backup/backup:latest
|
image: git.realmanual.ru/pub/sqlite-backup/backup:latest
|
||||||
container_name: sqlite_backup
|
container_name: sqlite_backup
|
||||||
restart: always
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
|
@@ -1,6 +1,8 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
echo "${CRONTAB} /scripts/backup.sh" > /etc/crontabs/root
|
# Create crontab in a writable location
|
||||||
|
mkdir -p /tmp/crontabs
|
||||||
|
echo "${CRONTAB} /scripts/backup.sh" > /tmp/crontabs/root
|
||||||
|
|
||||||
/scripts/backup.sh
|
/scripts/backup.sh
|
||||||
exec crond -f
|
exec crond -f -c /tmp/crontabs
|
||||||
|
@@ -1,18 +1,32 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
rclone config create myminio s3 provider Minio access_key_id $MINIO_ACCOUNT_ID secret_access_key $MINIO_APPLICATION_KEY endpoint $MINIO_ENDPOINT region $MINIO_LOCATION acl private
|
# Create rclone config on-the-fly in a writable location
|
||||||
|
RCLONE_CONFIG_DIR="/tmp/rclone"
|
||||||
|
mkdir -p "$RCLONE_CONFIG_DIR"
|
||||||
|
export RCLONE_CONFIG="$RCLONE_CONFIG_DIR/rclone.conf"
|
||||||
|
|
||||||
|
cat > "$RCLONE_CONFIG" << EOF
|
||||||
|
[myminio]
|
||||||
|
type = s3
|
||||||
|
provider = Minio
|
||||||
|
access_key_id = $MINIO_ACCOUNT_ID
|
||||||
|
secret_access_key = $MINIO_APPLICATION_KEY
|
||||||
|
endpoint = $MINIO_ENDPOINT
|
||||||
|
region = $MINIO_LOCATION
|
||||||
|
acl = private
|
||||||
|
EOF
|
||||||
|
|
||||||
case $1 in
|
case $1 in
|
||||||
copy)
|
copy)
|
||||||
echo "copy from $2 to $3"
|
echo "copy from $2 to $3"
|
||||||
rclone copy --progress $2 $3
|
rclone copy --progress $2 myminio:$3
|
||||||
;;
|
;;
|
||||||
list)
|
list)
|
||||||
echo "list $2"
|
echo "list $2"
|
||||||
rclone ls $2
|
rclone ls myminio:$2
|
||||||
;;
|
;;
|
||||||
delete)
|
delete)
|
||||||
echo "delete $2"
|
echo "delete $2"
|
||||||
rclone delete $2
|
rclone delete myminio:$2
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
Reference in New Issue
Block a user