2020-03-29 08:44:47 -06:00
# github-action-push-to-another-repository
2020-03-29 12:59:13 -06:00
Used to push generated files from a directory from Git Action step into another repository on Github.
E.g.
Repository pandoc-test contains Markdown and a Git Action to generate, using Pandoc, an output: HTML, PDF, odt, epub, etc.
Repository pandoc-test-output: contains only the generated files from the first Git Action. Pushed here with github-action-push-to-another-repository
And pandoc-test-output can have Git Pages to give access to the files (or just links to the raw version of the files)
2020-03-29 08:44:47 -06:00
## Inputs
2020-03-29 12:59:13 -06:00
### `source-directory` (argument)
From the repository that this Git Action is executed the directory that contains the files to be pushed into the repository.
### `destination-github-username` (argument)
2020-03-29 13:46:29 -06:00
For the repository `https://github.com/cpina/push-to-another-repository-output` is `cpina` . It's also used for the `Author:` in the generated git messages.
2020-03-29 12:59:13 -06:00
### `destination-repository-name` (argument)
2020-03-29 13:46:29 -06:00
For the repository `https://github.com/cpina/push-to-another-repository-output` is `push-to-another-repository-output`
2020-03-29 12:59:13 -06:00
### `user-email` (argument)
The email that will be used for the commit in the destination-repository-name.
2020-03-29 08:44:47 -06:00
2020-03-29 12:59:13 -06:00
### `API_TOKEN_GITHUB` (environment)
E.g.:
`API_TOKEN_GITHUB: ${{ secrets.API_TOKEN_GITHUB }}`
2020-03-29 08:44:47 -06:00
2020-03-29 13:46:29 -06:00
Generate your personal token following the steps:
* Go to the Github Settings (on the right hand side on the profile picture)
* On the left hand side pane click on "Developer Settings"
* Click on "Personal Access Tokens" (also available at https://github.com/settings/tokens)
* Generate a new token, choose "Repo". Copy the token.
Then make the token available to the Github Action following the steps:
* Go to the Github page for the repository that you push from, click on "Settings"
* On the left hand side pane click on "Secrets"
* Click on "Add a new secret" and name it "API_TOKEN_GITHUB"
2020-03-29 08:44:47 -06:00
## Example usage
2020-03-29 13:46:29 -06:00
```yaml
2020-03-29 12:59:13 -06:00
- name: Pushes to another repository
uses: cpina/github-action-push-to-another-repository@master
env:
API_TOKEN_GITHUB: ${{ secrets.API_TOKEN_GITHUB }}
with:
source-directory: 'output'
destination-github-username: 'cpina'
destination-repository-name: 'pandoc-test-output'
2020-06-08 15:49:19 -06:00
user-email: carles3@pina.cat
2020-03-29 13:46:29 -06:00
```
Working example:
https://github.com/cpina/push-to-another-repository-example/blob/master/.github/workflows/ci.yml
2020-04-03 15:10:49 -06:00
It generates files from:
https://github.com/cpina/push-to-another-repository-example
To:
https://github.com/cpina/push-to-another-repository-output