mirror of
https://github.com/stefanzweifel/git-auto-commit-action.git
synced 2024-11-06 02:08:05 +00:00
Create lib.sh and update entrypoint.sh
This commit is contained in:
parent
3c148f8a94
commit
4280601118
@ -1,48 +1,22 @@
|
|||||||
#!/bin/sh
|
#!/bin/bash
|
||||||
|
|
||||||
set -eu
|
set -eu
|
||||||
|
|
||||||
# Set up .netrc file with GitHub credentials
|
source /lib.sh
|
||||||
git_setup ( ) {
|
|
||||||
cat <<- EOF > $HOME/.netrc
|
|
||||||
machine github.com
|
|
||||||
login $GITHUB_ACTOR
|
|
||||||
password $GITHUB_TOKEN
|
|
||||||
|
|
||||||
machine api.github.com
|
_switch_to_repository
|
||||||
login $GITHUB_ACTOR
|
|
||||||
password $GITHUB_TOKEN
|
|
||||||
EOF
|
|
||||||
chmod 600 $HOME/.netrc
|
|
||||||
|
|
||||||
git config --global user.email "actions@github.com"
|
if _git_is_dirty; then
|
||||||
git config --global user.name "GitHub Actions"
|
|
||||||
}
|
|
||||||
|
|
||||||
echo "INPUT_REPOSITORY value: $INPUT_REPOSITORY";
|
_setup_git
|
||||||
|
|
||||||
cd $INPUT_REPOSITORY
|
_switch_to_branch
|
||||||
|
|
||||||
# This section only runs if there have been file changes
|
_add_files
|
||||||
echo "Checking for uncommitted changes in the git working tree."
|
|
||||||
if [[ -n "$(git status -s)" ]]
|
|
||||||
then
|
|
||||||
git_setup
|
|
||||||
|
|
||||||
echo "INPUT_BRANCH value: $INPUT_BRANCH";
|
_local_commit
|
||||||
|
|
||||||
# Switch to branch from current Workflow run
|
_push_to_github
|
||||||
git checkout $INPUT_BRANCH
|
|
||||||
|
|
||||||
echo "INPUT_FILE_PATTERN: ${INPUT_FILE_PATTERN}"
|
|
||||||
|
|
||||||
git add "${INPUT_FILE_PATTERN}"
|
|
||||||
|
|
||||||
echo "INPUT_COMMIT_OPTIONS: ${INPUT_COMMIT_OPTIONS}"
|
|
||||||
|
|
||||||
git commit -m "$INPUT_COMMIT_MESSAGE" --author="$GITHUB_ACTOR <$GITHUB_ACTOR@users.noreply.github.com>" ${INPUT_COMMIT_OPTIONS:+"$INPUT_COMMIT_OPTIONS"}
|
|
||||||
|
|
||||||
git push --set-upstream origin "HEAD:$INPUT_BRANCH"
|
|
||||||
else
|
else
|
||||||
echo "Working tree clean. Nothing to commit."
|
echo "Working tree clean. Nothing to commit."
|
||||||
fi
|
fi
|
||||||
|
48
lib.sh
Normal file
48
lib.sh
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
_switch_to_repository() {
|
||||||
|
echo "INPUT_REPOSITORY value: $INPUT_REPOSITORY";
|
||||||
|
cd $INPUT_REPOSITORY
|
||||||
|
}
|
||||||
|
|
||||||
|
_git_is_dirty() {
|
||||||
|
[[ -n "$(git status -s)" ]]
|
||||||
|
}
|
||||||
|
|
||||||
|
# Set up .netrc file with GitHub credentials
|
||||||
|
_setup_git ( ) {
|
||||||
|
cat <<- EOF > $HOME/.netrc
|
||||||
|
machine github.com
|
||||||
|
login $GITHUB_ACTOR
|
||||||
|
password $GITHUB_TOKEN
|
||||||
|
|
||||||
|
machine api.github.com
|
||||||
|
login $GITHUB_ACTOR
|
||||||
|
password $GITHUB_TOKEN
|
||||||
|
EOF
|
||||||
|
chmod 600 $HOME/.netrc
|
||||||
|
|
||||||
|
git config --global user.email "actions@github.com"
|
||||||
|
git config --global user.name "GitHub Actions"
|
||||||
|
}
|
||||||
|
|
||||||
|
_switch_to_branch() {
|
||||||
|
echo "INPUT_BRANCH value: $INPUT_BRANCH";
|
||||||
|
|
||||||
|
# Switch to branch from current Workflow run
|
||||||
|
git checkout $INPUT_BRANCH
|
||||||
|
}
|
||||||
|
|
||||||
|
_add_files() {
|
||||||
|
echo "INPUT_FILE_PATTERN: ${INPUT_FILE_PATTERN}"
|
||||||
|
git add "${INPUT_FILE_PATTERN}"
|
||||||
|
}
|
||||||
|
|
||||||
|
_local_commit() {
|
||||||
|
echo "INPUT_COMMIT_OPTIONS: ${INPUT_COMMIT_OPTIONS}"
|
||||||
|
git commit -m "$INPUT_COMMIT_MESSAGE" --author="$GITHUB_ACTOR <$GITHUB_ACTOR@users.noreply.github.com>" ${INPUT_COMMIT_OPTIONS:+"$INPUT_COMMIT_OPTIONS"}
|
||||||
|
}
|
||||||
|
|
||||||
|
_push_to_github() {
|
||||||
|
git push --set-upstream origin "HEAD:$INPUT_BRANCH"
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user