Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/node-link/cakephp-git-deploy
Plugin to operate automatic git-pull server with CakePHP 3 (Using WebHook from GitHub, GitLab and Bitbucket)
https://github.com/node-link/cakephp-git-deploy
bitbucket cakephp cakephp-plugin git github gitlab webhook
Last synced: 1 day ago
JSON representation
Plugin to operate automatic git-pull server with CakePHP 3 (Using WebHook from GitHub, GitLab and Bitbucket)
- Host: GitHub
- URL: https://github.com/node-link/cakephp-git-deploy
- Owner: node-link
- License: mit
- Created: 2018-09-26T06:29:59.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2018-10-09T10:46:36.000Z (over 6 years ago)
- Last Synced: 2024-11-22T14:08:10.423Z (2 months ago)
- Topics: bitbucket, cakephp, cakephp-plugin, git, github, gitlab, webhook
- Language: PHP
- Size: 2.01 MB
- Stars: 1
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# GitDeploy plugin for CakePHP
Plugin to operate automatic git-pull server with CakePHP 3 (Using WebHook from GitHub, GitLab and Bitbucket)
## Requirements
* CakePHP 3.5 or later
* PHP 5.6 or later## Installation
### 1. Install plugin
You can install this plugin into your CakePHP application using [composer](http://getcomposer.org).
The recommended way to install composer packages is:
```
composer require node-link/cakephp-git-deploy
```### 2. Load plugin
Please load the plugin manually as follows:
```php
addPlugin('NodeLink/GitDeploy');
}
}
```Prior to 3.6.0, you should use `Plugin::load()`:
```php
true, 'routes' => true]);
```Or, use `bin/cake` to load the plugin as follows:
```bash
bin/cake plugin load -b -r NodeLink/GitDeploy
```## Configuration
Edit `config/.env` or `config/app.php`.
The full default configuration is as follows:
```php
[
'enable' => filter_var(env('GIT_DEPLOY_ENABLE', false), FILTER_VALIDATE_BOOLEAN),
'token' => env('GIT_DEPLOY_TOKEN', 'secret'),
'branch' => env('GIT_DEPLOY_BRANCH', 'master'),
'git_path' => env('GIT_DEPLOY_GIT_PATH', '/usr/bin/git'),
'composer_path' => env('GIT_DEPLOY_COMPOSER_PATH', '/usr/local/bin/composer')
],
];
```It is recommended to add following items to `config/.env`.
```bash
export GIT_DEPLOY_ENABLE="true"
export GIT_DEPLOY_TOKEN="__TOKEN__"
export GIT_DEPLOY_BRANCH="master"
export GIT_DEPLOY_GIT_PATH="/usr/bin/git"
export GIT_DEPLOY_COMPOSER_PATH="/usr/local/bin/composer"
export COMPOSER_HOME="/var/www"
```It may not work unless `COMPOSER_HOME` is set correctly.
## Settings
### GitHub
In your repository, navigate to Settings → Webhooks → Add webhook, and use the following settings:
* Payload URL: https://example.com/git-deploy
* Content type: application/json
* Secret: The value of `GIT_DEPLOY_TOKEN` in `config/.env`
* Which events would you like to trigger this webhook?: :radio_button: Just the push event
* Active: :ballot_box_with_check:Click "Add webhook" to save your settings, and the script should start working.
![Example screenshot showing GitHub webhook settings](./github-webhook-settings.png)
### GitLab
In your repository, navigate to Settings → Integrations, and use the following settings:
* URL: https://example.com/git-deploy
* Secret Token: The value of `GIT_DEPLOY_TOKEN` in `config/.env`
* Trigger: :ballot_box_with_check: Push events
* Enable SSL verification: :ballot_box_with_check: (only if using SSL, see [GitLab's documentation](https://gitlab.com/help/user/project/integrations/webhooks#ssl-verification) for more details)Click "Add webhook" to save your settings, and the script should start working.
![Example screenshot showing GitLab webhook settings](./gitlab-webhook-settings.png)
### Bitbucket
In your repository, navigate to Settings → Webhooks → Add webhook, and use the following settings:
* Title: Git Deploy
* URL: https://example.com/git-deploy?token= `GIT_DEPLOY_TOKEN`
* Active: :ballot_box_with_check:
* SSL / TLS: :white_large_square: Skip certificate verification (only if using SSL, see [Bitbucket's documentation](https://confluence.atlassian.com/bitbucket/manage-webhooks-735643732.html#ManageWebhooks-skip_certificate) for more details)
* Triggers: :radio_button: Repository pushClick "Save" to save your settings, and the script should start working.
![Example screenshot showing Bitbucket webhook settings](./bitbucket-webhook-settings.png)
## Trouble Shooting
If execution is not successful, please refer to `logs/error.log` and `logs/debug.log`.
Details of the error at the time of execution may be listed in some cases.
### Permissions
When it does not work well, in many cases, there is a problem with permissions.
Please set so that the web server user (`www`, `www-data`, `apache`, etc...) can `git pull` and `composer install`.
It is suggested this be accomplished by changing the repository group to the web server user's and giving the group write permissions:
1. Open a terminal to the directory containing the repository on the server.
2. run `sudo chown -R yourusername:webserverusername project-dir/` to change the group of the repo.
3. run `sudo chmod -R g+s project-dir/` to make the group assignment inherited for new files/dirs.
4. run `sudo chmod -R 775 project-dir/` to set read & write for both owner and group.### SSH
Generate an SSH key and add it to your account so that git pull can be run without a password.
* [GitHub documentation](https://help.github.com/articles/connecting-to-github-with-ssh/)
* [GitLab documentation](https://docs.gitlab.com/ce/ssh/README.html)
* [Bitbucket documentation](https://confluence.atlassian.com/bitbucket/set-up-an-ssh-key-728138079.html)## Reporting Issues
If you have a problem with the GitDeploy plugin, please send a pull request or open an issue on [GitHub](https://github.com/node-link/cakephp-git-deploy/issues).
Also, I would appreciate it if you contribute to updating `README.md` file.