Added sync function
This commit is contained in:
parent
9e0630f9c8
commit
fa1329b62f
@ -0,0 +1,9 @@
|
|||||||
|
FROM alpine/git
|
||||||
|
|
||||||
|
RUN apk update && apk add bash curl jq
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
|
||||||
|
ADD sync.sh sync.sh
|
||||||
|
|
||||||
|
ENTRYPOINT ["/app/sync.sh"]
|
82
sync.sh
Executable file
82
sync.sh
Executable file
@ -0,0 +1,82 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
EXIT_CODE=0
|
||||||
|
|
||||||
|
GITEA_TOKEN=${GITEA_TOKEN:?is not set}
|
||||||
|
GITHUB_TOKEN=${GITHUB_TOKEN:?is not set}
|
||||||
|
# BITBUCKET_TOKEN=${BITBUCKET_TOKEN:?is not set}
|
||||||
|
# GITLAB_TOKEN=${GITLAB_TOKEN:?is not set}
|
||||||
|
|
||||||
|
GITEA_BASE="https://averagemarcus:${GITEA_TOKEN}@git.cluster.fun/AverageMarcus/"
|
||||||
|
GITHUB_BASE="https://averagemarcus:${GITHUB_TOKEN}@github.com/AverageMarcus/"
|
||||||
|
BITBUCKET_BASE="https://bitbucket.org/marcusnoble/"
|
||||||
|
GITLAB_BASE="https://gitlab.com/AverageMarcus/"
|
||||||
|
|
||||||
|
REPOS=$(curl -X GET "https://git.cluster.fun/api/v1/user/repos?page=1&limit=50&access_token=${GITEA_TOKEN}" -H "accept: application/json" --silent | jq -r '.[] | select(.private!=true) | .name')
|
||||||
|
|
||||||
|
getDefaultBranch() {
|
||||||
|
curl -X GET "https://git.cluster.fun/api/v1/repos/AverageMarcus/${1}?access_token=${GITEA_TOKEN}" -H "accept: application/json" --silent | jq -r '.default_branch'
|
||||||
|
}
|
||||||
|
|
||||||
|
githubGetRepo() {
|
||||||
|
curl -f -u averagemarcus:${GITHUB_TOKEN} "https://api.github.com/repos/averagemarcus/${1}" -H "accept: application/vnd.github.v3+json" --silent
|
||||||
|
}
|
||||||
|
githubMakeRepo() {
|
||||||
|
curl -X POST -f -u averagemarcus:${GITHUB_TOKEN} "https://api.github.com/user/repos" -H "accept: application/vnd.github.v3+json" -d '{"name": "'${1}'", "private": false, "auto_init": false, "delete_branch_on_merge": true}' --silent
|
||||||
|
}
|
||||||
|
|
||||||
|
# bitbucketGetRepo() {
|
||||||
|
|
||||||
|
# }
|
||||||
|
# bitbucketMakeRepo() {
|
||||||
|
|
||||||
|
# }
|
||||||
|
|
||||||
|
# gitlabGetRepo() {
|
||||||
|
|
||||||
|
# }
|
||||||
|
# gitlabMakeRepo() {
|
||||||
|
|
||||||
|
# }
|
||||||
|
|
||||||
|
for REPO in ${REPOS}; do
|
||||||
|
echo "Syncing ${REPO}"
|
||||||
|
|
||||||
|
rm -rf ${REPO}
|
||||||
|
mkdir -p ${REPO}
|
||||||
|
cd ${REPO}
|
||||||
|
git init
|
||||||
|
|
||||||
|
BRANCH=$(getDefaultBranch ${REPO})
|
||||||
|
|
||||||
|
git remote add gitea "${GITEA_BASE}${REPO}"
|
||||||
|
git remote add github "${GITHUB_BASE}${REPO}"
|
||||||
|
# git remote add bitbucket "${BITBUCKET_BASE}${REPO}"
|
||||||
|
# git remote add gitlab "${GITLAB_BASE}${REPO}"
|
||||||
|
|
||||||
|
failed() {
|
||||||
|
EXIT_CODE=1
|
||||||
|
printf "\n⚠️ Failed to sync ${REPO}\n\n"
|
||||||
|
cd ..
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
githubGetRepo ${REPO} || githubMakeRepo ${REPO}
|
||||||
|
|
||||||
|
git pull --ff-only gitea ${BRANCH} || failed
|
||||||
|
git pull --ff-only github ${BRANCH} || printf "\nℹ️ Unable to pull from GitHub\n\n"
|
||||||
|
# git pull --ff-only bitbucket ${BRANCH} || printf "\nℹ️ Unable to pull from BitBucket\n\n"
|
||||||
|
# git pull --ff-only gitlab ${BRANCH} || printf "\nℹ️ Unable to pull from Gitlab\n\n"
|
||||||
|
|
||||||
|
git push gitea ${BRANCH} || failed
|
||||||
|
git push github ${BRANCH} || failed
|
||||||
|
# git push bitbucket ${BRANCH} || failed
|
||||||
|
# git push gitlab ${BRANCH} || failed
|
||||||
|
|
||||||
|
cd ..
|
||||||
|
rm -rf ${REPO}
|
||||||
|
printf "\n✅ Successfully synced ${REPO}\n\n"
|
||||||
|
done
|
||||||
|
|
||||||
|
|
||||||
|
exit ${EXIT_CODE}
|
Loading…
Reference in New Issue
Block a user