Compare commits
13 Commits
gitea-work
...
21b21ce73c
Author | SHA1 | Date | |
---|---|---|---|
21b21ce73c | |||
4a7fbef176 | |||
a1ec0ba829 | |||
6d78af4d3a | |||
85428100c0 | |||
407cfcfb69 | |||
5e03c2c30d | |||
9c1d769ed8 | |||
7989b82c04 | |||
b0e982ba6f | |||
e83868695b | |||
b6e113fbef | |||
b88e26100f |
64
.github/workflows/publish-image.yaml
vendored
64
.github/workflows/publish-image.yaml
vendored
@@ -1,14 +1,60 @@
|
||||
name: Docker image CI for GHCR
|
||||
name: Docker Image CI
|
||||
|
||||
on: push
|
||||
on:
|
||||
# schedule:
|
||||
# - cron: "0 10 * * *"
|
||||
push:
|
||||
branches:
|
||||
- "**"
|
||||
tags:
|
||||
- "v*.*.*"
|
||||
pull_request:
|
||||
|
||||
jobs:
|
||||
build_and_publish:
|
||||
docker:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- name: Build and push image
|
||||
run: |
|
||||
docker login --username anaxios --password ${{ secrets.GH_TOKEN }} ghcr.io
|
||||
docker build . --tag ghcr.io/anaxios/holesail-docker:latest
|
||||
docker push ghcr.io/anaxios/holesail-docker:latest
|
||||
- name: Docker meta
|
||||
id: meta
|
||||
uses: docker/metadata-action@v5
|
||||
with:
|
||||
# list of Docker images to use as base name for tags
|
||||
images: |
|
||||
anaxios/holesail
|
||||
# generate Docker tags based on the following events/attributes
|
||||
tags: |
|
||||
type=schedule
|
||||
type=ref,event=branch
|
||||
type=ref,event=pr
|
||||
type=semver,pattern={{version}}
|
||||
type=semver,pattern={{major}}.{{minor}}
|
||||
type=semver,pattern={{major}}
|
||||
type=sha
|
||||
|
||||
- name: Login to Docker Hub
|
||||
if: github.event_name != 'pull_request'
|
||||
uses: docker/login-action@v3
|
||||
with:
|
||||
username: ${{ secrets.DOCKER_USERNAME }}
|
||||
password: ${{ secrets.DOCKER_PASSWORD }}
|
||||
|
||||
# - name: Login to GHCR
|
||||
# if: github.event_name != 'pull_request'
|
||||
# uses: docker/login-action@v3
|
||||
# with:
|
||||
# registry: ghcr.io
|
||||
# username: ${{ github.repository_owner }}
|
||||
# password: ${{ secrets.GITHUB_TOKEN }}
|
||||
|
||||
- name: Set up QEMU
|
||||
uses: docker/setup-qemu-action@v3
|
||||
|
||||
- name: Set up Docker Buildx
|
||||
uses: docker/setup-buildx-action@v3
|
||||
|
||||
- name: Build and push
|
||||
uses: docker/build-push-action@v6
|
||||
with:
|
||||
push: ${{ github.event_name != 'pull_request' }}
|
||||
tags: ${{ steps.meta.outputs.tags }}
|
||||
labels: ${{ steps.meta.outputs.labels }}
|
34
Dockerfile
34
Dockerfile
@@ -1,23 +1,23 @@
|
||||
FROM node:lts-slim AS base
|
||||
|
||||
WORKDIR /temp
|
||||
RUN npm install -g holesail@2.1.0
|
||||
|
||||
FROM base AS dev
|
||||
|
||||
WORKDIR /
|
||||
COPY run.sh .
|
||||
COPY fetch-my-mc-connector.js .
|
||||
RUN chmod +x run.sh
|
||||
|
||||
RUN npm install -g holesail@1.10.1
|
||||
ENV MODE=server
|
||||
ENV HOST=0.0.0.0
|
||||
ENV PORT=8989
|
||||
ENV PUBLIC=true
|
||||
ENV USERNAME=admin
|
||||
ENV PASSWORD=admin
|
||||
ENV ROLE=user
|
||||
ENV KEY=""
|
||||
ENV MY_MC_API_KEY=""
|
||||
#ENV FORCE ""
|
||||
|
||||
ENV MODE server
|
||||
ENV HOST 0.0.0.0
|
||||
ENV PORT 8989
|
||||
ENV PUBLIC true
|
||||
ENV USERNAME admin
|
||||
ENV PASSWORD admin
|
||||
ENV ROLE user
|
||||
ENV CONNECTOR ""
|
||||
ENV FORCE ""
|
||||
|
||||
#EXPOSE 8989
|
||||
|
||||
WORKDIR /data
|
||||
|
||||
ENTRYPOINT [ "/temp/run.sh" ]
|
||||
CMD [ "/usr/bin/bash", "/run.sh" ]
|
||||
|
17
fetch-my-mc-connector.js
Normal file
17
fetch-my-mc-connector.js
Normal file
@@ -0,0 +1,17 @@
|
||||
const apiKey = process.env.MY_MC_API_KEY;
|
||||
|
||||
const result = fetch('https://api.my-mc.link/my-hash',{
|
||||
method: "GET",
|
||||
headers: {
|
||||
'Accept': 'application/json', 'Content-Type': 'application/json', 'x-my-mc-auth': apiKey}
|
||||
})
|
||||
.then(async response => {
|
||||
const r = await response.json();
|
||||
if (r.success == true) {
|
||||
console.log(r.message);
|
||||
} else {
|
||||
throw new Error("failed to fetch holesail key");
|
||||
}
|
||||
}).catch(err => {
|
||||
throw Error(err);
|
||||
})
|
51
run.sh
51
run.sh
@@ -1,5 +1,9 @@
|
||||
#!/bin/bash
|
||||
|
||||
#set -x
|
||||
|
||||
pid=0
|
||||
|
||||
CYAN="\033[1;96m"
|
||||
RED="\033[0;91m"
|
||||
GREEN="\033[0;92m"
|
||||
@@ -21,20 +25,26 @@ success() {
|
||||
print "$GREEN" "$1"
|
||||
}
|
||||
|
||||
get_connector_my_mc() {
|
||||
KEY="$(/usr/local/bin/node /fetch-my-mc-connector.js)"
|
||||
}
|
||||
|
||||
cmd_argument_builder () {
|
||||
local args="";
|
||||
case "$MODE" in
|
||||
"client")
|
||||
[[ "$PORT" ]] && args="$args --port $PORT";
|
||||
[[ "$HOST" ]] && args="$args --host $HOST";
|
||||
[[ "$CONNECTOR" ]] && args="$args $CONNECTOR";
|
||||
[[ "$KEY" ]] && args="$args $KEY";
|
||||
[[ "$UDP" = "true" ]] && args="$args --udp";
|
||||
;;
|
||||
"server")
|
||||
[[ "$PORT" ]] && args="$args --live $PORT";
|
||||
[[ "$HOST" ]] && args="$args --host $HOST";
|
||||
[[ "$PUBLIC" = "true" ]] && args="$args --public";
|
||||
[[ "$FORCE" = "true" ]] && args="$args --force";
|
||||
[[ "$CONNECTOR" ]] && args="$args --connector $CONNECTOR";
|
||||
[[ "$KEY" ]] && args="$args --key $KEY";
|
||||
[[ "$UDP" = "true" ]] && args="$args --udp";
|
||||
;;
|
||||
"filemanager")
|
||||
args="--filemanager";
|
||||
@@ -45,13 +55,35 @@ cmd_argument_builder () {
|
||||
[[ "$PASSWORD" ]] && args="$args --password $PASSWORD";
|
||||
[[ "$ROLE" = "admin" ]] && args="$args --role admin";
|
||||
[[ "$ROLE" = "user" ]] && args="$args --role user";
|
||||
[[ "$CONNECTOR" ]] && args="$args --connector $CONNECTOR";
|
||||
[[ "$KEY" ]] && args="$args --key $KEY";
|
||||
[[ "$UDP" = "true" ]] && args="$args --udp";
|
||||
;;
|
||||
"my-mc")
|
||||
[[ "$PORT" ]] && args="$args --port $PORT";
|
||||
[[ "$HOST" ]] && args="$args --host $HOST";
|
||||
[[ "$KEY" ]] && args="$args --connect $KEY";
|
||||
[[ "$UDP" = "true" ]] && args="$args --udp";
|
||||
;;
|
||||
esac
|
||||
|
||||
printf "%s" "$args";
|
||||
}
|
||||
|
||||
# SIGUSR1-handler
|
||||
my_handler() {
|
||||
echo "my_handler"
|
||||
}
|
||||
|
||||
term_handler() {
|
||||
if [ $pid -ne 0 ]; then
|
||||
kill -SIGTERM "$pid"
|
||||
wait "$pid"
|
||||
fi
|
||||
exit 143; # 128 + 15 -- SIGTERM
|
||||
}
|
||||
|
||||
|
||||
if ! get_connector_my_mc; then exit 1; fi
|
||||
|
||||
ARGS="$(cmd_argument_builder)"
|
||||
|
||||
@@ -60,5 +92,16 @@ if [[ ! $ARGS ]]; then
|
||||
exit 1
|
||||
fi
|
||||
|
||||
holesail $ARGS
|
||||
# setup handlers
|
||||
# on callback, kill the last background process, which is `tail -f /dev/null` and execute the specified handler
|
||||
#trap 'kill ${!}; my_handler' SIGUSR1
|
||||
trap 'kill ${!}; term_handler' SIGTERM SIGINT
|
||||
|
||||
# run application
|
||||
/usr/local/bin/holesail $ARGS &
|
||||
pid="$!"
|
||||
|
||||
# wait forever
|
||||
while true; do
|
||||
tail -f /dev/null & wait ${!}
|
||||
done
|
||||
|
Reference in New Issue
Block a user