2017-06-08 07:25:03 +00:00
# Devilbox Documentation
2017-06-15 06:46:50 +00:00
[Overview ](README.md ) |
2017-06-14 07:25:57 +00:00
[Quickstart ](Quickstart.md ) |
[Install ](Install.md ) |
[Update ](Update.md ) |
[Configure ](Configure.md ) |
[Run ](Run.md ) |
[Usage ](Usage.md ) |
2017-06-21 07:19:51 +00:00
[OS ](OS.md ) |
2017-06-14 07:25:57 +00:00
[Backups ](Backups.md ) |
Examples |
[Technical ](Technical.md ) |
[Hacking ](Hacking.md ) |
[FAQ ](FAQ.md )
2017-06-08 07:25:03 +00:00
---
## Examples
2017-06-18 18:20:45 +00:00
1. [Introduction ](#1-introduction )
2. [Setup CakePHP ](#2-setup-cakephp )
3. [Setup Drupal ](#3-setup-drupal )
2017-06-20 19:31:00 +00:00
4. [Setup Phalcon ](#4-setup-phalcon )
5. [Setup Symfony ](#5-setup-symfony )
6. [Setup Wordpress ](#6-setup-wordpress )
7. [Setup Yii ](#7-setup-yii )
8. [Setup Zend ](#8-setup-zend )
2017-06-08 07:25:03 +00:00
---
2017-06-18 18:20:45 +00:00
## 1. Introduction
2017-06-08 07:25:03 +00:00
2017-06-18 18:20:45 +00:00
The devilbox provides popular tools for setting up and managing major frameworks or content management systems. The following bundled tools are available:
2017-06-08 07:25:03 +00:00
2017-06-18 18:20:45 +00:00
| Binary | Tool name | Framework/CMS |
|------------|-------------------|--------------------|
2017-06-20 19:31:00 +00:00
| `composer` | [composer ](https://getcomposer.org ) | CakePHPi, Symfony, Yii, Zend and others |
2017-06-18 18:20:45 +00:00
| `drush` | [drush ](http://www.drush.org/ ) | Drupal |
| `drupal` | [drupal-consol ](https://drupalconsole.com ) | Drupal |
| `git` | [git ](https://git-scm.com ) | Everything available on github and other git servers |
2017-06-22 09:32:43 +00:00
| `laravel` | [laravel installer ](https://github.com/laravel/installer ) | Laravel |
2017-06-20 10:15:32 +00:00
| `phalcon` | [phalcon devtools ](https://github.com/phalcon/phalcon-devtools ) | Phalcon |
| `symfony` | [symfony installer ](https://github.com/symfony/symfony-installer ) | Symfony |
2017-06-18 18:20:45 +00:00
| `wp` | [wp-cli ](https://wp-cli.org/ ) | Wordpress |
2017-06-15 06:46:50 +00:00
2017-06-18 18:20:45 +00:00
## 2. Setup CakePHP
2017-06-08 07:25:03 +00:00
2017-06-18 18:20:45 +00:00
The following configuration will be used:
| Project name | VirtualHost directory | Database | TLD_SUFFIX | Url |
|--------------|-----------------------|------------|------------|-----|
| my-cake | /shared/httpd/my-cake | my_cake | local | http://my-cake.local |
It will be ready in eight simple steps:
1. Enter the PHP container
2. Create a new VirtualHost directory
3. Install CakePHP via `composer`
4. Symlink webroot directory
5. Add MySQL database
6. Configure datbase connection
7. Setup DNS record
8. Visit http://my-cake.local in your browser
```shell
# 1. Enter the PHP container
host> ./bash.sh
# 2. Create a new VirtualHost directory
devilbox@php-7.0.20 in /shared/httpd $ mkdir my-cake
# 3. Install CakePHP via composer
devilbox@php-7.0.20 in /shared/httpd $ cd my-cake
devilbox@php-7.0.20 in /shared/httpd $ composer create-project --prefer-dist cakephp/app cakephp
# 4. Symlink webroot directory
devilbox@php-7.0.20 in /shared/httpd $ ln -s cakephp/webroot/ htdocs
# 5. Add MySQL datbase
devilbox@php-7.0.20 in /shared/httpd $ mysql -u root -h 127.0.0.1 -p -e 'CREATE DATABASE my_cake;'
# 6. Configure datbase connection
devilbox@php-7.0.20 in /shared/httpd $ vi cakephp/config/app.php
```
```php
< ?php
'Datasources' => [
'default' => [
'className' => 'Cake\Database\Connection',
'driver' => 'Cake\Database\Driver\Mysql',
'persistent' => false,
'host' => '127.0.0.1',
/**
* CakePHP will use the default DB port based on the driver selected
* MySQL on MAMP uses port 8889, MAMP users will want to uncomment
* the following line and set the port accordingly
*/
//'port' => 'non_standard_port_number',
'username' => 'root',
'password' => 'secret',
'database' => 'my_cake',
'encoding' => 'utf8',
'timezone' => 'UTC',
'flags' => [],
'cacheMetadata' => true,
```
**7. DNS record**
If you do not have auto-DNS configured, you will need to add the following line to your Host computer's `/etc/hosts` :
```shell
127.0.0.1 my-cake.local
```
**8. Open your browser**
All set now, you can visit http://my-cake.local in your browser.
If you want to dig deeper into installing CakePHP, visit their documentation [https://book.cakephp.org/3.0/en/installation.html ](https://book.cakephp.org/3.0/en/installation.html ).
2017-06-22 09:32:43 +00:00
2017-06-18 18:20:45 +00:00
## 3. Setup Drupal
The following configuration will be used:
| Project name | VirtualHost directory | Database | TLD_SUFFIX | Url |
|--------------|-----------------------|------------|------------|-----|
| my-drupal | /shared/httpd/my-drupal | my_drupal| local | http://my-drupal.local |
It will be ready in six simple steps:
1. Enter the PHP container
2. Create a new VirtualHost directory
3. Install Drupal via `drush`
4. Symlink Drupal directory
5. Setup DNS record
6. Visit http://my-drupal.local in your browser and follow instructions
```shell
# 1. Enter the PHP container
host> ./bash.sh
# 2. Create a new VirtualHost directory
devilbox@php-7.0.20 in /shared/httpd $ mkdir my-drupal
# 3. Install Drupal via drush
devilbox@php-7.0.20 in /shared/httpd $ cd my-drupal
devilbox@php-7.0.20 in /shared/httpd $ drush dl drupal
# 4. Symlink Drupal directory
devilbox@php-7.0.20 in /shared/httpd $ ln -s drupal-8.3.3 htdocs
```
**5. DNS record**
If you do not have auto-DNS configured, you will need to add the following line to your Host computer's `/etc/hosts` :
```shell
127.0.0.1 my-drupal.local
```
**6. Open your browser**
Open your browser at http://my-drupal.local and follow the Drupal installation steps.
**Note:** For MySQL host choose `127.0.0.1` .
2017-06-22 09:32:43 +00:00
2017-06-20 19:31:00 +00:00
## 4. Setup Phalcon
The following configuration will be used:
| Project name | VirtualHost directory | Database | TLD_SUFFIX | Url |
|--------------|-----------------------|------------|------------|-----|
| my-phalcon | /shared/httpd/my-phalcon | - | local | http://my-phalcon.local |
It will be ready in six simple steps:
1. Enter the PHP container
2. Create a new VirtualHost directory
3. Install Phalcon via `phalcon`
4. Symlink public directory
5. Setup DNS record
6. Visit http://my-phalcon.local in your browser
```shell
# 1. Enter the PHP container
host> ./bash.sh
# 2. Create a new VirtualHost directory
devilbox@php-7.0.20 in /shared/httpd $ mkdir my-phalcon
# 3. Install Phalcon via phalcon
devilbox@php-7.0.20 in /shared/httpd $ cd my-phalcon
devilbox@php-7.0.20 in /shared/httpd $ phalcon project phalconphp
# 4. Symlink public directory
devilbox@php-7.0.20 in /shared/httpd $ ln -s phalconphp/public htdocs
```
**5. DNS record**
If you do not have auto-DNS configured, you will need to add the following line to your Host computer's `/etc/hosts` :
```shell
127.0.0.1 my-phalcon.local
```
**7. Open your browser**
Open your browser at http://my-phalcon.local
## 5. Setup Symfony
2017-06-18 18:20:45 +00:00
The following configuration will be used:
| Project name | VirtualHost directory | Database | TLD_SUFFIX | Url |
|--------------|-----------------------|------------|------------|-----|
| my-symfony | /shared/httpd/my-symfony | - | local | http://my-symfony.local |
It will be ready in six simple steps:
1. Enter the PHP container
2. Create a new VirtualHost directory
3. Install Symfony via `symfony`
4. Symlink web directory
2017-06-20 10:15:32 +00:00
5. Enable Symfony prod (app.php)
6. Setup DNS record
7. Visit http://my-symfony.local in your browser
2017-06-18 18:20:45 +00:00
```shell
# 1. Enter the PHP container
host> ./bash.sh
# 2. Create a new VirtualHost directory
devilbox@php-7.0.20 in /shared/httpd $ mkdir my-symfony
# 3. Install Symfony via symfony
devilbox@php-7.0.20 in /shared/httpd $ cd my-symfony
devilbox@php-7.0.20 in /shared/httpd $ symfony new symfony
# 4. Symlink web directory
devilbox@php-7.0.20 in /shared/httpd $ ln -s symfony/web htdocs
2017-06-20 10:15:32 +00:00
# 5. Enable Symfony production (app.php)
devilbox@php-7.0.20 in /shared/httpd $ cd symfony/web
devilbox@php-7.0.20 in /shared/httpd $ ln -s app.php index.php
2017-06-18 18:20:45 +00:00
```
2017-06-20 10:15:32 +00:00
**6. DNS record**
2017-06-18 18:20:45 +00:00
If you do not have auto-DNS configured, you will need to add the following line to your Host computer's `/etc/hosts` :
```shell
127.0.0.1 my-symfony.local
```
2017-06-20 10:15:32 +00:00
**7. Open your browser**
2017-06-18 18:20:45 +00:00
2017-06-20 19:31:00 +00:00
Open your browser at http://my-symfony.local
2017-06-18 18:20:45 +00:00
2017-06-20 19:31:00 +00:00
## 6. Setup Wordpress
2017-06-18 18:20:45 +00:00
The following configuration will be used:
| Project name | VirtualHost directory | Database | TLD_SUFFIX | Url |
|--------------|-----------------------|------------|------------|-----|
| my-wp | /shared/httpd/my-wp | my_wp | local | http://my-wp.local |
It will be ready in six simple steps:
1. Enter the PHP container
2. Create a new VirtualHost directory
3. Download Wordpress via `git`
4. Symlink wordpress git directory
5. Setup DNS record
6. Visit http://my-wp.local in your browser
```shell
# 1. Enter the PHP container
host> ./bash.sh
# 2. Create a new VirtualHost directory
devilbox@php-7.0.20 in /shared/httpd $ mkdir my-wp
# 3. Download Wordpress via git
devilbox@php-7.0.20 in /shared/httpd $ cd my-wp
devilbox@php-7.0.20 in /shared/httpd $ git clone https://github.com/WordPress/WordPress wordpress.git
# 4. Symlink wordpress git directory
devilbox@php-7.0.20 in /shared/httpd $ ln -s wordpress.git htdocs
```
**5. DNS record**
If you do not have auto-DNS configured, you will need to add the following line to your Host computer's `/etc/hosts` :
```shell
127.0.0.1 my-wp.local
```
**6. Open your browser**
Open your browser at http://my-wp.local
2017-06-20 19:31:00 +00:00
## 7. Setup Yii
2017-06-18 18:20:45 +00:00
The following configuration will be used:
| Project name | VirtualHost directory | Database | TLD_SUFFIX | Url |
|--------------|-----------------------|------------|------------|-----|
| my-yii | /shared/httpd/my-yii | - | local | http://my-yii.local |
It will be ready in six simple steps:
1. Enter the PHP container
2. Create a new VirtualHost directory
3. Install Yii2 via `composer`
4. Symlink web directory
5. Setup DNS record
6. Visit http://my-yii.local in your browser
```shell
# 1. Enter the PHP container
host> ./bash.sh
# 2. Create a new VirtualHost directory
devilbox@php-7.0.20 in /shared/httpd $ mkdir my-yii
# 3. Install Yii2 via composer
devilbox@php-7.0.20 in /shared/httpd $ cd my-yii
devilbox@php-7.0.20 in /shared/httpd $ composer create-project --prefer-dist --stability=dev yiisoft/yii2-app-basic yii2-dev
# 4. Symlink web directory
devilbox@php-7.0.20 in /shared/httpd $ ln -s yii2-dev/web htdocs
```
**5. DNS record**
If you do not have auto-DNS configured, you will need to add the following line to your Host computer's `/etc/hosts` :
```shell
127.0.0.1 my-yii.local
```
**6. Open your browser**
Open your browser at http://my-yii.local
2017-06-20 19:31:00 +00:00
## 8. Setup Zend
The following configuration will be used:
| Project name | VirtualHost directory | Database | TLD_SUFFIX | Url |
|--------------|-----------------------|------------|------------|-----|
| my-zend | /shared/httpd/my-zend | - | local | http://my-zend.local |
It will be ready in six simple steps:
1. Enter the PHP container
2. Create a new VirtualHost directory
3. Install Zendframework via `composer`
4. Symlink public directory
5. Setup DNS record
6. Visit http://my-zend.local in your browser
```shell
# 1. Enter the PHP container
host> ./bash.sh
# 2. Create a new VirtualHost directory
devilbox@php-7.0.20 in /shared/httpd $ mkdir my-zend
# 3. Install Zendframework via composer
devilbox@php-7.0.20 in /shared/httpd $ cd my-zend
devilbox@php-7.0.20 in /shared/httpd $ composer create-project --prefer-dist zendframework/skeleton-application zend
# 4. Symlink public directory
devilbox@php-7.0.20 in /shared/httpd $ ln -s zend/public htdocs
```
**5. DNS record**
If you do not have auto-DNS configured, you will need to add the following line to your Host computer's `/etc/hosts` :
```shell
127.0.0.1 my-zend.local
```
**7. Open your browser**
Open your browser at http://my-zend.local