Skip to content

Haitham-ghaida/bw25fastapi

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

bw25fastapi

FastAPI application designed to facilitate life cycle assessment (LCA) calculations using the Brightway2 framework.

  • Project Management: Create and manage LCA projects.
  • Ecoinvent Integration: Set Ecoinvent credentials, import Ecoinvent releases, and list available release versions and system models.
  • LCA Calculations: Perform static LCA calculations by specifying demands and impact categories or LCIA methods.

Installing

There are several ways to get bw25fastapi up and running. You can build it yourself, run it locally, or use the Docker image.

Build It Yourself

Clone the Repository:

git clone https://github.com/Haitham-ghaida/bw25fastapi.git
cd bw25fastapi

Set up a Virtual Environment (Optional but recommended):

python -m venv venv
source venv/bin/activate  # On Windows, use `venv\Scripts\activate`

Install Dependencies:

pip install -r requirements.txt

Run the Application:

uvicorn main:app --reload

The application will be available at http://localhost:8000.

Build the Docker Image

Instead of running the application directly on your local machine, you can easily containerize bw25fastapi using Docker. This approach ensures that the application runs consistently across different environments.

Just clone the git repo like the previous option, then cd into that dir run:

docker build -t bw25fastapi:latest .

This command builds a Docker image named bw25fastapi tagged as latest.

Run the Docker Container

After building the image, you can run bw25fastapi inside a Docker container.

docker run -d -p 8000:8000 bw25fastapi:latest

You can change the local port to whatever you want in case you are using it for something else for example 5000:8000 if you want port 5000

Access the Application

With the container running, you can access the FastAPI documentation and test the API directly from your web browser by navigating to http://localhost:8000/docs.

Use the Docker Image

docker pull haithamthabet/bw25fastapi:latest

then run it

docker run -d --name bw25fastapi -p 8000:8000 haithamthabet/bw25fastapi:latest

This command runs the application in a Docker container named bw25fastapi and makes it accessible on port 8000.

Using your host's brightway projects and databases.

if you would like the container to use the host's brightway directory then you need to run the container like this:

docker run docker run -d --name bw25fastapi -p 8000:8000 -v /path/to/your/brightway/dir:/root/.local/share/Brightway3 haithamthabet/bw25fastapi:latest

you can refer to the brightway docs to find what is the directory for your system. it's different for mac, windows, linux.

you can also run:

bw2data.projects.dir

to find your directory

Getting started

Here are some examples using curl

Projects

You can see what projects you have by:

curl -X 'GET' \
  'http://localhost:8000/api/v1/projects/' \
  -H 'accept: application/json'

to create a project:

curl -X POST "http://localhost:8000/api/v1/project/?project_name=my_new_project"

Ecoinvent import

We use the ecoinvent_interface to import ecoinvent databases

to use it first you need to have a vaild ecoinvent account with access to some databases. you can store your login details with this:

curl -X 'POST' \
  'http://localhost:8000/api/v1/set_ecoinvent_credentials/' \
  -H 'accept: application/json' \
  -H 'Content-Type: application/json' \
  -d '{
  "username": "your_ecoinvent_username",
  "password": "your_ecoinvent_password"
}'

afterwards you can import any database available for you using:

Note that this will take some time, i haven't implemented a way to check the progress so you just need to wait.

curl -X 'POST' \
  'http://localhost:8000/api/v1/project/my_new_project/import_ecoinvent/' \
  -H 'accept: application/json' \
  -H 'Content-Type: application/json' \
  -d '{
  "version": "3.8",
  "system_model": "cutoff"
}'

Databases

to see what databases are available in a project.

curl -X GET "http://localhost:8000/api/v1/project/{project_name}/database" \
     -H "accept: application/json"

to search through the database

curl -X GET "http://localhost:8000/api/v1/project/{project_name}/database/{database_name}/activity/search?search_term={search_term}" \
     -H "accept: application/json"

to see exchanges of an activity

curl -X GET "http://localhost:8000/api/v1/project/{project_name}/database/{database_name}/activity/{activity_code}/exchanges" \
     -H "accept: application/json"

Methods

To see what LCIA methods are available:

curl -X GET "http://localhost:8000/api/v1/project/{project_name}/lcia_methods" \
     -H "accept: application/json"

to see impact categories of a method

curl -X GET "http://localhost:8000/api/v1/project/{project_name}/lcia_methods/{lcia_method}/impact_categories" \
     -H "accept: application/json"

LCA

to run an LCA given a specfic lcia method

curl -X POST "http://localhost:8000/api/v1/project/{project_name}/database/{database_name}/lca" \
     -H "Content-Type: application/json" \
     -d '{
         "demands": [{"{activity1_code}": 1.0}, {"{activity2_code}": 2.0}],
         "lcia_method": "{lcia_method_name}"
     }'

or you can simply provide a list of impact categories that you want:

       curl -X POST "http://localhost:8000/api/v1/project/my_project/database/ecoinvent-3.9-cutoff/lca" \  
         -H "Content-Type: application/json" \
         -d '{
         "demands": [{"67607aa7b3530fe7fbd3a6de8ae58527": 2.0}, {"cf58e5107752177423205ce5e78d16f4": 1}],
         "impact_categories": [["EF v3.1 EN15804", "climate change", "global warming potential (GWP100)"]]
     }'

Contributing

Contributions to bw25fastapi are welcome! Please feel free to submit pull requests or create issues for bugs, questions, and feature requests.

todo

  • Add response from fastapi
  • Add caching
  • Create methods to add/write databases
  • also general functionality, delete/edit db, project, activity, exchange.
  • ideas?

Feel free to reach out at [email protected].

License

This project is licensed under BSD-3-Clause license - see the LICENSE file for details.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published