Blame view

Vagrantfile 2.38 KB
4ca21c3e   Alexey Boroda   first commit
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
  require 'yaml'
  require 'fileutils'
  
  domains = {
    frontend: 'y2aa-frontend.dev',
    backend:  'y2aa-backend.dev'
  }
  
  config = {
    local: './vagrant/config/vagrant-local.yml',
    example: './vagrant/config/vagrant-local.example.yml'
  }
  
  # copy config from example if local config not exists
  FileUtils.cp config[:example], config[:local] unless File.exist?(config[:local])
  # read config
  options = YAML.load_file config[:local]
  
  # check github token
  if options['github_token'].nil? || options['github_token'].to_s.length != 40
    puts "You must place REAL GitHub token into configuration:\n/yii2-app-advancded/vagrant/config/vagrant-local.yml"
    exit
  end
  
  # vagrant configurate
  Vagrant.configure(2) do |config|
    # select the box
    config.vm.box = 'ubuntu/trusty64'
  
    # should we ask about box updates?
    config.vm.box_check_update = options['box_check_update']
  
    config.vm.provider 'virtualbox' do |vb|
      # machine cpus count
      vb.cpus = options['cpus']
      # machine memory size
      vb.memory = options['memory']
      # machine name (for VirtualBox UI)
      vb.name = options['machine_name']
    end
  
    # machine name (for vagrant console)
    config.vm.define options['machine_name']
  
    # machine name (for guest machine console)
    config.vm.hostname = options['machine_name']
  
    # network settings
    config.vm.network 'private_network', ip: options['ip']
  
    # sync: folder 'yii2-app-advanced' (host machine) -> folder '/app' (guest machine)
    config.vm.synced_folder './', '/app', owner: 'vagrant', group: 'vagrant'
  
    # disable folder '/vagrant' (guest machine)
    config.vm.synced_folder '.', '/vagrant', disabled: true
  
    # hosts settings (host machine)
    config.vm.provision :hostmanager
    config.hostmanager.enabled            = true
    config.hostmanager.manage_host        = true
    config.hostmanager.ignore_private_ip  = false
    config.hostmanager.include_offline    = true
    config.hostmanager.aliases            = domains.values
  
    # provisioners
    config.vm.provision 'shell', path: './vagrant/provision/once-as-root.sh', args: [options['timezone']]
    config.vm.provision 'shell', path: './vagrant/provision/once-as-vagrant.sh', args: [options['github_token']], privileged: false
    config.vm.provision 'shell', path: './vagrant/provision/always-as-root.sh', run: 'always'
  
    # post-install message (vagrant console)
    config.vm.post_up_message = "Frontend URL: http://#{domains[:frontend]}\nBackend URL: http://#{domains[:backend]}"
  end