Download the PHP package hi-folks/ghygen without Composer
On this page you can find all versions of the php package hi-folks/ghygen. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package 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:
- select triggering events: manually or automatically, when the developer push the code on a specific branch, or a developer create a new Pull Request;
- select branches;
- enable caching for all vendors;
- enable caching PHP packages;
- select multiple PHP versions (8.3, 8.2, 8.1, 8.0, 7.4);
- select multiple Laravel versions (11, 10, 9, 8, 7, 6), useful if you are developing a Laravel Package and you want to test it with multiple Laravel version;
- select Node version for NPM (executing scripts via
npm run
); - caching node packages;
- setup Mysql Database service;
- setup PostgreSQL Database service;
- setup Sqlite in memory database;
- run migrations;
- execute tests via phpunit;
- execute tests via PestPHP;
- static code analysis with phpstan or psalm;
- create Sarif report (with Psalm) for GitHub integration with code scanning;
- code sniffer (via phpcs for PSR12 compatibility);
- validate Yaml file;
- execute Browser Test via Laravel Dusk.
- Run Deployments via Ploi using Ploi Deploy Action.
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:
Once you installed Ghygen, you can execute:
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:
composer.json
package.json
(if it exists).env
file- ... and other assets
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:
If you want to autogenerate Yaml file in the .github/workflows
directory use --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:
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:
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:
Start development server
Open the browser to the URL: http://127.0.0.1:8000
Usage
Follow these steps:
- access to the form (by default the URL is http://127.0.0.1:8000 if you run php artisan serve);
- fill the form;
- click on "Generate Yaml File" button.
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.
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.
All versions of ghygen with dependencies
composer/semver Version ^3.4
danharrin/livewire-rate-limiting Version ^1.3
hi-folks/lara-lens Version ^1.0
laravel/framework Version ^11.0
laravel/tinker Version ^2.9
livewire/livewire Version ^3.4
swaggest/json-schema Version ^0.12.42
symfony/yaml Version ^7.0