Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/andrewthetechie/gha-cookiecutter
Generate a cookiecutter template in Github Actions
https://github.com/andrewthetechie/gha-cookiecutter
Last synced: about 1 month ago
JSON representation
Generate a cookiecutter template in Github Actions
- Host: GitHub
- URL: https://github.com/andrewthetechie/gha-cookiecutter
- Owner: andrewthetechie
- License: mit
- Created: 2022-06-10T02:24:15.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-03-25T03:41:40.000Z (9 months ago)
- Last Synced: 2024-05-04T00:25:25.345Z (8 months ago)
- Language: Python
- Size: 116 KB
- Stars: 5
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# Cookiecutter in GHA
[![Action Template](https://img.shields.io/badge/Action%20Template-Python%20Container%20Action-blue.svg?colorA=24292e&colorB=0366d6&style=flat&longCache=true&logo=)](https://github.com/andrewthetechie/gha-cookiecutter)
[![Actions Status](https://github.com/andrewthetechie/gha-cookiecutter/workflows/Lint/badge.svg)](https://github.com/andrewthetechie/gha-cookiecutter/actions)
[![Actions Status](https://github.com/andrewthetechie/gha-cookiecutter/workflows/Integration%20Test/badge.svg)](https://github.com/andrewthetechie/gha-cookiecutter/actions)## Description
Generate from a cookiecutter template as part of your github workflow
## Usage
Runs cookiecutter on the specified template, passing in the values input as cookiecutterValues.
This action does not commit or push any files, check out an action like [stefanzweifel/git-auto-commit-action](https://github.com/stefanzweifel/git-auto-commit-action) for a way to commit generated files.
### Example workflow
```yaml
name: Run Cookiecutter
on: [workflow_dispatch]
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Run Cookiecutter
uses: andrewthetechie/gha-cookiecutter@main
with:
# can be a link to a git repo or a local path
template: https://github.com/cjolowicz/cookiecutter-hypermodern-python
cookiecutterValues: '{
"foo": "bar",
"baz": "boo",
"num": 2
}'
```Or to use a cookiecutter in a private repo, use a checkout with a token that has access to that repo
```
name: Run Cookiecutter Private
on: [workflow_dispatch]
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
with:
repository: "yourprivatecookiecutter"
token: ${{ secrets.GITHUB_TOKEN }}
- name: Run Cookiecutter
uses: andrewthetechie/gha-cookiecutter@main
with:
# path to what you checked out
template: ./yourprivatecookiecutter
cookiecutterValues: '{
"foo": "bar",
"baz": "boo",
"num": 2
}'
```## Inputs
| parameter | description | required | default |
| - | - | - | - |
| cookiecutterValues | Json blob to pass to the cookiecutter template. Any values not filled in will be set to template's default | `false` | {} |
| template | A directory containing a project template directory (or zip file), or a URL to a git repository. | `true` | |
| templateCheckout | The branch, tag or commit ID to checkout after clone. | `false` | |
| templateDirectory | Relative path to a cookiecutter template in a repository. | `false` | |
| outputDir | Where to output the generated project dir into. | `false` | . |
| overwrite | Overwrite files if they already exist in outputDir if true. Takes priority over 'skip' | `false` | false |
| skip | Skip files if they already exist in outputDir if true. Ignored if 'overwrite' is true | `false` | false |
| zipPassword | If your template zip is password protected, put your password here | `false` | |
| acceptHooks | Accept pre and post hooks if set to true. | `false` | true |## Outputs
| parameter | description |
| - | - |
| outputDir | Directory the cookiecutter outputted to |## Runs
This action is a `docker` action.
### Contributors
Thanks go to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)):