devilbox/docs/Examples.md

13 KiB

Devilbox Documentation

Overview | Quickstart | Install | Update | Configure | Run | Usage | OS | Backups | Examples | Technical | Hacking | FAQ


Examples

  1. Introduction
  2. Setup CakePHP
  3. Setup Drupal
  4. Setup Laravel
  5. Setup Phalcon
  6. Setup Symfony
  7. Setup Wordpress
  8. Setup Yii
  9. Setup Zend

1. Introduction

The devilbox provides popular tools for setting up and managing major frameworks or content management systems. The following bundled tools are available:

Binary Tool name Framework/CMS
composer composer CakePHPi, Symfony, Yii, Zend and others
drush drush Drupal
drupal drupal-consol Drupal
git git Everything available on github and other git servers
laravel laravel installer Laravel
phalcon phalcon devtools Phalcon
symfony symfony installer Symfony
wp wp-cli Wordpress

2. Setup CakePHP

Official CakePHP Documentation

The following configuration will be used:

Project name VirtualHost directory Database TLD_SUFFIX Url
my-cake /shared/httpd/my-cake my_cake loc http://my-cake.loc

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.loc in your browser
# 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
  '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:

127.0.0.1 my-cake.loc

8. Open your browser

All set now, you can visit http://my-cake.loc in your browser.

3. Setup Drupal

Official Drupal Documentation

The following configuration will be used:

Project name VirtualHost directory Database TLD_SUFFIX Url
my-drupal /shared/httpd/my-drupal my_drupal loc http://my-drupal.loc

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.loc in your browser and follow instructions
# 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:

127.0.0.1 my-drupal.loc

6. Open your browser

Open your browser at http://my-drupal.loc and follow the Drupal installation steps.

Note: For MySQL host choose 127.0.0.1.

4. Setup Laravel

Official Laravel Documentation

The following configuration will be used:

Project name VirtualHost directory Database TLD_SUFFIX Url
my-laravel /shared/httpd/my-laravel - loc http://my-laravel.loc

It will be ready in six simple steps:

  1. Enter the PHP container
  2. Create a new VirtualHost directory
  3. Install Laravel via laravel
  4. Symlink public directory
  5. Setup DNS record
  6. Visit http://my-laravel.loc in your browser
# 1. Enter the PHP container
host> ./bash.sh

# 2. Create a new VirtualHost directory
devilbox@php-7.0.20 in /shared/httpd $ mkdir my-laravel

# 3. Install Laravel via laravel
devilbox@php-7.0.20 in /shared/httpd $ cd my-laravel
devilbox@php-7.0.20 in /shared/httpd $ laravel new laravel-project

# 4. Symlink public directory
devilbox@php-7.0.20 in /shared/httpd $ ln -s laravel-project/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:

127.0.0.1 my-laravel.loc

6. Open your browser

Open your browser at http://my-laravel.loc

5. Setup Phalcon

Official Phalcon Documentation

The following configuration will be used:

Project name VirtualHost directory Database TLD_SUFFIX Url
my-phalcon /shared/httpd/my-phalcon - loc http://my-phalcon.loc

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.loc in your browser
# 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:

127.0.0.1 my-phalcon.loc

6. Open your browser

Open your browser at http://my-phalcon.loc

6. Setup Symfony

Official Symfony Documentation

The following configuration will be used:

Project name VirtualHost directory Database TLD_SUFFIX Url
my-symfony /shared/httpd/my-symfony - loc http://my-symfony.loc

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
  5. Enable Symfony prod (app.php)
  6. Setup DNS record
  7. Visit http://my-symfony.loc in your browser
# 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

# 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

6. 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:

127.0.0.1 my-symfony.loc

7. Open your browser

Open your browser at http://my-symfony.loc

7. Setup Wordpress

Official Wordpress Documentation

The following configuration will be used:

Project name VirtualHost directory Database TLD_SUFFIX Url
my-wp /shared/httpd/my-wp my_wp loc http://my-wp.loc

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.loc in your browser
# 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:

127.0.0.1 my-wp.loc

6. Open your browser

Open your browser at http://my-wp.loc

8. Setup Yii

Official Yii Documentation

The following configuration will be used:

Project name VirtualHost directory Database TLD_SUFFIX Url
my-yii /shared/httpd/my-yii - loc http://my-yii.loc

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.loc in your browser
# 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:

127.0.0.1 my-yii.loc

6. Open your browser

Open your browser at http://my-yii.loc

9. Setup Zend

Official Zend Documentation

The following configuration will be used:

Project name VirtualHost directory Database TLD_SUFFIX Url
my-zend /shared/httpd/my-zend - loc http://my-zend.loc

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.loc in your browser
# 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:

127.0.0.1 my-zend.loc

6. Open your browser

Open your browser at http://my-zend.loc