Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/termkit/gama
Manage your GitHub Actions from Terminal with great UI 🧪
https://github.com/termkit/gama
actions bubbles bubbletea cd ci cicd githubactions go golang terminal terminal-ui tui
Last synced: 13 days ago
JSON representation
Manage your GitHub Actions from Terminal with great UI 🧪
- Host: GitHub
- URL: https://github.com/termkit/gama
- Owner: termkit
- License: gpl-3.0
- Created: 2023-11-30T18:55:16.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-12-17T23:07:04.000Z (25 days ago)
- Last Synced: 2024-12-17T23:27:00.065Z (25 days ago)
- Topics: actions, bubbles, bubbletea, cd, ci, cicd, githubactions, go, golang, terminal, terminal-ui, tui
- Language: Go
- Homepage:
- Size: 1.46 MB
- Stars: 200
- Watchers: 3
- Forks: 14
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- charm-in-the-wild - gama - Manage GitHub Actions from the terminal. (_built with Bubble Tea_) (Applications / Development Tools)
- stars - gama
- stars - gama
README
# GitHub Actions Manager (GAMA)
GAMA is a powerful terminal-based user interface tool designed to streamline the management of GitHub Actions workflows. It allows developers to list, trigger, and manage workflows with ease directly from the terminal.
![gama demo](docs/gama.gif)
## Key Features
- **Extended Workflow Inputs**: Supports more than 10 workflow inputs using JSON format.
- **Workflow History**: Conveniently list all historical runs of workflows in a repository.
- **Discoverability**: Easily list all triggerable (dispatchable) workflows in a repository.
- **Workflow Management**: Trigger specific workflows with custom inputs.## Getting Started
### Prerequisites
Before using GAMA, you need to generate a GitHub token. Follow these [instructions](docs/generate_github_token/README.md) to create your token.
### Configuration
#### YAML Configuration
Place a `~/.config/gama/config.yaml` file in your home directory with the following content:
```yaml
github:
token:keys:
switch_tab_right: shift+right
switch_tab_left: shift+left
quit: ctrl+c
refresh: ctrl+r
enter: enter
tab: tab
```#### Environment Variable Configuration
Alternatively, you can use an environment variable:
```bash
GITHUB_TOKEN="" gama
```You can also make it an alias for a better experience:
```bash
alias gama='GITHUB_TOKEN="" command gama'
```If you have the [GitHub CLI](https://cli.github.com/) installed, you automatically insert the var via:
```bash
GITHUB_TOKEN="$(gh auth token)" gama
```This will skip needing to generate a token via the GitHub website.
> [!WARNING]
> For security reasons, you should not `export` your token globally in your shell.
> That would make it available to any app that can read environment variables.
> You should avoid committing it to your dotfiles repository, too.## Build & Installation
### Using Docker
Run GAMA in a Docker container:
```bash
docker run --rm -it --env GITHUB_TOKEN="" termkit/gama:latest
```### Download Binary
Download the latest binary from the [releases page](https://github.com/termkit/gama/releases).
### Build from Source
```bash
make build
# output: ./release/gama
```---
## Contributing
Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are **greatly appreciated**.
## License
Distributed under the GNU GENERAL PUBLIC LICENSE Version 3 or later. See [LICENSE](LICENSE) for more information.
## Contact & Author
[Engin Açıkgöz](https://github.com/canack)
## Stargazers over time
[![Stargazers over time](https://starchart.cc/termkit/gama.svg?variant=adaptive)](https://starchart.cc/termkit/gama)