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
73
74
75
76
77
78
79
80
81
82
83
84
|
# -*- mode: ruby -*-
# vi: set ft=ruby :
##############################################################################
# Copyright (c) 2020
# All rights reserved. This program and the accompanying materials
# are made available under the terms of the Apache License, Version 2.0
# which accompanies this distribution, and is available at
# http://www.apache.org/licenses/LICENSE-2.0
##############################################################################
$no_proxy = ENV['NO_PROXY'] || ENV['no_proxy'] || "127.0.0.1,localhost"
# NOTE: This range is based on vagrant-libvirt network definition CIDR 192.168.121.0/24
(1..254).each do |i|
$no_proxy += ",192.168.121.#{i}"
end
$no_proxy += ",10.0.2.15"
$socks_proxy = ENV['socks_proxy'] || ENV['SOCKS_PROXY'] || ""
Vagrant.configure("2") do |config|
config.vm.provider :libvirt
config.vm.provider :virtualbox
config.vm.box = "generic/ubuntu1804"
config.vm.box_version = "3.0.8"
config.vm.synced_folder './', '/vagrant'
[:virtualbox, :libvirt].each do |provider|
config.vm.provider provider do |p|
p.cpus = 2
p.memory = 4096
end
end
config.vm.provider "virtualbox" do |v|
v.gui = false
end
config.vm.provider :libvirt do |v|
v.cpu_mode = 'host-passthrough'
v.random_hostname = true
v.management_network_address = "192.168.121.0/24"
end
if ENV['http_proxy'] != nil and ENV['https_proxy'] != nil
if Vagrant.has_plugin?('vagrant-proxyconf')
config.proxy.http = ENV['http_proxy'] || ENV['HTTP_PROXY'] || ""
config.proxy.https = ENV['https_proxy'] || ENV['HTTPS_PROXY'] || ""
config.proxy.no_proxy = $no_proxy
config.proxy.enabled = { docker: false, git: false }
end
end
# Install requirements
config.vm.provision 'shell', privileged: false, inline: <<-SHELL
source /etc/os-release || source /usr/lib/os-release
case ${ID,,} in
ubuntu|debian)
sudo apt-get update
sudo apt-get install -y -qq -o=Dpkg::Use-Pty=0 curl
;;
esac
# NOTE: Shorten link -> https://github.com/electrocucaracha/pkg-mgr_scripts
curl -fsSL http://bit.ly/install_pkg | PKG="docker docker-compose" bash
SHELL
# Deploy services
config.vm.provision 'shell', inline: <<-SHELL
set -o pipefail
set -o errexit
cd /vagrant
docker network create --subnet 10.10.0.0/16 --opt com.docker.network.bridge.name=docker_gwbridge docker_gwbridge
docker swarm init --advertise-addr 10.0.2.15
docker build --no-cache -t vpp vpp/
docker-compose up -d
docker image prune --force
#curl -X PUT \
# -H "Authorization: Basic YWRtaW46YWRtaW4=" \
# -H "Content-Type: application/json" \
# -H "Cache-Control: no-cache" \
# -d '{"pg-streams":{"pg-stream": [{"id":"fw_udp1", "is-enabled":"true"},{"id":"fw_udp2", "is-enabled":"true"},{"id":"fw_udp3", "is-enabled":"true"},{"id":"fw_udp4", "is-enabled":"true"},{"id":"fw_udp5", "is-enabled":"true"}]}}' \
# "http://127.0.0.1:8083/restconf/config/sample-plugin:sample-plugin/pg-streams"
SHELL
config.vm.network :forwarded_port, guest: 8080, host: 8080
end
|