diff options
author | Mircea Moise <mmoise@thoughtworks.com> | 2014-11-19 20:31:04 +0000 |
---|---|---|
committer | Mircea Moise <mmoise@thoughtworks.com> | 2014-11-19 20:31:04 +0000 |
commit | 5d6b14b54fb69c3a611cf1f03d9e8bf2d76a2cad (patch) | |
tree | aa078297d619bfe34b7fa7681aacdb7d1372022c /provisioning | |
parent | f202ed1c57d5a727dbcc6d10d6a669d363639ab3 (diff) |
Added vagrantfile and provisioning scripts so the service can be run inside a vagrant box
Diffstat (limited to 'provisioning')
-rw-r--r-- | provisioning/README.md | 22 | ||||
-rwxr-xr-x | provisioning/bootstrap.sh | 61 | ||||
-rw-r--r-- | provisioning/provision.sh | 13 |
3 files changed, 96 insertions, 0 deletions
diff --git a/provisioning/README.md b/provisioning/README.md new file mode 100644 index 00000000..46acbf0b --- /dev/null +++ b/provisioning/README.md @@ -0,0 +1,22 @@ + Setup for developers +===================== +The following instructions describe how to setup a Vagrant box for development. You need to have Vagrant installed on your system. + +# Vagrant setup + +Create and provision Vagrant box +```sh +$ vagrant up +``` + +# Running the server +Activate virtualenv and run Pixelated server +```sh +$ cd /vagrant/service +$ source .virtualenv/bin/activate +$ pixelated-user-agent --host 0.0.0.0 +``` + +After this you will be asked to setup a LEAP provider. Once entering valid LEAP credentials, you should have the server running. + +You should now be able to access the web app by typing localhost:3333 on any browser running on your host machine. diff --git a/provisioning/bootstrap.sh b/provisioning/bootstrap.sh new file mode 100755 index 00000000..eb444382 --- /dev/null +++ b/provisioning/bootstrap.sh @@ -0,0 +1,61 @@ +#!/bin/bash +# +# Copyright (c) 2014 ThoughtWorks, Inc. +# +# Pixelated is free software: you can redistribute it and/or modify +# it under the terms of the GNU Affero General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Pixelated is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Affero General Public License for more details. +# +# You should have received a copy of the GNU Affero General Public License +# along with Pixelated. If not, see <http://www.gnu.org/licenses/>. + +# test dependencies +function check_installed() { + which $1 + if [ $? -ne 0 ]; then + echo "## You must have ${1} installed and in the PATH to run Pixelated-User-Agent" + echo "## exiting..." + exit 1 + fi +} + +for dependency in node npm ruby bundle virtualenv git gpg; do + check_installed $dependency +done + +# install web-ui dependencies +cd /vagrant/web-ui +npm install +node_modules/bower/bin/bower install --config.interactive=false +bundle install +LC_ALL=en_US.UTF-8 ./go build + +# install service dependencies +cd ../service +virtualenv .virtualenv +source .virtualenv/bin/activate +./go develop --always-unzip +pip uninstall -y gnupg; pip install gnupg + +# print usage +cat <<EOF + +############### + +## You will need an account in a LEAP provider. You may find some at http://bitmask.net/ + +## Once you have it, modify the service/pixelated.example file and move it to ~/.pixelated + +## You might also need to add your LEAP provider ssl certificate to the pixelated/certificates folder, named as your provider domain name (in case it uses TLS): +## - example: your.leapprovider.org.crt + +## Once you are done, just run: +## pixelated-user-agent + +EOF diff --git a/provisioning/provision.sh b/provisioning/provision.sh new file mode 100644 index 00000000..e130e34a --- /dev/null +++ b/provisioning/provision.sh @@ -0,0 +1,13 @@ +sudo apt-get update +sudo apt-get install -y git +sudo apt-get install -y nodejs-legacy +sudo apt-get install -y npm +sudo apt-get install -y python-setuptools +sudo easy_install pip +sudo pip install virtualenv +sudo apt-get install -y python-dev +sudo apt-get install -y libffi-dev +sudo apt-get install -y g++ +sudo gem install bundler + +/vagrant/provisioning/bootstrap.sh |