Working on a new version of Brainspell. This platform allows users to curate neuroimaging literature, and version-control their meta-analyses on GitHub.
Clients can make requests to the JSON API directly, or access Brainspell through the web interface. A running Heroku instance is available at https://brainspell.herokuapp.com/.
To view a list of all JSON API endpoints, take a look at https://brainspell.herokuapp.com/json/list-endpoints. If you're unsure about the parameters for an endpoint, add /help
to the end of the URL (e.g., the documentation for https://brainspell.herokuapp.com/json/split-table is available at https://brainspell.herokuapp.com/json/split-table/help). Alternatively, you can try our API via Swagger.
To run Brainspell locally:
- Clone the Git repo with
git clone git@github.com:OpenNeuroLab/brainspell-neo.git
. - Install Postgres (if not already installed). If you have Homebrew installed, you can use
brew install postgres
. - Make sure that you're using Python 3.5.
- Enter the repo with
cd brainspell-neo/
, and install the Python dependencies withpip install -r requirements.txt
.
Now you can run Brainspell with python3 brainspell/brainspell.py
. Brainspell should be running at http://localhost:5000
.
Having difficulty getting Brainspell running? Install Conda, and create an environment for Python 3.5.
First, make sure that you have Docker installed. Then:
- Navigate into the Brainspell directory. (
cd brainspell-neo/
) - Build the Docker image with
docker build -t brainspell .
- Create the Docker container and run with
docker run --name brainspell -ti -p 5000:5000 brainspell
Brainspell should be running at http://localhost:5000/
. The next time that you want to run the Docker container, simply execute docker start -a brainspell
, and stop the Docker container with docker stop brainspell
.
In this section, we'll describe the steps required to start Brainspell automatically on boot, and to monitor the Brainspell process with Supervisor so that it doesn't get killed.
-
First, enter the Brainspell directory with
cd brainspell-neo/
. -
Next, check that you can generate a valid
supervisor.conf
file withpython3 server/generate_supervisor.py `which python` `pwd`
. -
If the previous command worked, then execute the setup script with
./setup-server.sh
. Now, Supervisor should be installed on your computer, and there should be a valid .conf file inserver/supervisor.conf
. -
Now we need to set Supervisor to automatically launch on startup.
- If you're on macOS, you can do so by adding a .plist file to
launchd
.- First, execute
python3 server/generate_mac_launchd.py `which supervisord` `pwd` > ~/Library/LaunchAgents/brainspell.plist
. - Then, launch the process with
launchctl load ~/Library/LaunchAgents/brainspell.plist
. Brainspell will automatically be running at port 5000 on startup. - If you use this script, you won’t be able to kill supervisord, since launchd will keep it alive. (You can make it so that you can kill supervisord by modifying the
generate_mac_launchd.py
script, and removing the “KeepAlive” key in .plist file text.)
- First, execute
- If you're on Linux, you can use
init.d
.- First, make sure that you have an init.d folder at
/etc/init.d/
. - Next, execute:
sudo python3 server/generate_linux_initd.py `which supervisord` `pwd` > /etc/init.d/brainspell.sh
.sudo chmod +x /etc/init.d/brainspell.sh
sudo update-rc.d brainspell.sh defaults
- First, make sure that you have an init.d folder at
- If you're on macOS, you can do so by adding a .plist file to
-
Now Brainspell should be running at port 5000, it should automatically start, and it should reboot automatically if an error occurs. Here’s an article from Namecheap on mapping that port to a domain name, once the port is publicly accessible from your server’s IP.
brainspell/brainspell.py
runs the Tornado main event loop.
Handlers go in one of three files:
json_api.py
, which contains JSON API endpoints that do not make GitHub API requests,user_interface.py
, which contains all handlers that render Tornado HTML templates, orgithub_collections.py
, which contains all API endpoints and handlers that communicate with GitHub.
Our naming convention is to use [*]EndpointHandler
for API endpoint handlers, and [*]Handler
for web interface handlers.
brainspell/article_helpers.py
contains helper functions for adding articles to the database.
brainspell/base_handler.py
is our abstract handler, which provides various helper functions. All handlers should subclass BaseHandler
.
brainspell/deploy.py
is a module for deploying to a remote server using Git.
brainspell/models.py
is for our ORM, PeeWee, which lets us treat our database like a Python object.
brainspell/search_helpers.py
contains helper functions for searching articles in the database.
brainspell/test_tornado.py
is our suite of continuous integration tests.
brainspell/user_account_helpers.py
contains helper functions for accessing and mutating user information.
brainspell/websockets.py
contains a WebSocket that allows developers to connect to the API using the WebSockets protocol.
brainspell/static/
contains the HTML, CSS, images, fonts, and Javascript code for the website.
Our official Postgres database is hosted on AWS, but we have a static database available on Heroku. The full database is available in the database_dumps
folder.
Former website for Brainspell: http://www.brainspell.org