Skip to main content

A BRAPI server instance that functions as a proxy to merge and combine endpoints from existing BRAPI services

Project description

BrAPI proxy solution

A BrAPI server instance that functions as a proxy to merge and combine endpoints from existing BrAPI services.

Installation

  • Step 1: Install BrAPI Proxy
    • To install the BrAPI Proxy, run the following command:
      pip install brapi_proxy
      
  • Step 2: Test the Installation (Optional)
    • To ensure that the installation was successful, you can run the BrAPI Proxy in demo mode with the following command:
      brapi_proxy --demo
      
      This will start a service on port 8080 from a configuration based on the BrAPI Test Server

Usage

  • Step 1: Create Configuration File

    • Create a file named config.ini.
    • Populate this file with the necessary configuration settings.
  • Step 2: Start the Service

    • Start the service by running the command:
      brapi_proxy
      
    • If the config.ini file is located outside the working directory, use the --config option to specify its location. For example:
      brapi_proxy --config /path/to/config.ini
      

Currently Supported

BrAPI Versions

  • version 2.1

Endpoints

  • BrAPI-Core
    • /commoncropnames
    • /lists
    • /lists/{listDbId}
    • /locations
    • /locations/{locationDbId}
    • /people
    • /people/{personDbId}
    • /programs
    • /programs/{programDbId}
    • /seasons
    • /seasons/{seasonDbId}
    • /studies
    • /studies/{studyDbId}
    • /trials
    • /trials/{trialDbId}
  • BrAPI-Phenotyping
    • /ontologies
    • /ontologies/{ontologyDbId}
  • BrAPI-Genotyping
    • /allelematrix
    • /callsets
    • /callsets/{callSetDbId}
    • /plates
    • /plates/{plateDbId}
    • /references
    • /references/{referenceDbId}
    • /referencesets
    • /referencesets/{referenceSetDbId}
    • /samples
    • /samples/{sampleDbId}
    • /variants
    • /variants/{variantDbId}
    • /variantsets
    • /variantsets/{variantSetDbId}
  • BrAPI-Germplasm
    • /attributes
    • /attributes/{attributeDbId}
    • /attributevalues
    • /attributevalues/{attributeValueDbId}
    • /breedingmethods
    • /breedingmethods/{breedingMethodDbId}
    • /germplasm
    • /germplasm/{germplasmDbId}

ToDo

  • Implement additional endpoints

Structure Configuration File

Create a config.ini file with the necessary configuration settings.

Basic Configuration

Include at least the brapi section:

[brapi]
port=8080
host=0.0.0.0
location=/
threads=4
debug=False
version=1.2.3

Optional: Serverinfo

Optionally, provide serverinfo entries:

contactEmail=noreply@wur.nl
documentationURL=https://github.com/matthijsbrouwer/brapi-proxy/
location=Wageningen
organizationName=Wageningen University and Research
organizationURL=https://www.plantbreeding.wur.nl/
serverDescription=Demo-version proxy to combine multiple BrAPI services
serverName=BrAPI-Proxy

Optional: Authorization

Optionally, provide authentication tokens to restrict access in the authorization section:

[authorization]
john=tokenjohn123abc
mary=tokenmary456def

Server Definitions

Within sections prefixed with server., define the underlying servers:

[server.test1]
url=https://test-server.brapi.org/brapi/v2
calls=commoncropnames,variants,allelematrix
authorization=XXXX
prefix.variants=barley:
prefix.variantsets=barley:
prefix.references=barley:
prefix.referencesets=barley:
prefix.callsets=barley:

[server.test2]
url=https://test-server.brapi.org/brapi/v2
calls=commoncropnames,variants,allelematrix
prefix.variants=wheat:
prefix.variantsets=wheat:
prefix.references=wheat:
prefix.referencesets=wheat:
prefix.callsets=wheat:

[server.test3]
url=https://test-server.brapi.org/brapi/v2
calls=samples,studies,plates,callsets,variantsets,referencesets,references

To include all available and supported calls from a namespace:

[server.test3]
url=https://test-server.brapi.org/brapi/v2
calls=core.*

To include all available and supported calls:

[server.test3]
url=https://test-server.brapi.org/brapi/v2
calls=*

This software has been developed for the AGENT project

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

brapi_proxy-0.0.16.tar.gz (26.8 kB view details)

Uploaded Source

Built Distribution

brapi_proxy-0.0.16-py3-none-any.whl (52.4 kB view details)

Uploaded Python 3

File details

Details for the file brapi_proxy-0.0.16.tar.gz.

File metadata

  • Download URL: brapi_proxy-0.0.16.tar.gz
  • Upload date:
  • Size: 26.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.10.4

File hashes

Hashes for brapi_proxy-0.0.16.tar.gz
Algorithm Hash digest
SHA256 6ea0c2b4a99b81598329003db69788b153cb3d089828344a5cb5795f965fe8e3
MD5 783a629c7fd73553c5ef075e79bcf190
BLAKE2b-256 47eb366299353569b655fb874583fd31627c9b470390a3306020203b0fd3c818

See more details on using hashes here.

File details

Details for the file brapi_proxy-0.0.16-py3-none-any.whl.

File metadata

  • Download URL: brapi_proxy-0.0.16-py3-none-any.whl
  • Upload date:
  • Size: 52.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.10.4

File hashes

Hashes for brapi_proxy-0.0.16-py3-none-any.whl
Algorithm Hash digest
SHA256 11691e716a2863184af7830b749b1602726cd867e732507155da9b81be1eb752
MD5 f5a476c5c025036f29b459badc24b9e2
BLAKE2b-256 8cf55a004e6d189742e3c0f0ef7f34e61a80b8e72c2d17fa2d109939efb5a267

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page