/smappboard

:flower_playing_cards: a dashboard to manage twitter collections, previously smapp-twitter-admin

Primary LanguagePython

                                 _                         _ 
 ___ _ __ ___   __ _ _ __  _ __ | |__   ___   __ _ _ __ __| |
/ __| '_ ` _ \ / _` | '_ \| '_ \| '_ \ / _ \ / _` | '__/ _` |
\__ \ | | | | | (_| | |_) | |_) | |_) | (_) | (_| | | | (_| |
|___/_| |_| |_|\__,_| .__/| .__/|_.__/ \___/ \__,_|_|  \__,_|
                    |_|   |_|

🎴 smappboard is a flask app for the smapp dashboard, previously smapp-twitter-admin.

user_guide

1 - go to http://philosoraptor.bio.nyu.edu/

2 - click the 'sign in with twitter' button

3 - if your twitter account is authorized you should be redirected to the main page (the first one when you come to the site). if you are not autorized you need to ask a programmer to add your id to the list of authorized users.

how to add terms to a dataset stream:

1 - click datasets

2 - click on the name of the dataset you want to see. if you are not autorized you need to ask a programmer to add your id to the list of authorized users for that dataset.

3 - click filters and scroll to the bottom, add a term by filling in the two fields like so -

value: 

# turkeyprotest

type of filter:

track

add a user_id -

value:

1275323112

type of filter:

follow

add a geobox -

value:

-77.042 38.88 -77.0103 38.894

type of filter:

location

programmer_guide

/datasets

lists all collections that should be running

/dataset/data_set_name

get the page for an individual dataset, this is where you can do things related to that dataset

/access

takes you to a page that shows individual user permissions

/trending

takes you to a page that has the current top global twitter trends, feulued by an a twitter api token with a standard rate 15 per 15 min rate limit, so dont reload like crazy.

/samples

lists the names of the datasets you can get samples for. click a dataset name to get a sample for it.

/sample/data_set_name

get you samples of a dataset from the most recent file for dataset_name.

static

static files for css, bootstrap, themes, etc

templates

jinja2 templates for displaying the pages of our flask app

tests

tests for the flask app

development

core app logic is in app.py, decided against using models, views and separating out all the code as for this dashboard this created a lot of extra uneeded complexity. my goal was: simple functionality that was easy to maintain. all code is right in front of you instead scattered through 10 layers of abstraction. complexity that was difficult to maintain and keep the dashboard working (you can see this in the old dashboard, smapp-twitter-admin. if the link breaks look inside the sandbox which also functions as a graveyard.)

if you try to run the oauth routes for twitter (specifically the /login route) it will complain at you with this issue:

flask_oauthlib.client.OAuthException: Failed to generate request token

this is caused by lacking a callback url setting on your app's page. if you are working on localhost this is a pain. you can put a placeholder url there until you get the real one.

create anaconda environment conda env create -f environment.yml

load environment vars with source env.sh (needs to be done everytime you restart your commandline)

export a flask secret wih export FLASK_SECRET_KEY=YOUR_SECRET read aobut how to generate a secret here (save this secret because you'll need to use it for future setups)

then type make runprod you can check the makefile to see what it does exactly but it basically run gunicorn with a few workers.

you will have to create files: env.sh (in project root) smappboard_users.json (next to app.py in smappboard/)

how to connect to olympus

1 - map a port from a machine with scratch to the machine running the flask app

2 - mount sshfs over this port mapping.

3 - you can map a port from where we run our collector tunnels, or any other place with access to hpc /scratch/olympus/

in practice:

sudo mkdir -p /mnt/olympus/

setup hpctunnel as here.

ssh hpctunnel

bash sshfs_mount.sh yns207 8023 /home/yvan/.ssh/id_rsa (enter your hpc password when prompted).

to run sshfs you will need fuse and sshfs from here: https://osxfuse.github.io/

to unmount the fs:

sudo umount /mnt/olympus

there may be two password prompts that look the same, first is your computers sudo password, the second i you hpc password.

you can edit the script to mount /scratch/olympus (more performant but gets purged) or to mount /archive/smapp/olympus, but there are some concerns about the performance of the archive.

you may have to remove defer_permissions from sshfs_mount on some unix oses. sshfs on mac is a bit different from those places.

#nginx_setup

how to setup nginx (the http server) and gunicorn (the app server):

there are a 100 different ways to configure nginx. this is the way that works well for flask apps and is modular.

http://alexandersimoes.com/hints/2015/10/28/deploying-flask-with-nginx-gunicorn-supervisor-virtualenv-on-ubuntu.html

1 - install and setup nginx

sudo apt-get install nginx

2- remove nginx default site

sudo rm /etc/nginx/sites-enabled/default

3 - setup an nginx config file for your server in /etc/nginx/sites-available/YOUR_APP_NAME

server {
    listen 80;
    server_name DOMAIN_OR_IP_FOR_SITE;

    root /path/to/folder/containing/your/app/file/;

    access_log /path/to/where/you/want/your/access/logs/nginx/access.log;
    error_log /path/to/where/you/want/your/error/logs/nginx/error.log;

    location / {
        proxy_set_header X-Forward-For $proxy_add_x_forwarded_for;
        proxy_set_header Host $http_host;
        proxy_redirect off;
        if (!-f $request_filename) {
            proxy_pass http://127.0.0.1:8000;
            break;
        }
    }

    location /static {
        alias  /path/to/folder/containing/your/static/files/folder;
        autoindex on;
    }
}

note proxy_pass is the bind address of your gunicorn deamon / porgram, i've left it on 127.0.0.1 (localhost) port 8000 as that is gunicorn's default port binding.

4 - setup log files declared in nginx (access_log and error_log) and also for gunicorn

mkdir -p ~/path/to/where/you/want/your/access/logs/nginx ~/path/to/where/you/want/your/access/logs/gunicorn

5 - link the site you declared

sudo ln -s /etc/nginx/sites-available/YOUR_APP_NAME /etc/nginx/sites-enabled/

6 - restart nginx

sudo service nginx restart

7 - run gunicorn app sever

gunicorn smappboard.app:app -w 4 -t 120 -D --access-logfile /home/YOUR_USER/logs/gunicorn_access.log --error-logfile /home/YOUR_USER/logs/gunicorn_error.log

gunicorn -h to see what these flags do

8 - load site

http://DOMAIN_OR_IP_FOR_SITE

resources:

nginx docs

how to deploy on digital ocean

built on this standard specification

this flask app

python packages and modules

pymongo docs

werkzeug docs

flask docs

[app.route in flask] (http://ains.co/blog/things-which-arent-magic-flask-part-1.html)

[explanation of decorators] (http://stackoverflow.com/questions/17330160/how-does-the-property-decorator-work)

[deploy flask app to digital ocean with gunicorn] (http://blog.marksteve.com/deploy-a-flask-application-inside-a-digitalocean-droplet)

nginx tutorial

requirements.txt

dependencies to run this flask app

install with:

pip install -r requirements.txt

env.sh

make an env.sh

export FLASK_SECRET_KEY='YOUR_APP_SECRET_KEY'
export APP_SETTINGS='smappboard.config.DevelopmentProduction'
export SMAPPBOARD_TRENDS_CONSUMER_KEY='CONSUMER_KEY'
export SMAPPBOARD_TRENDS_CONSUMER_SECRET='CONSUMER_SECRET'
export SMAPPBOARD_TRENDS_ACCESS_TOKEN='ACCESS_TOKEN'
export SMAPPBOARD_TRENDS_ACCESS_TOKEN_SECRET='ACCESS_TOKEN_SECRET'
export SMAPPBOARD_CONSUMER_KEY='YOUR_APPS_CONSUMER_KEY'
export SMAPPBOARD_CONSUMER_SECRET='YOUR_APPS_CONSUMRE_SECRET'
export PATH_TO_SMAPPBOARD_USERS='smappboard_users.json'
export SMAPPBOARD_SSHFS_MOUNT_POINT='/mnt/olympus'

then run:

source env.sh

these environment variable are stored in the bash environment and can be used to store any appwide constants that you wish. they are loaded from this bash environment inside smappboard/config.py.

#author

yvan