Skip to content

Your climate action is here 🌎 Our API is a source for learning how climate change personally affects you and the things you care about most. Additionally, it will teach a scientifically proven method for communicating to others that climate change is a personally relevant issue to inspire action.

License

Notifications You must be signed in to change notification settings

ClimateMind/climatemind-backend

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Climatemind Backend

Code style: black

Using Docker you need to install it first: https://www.docker.com/products/docker-desktop

On Windows it is running in a strict secure mode. You need to add the source directory to the Docker Resources: Settings / Resources / File Sharing -> add the application root directory

Before doing what's below, be sure the Docker application is running and the command line working directory is changed to the climatemind-backend path.

Running the application with Docker Compose (for development)

Build the image container to download and install code dependencies needed for running the app. SPECIAL NOTE: Whenever the backend repo has added new dependancies in the requirements.txt file the docker image will need to be re-built by re-running the build command below .

docker-compose build

Start in foreground (good for debugging flask and see the logs). You can stop it with [CTRL + C] on OSX, Windows, and Linux.

docker-compose up

Start in background (best for when trying to visualize the ontology)

docker-compose up -d

Stop the container when running in the background. Stops containers and removes containers, networks, volumes, and images created by docker-compose up.

docker-compose down

SPECIAL NOTE: Sometimes the terminal says 'Running on http://0.0.0.0:5000' and that url does not work in the browser. If this happens, try going to "http://127.0.0.1:5000" instead.

Running the application with Docker (for deployment)

The Docker lifecycle is to build the image and run it only once. After that you can stop or start the image.

Building Docker image

docker build -t "climatemind-backend:0.1" .

Checking the built image

docker images climatemind-backend

Running Docker

docker run -d --name climatemind-backend --publish 5000:5000 climatemind-backend:0.1

Stop the container

docker stop climatemind-backend

Start the container

docker start climatemind-backend

Api Documentation

Swagger Documentation is available at detailing the API endpoints available and how they should be used. Whilst in development this can be for at http://localhost:5000/swagger.


Processing any new Climate Mind OWL ontology file

Follow these instructions to process a new version of a Climate Mind ontology OWL file into files used by Climate Mind (such as Networkx pickle file, test ontology JSON, edge list output CSV, etc).

  1. Download the new OWL ontology file (if haven't already) and put it in the proper place:

    • Download the OWL ontology file by going to webprotege.stanford.edu and downloading in the format 'RDF/XML'. (If you don't have access, simply email hello@climatemind.org with your webprotege username to get access).
    • Unzip the download and go into the folder and move/copy the single ontology file to the folder in the climatemind-backend directory folder named 'PUT_NEW_OWL_FILE_IN_HERE'
  2. Change the directory to be the climatemind-backend by using the following command with the part in caps replaced with the path to climatemind-backend on your system (for mac):

    for OSX: cd PATH_TO_CLIMATEMIND-BACKEND

  3. Remove any pre-existing docker container, build the new docker container, and start the new container in developer mode by running the following:

        docker-compose down
        docker-compose build
        docker-compose up -d
    
  4. Store the docker container id as a variable by doing:

    • FOR MAC/LINUX:
        CLIMATEMIND_ID=$(docker ps -lq)
    
    • FOR PC with powershell:
        $CLIMATEMIND_ID=$(docker ps -lq)
    
  5. Process the OWL file either without the visualization app being triggered (OPTION A) or with visualization being triggered (OPTION B)

    • OPTION A. Do this option for processing the new OWL file without visualizing it after it's done processing: From the climatemind-backend directory run process_new_ontology_file.py using the climatemind docker image running in the background. Note: New files will be generated and appear in the climatemind-backend directory. These files are also listed in the git.ignore file, so don't worry about them getting pushed accidentally to the git repo.

      for OSX, run this exactly as below:

        docker exec -it $CLIMATEMIND_ID python process_new_ontology_file.py
    
    • OPTION B. Do this option for processing the new OWL file with visualizing it after it's done processing. Follow these instructions to visualize an OWL file using the Dash dashboard generated by the visualize.py script: From the climatemind-backend directory run the process_new_ontology_and_visualize.py using the climatemind docker image running in the background. Note: New files will be generated and appear in the climatemind-backend directory. These files are also listed in the git.ignore file, so don't worry about them getting pushed accidentally to the git repo.

      for OSX or PC with powershell, run this exactly as below:

        docker exec -it $CLIMATEMIND_ID python process_new_ontology_and_visualize.py
    

Extra details if started the visualization script directly above.

  1. After running step 3 OPTION B above, find the URL that appears in the terminal and go to it in your internet browser.

    Example: "Dash is running on http://127.0.0.1:8050/" appears in the terminal, so go to http://127.0.0.1:8050/ in your internet browser.

  2. Use the visualization dashboard in your internet browser.

  3. When done using the dashboard, close the browser and stop the script from running by going to the terminal and pressing [CTRL + C]

Code Style

The python code is style using Black

You can run Black locally to see which files need formatting using python3 -m black --check ./

You can use Black to automatically format your files using python3 -m black ./

About

Your climate action is here 🌎 Our API is a source for learning how climate change personally affects you and the things you care about most. Additionally, it will teach a scientifically proven method for communicating to others that climate change is a personally relevant issue to inspire action.

Topics

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Sponsor this project

Packages

No packages published

Languages