ethicaladitya / AnsiblePress

Boilerplate WordPress Development Environment with Ansible

Home Page:http://jeanpier.re/ansiblepress

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

AnsiblePress (alpha)

A minimal WordPress (LEMP) development environment using: Vagrant, Virtualbox, Ansible, Ubuntu, Nginx, MySQL, and PhP. This is meant to be a quick and easy boilerplate for continued development.

##Pre-Requisites

  1. Vagrant
  2. VirtualBox
  3. Vagrant Host Updater (optional)
  4. Vagrant Bindfs (required)
  5. Ansible

##Quick Setup

  1. Run git clone git@github.com:jeanpierreb/AnsiblePress.git && mkdir WordPress && cd AnsiblePress from your project root
  2. Then run vagrant up

Directory Structure

├── project_root
│   ├── AnsiblePress
│   ├── WordPress

All that's left is to go to wp.dev in your browser and follow WordPress's famous 5-minute installer and start working.

##Custom Url In OSX add this to the end of your /ect/hosts file

192.168.50.50    wp.dev

From Vagrant's Docs

While you can choose any IP you'd like, you should use an IP from the reserved private address space. These IPs are guaranteed to never be publicly routable, and most routers actually block traffic from going to them from the outside world.

##Aliases I added some helper files extracted from my dotfiles repo. You can check them out here if you want more details.

Shortcuts included:

alias ..="cd .."
alias ...="cd ../.."
alias ....="cd ../../.."
alias .....="cd ../../../.."
alias ~="cd ~" # `cd` is probably faster to type though
alias web="cd /etc/nginx/sites-available"
alias wpdir="cd /var/www/wordpress/"

# List all files colorized in long format
alias l="ls -lF ${colorflag}"

# List all files colorized in long format, including dot files
alias la="ls -laF ${colorflag}"

# List only directories
alias lsd="ls -lF ${colorflag} | grep --color=never '^d'"

alias restart="sudo service nginx restart; sudo service php5-fpm restart"
alias status="service nginx status; service php5-fpm status; service mysql status"

##Variables The only file you should have to touch is the group_vars/all It's pretty self explanatory, all you need to do is add your names, passwords and database credentials and ansible will handle the rest.

site: {
  name: wp.dev,
  ip: "192.168.50.50", #Be sure to change this in your VagrantFile as well
  www_root: /var/www/wordpress #there should be no reason to change this but you can.
}

database: {
  name: wordpress, #Database name
  user: wordpress, #Database user given all privs in the database
  password: password #Database user's password
}

##Contributions Pull requests are always welcome.

##Todo

  • Install phpmyadmin
  • Tutorial (Medium)
  • Screencast
  • Update WordPress
  • Use Sage/Bedrock
  • Multisite Support

About

Boilerplate WordPress Development Environment with Ansible

http://jeanpier.re/ansiblepress

License:MIT License


Languages

Language:PHP 92.1%Language:Shell 7.9%