2023-03-24 22:42:52 +01:00
|
|
|
#!/bin/bash
|
2023-04-01 11:08:06 +02:00
|
|
|
# SPDX-License-Identifier: MIT
|
2023-03-24 22:42:52 +01:00
|
|
|
|
2023-04-01 14:51:42 +02:00
|
|
|
set -e
|
|
|
|
|
2023-12-17 22:21:10 +01:00
|
|
|
SELF_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
|
|
|
source $SELF_DIR/forgejo-lib.sh
|
|
|
|
|
2023-04-01 14:51:42 +02:00
|
|
|
if ${VERBOSE:-false}; then set -x; fi
|
|
|
|
: ${CONTAINER:=forgejo}
|
2023-12-17 22:21:10 +01:00
|
|
|
: ${DIR:=$(pwd)}
|
2023-03-24 22:42:52 +01:00
|
|
|
|
2023-03-25 14:34:41 +01:00
|
|
|
function run() {
|
|
|
|
local image="$1"
|
2023-04-05 17:40:06 +02:00
|
|
|
local version="$2"
|
|
|
|
|
2023-04-05 23:27:33 +02:00
|
|
|
if test "$version" != "1.19" && dpkg --compare-versions "$version" "lt" "1.19.0-3"; then
|
2023-04-05 17:40:06 +02:00
|
|
|
actions_unit="actions.actions"
|
|
|
|
else
|
|
|
|
actions_unit="repo.actions"
|
|
|
|
fi
|
2023-03-24 22:42:52 +01:00
|
|
|
|
2023-04-01 16:04:26 +02:00
|
|
|
docker run --restart unless-stopped --name ${CONTAINER} \
|
2023-03-24 22:42:52 +01:00
|
|
|
-e "RUN_MODE=dev" \
|
|
|
|
-e "FORGEJO__security__INSTALL_LOCK=true" \
|
2023-10-12 15:47:32 +02:00
|
|
|
-e "FORGEJO__log__LEVEL=trace" \
|
2023-03-24 22:42:52 +01:00
|
|
|
-e "FORGEJO__actions__ENABLED=true" \
|
2023-10-11 18:40:44 +02:00
|
|
|
-e "FORGEJO__queue__TYPE=immediate" \
|
|
|
|
-e "FORGEJO__queue.push_update__TYPE=immediate" \
|
2023-03-24 22:42:52 +01:00
|
|
|
-e "FORGEJO__repository__ENABLE_PUSH_CREATE_USER=true" \
|
2023-03-25 14:34:41 +01:00
|
|
|
-e "FORGEJO__repository__DEFAULT_PUSH_CREATE_PRIVATE=false" \
|
2023-04-05 17:40:06 +02:00
|
|
|
-e "FORGEJO__repository__DEFAULT_REPO_UNITS=repo.code,repo.releases,repo.issues,repo.pulls,repo.wiki,repo.projects,repo.packages,$actions_unit" \
|
|
|
|
-d $image:$version
|
2023-04-01 14:51:42 +02:00
|
|
|
local ip="$(docker inspect -f "{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}" ${CONTAINER})"
|
2023-12-17 22:21:10 +01:00
|
|
|
echo 'docker exec --user 1000 '${CONTAINER}' forgejo "$@"' > $DIR/forgejocli
|
|
|
|
chmod +x $DIR/forgejocli
|
|
|
|
echo $ip > $DIR/forgejo-ip
|
|
|
|
echo "http://$(cat $DIR/forgejo-ip):3000" > $DIR/forgejo-url
|
2023-04-01 14:51:42 +02:00
|
|
|
docker exec ${CONTAINER} sed -i -e "s|localhost|$ip|" /data/gitea/conf/app.ini
|
|
|
|
docker restart ${CONTAINER}
|
2023-03-25 14:34:41 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
function setup() {
|
|
|
|
local user="${1:-root}"
|
|
|
|
local password="${2:-admin1234}"
|
2023-04-05 17:40:06 +02:00
|
|
|
local image="${3:-codeberg.org/forgejo/forgejo}"
|
2023-07-27 20:45:06 +02:00
|
|
|
local version="${4:-1.20}"
|
2023-03-25 14:34:41 +01:00
|
|
|
|
2023-04-05 17:40:06 +02:00
|
|
|
run $image $version
|
2023-03-24 22:42:52 +01:00
|
|
|
|
|
|
|
sleep 5 # for some reason trying to run "forgejo admin" while forgejo is booting will permanently break everything
|
2023-12-17 22:21:10 +01:00
|
|
|
if $DIR/forgejocli admin user list --admin | grep "$user" ; then
|
|
|
|
$DIR/forgejocli admin user change-password --username "$user" --password "$password"
|
2023-03-24 22:42:52 +01:00
|
|
|
else
|
2023-12-17 22:21:10 +01:00
|
|
|
retry $DIR/forgejocli admin user create --admin --username "$user" --password "$password" --email "$user@example.com"
|
2023-03-24 22:42:52 +01:00
|
|
|
fi
|
2023-09-24 16:54:52 +02:00
|
|
|
#
|
|
|
|
# The 'sudo' scope was removed in Forgejo v1.20 and is ignored
|
|
|
|
#
|
2023-12-17 22:21:10 +01:00
|
|
|
echo "http://${user}:${password}@$(cat $DIR/forgejo-ip):3000" > $DIR/forgejo-auth-url
|
|
|
|
$DIR/forgejocli admin user generate-access-token -u $user --raw --scopes 'all,sudo' > $DIR/forgejo-token
|
|
|
|
retry forgejo-curl.sh --user "$user" --password "$password" --token @$DIR/forgejo-token login http://$(cat $DIR/forgejo-ip):3000
|
2023-09-24 16:54:52 +02:00
|
|
|
#
|
|
|
|
# Redundant with forgejo-curl.sh, kept around for backward compatibility 09/2023
|
|
|
|
#
|
2023-12-17 22:21:10 +01:00
|
|
|
( echo -n 'Authorization: token ' ; cat $DIR/forgejo-token ) > $DIR/forgejo-header
|
|
|
|
( echo "#!/bin/sh" ; echo 'curl -sS -H "Content-Type: application/json" -H @'$DIR/forgejo-header' "$@"' ) > $DIR/forgejo-api && chmod +x $DIR/forgejo-api
|
2023-03-24 22:42:52 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
function teardown() {
|
2023-04-01 14:51:42 +02:00
|
|
|
docker stop ${CONTAINER} >& /dev/null || true
|
|
|
|
docker rm -f ${CONTAINER} >& /dev/null || true
|
2023-03-24 22:42:52 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
"$@"
|