mirror of
https://github.com/stefanzweifel/git-auto-commit-action.git
synced 2025-01-05 02:15:35 +00:00
120 lines
3.2 KiB
Bash
Executable File
120 lines
3.2 KiB
Bash
Executable File
#!/bin/bash
|
||
|
||
set -eu
|
||
|
||
_main() {
|
||
_switch_to_repository
|
||
|
||
if _git_is_dirty || "$INPUT_SKIP_DIRTY_CHECK"; then
|
||
|
||
echo "::set-output name=changes_detected::true";
|
||
|
||
_switch_to_branch
|
||
|
||
_add_files
|
||
|
||
_local_commit
|
||
|
||
_tag_commit
|
||
|
||
_push_to_github
|
||
else
|
||
|
||
echo "::set-output name=changes_detected::false";
|
||
|
||
echo "Working tree clean. Nothing to commit.";
|
||
fi
|
||
}
|
||
|
||
|
||
_switch_to_repository() {
|
||
echo "INPUT_REPOSITORY value: $INPUT_REPOSITORY";
|
||
cd "$INPUT_REPOSITORY";
|
||
}
|
||
|
||
_git_is_dirty() {
|
||
# shellcheck disable=SC2086
|
||
[ -n "$(git status -s -- $INPUT_FILE_PATTERN)" ]
|
||
}
|
||
|
||
_switch_to_branch() {
|
||
echo "INPUT_BRANCH value: $INPUT_BRANCH";
|
||
|
||
# Fetch remote to make sure that repo can be switched to the right branch.
|
||
|
||
if "$INPUT_SKIP_FETCH"; then
|
||
echo "::debug::git-fetch has not been executed";
|
||
else
|
||
git fetch --depth=1;
|
||
fi
|
||
|
||
# Switch to branch from current Workflow run
|
||
# shellcheck disable=SC2086
|
||
git checkout $INPUT_BRANCH;
|
||
}
|
||
|
||
_add_files() {
|
||
echo "INPUT_FILE_PATTERN: ${INPUT_FILE_PATTERN}";
|
||
|
||
# shellcheck disable=SC2086
|
||
git add ${INPUT_FILE_PATTERN};
|
||
}
|
||
|
||
_local_commit() {
|
||
echo "INPUT_COMMIT_OPTIONS: ${INPUT_COMMIT_OPTIONS}";
|
||
echo "::debug::Apply commit options ${INPUT_COMMIT_OPTIONS}";
|
||
|
||
# shellcheck disable=SC2206
|
||
INPUT_COMMIT_OPTIONS_ARRAY=( $INPUT_COMMIT_OPTIONS );
|
||
|
||
echo "INPUT_COMMIT_USER_NAME: ${INPUT_COMMIT_USER_NAME}";
|
||
echo "INPUT_COMMIT_USER_EMAIL: ${INPUT_COMMIT_USER_EMAIL}";
|
||
echo "INPUT_COMMIT_MESSAGE: ${INPUT_COMMIT_MESSAGE}";
|
||
echo "INPUT_COMMIT_AUTHOR: ${INPUT_COMMIT_AUTHOR}";
|
||
|
||
git -c user.name="$INPUT_COMMIT_USER_NAME" -c user.email="$INPUT_COMMIT_USER_EMAIL" \
|
||
commit -m "$INPUT_COMMIT_MESSAGE" \
|
||
--author="$INPUT_COMMIT_AUTHOR" \
|
||
${INPUT_COMMIT_OPTIONS:+"${INPUT_COMMIT_OPTIONS_ARRAY[@]}"};
|
||
}
|
||
|
||
_tag_commit() {
|
||
echo "INPUT_TAGGING_MESSAGE: ${INPUT_TAGGING_MESSAGE}"
|
||
|
||
if [ -n "$INPUT_TAGGING_MESSAGE" ]
|
||
then
|
||
echo "::debug::Create tag $INPUT_TAGGING_MESSAGE";
|
||
git -c user.name="$INPUT_COMMIT_USER_NAME" -c user.email="$INPUT_COMMIT_USER_EMAIL" tag -a "$INPUT_TAGGING_MESSAGE" -m "$INPUT_TAGGING_MESSAGE";
|
||
else
|
||
echo "No tagging message supplied. No tag will be added.";
|
||
fi
|
||
}
|
||
|
||
_push_to_github() {
|
||
|
||
echo "INPUT_PUSH_OPTIONS: ${INPUT_PUSH_OPTIONS}";
|
||
echo "::debug::Apply push options ${INPUT_PUSH_OPTIONS}";
|
||
|
||
# shellcheck disable=SC2206
|
||
INPUT_PUSH_OPTIONS_ARRAY=( $INPUT_PUSH_OPTIONS );
|
||
|
||
if [ -z "$INPUT_BRANCH" ]
|
||
then
|
||
# Only add `--tags` option, if `$INPUT_TAGGING_MESSAGE` is set
|
||
if [ -n "$INPUT_TAGGING_MESSAGE" ]
|
||
then
|
||
echo "::debug::git push origin --tags";
|
||
git push origin --tags ${INPUT_PUSH_OPTIONS:+"${INPUT_PUSH_OPTIONS_ARRAY[@]}"};
|
||
else
|
||
echo "::debug::git push origin";
|
||
git push origin ${INPUT_PUSH_OPTIONS:+"${INPUT_PUSH_OPTIONS_ARRAY[@]}"};
|
||
fi
|
||
|
||
else
|
||
echo "::debug::Push commit to remote branch $INPUT_BRANCH";
|
||
git push --set-upstream origin "HEAD:$INPUT_BRANCH" --tags ${INPUT_PUSH_OPTIONS:+"${INPUT_PUSH_OPTIONS_ARRAY[@]}"};
|
||
fi
|
||
}
|
||
|
||
_main
|