Compare commits

..

39 Commits
v1 ... v2.1.0

Author SHA1 Message Date
Stefan Zweifel
3ffeab2fe0 Tag v2.1.0 2019-09-20 21:20:34 +02:00
Stefan Zweifel
5adbb8cb3e Use GITHUB_ACTOR instead of args 2019-09-20 20:34:57 +02:00
Stefan Zweifel
97f9868da0 Rename ref to branch 2019-09-20 20:26:41 +02:00
Stefan Zweifel
8a0c95d76c Merge pull request #7 from stefanzweifel/fix-branch-checkout
Bugfix: Fix git checkout and git push commands
2019-09-20 19:50:49 +02:00
Stefan Zweifel
4c6d2819f0 Update README 2019-09-20 10:47:19 +02:00
Stefan Zweifel
7fec5eda4a Cleanup 2019-09-20 10:46:35 +02:00
Stefan Zweifel
6c17ba31a9 Output $INPUT_REF 2019-09-20 10:43:15 +02:00
Stefan Zweifel
6f1c9227f5 Fix git push command 2019-09-20 10:37:16 +02:00
Stefan Zweifel
72e2d4cb1e Fix git checkout 2019-09-20 10:33:12 +02:00
Stefan Zweifel
8cc484cbc5 Add ref argument 2019-09-20 10:30:36 +02:00
Stefan Zweifel
ed0ebb9072 Log $PUSH_BRANCH value 2019-09-20 10:19:34 +02:00
Stefan Zweifel
0b91625aed WIP 2019-09-20 10:11:50 +02:00
Stefan Zweifel
ba1c2a6047 Try to fix that push command 2019-09-20 10:08:13 +02:00
Stefan Zweifel
12282205b7 Try to fix git push 2019-09-20 10:01:27 +02:00
Stefan Zweifel
ef8610f6df Fix git push 2019-09-20 09:56:20 +02:00
Stefan Zweifel
f4fd59c4d4 Use $PUSH_BRANCH in git push command 2019-09-20 09:49:26 +02:00
Stefan Zweifel
ea88bd7cde Try to fix checkout command 2019-09-20 09:42:26 +02:00
Stefan Zweifel
80f825a9bc Update how the branch is checked out 2019-09-20 09:27:50 +02:00
Stefan Zweifel
845dc426e7 Update README.md 2019-09-06 07:34:41 +02:00
Stefan Zweifel
fcfae8cf7e Merge pull request #5 from tupaschoal/patch-1
Fix puzzled explanation on README.md
2019-09-06 07:33:37 +02:00
Tulio Leao
ef125417f8 Fix puzzled explanation on README.md 2019-09-06 02:19:37 -03:00
Stefan Zweifel
709206b68e Update Changelog 2019-08-31 18:47:56 +02:00
Stefan Zweifel
c37291d29c Merge pull request #3 from stefanzweifel/dev
Make Action compatible with GitHub Actions BETA2 / YAML Version
2019-08-31 18:45:42 +02:00
Stefan Zweifel
fc34a4d3a2 Update README 2019-08-31 18:43:23 +02:00
Stefan Zweifel
e14499263c Add GH Actions Stuff to Dockerfile 2019-08-31 18:34:50 +02:00
Stefan Zweifel
11769ba87f Merge branch 'dev-tinker' into dev 2019-08-31 18:34:10 +02:00
Stefan Zweifel
0364ecfe57 Update Entrypoint 2019-08-31 18:34:01 +02:00
Stefan Zweifel
8d47eb33c5 Use Actions as Git User 2019-08-31 18:15:13 +02:00
Stefan Zweifel
49fa6b4e7a WIP 2019-08-31 18:14:28 +02:00
Stefan Zweifel
ef070dad05 Updates 2019-08-31 18:10:59 +02:00
Stefan Zweifel
fbe300afdf Tinker tinker 2019-08-31 18:07:25 +02:00
Stefan Zweifel
4b2201fcd1 Update Entrypoint 2019-08-31 18:02:55 +02:00
Stefan Zweifel
a93a9a308d Use git checkout 2019-08-27 20:30:31 +02:00
Stefan Zweifel
fdf062fc1c Switch to branch and setup remote origin 2019-08-27 20:26:44 +02:00
Stefan Zweifel
6280a31960 Remove entrypoint 2019-08-20 21:12:28 +02:00
Stefan Zweifel
1dd709d949 Update Dockerfile 2019-08-20 21:05:17 +02:00
Stefan Zweifel
8620a4b744 Update README 2019-08-20 21:05:10 +02:00
Stefan Zweifel
6057956931 Fix Typo 2019-08-20 20:51:00 +02:00
Stefan Zweifel
3fe53a7d31 Add actions.yml 2019-08-20 20:43:07 +02:00
4 changed files with 127 additions and 43 deletions

View File

@@ -4,7 +4,25 @@ All notable changes to this project will be documented in this file.
The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/) The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/)
and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html). and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html).
## [Unreleased](https://github.com/stefanzweifel/git-auto-commit-action/compare/v1.0.0...HEAD) ## [Unreleased](https://github.com/stefanzweifel/git-auto-commit-action/compare/v2.1.0...HEAD)
## [v2.1.0](https://github.com/stefanzweifel/git-auto-commit-action/compare/v2.0.0...v2.1.0) - 2019-09-20
### Added
- Add `branch`-argument to determine, to which branch changes should be pushed. See README for usage details.
### Fixed
- Fixes Issue where changes couldn't be pushed to GitHub due to wrong ref-name.
### Removed
- Remove `commit_author_email` and `commit_author_name` arguments. The `$GITHUB_ACTOR` is now used as the Git Author
## [v2.0.0](https://github.com/stefanzweifel/git-auto-commit-action/compare/v1.0.0...v2.0.0) - 2019-08-31
### Changed
- Make Action Compatible with latest beta of GitHub Actions [#3](https://github.com/stefanzweifel/git-auto-commit-action/pull/3)
## v1.0.0 - 2019-06-10 ## v1.0.0 - 2019-06-10

View File

@@ -1,57 +1,73 @@
# git-auto-commit-action # git-auto-commit-action
This GitHub Action automatically commits files which have been changed during a Workflow run and pushes the Commit back to GitHub. This GitHub Action automatically commits files which have been changed during a Workflow run and pushes the Commit back to GitHub.
The Committer is "GitHub Actions <actions@github.com>" and the Author of the Commit can be configured with environment variables. The Committer is "GitHub Actions <actions@github.com>" and the Author of the Commit can be configured with input variables.
If no changes are available, the Actions does nothing. If no changes are available, the Actions does nothing.
This Action has been inspired and adapted from the [auto-commit](https://github.com/cds-snc/github-actions/tree/master/auto-commit This Action has been inspired and adapted from the [auto-commit](https://github.com/cds-snc/github-actions/tree/master/auto-commit
)-Action of the Canadian Digital Service. )-Action of the Canadian Digital Service and the [commit](https://github.com/elstudio/actions-js-build/blob/41d604d6e73d632e22eac40df8cc69b5added04b/commit/entrypoint.sh)-Action by Eric Johnson.
## Usage ## Usage
You have to have an Action in your Workflow, which changes some of your project files. Add the following step at the end of your job.
```yaml
- uses: stefanzweifel/git-auto-commit-action@v2.0.0
with:
commit_message: Apply automatic changes
branch: ${{ github.head_ref }}
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
```
The Action will only commit files back, if changes are available. The resulting commit **will not trigger** another GitHub Actions Workflow run!
### Inputs
The following inputs are required
- `commit_message`: The commit message used when changes are available
- `branch`: Branch name where changes should be pushed to
### Environment Variables
The `GITHUB_TOKEN` secret is required. It is automatically available in your repository. You have to add it to the configuration though.
## Example Usage
This Action will only work, if the job in your workflow changes project files.
The most common use case for this, is when you're running a Linter or Code-Style fixer on GitHub Actions. The most common use case for this, is when you're running a Linter or Code-Style fixer on GitHub Actions.
In this example I'm running `php-cs-fixer` in a PHP project. In this example I'm running `php-cs-fixer` in a PHP project.
```terraform
workflow "php-cs-fixer" {
on = "push"
resolves = [
"auto-commit-php-cs-fixer"
]
}
action "php-cs-fixer" { ```yaml
uses = "docker://oskarstark/php-cs-fixer-ga" on: push
} name: php-cs-fixer
jobs:
php-cs-fixer:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v1
with:
fetch-depth: 1
- name: Run php-cs-fixer
uses: docker://oskarstark/php-cs-fixer-ga
- name: Commit changed files
uses: stefanzweifel/git-auto-commit-action@v2.0.0
with:
commit_message: Apply php-cs-fixer changes
branch: ${{ github.head_ref }}
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
action "auto-commit-php-cs-fixer" {
needs = ["php-cs-fixer"]
uses = "stefanzweifel/git-auto-commit-action@v1.0.0"
secrets = ["GITHUB_TOKEN"]
env = {
COMMIT_MESSAGE = "Apply php-cs-fixer changes"
COMMIT_AUTHOR_EMAIL = "john.doe@example.com"
COMMIT_AUTHOR_NAME = "John Doe"
}
}
``` ```
## Secrets
The `GITHUB_TOKEN` secret is required. Add the secret in the Workflow Editor on github.com.
## Environment variables
The following environment variables are required:
- `COMMIT_MESSAGE`: The commit message used when changes are available
- `COMMIT_AUTHOR_EMAIL`: The Commit Authors Email Address
- `COMMIT_AUTHOR_NAME`: The Commit Authors Name
## Versioning ## Versioning
We use [SemVer](http://semver.org/) for versioning. For the versions available, see the [tags on this repository](https://github.com/stefanzweifel/git-auto-commit-action/tags). We use [SemVer](http://semver.org/) for versioning. For the versions available, see the [tags on this repository](https://github.com/stefanzweifel/git-auto-commit-action/tags).

20
actions.yml Normal file
View File

@@ -0,0 +1,20 @@
name: Git Auto Commit
description: 'Automatically commits files which have been changed.'
author: Stefan Zweifel <hello@stefanzweifel.io>
inputs:
commit_message:
description: Commit message
required: true
branch:
description: Branch where changes should be pushed too
required: true
runs:
using: 'docker'
image: 'Dockerfile'
branding:
icon: 'git-commit'
color: orange

View File

@@ -1,10 +1,40 @@
#!/bin/sh #!/bin/sh
set -eu set -eu
git config --global user.email "actions@github.com" # Set up .netrc file with GitHub credentials
git config --global user.name "GitHub Actions" git_setup ( ) {
cat <<- EOF > $HOME/.netrc
machine github.com
login $GITHUB_ACTOR
password $GITHUB_TOKEN
git add -A machine api.github.com
git status login $GITHUB_ACTOR
git commit -m "$COMMIT_MESSAGE" --author="$COMMIT_AUTHOR_NAME <$COMMIT_AUTHOR_EMAIL>" || echo "No changes found. Nothing to commit." password $GITHUB_TOKEN
git push -u origin HEAD EOF
chmod 600 $HOME/.netrc
git config --global user.email "actions@github.com"
git config --global user.name "GitHub Actions"
}
# This section only runs if there have been file changes
echo "Checking for uncommitted changes in the git working tree."
if ! git diff --quiet
then
git_setup
echo "INPUT_BRANCH value: $INPUT_BRANCH";
# Switch to branch from current Workflow run
git checkout $INPUT_BRANCH
git add .
git commit -m "$INPUT_COMMIT_MESSAGE" --author="$GITHUB_ACTOR <$GITHUB_ACTOR@users.noreply.github.com>"
git push --set-upstream origin "HEAD:$INPUT_BRANCH"
else
echo "Working tree clean. Nothing to commit."
fi