mirror of https://github.com/flarum/flarum
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
322 lines
11 KiB
322 lines
11 KiB
# -*- mode: ruby -*- |
|
# vi: set ft=ruby : |
|
|
|
# Config Github Settings |
|
github_username = "fideloper" |
|
github_repo = "Vaprobash" |
|
github_branch = "1.4.2" |
|
github_url = "https://raw.githubusercontent.com/#{github_username}/#{github_repo}/#{github_branch}" |
|
|
|
# Server Configuration |
|
hostname = "flarum.dev" |
|
|
|
# Set a local private network IP address. |
|
# See http://en.wikipedia.org/wiki/Private_network for explanation |
|
# You can use the following IP ranges: |
|
# 10.0.0.1 - 10.255.255.254 |
|
# 172.16.0.1 - 172.31.255.254 |
|
# 192.168.0.1 - 192.168.255.254 |
|
server_ip = "192.168.29.29" |
|
server_cpus = "1" # Cores |
|
server_memory = "512" # MB |
|
server_swap = "768" # Options: false | int (MB) - Guideline: Between one or two times the server_memory |
|
|
|
# UTC for Universal Coordinated Time |
|
# EST for Eastern Standard Time |
|
# US/Central for American Central |
|
# US/Eastern for American Eastern |
|
server_timezone = "UTC" |
|
|
|
# Database Configuration |
|
mysql_root_password = "root" # We'll assume user "root" |
|
mysql_version = "5.5" # Options: 5.5 | 5.6 |
|
mysql_enable_remote = "false" # remote access enabled when true |
|
pgsql_root_password = "root" # We'll assume user "root" |
|
mongo_enable_remote = "false" # remote access enabled when true |
|
|
|
# Languages and Packages |
|
php_timezone = "UTC" # http://php.net/manual/en/timezones.php |
|
php_version = "5.6" # Options: 5.5 | 5.6 |
|
ruby_version = "latest" # Choose what ruby version should be installed (will also be the default version) |
|
ruby_gems = [ # List any Ruby Gems that you want to install |
|
#"jekyll", |
|
#"sass", |
|
#"compass", |
|
] |
|
|
|
# To install HHVM instead of PHP, set this to "true" |
|
hhvm = "false" |
|
|
|
# PHP Options |
|
composer_packages = [ # List any global Composer packages that you want to install |
|
#"phpunit/phpunit:4.0.*", |
|
#"codeception/codeception=*", |
|
"phpspec/phpspec:2.0.*@dev", |
|
"squizlabs/php_codesniffer:1.5.*", |
|
"franzl/studio:dev-master" |
|
] |
|
|
|
# Default web server document root |
|
# Symfony's public directory is assumed "web" |
|
# Laravel's public directory is assumed "public" |
|
public_folder = "/vagrant" |
|
|
|
laravel_root_folder = "/vagrant/laravel" # Where to install Laravel. Will `composer install` if a composer.json file exists |
|
laravel_version = "latest-stable" # If you need a specific version of Laravel, set it here |
|
symfony_root_folder = "/vagrant/symfony" # Where to install Symfony. |
|
|
|
nodejs_version = "latest" # By default "latest" will equal the latest stable version |
|
nodejs_packages = [ # List any global NodeJS packages that you want to install |
|
"bower", |
|
"gulp" |
|
] |
|
|
|
sphinxsearch_version = "rel22" # rel20, rel21, rel22, beta, daily, stable |
|
|
|
|
|
Vagrant.configure("2") do |config| |
|
|
|
# Set server to Ubuntu 14.04 |
|
config.vm.box = "ubuntu/trusty32" |
|
|
|
config.vm.define "Vaprobash" do |vapro| |
|
end |
|
|
|
if Vagrant.has_plugin?("vagrant-hostmanager") |
|
config.hostmanager.enabled = true |
|
config.hostmanager.manage_host = true |
|
config.hostmanager.ignore_private_ip = false |
|
config.hostmanager.include_offline = false |
|
end |
|
|
|
# Create a hostname, don't forget to put it to the `hosts` file |
|
# This will point to the server's default virtual host |
|
# TO DO: Make this work with virtualhost along-side xip.io URL |
|
config.vm.hostname = hostname |
|
|
|
# Create a static IP |
|
config.vm.network :private_network, ip: server_ip |
|
|
|
# A private dhcp network is required for NFS to work (on Windows hosts, at least) |
|
# Windows users should use the winnfsd plugin: https://github.com/GM-Alex/vagrant-winnfsd |
|
config.vm.network :private_network, type: "dhcp" |
|
|
|
# Use NFS for the shared folder |
|
config.vm.synced_folder ".", "/vagrant", |
|
id: "core", |
|
:nfs => true, |
|
:mount_options => ['nolock,vers=3,udp,noatime,actimeo=1'] |
|
|
|
# If using VirtualBox |
|
config.vm.provider :virtualbox do |vb| |
|
|
|
vb.name = "FlarumVm" |
|
|
|
# Set server cpus |
|
vb.customize ["modifyvm", :id, "--cpus", server_cpus] |
|
|
|
# Set server memory |
|
vb.customize ["modifyvm", :id, "--memory", server_memory] |
|
|
|
# Set the timesync threshold to 10 seconds, instead of the default 20 minutes. |
|
# If the clock gets more than 15 minutes out of sync (due to your laptop going |
|
# to sleep for instance, then some 3rd party services will reject requests. |
|
vb.customize ["guestproperty", "set", :id, "/VirtualBox/GuestAdd/VBoxService/--timesync-set-threshold", 10000] |
|
|
|
# Prevent VMs running on Ubuntu to lose internet connection |
|
vb.customize ["modifyvm", :id, "--natdnshostresolver1", "on"] |
|
vb.customize ["modifyvm", :id, "--natdnsproxy1", "on"] |
|
|
|
end |
|
|
|
# If using VMWare Fusion |
|
config.vm.provider "vmware_fusion" do |vb, override| |
|
override.vm.box_url = "http://files.vagrantup.com/precise64_vmware.box" |
|
|
|
# Set server memory |
|
vb.vmx["memsize"] = server_memory |
|
|
|
end |
|
|
|
# If using Vagrant-Cachier |
|
# http://fgrehm.viewdocs.io/vagrant-cachier |
|
if Vagrant.has_plugin?("vagrant-cachier") |
|
# Configure cached packages to be shared between instances of the same base box. |
|
# Usage docs: http://fgrehm.viewdocs.io/vagrant-cachier/usage |
|
config.cache.scope = :box |
|
|
|
config.cache.synced_folder_opts = { |
|
type: :nfs, |
|
mount_options: ['rw', 'vers=3', 'tcp', 'nolock'] |
|
} |
|
end |
|
|
|
# Adding vagrant-digitalocean provider - https://github.com/smdahlen/vagrant-digitalocean |
|
# Needs to ensure that the vagrant plugin is installed |
|
config.vm.provider :digital_ocean do |provider, override| |
|
override.ssh.private_key_path = '~/.ssh/id_rsa' |
|
override.vm.box = 'digital_ocean' |
|
override.vm.box_url = "https://github.com/smdahlen/vagrant-digitalocean/raw/master/box/digital_ocean.box" |
|
|
|
provider.token = 'YOUR TOKEN' |
|
provider.image = 'Ubuntu 14.04 x64' |
|
provider.region = 'nyc2' |
|
provider.size = '512mb' |
|
end |
|
|
|
#### |
|
# Base Items |
|
########## |
|
|
|
# Provision Base Packages |
|
config.vm.provision "shell", path: "#{github_url}/scripts/base.sh", args: [github_url, server_swap, server_timezone] |
|
|
|
# optimize base box |
|
config.vm.provision "shell", path: "#{github_url}/scripts/base_box_optimizations.sh", privileged: true |
|
|
|
# Provision PHP |
|
config.vm.provision "shell", path: "#{github_url}/scripts/php.sh", args: [php_timezone, hhvm, php_version] |
|
|
|
# Enable MSSQL for PHP |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/mssql.sh" |
|
|
|
# Provision Vim |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/vim.sh", args: github_url |
|
|
|
# Provision Docker |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/docker.sh" |
|
|
|
|
|
#### |
|
# Web Servers |
|
########## |
|
|
|
# Provision Apache Base |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/apache.sh", args: [server_ip, public_folder, hostname, github_url] |
|
|
|
# Provision Nginx Base |
|
config.vm.provision "shell", path: "#{github_url}/scripts/nginx.sh", args: [server_ip, public_folder, hostname, github_url] |
|
|
|
|
|
#### |
|
# Databases |
|
########## |
|
|
|
# Provision MySQL |
|
config.vm.provision "shell", path: "#{github_url}/scripts/mysql.sh", args: [mysql_root_password, mysql_version, mysql_enable_remote] |
|
|
|
# Provision PostgreSQL |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/pgsql.sh", args: pgsql_root_password |
|
|
|
# Provision SQLite |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/sqlite.sh" |
|
|
|
# Provision RethinkDB |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/rethinkdb.sh", args: pgsql_root_password |
|
|
|
# Provision Couchbase |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/couchbase.sh" |
|
|
|
# Provision CouchDB |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/couchdb.sh" |
|
|
|
# Provision MongoDB |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/mongodb.sh", args: mongo_enable_remote |
|
|
|
# Provision MariaDB |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/mariadb.sh", args: [mysql_root_password, mysql_enable_remote] |
|
|
|
#### |
|
# Search Servers |
|
########## |
|
|
|
# Install Elasticsearch |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/elasticsearch.sh" |
|
|
|
# Install SphinxSearch |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/sphinxsearch.sh", args: [sphinxsearch_version] |
|
|
|
#### |
|
# Search Server Administration (web-based) |
|
########## |
|
|
|
# Install ElasticHQ |
|
# Admin for: Elasticsearch |
|
# Works on: Apache2, Nginx |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/elastichq.sh" |
|
|
|
|
|
#### |
|
# In-Memory Stores |
|
########## |
|
|
|
# Install Memcached |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/memcached.sh" |
|
|
|
# Provision Redis (without journaling and persistence) |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/redis.sh" |
|
|
|
# Provision Redis (with journaling and persistence) |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/redis.sh", args: "persistent" |
|
# NOTE: It is safe to run this to add persistence even if originally provisioned without persistence |
|
|
|
|
|
#### |
|
# Utility (queue) |
|
########## |
|
|
|
# Install Beanstalkd |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/beanstalkd.sh" |
|
|
|
# Install Heroku Toolbelt |
|
# config.vm.provision "shell", path: "https://toolbelt.heroku.com/install-ubuntu.sh" |
|
|
|
# Install Supervisord |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/supervisord.sh" |
|
|
|
# Install ØMQ |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/zeromq.sh" |
|
|
|
#### |
|
# Additional Languages |
|
########## |
|
|
|
# Install Nodejs |
|
config.vm.provision "shell", path: "#{github_url}/scripts/nodejs.sh", privileged: false, args: nodejs_packages.unshift(nodejs_version, github_url) |
|
|
|
# Install Ruby Version Manager (RVM) |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/rvm.sh", privileged: false, args: ruby_gems.unshift(ruby_version) |
|
|
|
#### |
|
# Frameworks and Tooling |
|
########## |
|
|
|
# Provision Composer |
|
config.vm.provision "shell", path: "#{github_url}/scripts/composer.sh", privileged: false, args: composer_packages.join(" ") |
|
|
|
# Provision Laravel |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/laravel.sh", privileged: false, args: [server_ip, laravel_root_folder, public_folder, laravel_version] |
|
|
|
# Provision Symfony |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/symfony.sh", privileged: false, args: [server_ip, symfony_root_folder, public_folder] |
|
|
|
# Install Screen |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/screen.sh" |
|
|
|
# Install Mailcatcher |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/mailcatcher.sh" |
|
|
|
# Install git-ftp |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/git-ftp.sh", privileged: false |
|
|
|
# Install Ansible |
|
# config.vm.provision "shell", path: "#{github_url}/scripts/ansible.sh" |
|
|
|
#### |
|
# Local Scripts |
|
# Any local scripts you may want to run post-provisioning. |
|
# Add these to the same directory as the Vagrantfile. |
|
########## |
|
config.vm.provision "shell", path: "./scripts/environment.sh", privileged: false |
|
|
|
end
|
|
|