diff options
author | Kali Kaneko <kali@leap.se> | 2016-04-27 15:33:51 -0400 |
---|---|---|
committer | Kali Kaneko <kali@leap.se> | 2016-04-27 20:32:42 -0400 |
commit | d2806583ead2712c9095b82f31b50924dfc80411 (patch) | |
tree | ecaff8b4342905a1eb0149809439d2c4566bfc04 /docker | |
parent | c9066a10f3fb8c34b3db2ef9be55501ba91fdca5 (diff) |
split packages: debian-core, debian-cli
Diffstat (limited to 'docker')
-rw-r--r-- | docker/Dockerfile | 32 | ||||
-rw-r--r-- | docker/README.rst | 47 | ||||
-rwxr-xr-x | docker/bitmask-docker.sh | 119 | ||||
-rw-r--r-- | docker/bitmask-nightly.json | 11 | ||||
-rwxr-xr-x | docker/debian/apt-bitmask.sh | 123 | ||||
-rwxr-xr-x | docker/debian/bitmask-on-docker.sh | 23 | ||||
-rw-r--r-- | docker/debian/leap-experimental.key | 52 | ||||
-rwxr-xr-x | docker/debian/run-docker-for-bitmask.sh | 22 | ||||
-rwxr-xr-x | docker/leap_bootstrap.sh | 324 |
9 files changed, 0 insertions, 753 deletions
diff --git a/docker/Dockerfile b/docker/Dockerfile deleted file mode 100644 index d5a7b57e..00000000 --- a/docker/Dockerfile +++ /dev/null @@ -1,32 +0,0 @@ -FROM ubuntu:trusty - -MAINTAINER Ivan Alejandro <ivanalejandro0@gmail.com> - -RUN apt-get update && DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends \ - g++ \ - git \ - libffi-dev \ - libsqlite3-dev \ - libssl-dev \ - libzmq-dev \ - openvpn \ - pyside-tools \ - python-dev \ - python-openssl \ - python-pip \ - python-pyside \ - python-setuptools \ - python-virtualenv \ - make realpath lxpolkit policykit-1 iptables && \ - apt-get clean && rm -rf /var/lib/apt/lists/* - - -RUN mkdir -p /bitmask -WORKDIR /bitmask - -COPY leap_bootstrap.sh /bitmask/ - -VOLUME ["/data/"] - -EXPOSE 1984 2013 -ENTRYPOINT ["/bitmask/leap_bootstrap.sh"] diff --git a/docker/README.rst b/docker/README.rst deleted file mode 100644 index 4a2d08e7..00000000 --- a/docker/README.rst +++ /dev/null @@ -1,47 +0,0 @@ -Bitmask and Docker -================== - -Here we have several tools that leverages docker to ease Bitmask testing. - -``bitmask-docker.sh`` is a helper script to ``build`` and ``run`` the bitmask app, -here is an example usage:: - - $ ./bitmask-docker.sh build # build docker image - $ ./bitmask-docker.sh init bitmask-nightly.json # initialize (takes time) - $ ./bitmask-docker.sh run # run bitmask in docker - -``bitmask-nightly.json`` is the version specifier for each bitmask component that -will be used to run bitmask. - -``Dockerfile`` is the file used to build the docker image that will run bitmask. - -``leap_bootstrap.sh`` is the script that takes care of cloning repos, installing -python dependencies, running bitmask, etc. - - -Debian/ -------- - -``apt-bitmask.sh`` script that installs bitmask from the Debian packages. - -``bitmask-on-docker.sh`` installs bitmask and runs it in a dummy X server, -waits a little and takes a screenshot. - -``leap-experimental.key`` is needed by ``apt-bitmask.sh`` to ``apt-key add`` -and verify apt sources. - -``run-docker-for-bitmask.sh`` is a helper script that runs an Ubuntu/Debian -container ready to run the ``apt-bitmask.sh`` command, it does (among other -stuff) X11 forwarding to display Bitmask UI on the host linux. - -An example usage:: - - $ ./run-docker-for-bitmask.sh - non-network local connections being added to access control list - root@hostname:/# cd /host/ - root@hostname:/host# ./apt-bitmask.sh unstable - # [... not so relevant output ...] - root@hostname:/host# apt-get install -y lxpolkit # install a small polkit agent - # [... not so relevant output ...] - root@hostname:/host# lxpolkit & # run the polkit agent in the background, ignore the "No session for pid 6034" error. - root@hostname:/host# bitmask -d # tadaa, you have bitmask running in a container! diff --git a/docker/bitmask-docker.sh b/docker/bitmask-docker.sh deleted file mode 100755 index 329900f8..00000000 --- a/docker/bitmask-docker.sh +++ /dev/null @@ -1,119 +0,0 @@ -#!/bin/bash - -run(){ - # NOTE: you may need this line if you get an error using ip6tables - # (host needs ip6 kernel modules to use it in the container) - # sudo modprobe ip6_tables - - # NOTE: to get X11 socket forwarding to work we need this - xhost local:root - - CREDS_OPTS='' - if [[ -n $BITMASK_CREDENTIALS ]]; then - BITMASK_CREDENTIALS=`realpath $BITMASK_CREDENTIALS` - CREDS_OPTS="-e BITMASK_CREDENTIALS=/data/credentials.ini -v $BITMASK_CREDENTIALS:/data/credentials.ini" - fi - - # NOTE: to use containerized VPN from the host you need to add `--net host` - docker run --rm -it \ - --privileged \ - -v /tmp/.X11-unix:/tmp/.X11-unix \ - -e DISPLAY=unix$DISPLAY \ - $CREDS_OPTS \ - -v `pwd`/data/:/data/ -v `pwd`:/SHARED/ \ - -v `pwd`/data/config:/root/.config/leap \ - -p 1984:1984 -p 2013:2013 \ - -e LEAP_DOCKERIZED=1 \ - --name bitmask \ - test/bitmask run $@ - - # Services' related ports - # eip: ["80", "53", "443", "1194"] - # mail: ["1984", "2013"] - - # logs when no ip6_tables module is not loaded on host: - # root@bitmask-container:/bitmask# sudo ip6tables --new-chain bitmask - # modprobe: ERROR: ../libkmod/libkmod.c:556 kmod_search_moddep() could not open moddep file '/lib/modules/4.1.6-040106-generic/modules.dep.bin' - # ip6tables v1.4.21: can't initialize ip6tables table `filter': Table does not exist (do you need to insmod?) - # Perhaps ip6tables or your kernel needs to be upgraded. - - # logs when ip6_tables module is loaded on host: - # root@bitmask-container:/bitmask# sudo ip6tables --new-chain bitmask - # root@bitmask-container:/bitmask# # success! -} - -shell(){ - xhost local:root - - # NOTE: to use containerized VPN from the host you need to add `--net host` - docker run --rm -it \ - --privileged \ - -v /tmp/.X11-unix:/tmp/.X11-unix \ - -e DISPLAY=unix$DISPLAY \ - -v `pwd`/data/:/data/ -v `pwd`:/SHARED/ \ - -v `pwd`/data/config:/root/.config/leap \ - -p 1984:1984 -p 2013:2013 \ - -e LEAP_DOCKERIZED=1 \ - --name bitmask \ - --entrypoint=bash \ - test/bitmask -} - -init(){ - JSON=`realpath $1` - docker run --rm -it \ - -v `pwd`/data:/data \ - -v $JSON:/shared/bitmask.json \ - test/bitmask init ro /shared/bitmask.json -} - -update(){ - JSON=`realpath $1` - docker run --rm -it \ - -v `pwd`/data:/data \ - -v $JSON:/shared/bitmask.json \ - test/bitmask update /shared/bitmask.json -} - -build(){ - docker build -t test/bitmask . -} - -help() { - echo ">> Bitmask on docker" - echo "Run the bitmask app in a docker container." - echo - echo "Usage: $0 {init bitmask.json | update bitmask.json | build | shell | run | help}" - echo - echo " ?.json : The bitmask*.json file describes the version that will be used for each repo." - echo - echo " init : Clone repositories, install dependencies, and get bitmask ready to be used." - echo " update : Update the repositories and install new deps (if needed)." - echo " build : Build the docker image for bitmask." - echo " shell : Run a shell inside a bitmask docker container (useful to debug)." - echo " run : Run the client (any extra parameters will be sent to the app)." - echo " help : Show this help" - echo -} - - -case "$1" in - run) - run "$@" - ;; - init) - init $2 - ;; - update) - update $2 - ;; - build) - build - ;; - shell) - shell - ;; - *) - help - ;; -esac diff --git a/docker/bitmask-nightly.json b/docker/bitmask-nightly.json deleted file mode 100644 index 5b1c3cf0..00000000 --- a/docker/bitmask-nightly.json +++ /dev/null @@ -1,11 +0,0 @@ -{ - "version": "nightly", - "tuf_repo": "", - "bitmask_client": "develop", - "soledad": "develop", - "keymanager": "develop", - "leap_mail": "develop", - "leap_pycommon": "develop", - "bitmask_launcher": "develop", - "leap_assets": "master" -} diff --git a/docker/debian/apt-bitmask.sh b/docker/debian/apt-bitmask.sh deleted file mode 100755 index 99c5f07e..00000000 --- a/docker/debian/apt-bitmask.sh +++ /dev/null @@ -1,123 +0,0 @@ -#!/bin/bash -set -euo pipefail -IFS=$'\n\t' - -distro(){ - # for ubuntu/mint: - name=`lsb_release -a 2>&1 | grep Codename | cut -f2` - - # for debian: - [[ -z $name ]] && name=`grep -oP "VERSION=.*\(\K\w+" /etc/os-release` - - # for debian sid - [[ -z $name ]] && name=`grep -o sid /etc/debian_version` - - declare -A distros - distros=( - ['nadia']='quantal' - ['olivia']='raring' - ['petra']='saucy' - ['qiana']='trusty' - ['rebecca']='trusty' - ['rafaela']='trusty' - ['sana']='jessie' - ) - - # if name is in the above list -> replace - [ ${distros[$name]+abc} ] && name=${distros[$name]} - - echo $name | tr "[A-Z]" "[a-z]" -} - -is_supported(){ - distros=( - # 'wheezy' # Debian 7 - stable - 'jessie' # Debian 8 - testing - 'sid' # Debian unstable - # 'quantal' # Ubuntu 12.10 - # 'raring' # Ubuntu 13.04 - # 'saucy' # Ubuntu 13.10 - # 'trusty' # Ubuntu 14.04 - # 'utopic' # Ubuntu 14.10 - 'vivid' # Ubuntu 15.04 - 'wily' # Ubuntu 15.10 - ) - - my_distro=`distro` - - for p in "${distros[@]}"; do - if [[ $my_distro = ${p}* ]]; then - echo true - return - fi - done - echo false -} - -if [[ `is_supported` == "false" ]]; then - echo "ERROR: Sorry, your distro (`distro`) is currently not supported." - exit 1 -fi; - -help() { - echo ">> Bitmask .deb automatic installer helper" - echo "This script does all the needed stuff in order to get bitmask stable or unstable into your machine." - echo - echo "Usage: $0 ( stable | unstable | help )" - echo - echo " stable : Install the stable bitmask package." - echo " unstable : Install the unstable bitmask package." - echo " help : Show this help" - echo - echo "NOTE: you need to run this with root privileges." - echo -} - -case ${1:-} in - stable) - REPO='debian' - ;; - unstable) - REPO='experimental' - ;; - *) - help - exit 1 - ;; -esac - -if [[ $EUID -ne 0 ]]; then - echo "This script must be run as root" 1>&2 - exit 1 -fi - -# ------------------------------- -# instructions from http://deb.leap.se/experimental/ -# run this with admin privileges - -DISTRO=`distro` - -if [[ $REPO == 'debian' ]]; then - # stable - # wget -O- https://dl.bitmask.net/apt.key | apt-key add - - - # HACK: do this twice since the first one fails due to gpg not having a configuration - gpg --recv-key 0x1E34A1828E207901 &> /dev/null || true - gpg --recv-key 0x1E34A1828E207901 - - gpg --armor --export 0x1E34A1828E207901 | apt-key add - -else # $REPO == 'experimental' - if [[ ! -f "leap-experimental.key" ]]; then - echo "ERROR: you need to copy the leap-experimental.key file into this directory." - exit 1 - fi - - # sha256sum leap-experimental.key - echo "ed3f4f3e3e0835a044457451755ae743741d7bafa55bcd31cc464a54e8c5e7f9 leap-experimental.key" | sha256sum -c - - apt-key add leap-experimental.key -fi - -echo "deb http://deb.bitmask.net/$REPO $DISTRO main" > /etc/apt/sources.list.d/bitmask.list - -apt-get update -apt-get install -y bitmask diff --git a/docker/debian/bitmask-on-docker.sh b/docker/debian/bitmask-on-docker.sh deleted file mode 100755 index c3e42b22..00000000 --- a/docker/debian/bitmask-on-docker.sh +++ /dev/null @@ -1,23 +0,0 @@ -#!/bin/bash -# Helper script to install, run and do a screenshot of bitmask - -# You can use this as follows: -# $ docker run -t -i --rm -v `pwd`:/host/ ubuntu:14.04 /bin/bash -# $ cd /host/ -# $ ./bitmask-on-docker.sh stable - -[[ -z $1 ]] && exit 1 - -./apt-bitmask.sh $1 # this does an `apt-get update` -apt-get -y install xinit xvfb imagemagick lxpolkit - -startx -- `which Xvfb` :1 -screen 0 1024x768x24 & -sleep 1 - -DISPLAY=:1 lxpolkit & -sleep 0.5 # bitmask needs polkit to work - -DISPLAY=:1 bitmask & -sleep 2 # wait for bitmask to start - -DISPLAY=:1 import -window root bitmask.png diff --git a/docker/debian/leap-experimental.key b/docker/debian/leap-experimental.key deleted file mode 100644 index a07ec44c..00000000 --- a/docker/debian/leap-experimental.key +++ /dev/null @@ -1,52 +0,0 @@ ------BEGIN PGP PUBLIC KEY BLOCK----- -Version: GnuPG v1.4.12 (GNU/Linux) - -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 -=10ZN ------END PGP PUBLIC KEY BLOCK----- diff --git a/docker/debian/run-docker-for-bitmask.sh b/docker/debian/run-docker-for-bitmask.sh deleted file mode 100755 index 9ffb400b..00000000 --- a/docker/debian/run-docker-for-bitmask.sh +++ /dev/null @@ -1,22 +0,0 @@ -#!/bin/sh -# NOTE: to get X11 socket forwarding to work we need this -xhost local:root - -docker run --rm -it \ - --net host \ - --privileged \ - -v /tmp/.X11-unix:/tmp/.X11-unix \ - -e DISPLAY=unix$DISPLAY \ - -v `pwd`:/host/ \ - -p 1984:1984 -p 2013:2013 \ - ubuntu:vivid bash - -# NOTE: what to do next? -# Install bitmask package: -# $ apt-bitmask.sh stable -# Install polkit agent (bitmask needs it): -# $ apt-get install lxpolkit -# Run polkit in background: -# $ lxpolkit & # this will show you a message like: 'No session for pid 5801', ignore it -# Run bitmask: -# $ bitmask -d diff --git a/docker/leap_bootstrap.sh b/docker/leap_bootstrap.sh deleted file mode 100755 index a717ab6d..00000000 --- a/docker/leap_bootstrap.sh +++ /dev/null @@ -1,324 +0,0 @@ -#!/bin/bash -###################################################################### -# repo-versions.sh -# Copyright (C) 2014, 2015 LEAP -# -# This program is free software: you can redistribute it and/or modify -# it under the terms of the GNU General Public License as published by -# the Free Software Foundation, either version 3 of the License, or -# (at your option) any later version. -# -# This program 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 General Public License for more details. -# -# You should have received a copy of the GNU General Public License -# along with this program. If not, see <http://www.gnu.org/licenses/>. -###################################################################### -set -e # Exit immediately if a command exits with a non-zero status. -REPOSITORIES="bitmask_client leap_pycommon soledad keymanager leap_mail bitmask_launcher leap_assets" -PACKAGES="leap_pycommon keymanager soledad/common soledad/client leap_mail bitmask_client" - -_is_docker() { - grep -q docker /proc/1/cgroup -} - -SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" - -_is_docker && BASE_PATH="/data/" || BASE_PATH=$SCRIPT_DIR -REPOS_ROOT="$BASE_PATH/repositories" # Root path for all the needed repositories -VENV_DIR="$BASE_PATH/bitmask.venv" # Root path for all the needed repositories - -mkdir -p $REPOS_ROOT - -PS4=">> " # for debugging - -# Escape code -esc=`echo -en "\033"` - -# Set colors -cc_green="${esc}[0;32m" -cc_yellow="${esc}[0;33m" -cc_blue="${esc}[0;34m" -cc_red="${esc}[0;31m" -cc_normal=`echo -en "${esc}[m\017"` - -apt_install_dependencies() { - status="installing system dependencies" - echo "${cc_green}Status: $status...${cc_normal}" - set -x - sudo apt-get install -y git python-dev python-setuptools python-virtualenv python-pip libssl-dev python-openssl libsqlite3-dev g++ openvpn pyside-tools python-pyside libffi-dev libzmq-dev - set +x -} - -helpers() { - if [[ "$1" == "cleanup" ]]; then - status="removing helper files" - echo "${cc_green}Status: $status...${cc_normal}" - set -x - sudo rm -f /usr/sbin/bitmask-root - sudo rm -f /usr/share/polkit-1/actions/se.leap.bitmask.policy - set +x - else - status="installing helper files" - echo "${cc_green}Status: $status...${cc_normal}" - set -x - BASE=$REPOS_ROOT/bitmask_client/pkg/linux - sudo mkdir -p /usr/share/polkit-1/actions/ - sudo cp $BASE/bitmask-root /usr/sbin/ - sudo cp $BASE/polkit/se.leap.bitmask.policy /usr/share/polkit-1/actions/ - set +x - fi -} - -clone_repos() { - local status="clone repositories" - echo "${cc_green}Status: $status...${cc_normal}" - set -x # show commands - - if [[ "$1" == "rw" ]]; then - # read-write remotes: - src="ssh://gitolite@leap.se" - else - # read-only remotes: - src="https://leap.se/git" - fi - cd $REPOS_ROOT - - for repo in $REPOSITORIES; do - [ ! -d $repo ] && git clone $src/$repo - done - - cd - - - set +x - echo "${cc_green}Status: $status done!${cc_normal}" -} - -checkout_repos(){ - local status="checkout repositories" - echo "${cc_green}Status: $status...${cc_normal}" - set -x # show commands - - for repo in $REPOSITORIES; do - version=$(cat $1 | python -c "import json,sys;obj=json.load(sys.stdin);print obj['$repo'];") - cd $REPOS_ROOT/$repo - git fetch origin && git fetch --tags origin - - if [[ -n `git tag -l | grep $version` ]]; then - # if is a tag - git checkout -f $version - else - # if is a branch - git reset --hard origin/$version - fi - done - - set +x - echo "${cc_green}Status: $status done!${cc_normal}" -} - -create_venv() { - local status="creating virtualenv" - echo "${cc_green}Status: $status...${cc_normal}" - set -x # show commands - - virtualenv $VENV_DIR && source $VENV_DIR/bin/activate - pip install --upgrade pip # get the latest pip - - set +x - echo "${cc_green}Status: $status done.${cc_normal}" -} - -setup_develop() { - local status="installing packages" - echo "${cc_green}Status: $status...${cc_normal}" - set -x # show commands - cd $REPOS_ROOT - source $VENV_DIR/bin/activate - - # do a setup develop in every package - for package in $PACKAGES; do - cd $REPOS_ROOT/$package - python setup.py develop --always-unzip - done - - set +x - echo "${cc_green}Status: $status done.${cc_normal}" -} - -install_dependencies() { - local status="installing dependencies" - echo "${cc_green}Status: $status...${cc_normal}" - set -x # show commands - cd $REPOS_ROOT - source $VENV_DIR/bin/activate - - # install defined 3rd party dependencies for every package - for package in $PACKAGES; do - cd $REPOS_ROOT/$package - pkg/pip_install_requirements.sh --use-leap-wheels - done - - # symlink system's PySide inside the venv - $REPOS_ROOT/bitmask_client/pkg/postmkvenv.sh - - # hack to solve gnupg version problem - pip uninstall -y gnupg && pip install gnupg - - set +x - echo "${cc_green}Status: $status done.${cc_normal}" -} - -docker_stuff() { - local status="doing stuff needed to run bitmask on a docker container" - echo "${cc_green}Status: $status...${cc_normal}" - set -x # show commands - - helpers - lxpolkit & - sleep 0.5 - - # this is needed for pkexec - mkdir -p /var/run/dbus - dbus-daemon --system | true - - set +x - echo "${cc_green}Status: $status done.${cc_normal}" -} - -run() { - echo "${cc_green}Status: running client...${cc_normal}" - set -x - - shift # remove 'run' from arg list - passthrough_args=$@ - - _is_docker && docker_stuff - - source $VENV_DIR/bin/activate - python $REPOS_ROOT/bitmask_client/src/leap/bitmask/app.py -d $passthrough_args - - set +x -} - -initialize() { - shift # remove 'init' - echo $@ - if [[ "$1" == "ro" ]]; then - # echo "RO" - shift # remove 'ro' - clone_repos "ro" - else - # echo "RW" - clone_repos - fi - - if [[ -z $1 ]]; then - echo "You need to specify a bitmask.json parameter." - echo "for example:" - cat << EOF -{ - "bitmask_client": "0.7.0", - "soledad": "0.6.3", - "leap_pycommon": "0.3.9", - "keymanager": "0.3.8", - "leap_mail": "0.3.10", - "bitmask_launcher": "0.3.3", - "leap_assets": "master" -} -EOF - exit 1 - fi - - JSON=`realpath $1` - - checkout_repos $JSON - create_venv - install_dependencies - setup_develop - - cd $REPOS_ROOT/bitmask_client/ - make - cd - -} -update() { - local status="updating repositories" - echo "${cc_green}Status: $status...${cc_normal}" - set -x # show commands - - if [[ -z $1 ]]; then - echo "You need to specify a bitmask.json parameter." - echo "for example:" - cat << EOF -{ - "bitmask_client": "0.7.0", - "soledad": "0.6.3", - "leap_pycommon": "0.3.9", - "keymanager": "0.3.8", - "leap_mail": "0.3.10", - "bitmask_launcher": "0.3.3", - "leap_assets": "master" -} -EOF - exit 1 - fi - - JSON=`realpath $1` - - checkout_repos $JSON - install_dependencies - setup_develop - - cd $REPOS_ROOT/bitmask_client/ - make - cd - - - set +x - echo "${cc_green}Status: $status done!${cc_normal}" -} - - -help() { - echo ">> LEAP bootstrap - help" - echo "Bootstraps the environment to start developing the bitmask client" - echo "with all the needed repositories and dependencies." - echo - echo "Usage: $0 {init [ro] bitmask.json | update bitmask.json | run | help | deps | helpers}" - echo - echo " init : Initialize repositories, create virtualenv and \`python setup.py develop\` all." - echo " You can use \`init ro\` in order to use the https remotes if you don't have rw access." - echo " The bitmask.json file contains the version that will be used for each repo." - echo " update : Update the repositories and install new deps (if needed)." - echo " The bitmask.json file contains the version that will be used for each repo." - echo " run : Runs the client (any extra parameters will be sent to the app)." - echo " help : Show this help" - echo " -- system helpers --" - echo " deps : Install the system dependencies needed for bitmask dev (Debian based Linux ONLY)." - echo " helpers : Install the helper files needed to use bitmask (Linux only)." - echo " You can use \`helpers cleanup\` to remove those files." - echo -} - - -case "$1" in - init) - initialize "$@" - ;; - update) - update $2 - ;; - helpers) - helpers $2 - ;; - deps) - apt_install_dependencies - ;; - run) - run "$@" - ;; - *) - help - ;; -esac |