git-auto-commit-action/entrypoint.sh

185 lines
5.4 KiB
Bash
Raw Normal View History

2019-12-12 19:41:00 +00:00
#!/bin/bash
2019-11-01 09:10:52 +00:00
2019-06-10 12:30:50 +00:00
set -eu
2021-04-10 15:10:27 +00:00
if "$INPUT_DISABLE_GLOBBING"; then
set -o noglob;
fi
2019-06-10 12:30:50 +00:00
_set_github_output() {
local name=${1}
local value=${2}
# Check if $GITHUB_OUTPUT is available
# (Feature detection will be removed in spring 2023)
if [ -z ${GITHUB_OUTPUT+x} ]; then
echo "::set-output name=$name::$value";
else
echo "$name=$value" >> $GITHUB_OUTPUT;
fi
}
_log() {
local level=${1}
local message=${2}
echo "::$level::$message";
}
_main() {
_check_if_git_is_available
_switch_to_repository
2019-08-31 16:02:55 +00:00
2020-06-26 19:00:48 +00:00
if _git_is_dirty || "$INPUT_SKIP_DIRTY_CHECK"; then
2019-08-31 16:02:55 +00:00
_set_github_output "changes_detected" "true"
2020-03-03 19:51:12 +00:00
_switch_to_branch
_add_files
# Check dirty state of repo again using git-diff.
2023-10-06 17:30:48 +00:00
# (git-diff detects better if CRLF of files changes and does NOT
# proceed, if only CRLF changes are detected. See #241 and #265
# for more details.)
if [ -n "$(git diff --staged)" ] || "$INPUT_SKIP_DIRTY_CHECK"; then
_local_commit
2019-09-20 08:43:15 +00:00
_tag_commit
2020-03-05 19:31:06 +00:00
_push_to_github
else
_set_github_output "changes_detected" "false"
echo "Working tree clean. Nothing to commit.";
fi
else
_set_github_output "changes_detected" "false"
2020-03-03 19:51:12 +00:00
2020-04-22 18:17:05 +00:00
echo "Working tree clean. Nothing to commit.";
fi
}
2019-08-31 16:34:01 +00:00
_check_if_git_is_available() {
if hash -- "$INPUT_INTERNAL_GIT_BINARY" 2> /dev/null; then
_log "debug" "git binary found.";
else
_log "error" "git-auto-commit could not find git binary. Please make sure git is available."
exit 1;
fi
}
_switch_to_repository() {
echo "INPUT_REPOSITORY value: $INPUT_REPOSITORY";
2020-10-22 05:37:16 +00:00
cd "$INPUT_REPOSITORY";
}
_git_is_dirty() {
2021-05-03 15:26:56 +00:00
echo "INPUT_STATUS_OPTIONS: ${INPUT_STATUS_OPTIONS}";
_log "debug" "Apply status options ${INPUT_STATUS_OPTIONS}";
2021-05-03 15:26:56 +00:00
echo "INPUT_FILE_PATTERN: ${INPUT_FILE_PATTERN}";
read -r -a INPUT_FILE_PATTERN_EXPANDED <<< "$INPUT_FILE_PATTERN";
2020-10-22 05:37:16 +00:00
# shellcheck disable=SC2086
[ -n "$(git status -s $INPUT_STATUS_OPTIONS -- ${INPUT_FILE_PATTERN_EXPANDED:+${INPUT_FILE_PATTERN_EXPANDED[@]}})" ]
}
_switch_to_branch() {
echo "INPUT_BRANCH value: $INPUT_BRANCH";
2022-02-22 19:02:04 +00:00
# Fetch remote to make sure that repo can be switched to the right branch.
2023-12-19 19:11:39 +00:00
# if "$INPUT_SKIP_FETCH"; then
# _log "debug" "git-fetch will not be executed.";
# else
# git fetch --depth=1;
# fi
# # If `skip_checkout`-input is true, skip the entire checkout step.
# if "$INPUT_SKIP_CHECKOUT"; then
# _log "debug" "git-checkout will not be executed.";
# else
# # Create new local branch if `create_branch`-input is true
# if "$INPUT_CREATE_BRANCH"; then
# # shellcheck disable=SC2086
# git checkout -B $INPUT_BRANCH --;
# else
# # Switch to branch from current Workflow run
# # shellcheck disable=SC2086
# # git checkout $INPUT_BRANCH --;
# fi
# fi
}
_add_files() {
2021-05-03 15:26:56 +00:00
echo "INPUT_ADD_OPTIONS: ${INPUT_ADD_OPTIONS}";
_log "debug" "Apply add options ${INPUT_ADD_OPTIONS}";
2021-05-03 15:26:56 +00:00
2020-04-22 18:17:05 +00:00
echo "INPUT_FILE_PATTERN: ${INPUT_FILE_PATTERN}";
read -r -a INPUT_FILE_PATTERN_EXPANDED <<< "$INPUT_FILE_PATTERN";
2020-10-15 18:15:31 +00:00
# shellcheck disable=SC2086
git add ${INPUT_ADD_OPTIONS} ${INPUT_FILE_PATTERN:+"${INPUT_FILE_PATTERN_EXPANDED[@]}"};
}
_local_commit() {
2020-04-22 18:17:05 +00:00
echo "INPUT_COMMIT_OPTIONS: ${INPUT_COMMIT_OPTIONS}";
_log "debug" "Apply commit options ${INPUT_COMMIT_OPTIONS}";
2020-04-22 18:07:31 +00:00
2020-10-15 18:15:31 +00:00
# shellcheck disable=SC2206
2020-04-22 19:17:10 +00:00
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}";
2020-04-22 19:04:17 +00:00
git -c user.name="$INPUT_COMMIT_USER_NAME" -c user.email="$INPUT_COMMIT_USER_EMAIL" \
commit -m "$INPUT_COMMIT_MESSAGE" \
--author="$INPUT_COMMIT_AUTHOR" \
2020-04-22 19:17:10 +00:00
${INPUT_COMMIT_OPTIONS:+"${INPUT_COMMIT_OPTIONS_ARRAY[@]}"};
2021-09-10 10:39:35 +00:00
_set_github_output "commit_hash" $(git rev-parse HEAD)
}
2020-03-05 19:31:06 +00:00
_tag_commit() {
2020-03-05 19:48:15 +00:00
echo "INPUT_TAGGING_MESSAGE: ${INPUT_TAGGING_MESSAGE}"
2020-03-05 19:35:32 +00:00
if [ -n "$INPUT_TAGGING_MESSAGE" ]
2020-03-05 19:31:06 +00:00
then
_log "debug" "Create tag $INPUT_TAGGING_MESSAGE";
2020-04-28 11:12:43 +00:00
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.";
2020-03-05 19:31:06 +00:00
fi
}
_push_to_github() {
echo "INPUT_PUSH_OPTIONS: ${INPUT_PUSH_OPTIONS}";
_log "debug" "Apply push options ${INPUT_PUSH_OPTIONS}";
2020-10-15 18:15:31 +00:00
# shellcheck disable=SC2206
INPUT_PUSH_OPTIONS_ARRAY=( $INPUT_PUSH_OPTIONS );
2020-02-06 16:51:55 +00:00
if [ -z "$INPUT_BRANCH" ]
2020-02-05 20:39:14 +00:00
then
2020-03-14 12:21:42 +00:00
# Only add `--tags` option, if `$INPUT_TAGGING_MESSAGE` is set
if [ -n "$INPUT_TAGGING_MESSAGE" ]
then
_log "debug" "git push origin --tags";
git push origin --follow-tags --atomic ${INPUT_PUSH_OPTIONS:+"${INPUT_PUSH_OPTIONS_ARRAY[@]}"};
2020-03-14 12:21:42 +00:00
else
_log "debug" "git push origin";
git push origin ${INPUT_PUSH_OPTIONS:+"${INPUT_PUSH_OPTIONS_ARRAY[@]}"};
2020-03-14 12:21:42 +00:00
fi
2020-02-05 20:39:14 +00:00
else
_log "debug" "Push commit to remote branch $INPUT_BRANCH";
git push --set-upstream origin "HEAD:$INPUT_BRANCH" --follow-tags --atomic ${INPUT_PUSH_OPTIONS:+"${INPUT_PUSH_OPTIONS_ARRAY[@]}"};
2020-02-05 20:39:14 +00:00
fi
}
_main