-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Added documentation in readme. Added example_scenario in the app.
- Loading branch information
Showing
11 changed files
with
336 additions
and
102 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,81 +1,150 @@ | ||
CAB - The friendly Computational Applications Boilerplate | ||
---------------------------------------------------------- | ||
# CUBA - The EGF Collection of Useful Biological Apps | ||
|
||
CAB makes it easy to do webpages for the following scenario: the user connects | ||
to the website and lands on a page listing all the apps (or "scenarios"). The user selects an app, | ||
select some options and parameters, click on "send". Then the computer thinks for a while | ||
(while giving progress feedback) then return a report which can be HTML (pictures, tables) or/and a file (PDF, ZIP...) | ||
This repository contains the source code of [cuba.genomefoundry.org](cuba.genomefoundry.org), | ||
a website of the Edinburgh Genome Foundry enabling anyone to use some of the EGF's | ||
biological software. | ||
|
||
CAB was written to | ||
|
||
Why use CAB ? | ||
------------- | ||
|
||
CAB only uses tools that are both powerful and fun to work with: | ||
|
||
- Python and Django in the backend, to run any scientific/computational software. | ||
|
||
|
||
## How is it built ? | ||
|
||
CUBA provides a programming environment that makes it easy to create new apps with | ||
a form in the frontend and custom computations in the backend. It features job | ||
queues (with progress feedback for the user), form widgets like file uploaders, | ||
help buttons, and many more. | ||
|
||
CAB only uses techologies that are versatile and fun to work with: | ||
|
||
- Python and Django in the backend, to run scientific/computational routines. | ||
- Vue.js in the frontend, one of the easiest frameworks to learn and maintain. | ||
- Docker-compose for deploying your app anywhere in just a few lines. | ||
|
||
data:image/s3,"s3://crabby-images/76e1e/76e1ee366b786d717a08ba4faa1baf608315a5ab" alt="" | ||
|
||
This comes with the following advantages: | ||
|
||
- Complete live-reload ! The changes you make to your backend or frontend code | ||
- Creating a new app is super simple: just add one file in the front end (for | ||
the input form) and one file in the back-end (the code for computations). | ||
- Full live-reload ! The changes you make to your backend or frontend code | ||
take effect immediately. No need to refresh a page or restart a server by hand. | ||
- Plenty of easy-to-use library of components to build your user interface without headache | ||
(by default, CAB uses [Element](http://element.eleme.io/#/en-US)) | ||
- Will work on any system, one-line install, one-line deploy, and without any | ||
clash with your current settings as everything runs inside a container. | ||
- Plenty of easy-to-use library of components to build your user interface without | ||
headache, using [Element](http://element.eleme.io/#/en-US). | ||
- Works on any nachine: one-line install, one-line deploy. No | ||
clash with the rest of your system since everything runs inside containers. | ||
|
||
## Installing and developing | ||
|
||
First you need to install ``docker`` and ``docker-compose`` on your machine. That's the difficult part. | ||
## User Guide | ||
|
||
Then install download your CAB application like this: | ||
Developing with CUBA app requires a good familiarity with Python, Vue, and | ||
base knowlege of Docker and Git. | ||
|
||
### Getting started | ||
|
||
The next steps will download, install, and launch CUBA on your computer. | ||
|
||
1. Install ``docker`` and ``docker-compose`` on your machine. This step depends | ||
on your machine (Windows, Linux, MacOS) so you'll need to google it. | ||
|
||
2. Download CUBA from Github: | ||
|
||
``` | ||
git clone CAB.git | ||
git clone git+github.com/Edinburgh-Genome-Foundry/CUBA.git | ||
``` | ||
|
||
Go to the root folder (the one containing this README and the ``docker-compose.yml``) and type this to launch your application in development mode | ||
3. Go to the root ``CUBA/`` directory (the one containing this README and the | ||
``docker-compose.yml``) and launch your application in development mode. The | ||
first time you try this, Docker will download and build a lot of things, | ||
which may take several minutes. It will only take a few seconds the next | ||
times you run this command. | ||
|
||
``` | ||
docker-compose up | ||
``` | ||
|
||
Note that the first time you type this, Docker will need to build the necessary | ||
containers, which may take a few minutes. Then this command just takes second. | ||
4. Go to your browser and type ``localhost`` or ``127.0.0.1`` in the address bar. | ||
You should see the website appear. the console in which you launched | ||
``docker-compose`` will keep printing logs of the different components | ||
(django, vue) so you can keep track and debug. | ||
|
||
### Creating a new app | ||
|
||
Now you can access the app from your browser on port 8080 of your machine, either | ||
[http://localhost:8080](http://localhost:8080/) if it is running on your local | ||
machine or something like ``http://139.59.162.184:8080`` if the CAB app is running | ||
on a distant server. | ||
The next steps will add a new app to the CUBA project. | ||
|
||
At this stage, any change you do to your code, back-end or front-end, will be reflected live without you needed to refresh. | ||
1. Go to ``frontend/src/components/scenarios`` and create a new scenario view | ||
with a form, for instance by duplicating the file | ||
[ExampleScenario.vue](ExampleScenario.vue). | ||
|
||
## Use in production | ||
2. Register your scenario in file ``scenarios.js`` (in the same folder) | ||
by adding ``require('./ExampleScenario')`` under the category you want. | ||
You should now see your new scenario in the home page and the menu of the | ||
website. | ||
|
||
3. Next we will add some backend computations to process the form and return a | ||
result. First go to ``backend/app/views`` and create a new folder | ||
on the model of [``/example_scenario``](backend/app/views/example_scenario). | ||
|
||
To run in production mode (this will turn down debug mode in the frontend and backend). | ||
4. Register the scenario in ``backend/app/views/__init__.py`` by adding | ||
|
||
``` | ||
docker-compose -f docker-compose.yml -f docker-compose.prod.yml up -d | ||
from .example_scenario import ExampleScenarioView | ||
``` | ||
|
||
5. Register the URL by adding the following line at the end of | ||
``backend/website/urls.py``: | ||
|
||
``` | ||
url(r'^api/start/example_scenario$', | ||
views.ExampleScenarioView.as_view()), | ||
``` | ||
|
||
6. That's it. You now have a new app with frontend and backend ! | ||
|
||
### Deploying the app on the web | ||
|
||
The next steps will put your website on the web. Note that many other deployment | ||
workflows are possible. | ||
|
||
1. Get a hosting server (for instance from Amazon Web Services or Digital Ocean). | ||
Get the IP address of this server (we'll assume it is 123.12.123.123). | ||
|
||
2. Log in this server (``ssh [email protected]``) and install Docker and | ||
Docker-Compose (some Digital Ocean servers come with these already installed). | ||
|
||
3. From your computer, in the CUBA root directory, run the following command to | ||
create a code repository on the distant server, and register that distant | ||
repository under the name ``prodserver`` | ||
|
||
``` | ||
git remote add production git+ssh:123.456.789.123: | ||
./init_remote_git.sh root@123.12.123.123 CUBA prodserver | ||
``` | ||
|
||
4. On the remote server, in the folder ``CUBA.git``, start the website in | ||
production mode: | ||
|
||
``` | ||
git push production master | ||
docker-compose -f docker-compose.yml -f docker-compose.prod.yml up -d | ||
``` | ||
|
||
5. Wait some time and go in your browser at the address ``123.12.123.123``, | ||
your website should be live ! | ||
|
||
Every time you want to update the website, from your computer in the CUBA root | ||
directory run ``git push prodserver master``. You will need to rebuild the | ||
containers on the server if you have modified the frontend or added dependencies | ||
to the backend (we may simplify this later). | ||
|
||
Licence | ||
------- | ||
|
||
CAB is an open source software originally written by [Zulko](https://github.com/Zulko) | ||
at the [Edinburgh Genome Foundry](http://genomefoundry.org/) and released on [Github](#) under the MIT licence (¢ Edinburgh Genome Foundry). Everyone is welcome to contribute. | ||
CUBA is an open source software originally written by [Zulko](https://github.com/Zulko) | ||
at the [Edinburgh Genome Foundry](http://genomefoundry.org/) and released on | ||
[Github](https://github.com/Edinburgh-Genome-Foundry/CUBA) under the MIT licence | ||
(¢ Edinburgh Genome Foundry). Everyone is welcome to contribute ! | ||
|
||
If you publish an app made with CAB, you can licence your own code under any other licence and copyright, by placing the terms of the licence on top of each new file you create (this will typically be one file in the frontend and one file in the backend). | ||
If you publish an app made with CAB, you can licence your own code under any | ||
other licence and copyright, by placing the terms of the licence on top of each | ||
new file you create (this will typically be one file in the frontend and one | ||
file in the backend). |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
"""Bla.""" | ||
|
||
from ..base import AsyncWorker, StartJobView, JobResult | ||
from ..serializers import FileSerializer | ||
from rest_framework import serializers | ||
|
||
# Every component of the frontend form must have its serializer. | ||
|
||
class serializer_class(serializers.Serializer): | ||
inputText = serializers.CharField() | ||
files = serializers.ListField(child=FileSerializer()) | ||
|
||
|
||
class worker_class(AsyncWorker): | ||
|
||
def work(self): | ||
|
||
self.logger(message="This message will be show to the website user!") | ||
|
||
# You can access any data from the frontend form as follows: | ||
|
||
user_input_text = self.data.inputText | ||
user_files = self.data.files | ||
|
||
# ==================================================================== | ||
# | ||
# Here you would write some code to process the user's input using | ||
# your awesome libraries to produce magnificent results. | ||
# | ||
# ==================================================================== | ||
|
||
# When the computations are done, return some results data. | ||
# The data returned will be displayed by the frontend app in the | ||
# results section | ||
return { | ||
'answer_text': 'After deliberation, the answer appears to be 42.', | ||
'figures_data': '(yep, you can send back figure data, see the other' | ||
'app for examples)' | ||
} | ||
|
||
class ExampleScenarioView(StartJobView): | ||
'''This will be the same for every scenario you write.''' | ||
serializer_class = serializer_class | ||
worker_class = worker_class |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
from .ExampleScenario import ExampleScenarioView |
This file was deleted.
Oops, something went wrong.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Oops, something went wrong.