diff options
author | Tomás Touceda <chiiph@leap.se> | 2013-11-01 10:50:38 -0300 |
---|---|---|
committer | Tomás Touceda <chiiph@leap.se> | 2013-11-01 10:50:38 -0300 |
commit | 23e9034664edf6b2a01a677c4fa4e6efd880e364 (patch) | |
tree | fc90f154cf81cbaf48dd2d4a738a379591c4e7c7 /pkg | |
parent | a06b5719f028e619a4b3800fb346ed3c984e4d25 (diff) | |
parent | 80fde752f0bf7946869361f6a77d1952f9339636 (diff) |
Merge branch 'release-0.3.6'0.3.6
Diffstat (limited to 'pkg')
-rw-r--r-- | pkg/requirements.pip | 7 | ||||
-rwxr-xr-x | pkg/scripts/bootstrap_develop.sh | 191 |
2 files changed, 195 insertions, 3 deletions
diff --git a/pkg/requirements.pip b/pkg/requirements.pip index 458db39c..885b19f8 100644 --- a/pkg/requirements.pip +++ b/pkg/requirements.pip @@ -6,7 +6,7 @@ # Use LEAP_VENV_SKIP_PYSIDE to avoid installing it! argparse -requests +requests>=1.1.0 srp>=1.0.2 pyopenssl python-dateutil @@ -16,11 +16,12 @@ twisted qt4reactor python-daemon # this should not be needed for Windows. keyring +zope.proxy leap.common>=0.3.4 -leap.soledad.client>=0.4.0 +leap.soledad.client>=0.4.2 leap.keymanager>=0.3.4 -leap.mail>=0.3.5 +leap.mail>=0.3.6 # Remove this when u1db fixes its dependency on oauth oauth diff --git a/pkg/scripts/bootstrap_develop.sh b/pkg/scripts/bootstrap_develop.sh new file mode 100755 index 00000000..4660c499 --- /dev/null +++ b/pkg/scripts/bootstrap_develop.sh @@ -0,0 +1,191 @@ +#!/bin/bash +###################################################################### +# boostrap_develop.sh +# Copyright (C) 2013 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" +PACKAGES="leap_pycommon keymanager soledad/common soledad/client soledad/server leap_mail bitmask_client" +REPOS_ROOT=`pwd` # Root path for all the needed repositories + +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"` + +clone_repos() { + status="cloning repositories" + echo "${cc_green}Status: $status...${cc_normal}" + set -x # show commands + + # clone the leap.se repos + git clone ssh://gitolite@leap.se/bitmask_client + git clone ssh://gitolite@leap.se/leap_pycommon + git clone ssh://gitolite@leap.se/soledad + git clone ssh://gitolite@leap.se/keymanager + git clone ssh://gitolite@leap.se/leap_mail + + set +x + echo "${cc_green}Status: $status done!${cc_normal}" +} + +checkout_develop(){ + status="checkout develop" + echo "${cc_green}Status: $status...${cc_normal}" + set -x # show commands + + # get the latest develop in every repo + for repo in $REPOSITORIES; do + cd $REPOS_ROOT/$repo + git checkout -f develop + done + + set +x + echo "${cc_green}Status: $status done!${cc_normal}" +} + +update_repos() { + status="updating repositories" + echo "${cc_green}Status: $status...${cc_normal}" + set -x # show commands + + # get the latest develop in every repo + for repo in $REPOSITORIES; do + cd $REPOS_ROOT/$repo + git checkout -f develop + git fetch origin; git fetch --tags origin + git reset --hard origin/develop + done + + set +x + echo "${cc_green}Status: $status done!${cc_normal}" +} + +create_venv() { + status="creating virtualenv" + echo "${cc_green}Status: $status...${cc_normal}" + set -x # show commands + + # create and activate the virtualenv + cd $REPOS_ROOT + virtualenv bitmask.venv && source ./bitmask.venv/bin/activate + + # symlink PySide to the venv + cd $REPOS_ROOT/bitmask_client + ./pkg/postmkvenv.sh + + set +x + echo "${cc_green}Status: $status done.${cc_normal}" +} + +setup_develop() { + status="installing packages" + echo "${cc_green}Status: $status...${cc_normal}" + set -x # show commands + + # do a setup develop in every package + for package in $PACKAGES; do + cd $REPOS_ROOT/$package + python setup.py develop + done + + # hack to solve gnupg version problem + pip uninstall -y gnupg && pip install gnupg + + set +x + echo "${cc_green}Status: $status done.${cc_normal}" +} + +finish(){ + echo "${cc_green}Status: process completed.${cc_normal}" + echo "You can run the client with the following command:" + echo -n "${cc_yellow}" + echo " shell> source bitmask.venv/bin/activate" + echo " shell> python bitmask_client/src/leap/bitmask/app.py -d" + echo "${cc_normal}" + echo "or with this script using:" + echo "${cc_yellow} shell> $0 run${cc_normal}" + echo +} + +initialize() { + clone_repos + checkout_develop + create_venv + setup_develop + + # make: compile ui and resources in client + make + + finish +} + +update() { + update_repos + + source $REPOS_ROOT/bitmask.venv/bin/activate + + setup_develop + + # make: compile ui and resources in client + make + + finish +} + +run() { + echo "${cc_green}Status: running client...${cc_normal}" + source bitmask.venv/bin/activate + set -x + python bitmask_client/src/leap/bitmask/app.py -d $* + set +x +} + +help() { + echo ">> LEAP developer helper" + echo "Bootstraps the environment to start developing the bitmask client" + echo "with all the needed repositories and dependencies." + echo + echo "Usage: $0 {init | update | help}" + echo + echo " init : Initialize repositories, create virtualenv and \`python setup.py develop\` all." + echo " update : Update the repositories and install new deps (if needed)." + echo " run : Runs the client (any extra parameters will be sent to the app)." + echo " help : Show this help" + echo +} + +case "$1" in + init) + initialize + ;; + update) + update + ;; + run) + run + ;; + *) + help + ;; +esac |