Compare commits
3 Commits
testing
...
012cc74576
Author | SHA1 | Date | |
---|---|---|---|
012cc74576 | |||
fd64e8f816 | |||
f71e8a6fcc |
60
.gitea/workflows/publish-image.yaml
Normal file
60
.gitea/workflows/publish-image.yaml
Normal file
@@ -0,0 +1,60 @@
|
||||
name: Docker Image CI
|
||||
|
||||
on:
|
||||
# schedule:
|
||||
# - cron: "0 10 * * *"
|
||||
push:
|
||||
branches:
|
||||
- "**"
|
||||
tags:
|
||||
- "v*.*.*"
|
||||
pull_request:
|
||||
|
||||
jobs:
|
||||
docker:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- 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 }}
|
27
Dockerfile
27
Dockerfile
@@ -1,23 +1,20 @@
|
||||
FROM node:lts-slim AS base
|
||||
|
||||
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
|
||||
|
||||
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 ""
|
||||
RUN npm install -g holesail@2.0.3
|
||||
|
||||
CMD [ "/usr/bin/bash", "/run.sh" ]
|
||||
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 ""
|
||||
|
||||
ENTRYPOINT [ "/run.sh" ]
|
||||
|
@@ -1,4 +1,4 @@
|
||||
const apiKey = process.env.MY_MC_API_KEY;
|
||||
const apiKey = process.env.CONNECTOR;
|
||||
|
||||
const result = fetch('https://api.my-mc.link/my-hash',{
|
||||
method: "GET",
|
||||
@@ -9,9 +9,5 @@ const result = fetch('https://api.my-mc.link/my-hash',{
|
||||
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);
|
||||
}
|
||||
})
|
||||
|
46
run.sh
46
run.sh
@@ -25,8 +25,8 @@ success() {
|
||||
print "$GREEN" "$1"
|
||||
}
|
||||
|
||||
get_connector_my_mc() {
|
||||
KEY="$(/usr/local/bin/node /fetch-my-mc-connector.js)"
|
||||
get_connector_my-mc() {
|
||||
printf "$(node /fetch-my-mc-connector.js)"
|
||||
}
|
||||
|
||||
cmd_argument_builder () {
|
||||
@@ -35,16 +35,14 @@ cmd_argument_builder () {
|
||||
"client")
|
||||
[[ "$PORT" ]] && args="$args --port $PORT";
|
||||
[[ "$HOST" ]] && args="$args --host $HOST";
|
||||
[[ "$KEY" ]] && args="$args $KEY";
|
||||
[[ "$UDP" = "true" ]] && args="$args --udp";
|
||||
[[ "$CONNECTOR" ]] && args="$args $CONNECTOR";
|
||||
;;
|
||||
"server")
|
||||
[[ "$PORT" ]] && args="$args --live $PORT";
|
||||
[[ "$HOST" ]] && args="$args --host $HOST";
|
||||
[[ "$PUBLIC" = "true" ]] && args="$args --public";
|
||||
[[ "$FORCE" = "true" ]] && args="$args --force";
|
||||
[[ "$KEY" ]] && args="$args --key $KEY";
|
||||
[[ "$UDP" = "true" ]] && args="$args --udp";
|
||||
[[ "$CONNECTOR" ]] && args="$args --connector $CONNECTOR";
|
||||
;;
|
||||
"filemanager")
|
||||
args="--filemanager";
|
||||
@@ -55,24 +53,29 @@ cmd_argument_builder () {
|
||||
[[ "$PASSWORD" ]] && args="$args --password $PASSWORD";
|
||||
[[ "$ROLE" = "admin" ]] && args="$args --role admin";
|
||||
[[ "$ROLE" = "user" ]] && args="$args --role user";
|
||||
[[ "$KEY" ]] && args="$args --key $KEY";
|
||||
[[ "$UDP" = "true" ]] && args="$args --udp";
|
||||
[[ "$CONNECTOR" ]] && args="$args --connector $CONNECTOR";
|
||||
;;
|
||||
"my-mc")
|
||||
[[ "$PORT" ]] && args="$args --port $PORT";
|
||||
[[ "$HOST" ]] && args="$args --host $HOST";
|
||||
[[ "$KEY" ]] && args="$args --connect $KEY";
|
||||
[[ "$UDP" = "true" ]] && args="$args --udp";
|
||||
[[ "$CONNECTOR" ]] && args="$args $(get_connector_my-mc)";
|
||||
;;
|
||||
esac
|
||||
|
||||
printf "%s" "$args";
|
||||
}
|
||||
|
||||
ARGS="$(cmd_argument_builder)"
|
||||
|
||||
if [[ ! $ARGS ]]; then
|
||||
error "Invalid Mode."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# SIGUSR1-handler
|
||||
my_handler() {
|
||||
echo "my_handler"
|
||||
}
|
||||
# my_handler() {
|
||||
# echo "my_handler"
|
||||
# }
|
||||
|
||||
term_handler() {
|
||||
if [ $pid -ne 0 ]; then
|
||||
@@ -82,26 +85,17 @@ term_handler() {
|
||||
exit 143; # 128 + 15 -- SIGTERM
|
||||
}
|
||||
|
||||
|
||||
if ! get_connector_my_mc; then exit 1; fi
|
||||
|
||||
ARGS="$(cmd_argument_builder)"
|
||||
|
||||
if [[ ! $ARGS ]]; then
|
||||
error "Invalid Mode."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# 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
|
||||
trap 'kill ${!}; term_handler' SIGTERM
|
||||
|
||||
# run application
|
||||
/usr/local/bin/holesail $ARGS &
|
||||
holesail $ARGS &
|
||||
pid="$!"
|
||||
|
||||
# wait forever
|
||||
while true; do
|
||||
while true
|
||||
do
|
||||
tail -f /dev/null & wait ${!}
|
||||
done
|
||||
|
Reference in New Issue
Block a user