opentronsfastapi is package for building FastAPIs that run protocols on an Opentrons
Project description
Example
from fastapi import FastAPI
from pydantic import BaseModel
import opentronsfastapi as otf
app = FastAPI()
app.include_router(otf.default_routes)
class DispenseWell(BaseModel):
address: str
@app.post("/api/procedure/demo_procedure")
@otf.opentrons_execute(apiLevel='2.8')
def demo_procedure(dispenseWell:DispenseWell,
version = otf.ot_flags.protocol_version_flag,
protocol = otf.ot_flags.protocol_context
):
plate = protocol.load_labware("corning_96_wellplate_360ul_flat", 1)
tip_rack = protocol.load_labware("opentrons_96_filtertiprack_20ul", 2)
p20 = protocol.load_instrument("p20_single_gen2", "left", tip_racks=[tip_rack])
p20.pick_up_tip()
p20.aspirate(10, plate.wells_by_name()['A1'])
p20.dispense(10, plate.wells_by_name()[dispenseWell.address])
p20.drop_tip()
Usage notes
There are three main touchpoints for most users:
@opentrons_execute()
Decorate your route with this function to have it executed on the OT2. There are two optional parameters:apiLevel
specifies the apiLevel that the OT2 should use when executing your function. Default is '2.9'msg
specifies the message that should be returned to the requesting server when protocol successfully initiates
opentronsfastapi.ot_flags.protocol_context
Every protocol must specify the variable that will be passed the Protocol Context by setting some value equal to this object in the parameters. This parameter will not be exposed to the APIopentronsfastapi.ot_flags.protocol_version_flag
Optionally, you may set a parameter equal to this obejct. This will expose an option in the API to query the protocol version without actually running the protocol. Protocol versions are reported as hashes of the code, so you can quickly determine if any of the protocol text has changed from what you expected.
opentronsfastapi
opentronsfastapi is a library that allows for FastAPIs to be easily deployed onto Opentrons liquid handling robots (OT2) with robotic protocols. The protocols can be parameterized, allowing complex robotic functions to take place. Communication is done over HTTP via a REST API, and execution of the protocols begins immediately, allowing the OT2 to work as part of a larger lab management system, or simply allowing the user to build a user interface that suits their needs better than the stock options Opentrons provides.
For example, a biofoundry might have the following components for successfully executing a protocol:
- A job queue that lists the tasks to be done
- A system-level execution manager that decides what job to do next and passes the job to an appropriate robot
- A client on the robot that receives job requests and, if accepted, initiates execution on the robot
- A low-level layer that converts job instructions to the acutation of motors
opentronsfastapi specifically helps with #3.
Features
opentronsfastapi:
- (done) Allows API endpoints to be wrapped with a decorator for execution on an Opentrons robot
- (done) Manages robot state - if the robot is busy, then job requests are refused until the robot work is complete, and an error code is returned to the requestor
- (done) Can report the state of the robot to a requestor, via API endpoint
- (done) Can report the protocol version the robot will use, in the form of a unique hash, via an API endpoint
- (done) Allows the API to be accessed by any arbitrary tool, as long as POST requests are sent in the right format
- (todo) Can be deployed on stock OT2's without special tools
Limitations
- Works at the level of a single robot, and is naive of other robots. However, it can be deployed on multiple robots, which can then be managed by a supervisor.
Todo
- Better and clearer exception handling of errors
- Automatic recongition of being deployed on a robot (users shouldn't have to set the
opentrons_env
global variable) - Simple git deployment onto robots
- Hash returns of any individual protocol
Install with systemd
export IP=xxx.xxx.x.xxx
ssh root@$IP 'mount -o remount,rw /'
scp opentronsfastapi.service root@$IP:/etc/systemd/system
ssh root@$IP 'systemctl enable opentronsfastapi'
ssh root@$IP 'reboot'
Contributors
- Thank you Tim Dobbs for writing most of the README, adding essential wrappers, and generally bringing this project into reality.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for opentronsfastapi-0.1.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9d19df2a59fe0026c7d45635299cd06881b87cd03eafa8330e7820bfed309ecd |
|
MD5 | a89f66aefb80691d5ce5a7108d729b5e |
|
BLAKE2b-256 | 158ad4263b40af343dfe9ffcd67928731f3eac9d0496c1b35443618958f02f73 |