# Install Script We provide a [script](../images/scripts/ubuntu-17.04.sh) which will perform all the steps outlined in this doc (except for creating a protocol handler -- see the bottom of the doc). The script creates a virtualenv of Blockstack Core and installs Browser in a subdirectory. It additionally creates some scripts for starting Core and Browser together. However, if you'd like to customize your install, step through it yourself, or you are on a different distro, continue on with this doc! # Setting up Blockstack Core API Service Install required binaries in Ubuntu: ``` sudo apt update && sudo apt-get install -y python-pip python-dev libssl-dev libffi-dev rng-tools curl build-essential ``` If you'd like to use a virtualenv to install Blockstack, you can do that ``` pip install virtualenv virtualenv --python=python2.7 ~/.blockstack.venv/ && source ~/.blockstack.venv/bin/activate ``` Let's install virtualchain 0.14.3 and blockstack 0.14.3 ``` sudo apt install git pip install git+https://github.com/blockstack/virtualchain.git@rc-0.14.3 pip install git+https://github.com/blockstack/blockstack-core.git@rc-0.14.3 ``` Get Blockstack core configured with default settings and choose your Bitcoin wallet password ``` blockstack setup -y --password BITCOIN_WALLET_PASSWORD --debug ``` # Setting up Blockstack Browser Node Application Install NodeJS through NodeSource PPA ``` curl -sL https://deb.nodesource.com/setup_7.x | sudo -E bash - sudo apt install -y nodejs ``` Download Blockstack Browser and install its dependencies ``` git clone https://github.com/blockstack/blockstack-browser.git -bv0.11.1 cd blockstack-browser npm install node-sass npm install ``` Note that `blockstack-browser` depends on `node-sass` which can sometimes install strangely on Linux, running `npm install node-sass` before trying to install the other dependencies solves that problem. # Running Blockstack Browser Now we're ready to run our Core API service and start the Browser node app. First, start the Core API service. ``` blockstack api start -y --password BITCOIN_WALLET_PASSWORD --debug ``` Start the CORS proxy. ``` npm run dev-proxy & ``` Start the Node Application ``` npm run dev ``` Then you can open `http://localhost:3000/` in your browser to get to the Blockstack Browser. You can copy your api password to your clipboard with this command: ``` grep api_password ~/.blockstack/client.ini | sed 's/api_password = //g' | xclip -selection clipboard ``` ## Setting up a protocol handler If you'd like your browser to automatically handle links with the `blockstack:` protocol specifier, you will need to register a protocol handler with your desktop environment. In Ubuntu/Gnome, this can be done by creating a file `~/.local/share/applications/blockstack.desktop` With the following contents: ``` [Desktop Entry] Type=Application Terminal=false Exec=bash -c 'xdg-open http://localhost:3000/auth?authRequest=$(echo "%u" | sed s,blockstack:////*,,)' Name=Blockstack-Browser MimeType=x-scheme-handler/blockstack; ``` Then you need to make this file executable, and register it as a protocol handler. ``` $ chmod +x ~/.local/share/applications/blockstack.desktop $ xdg-mime default blockstack.desktop x-scheme-handler/blockstack ``` Now, `blockstack:` protocol URLs should get handled by your Blockstack Browser. If you're running Browser in your browser's private mode, you may have to copy and paste the link, as this protocol handler will try to open in a regular browser window.