Download the PHP package kg-bot/laravel-deploy without Composer
On this page you can find all versions of the php package kg-bot/laravel-deploy. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package laravel-deploy
Laravel Deploy
Laravel deploy package, used to automatically deploy project from GIT VCS that supports webhooks.
Installing
Just require this package with composer.
Before you can use this package you have to export and run migrations and create clients for each VCS site or repository
You can create new client with artisan command (Web panel should be in next release)
Explanation of command parameters
name
- Name of the client (eg. GitHub)token
- Token you want to check when validating request, it will be encryptedscript_source
- Name of the .sh script that will be executed on deploy request ( this script needs to be placed in project root )source
- Can be anything and might be used in later versions of app, preferably set this to domain from where you expect request or repository URL
Because deploy is initiated from HTTP request user executing .sh script would be www-data and I find it cumbersome for non Linux or Server oriented developers to tweak with user permissions and server privileges.
This can be changed with some .env directives, you should create .sh script with your default server user and set rwx permissions for that user.
Next thing you need to do is add LARAVEL_DEPLOY_USERNAME
to .env file and set it to your default user (same user from your SSH/CLI).
Also you need to set LARAVEL_DEPLOY_PASSWORD
.env directive to match your default SSH/CLI login password.
Example
If you login to your server with ssh [email protected]
and you enter temp123
as your password then you would set LARAVEL_DEPLOY_USERNAME=forge
and LARAVEL_DEPLOY_PASSWORD=temp123
inside .env file.
Laravel Deploy is enabled by default, if you want to disable it add LARAVEL_DEPLOY_RUN=false
to your .env file.
Laravel 5.5+
Laravel 5.5 uses Package Auto-Discovery, so doesn't require you to manually add the ServiceProvider.
If you don't use auto-discovery, add the ServiceProvider to the providers array in config/app.php
Settings and configuration
You can export config by running
We have already explained some of this package config directives but that's not all.
Routing
This package exposes some routes (only one for now but there will be more of them in next versions)
How to setup webhooks in GIT VCS sites
GitHub
Let's say that your repository is located at [https://github.com/kg-bot/laravel-deploy], you would go to [https://github.com/kg-bot/laravel-deploy/settings/hooks/new].
There you will get screen like this
In the Payload URL you need to enter webhook URL which must be [http://example.com/laravel-deploy/deploy+_token=#####################] (it can be http or https, depend's on your server SSL settings), where example.com
should be your domain and laravel-deploy
should be the prefix you set in configuration, also the token part needs to match hashed value you got when creating new client.
Other parts are not important for now, in next versions this will be probably need to be changed because there will be different code for each site (drivers).
BitBucket
Everything is same as GitHub except links and field names.
Link to create new webhook should be [https://bitbucket.org/:USERNAME:/:REPO:/admin/addon/admin/bitbucket-webhooks/bb-webhooks-repo-admin]
It looks like this , Title can be anything, URL should be same as in GitHub settings, you must check Active and you can check Skip certificate verification for now (until next versions)
Front-end requirements and installation
Front part of this package works as Vue.js SPA and it heavily depends on npm packages
Then you have to export assets from this package, this will add some JavaScript and SASS files inside your resources/assets/vendor/laravel-deploy directory
After this you have to alter webpack.mix.js and add this at the end of file
You can now go to http://localhost/laravel-deploy/dashboard
or any other URL if you have changed route prefix, just add /dashboard
at the end.
Proposals, comments, feedback
Everything of this is highly welcome and appreciated
To-Do
- Web panel
- Driver for each site, system
- Notifications on success, failure (slack, sms, mail, etc.)
- Improved .sh script execution (without using username and password directly in command because it can be later seen in bash_history)
- Improved client validation and recognition
Anything else you can think of please leave me comments, mail me, create issue, whatever you prefer.
License
This project is licensed under the MIT License - see the LICENSE.md file for details
All versions of laravel-deploy with dependencies
ddtraceweb/monolog-parser Version ^1.2
kg-bot/laravel-localization-to-vue Version 1.*
laravel/framework Version 5.*
predis/predis Version ^1.1