mirror of https://github.com/flarum/flarum
Mike Dugan
10 years ago
4 changed files with 351 additions and 0 deletions
@ -0,0 +1,320 @@
|
||||
# -*- mode: ruby -*- |
||||
# vi: set ft=ruby : |
||||
|
||||
# Config Github Settings |
||||
github_username = "fideloper" |
||||
github_repo = "Vaprobash" |
||||
github_branch = "1.3.0" |
||||
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.*", |
||||
] |
||||
|
||||
# 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 |
||||
#"grunt-cli", |
||||
#"gulp", |
||||
#"bower", |
||||
#"yo", |
||||
] |
||||
|
||||
sphinxsearch_version = "rel22" # rel20, rel21, rel22, beta, daily, stable |
||||
|
||||
|
||||
Vagrant.configure("2") do |config| |
||||
|
||||
# Set server to Ubuntu 14.04 |
||||
config.vm.box = "ubuntu/trusty64" |
||||
|
||||
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 |
||||
|
||||
# Use NFS for the shared folder |
||||
config.vm.synced_folder ".", "/vagrant", |
||||
id: "core", |
||||
:nfs => true, |
||||
:mount_options => ['nolock,vers=3,udp,noatime'] |
||||
|
||||
# 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" |
||||
|
||||
end |
@ -0,0 +1,9 @@
|
||||
#! /bin/bash |
||||
cp /vagrant/scripts/aliases ~/.aliases |
||||
|
||||
if [ -e "/home/vagrant/.zshrc" ] |
||||
then |
||||
echo "source ~/.aliases" >> ~/.zshrc |
||||
else |
||||
echo "source ~/.aliases" >> ~/.bashrc |
||||
fi |
@ -0,0 +1,19 @@
|
||||
#! /bin/bash |
||||
|
||||
|
||||
|
||||
cp /vagrant/.env.example.php /vagrant/.env.local.php |
||||
|
||||
sudo apt-get install phantomjs zsh exuberant-ctags |
||||
|
||||
curl -L http://install.ohmyz.sh | sh |
||||
## Comment the below line out if you don't want zsh |
||||
chsh /bin/zsh vagrant |
||||
|
||||
cd /vagrant |
||||
php artisan migrate --bench="flarum/core" |
||||
php artisan db:seed --class="Flarum\Core\Support\Seeders\DatabaseSeeder" |
||||
cd /vagrant/workbench/flarum/core/ember |
||||
npm install |
||||
bower install |
||||
|
Loading…
Reference in new issue