Hi-Folks / gh-actions-yaml-generator

Ghygen is a GitHub Actions configurator for your PHP / Laravel project.
https://ghygen.hi-folks.dev/
MIT License
324 stars 36 forks source link
generator github-actions hacktoberfest laravel yaml yaml-configuration

GitHub Workflow Status (develop branch) GitHub release (latest by date) Website

Ghygen

Ghygen

Ghygen is a GitHub Actions configurator for your PHP / Laravel project.

Ghygen allows you creating your Yaml file for GitHub Actions, for Laravel/PHP web application, so you can:

If you want to test and use quickly this tool, I deployed the codebase (develop branch) on Digital Ocean Platform:

If you want to start using it locally you can clone the repo and install it following the instructions below.

Command line

Ghygen is also a command line tool for generating automatically a GitHub Actions workflow Yaml file. You can install Gygen as project with composer:

composer create-project hi-folks/ghygen
cd ghygen

Once you installed Ghygen, you can execute:

php artisan ghygen:generate --projectdir=../otherproject

Where ../otherproject is the directory (absolute or relative path name) with your Laravel project (application or package) that yuo want to automatically generate the GitHub Actions workflow yaml file.

This command, will extract information from some project file like:

in order to guess a configuration for your GitHub Actions workflow.

By default, the command execution will show the Yaml workflow file in the standard output. If you want to save it in a file, for example the "my-workflow.yml" file, you can use --save option:

php artisan ghygen:generate  --save=my-workflow.yml

If you want to autogenerate Yaml file in the .github/workflows directory use --save=auto:

php artisan ghygen:generate  --save=auto

The file name will be created with the name value found in the composer.json.

So if you want to generate the workflow for the project in the directory ../myproject, you can execute the command with --projectdir and the --save options:

php artisan ghygen:generate --projectdir=../myproject/ --save=auto

The Ghygen Web version

Install the Web version

For running the Web version of Ghygen, you can clone source code, enter the new directory and perform a couple of instructions:

git clone https://github.com/Hi-Folks/gh-actions-yaml-generator.git
cd gh-actions-yaml-generator
make install

Then create your database and update the .env file with the right values for DB_* .

Once your Database is configured you can execute the migrations:

php artisan migrate

Start development server

php artisan serve

Open the browser to the URL: http://127.0.0.1:8000

Usage

Follow these steps:

github-actions-generator-laravel

Next, copy the content of your generated Yaml in a new file in your Laravel project _.github/workflows/laravelworkflow.yaml .

Commit and push the new file.

If you configured "On - Push" you will see the running Actions in your Actions section of your GitHub project.

Thanks to

Thanks to all the people for providing feedback, opening issues, creating Pull Requests. Thank you to all the contributors! You can see the list of contributors at this section.

In the PHP ecosystem, we have many tools that help developers work with great productivity, reliability, and efficiency. One of these tools is JetBrains PHP Storm. JetBrains supports the open-source community by providing licenses for open-source projects. You can find more information in the Open Source section of the JetBrains website.

PhpStorm logo

JetBrains is providing me the license for the Ghygen project. This fills me with joy, because Ghygen has been recognized as a deserving open-source software. Thank you.