This repo uses Dash. See Dash installation documentation
Run in two different command lines.
flask run
flask worker start
The following configuration variables need to be set to get parts of the site
working. You can do this in a development version by including a .env
file
in the root directory.
In dokku you can set these variables using the dokku config:set explorer CONFIG_VAR=value
command.
# flask app
FLASK_APP=index:server
FLASK_ENV=development # if you're developing
# configuration for the newsletter signup box
NEWSLETTER_FORM_ACTION=https://threesixtygiving.us10.list-manage.com/subscribe
NEWSLETTER_FORM_U=216b8b926250184f90c7198e8
NEWSLETTER_FORM_ID=91870dde44
# file from which the 360Giving registry will be loaded
THREESIXTY_STATUS_JSON=https://store.data.threesixtygiving.org/reports/daily_status.json
# configuration for the mapbox map - an access token is needed for the map to work
MAPBOX_ACCESS_TOKEN=token_goes_here
MAPBOX_STYLE=mapbox://styles/davidkane/cjmtr1n101qlz2ruqszjcmhls
# files larger than this limit are not allowed on the site
FILE_SIZE_LIMIT=50000000
# add google analytics tracking ID to use GA
GOOGLE_ANALYTICS_TRACKING_ID=UA-118275561-3
You'll need to sign up to mapbox to create a token. Once you've created an account you can find and create access tokens through https://account.mapbox.com/.
The newsletter section is set up to send variables to a mailchimp signup form. The different parts needed can be found in the URL that you go to when you visit the "Join this mailing list" page:
https://threesixtygiving.us10.list-manage.com/subscribe?u=216b8b926250184f90c7198e8&id=91870dde44
From the URL above you find the following variables:
- NEWSLETTER_FORM_ACTION =
https://threesixtygiving.us10.list-manage.com/subscribe
- NEWSLETTER_FORM_U =
216b8b926250184f90c7198e8
- NEWSLETTER_FORM_ID =
91870dde44
# create app
dokku apps:create insights
# add redis cache
sudo dokku plugin:install https://github.com/dokku/dokku-redis.git redis
dokku redis:create insightscache
dokku redis:link insightscache insights
# enable domains
dokku domains:enable insights
dokku domains:set insights example.com
# letsencrypt
sudo dokku plugin:install https://github.com/dokku/dokku-letsencrypt.git
dokku config:set --no-restart insights [email protected]
dokku letsencrypt:enable insights
# create app storage
mkdir -p /var/lib/dokku/data/storage/insights-uploads
chown -R dokku:dokku /var/lib/dokku/data/storage/insights-uploads
chown -R 32767:32767 /var/lib/dokku/data/storage/insights-uploads
dokku storage:mount insights /var/lib/dokku/data/storage/insights-uploads:/app/uploads
By default dokku only allows 2mb file uploads. You can change this by installing the Dokku Nginx Max Upload Size plugin.
sudo dokku plugin:install https://github.com/Zeilenwerk/dokku-nginx-max-upload-size.git
dokku config:set insights MAX_UPLOAD_SIZE=20M
There are a number of server commands that can be used to maintain the database. They need to be run from the server(eg via SSH access).
When running from a dokku instance then dokku run insights
needs to be added to the start, so for exmaple:
dokku run insights flask registry update
Update the registry to the latest version
flask registry update
Fetch a file (by URL or registry identifier):
flask data fetch <file_url>
Fetch all files in the registry. <output>
should be a path to a csv, json or excel
file which will have a line with log details for each file.
flask data fetchall <output>
flask data fetchall <output> --file-limit=1000000 # max file size in bytes
Remove a file:
flask data remove <fileid>
Remove all files (use with caution!) It will ask you to confirm.
flask data removeall
Preview a file (Shows columns and rows from data):
flask data preview <fileid>
flask data preview <fileid> --field=Description # preview a single field
Move all files from redis to filesystem caching or vice versa:
flask data redistofile
flask data filetoredis
requests_cache
for caching URL requestsredis_queue
for managing worker processget_from_cache
&save_to_cache
use both redis and filesystem cache to store files & metadata about files
- save to cache when dataset is loaded from file or URL
- requests_cache used for looking up postcodes, charities & companies
- used in worker process for managed the tasks
- used when fetching registry file (can be switched off)
- used when fetching files from registry