From a29eb17be42a556e495e59f880ec1603e9cc4697 Mon Sep 17 00:00:00 2001 From: Pradeep Bashyal Date: Wed, 30 Oct 2024 16:04:11 -0500 Subject: [PATCH 1/2] Add `/ard` GET endpoint that `lgx` reduces the allele in path. e.g. `http://127.0.0.1:8080/ard/DPA1*02:07:01` Makes it easy to create a lgx reduction URL. --- api-spec.yaml | 77 +++++++++++++++++++++++++++++++++++++++++++++++---- api.py | 22 +++++++++++++-- 2 files changed, 91 insertions(+), 8 deletions(-) diff --git a/api-spec.yaml b/api-spec.yaml index 83ddb6f..954a9cf 100644 --- a/api-spec.yaml +++ b/api-spec.yaml @@ -36,22 +36,35 @@ paths: application/json: schema: properties: - ipd-version: + ipd_version: description: IPD-IMGT/HLA DB Version type: integer - example: 3560 - py-ard-version: + example: 3580 + pyard_version: description: py-ard library version type: string - example: "1.2.1" + example: "1.5.0" /redux: post: tags: - ARD Reduction operationId: api.redux_controller - summary: Reduce to ARD + summary: Reduce GL String at various level description: | - Given a GL String and a reduction method perform ARD Reduction + Given a GL String and a reduction method perform Reduction. + + Valid Reduction Method: + | Reduction Type | Description | + |----------------|-----------------------------------------------------------| + | `G` | Reduce to G Group Level | + | `P` | Reduce to P Group Level | + | `lg` | Reduce to 2 field ARD level (append `g`) | + | `lgx` | Reduce to 2 field ARD level | + | `W` | Reduce/Expand to full field(4,3,2) WHO nomenclature level | + | `exon` | Reduce/Expand to 3 field level | + | `U2` | Reduce to 2 field unambiguous level | + | `S` | Reduce to Serological level | + requestBody: content: application/json: @@ -97,6 +110,58 @@ paths: description: Describes what went wrong type: string example: "Invalid HLA locus" + /ard/{allele}: + get: + tags: + - ARD Reduction + operationId: api.lgx_controller + summary: Reduce to ARD + description: | + Get ARD Reduction for an Allele + parameters: + - name: allele + in: path + description: An allele or MAC + required: true + schema: + type: string + example: "DPA1*02:07:01" + responses: + 200: + description: ARD Reduction Result + content: + application/json: + schema: + type: object + properties: + allele: + description: Allele + type: string + example: "DPA1*02:07:01" + ard: + description: ARD version + type: string + example: "DPA1*02:02" + ipd_version: + description: IPD-IMGT/HLA DB Version + type: integer + example: 3580 + pyard_version: + description: py-ard library version + type: string + example: "1.2.1" + + 400: + description: Invalid Allele + content: + application/json: + schema: + type: object + properties: + message: + description: Describes what went wrong + type: string + example: "Invalid HLA locus" /cwd-redux: post: tags: diff --git a/api.py b/api.py index c841366..13291cb 100644 --- a/api.py +++ b/api.py @@ -58,6 +58,24 @@ def redux_controller(): return {"message": "No input data provided"}, 404 +def lgx_controller(allele): + # Perform redux + if allele: + try: + redux_string = ard.redux(allele, "lgx") + ipd_version = ard.get_db_version() + return { + "ipd_version": ipd_version, + "pyard_version": pyard.__version__, + "allele": allele, + "ard": redux_string, + }, 200 + except PyArdError as e: + return {"message": e.message}, 400 + else: + return {"message": f"No allele provided"}, 404 + + def mac_expand_controller(allele_code: str): try: if ard.is_mac(allele_code): @@ -107,8 +125,8 @@ def drbx_blender_controller(): def version_controller(): ipd_version = ard.get_db_version() return { - "ipd-version": ipd_version, - "py-ard-version": pyard.__version__, + "ipd_version": ipd_version, + "pyard_version": pyard.__version__, }, 200 From 98cc66a7bbd1b5d7b375731aaf9d32c1ea77823a Mon Sep 17 00:00:00 2001 From: Pradeep Bashyal Date: Wed, 30 Oct 2024 16:04:44 -0500 Subject: [PATCH 2/2] =?UTF-8?q?Bump=20version:=201.5.2=20=E2=86=92=201.5.3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Dockerfile | 2 +- api-spec.yaml | 2 +- pyard/__init__.py | 2 +- setup.cfg | 2 +- setup.py | 2 +- 5 files changed, 5 insertions(+), 5 deletions(-) diff --git a/Dockerfile b/Dockerfile index 52d1bd7..23df776 100644 --- a/Dockerfile +++ b/Dockerfile @@ -4,7 +4,7 @@ LABEL MAINTAINER="Pradeep Bashyal" WORKDIR /app -ARG PY_ARD_VERSION=1.5.2 +ARG PY_ARD_VERSION=1.5.3 COPY requirements.txt /app RUN pip install --no-cache-dir --upgrade pip && \ diff --git a/api-spec.yaml b/api-spec.yaml index 954a9cf..a9a4a84 100644 --- a/api-spec.yaml +++ b/api-spec.yaml @@ -2,7 +2,7 @@ openapi: 3.0.3 info: title: ARD Reduction description: Reduce to ARD Level - version: "1.5.2" + version: "1.5.3" servers: - url: 'http://localhost:8080' tags: diff --git a/pyard/__init__.py b/pyard/__init__.py index a2cc703..4672fad 100644 --- a/pyard/__init__.py +++ b/pyard/__init__.py @@ -26,7 +26,7 @@ from .misc import get_imgt_db_versions as db_versions __author__ = """NMDP Bioinformatics""" -__version__ = "1.5.2" +__version__ = "1.5.3" def init( diff --git a/setup.cfg b/setup.cfg index 038a518..2f89ff7 100644 --- a/setup.cfg +++ b/setup.cfg @@ -1,5 +1,5 @@ [bumpversion] -current_version = 1.5.2 +current_version = 1.5.3 commit = True tag = True diff --git a/setup.py b/setup.py index 65ed2c2..6f0f9db 100644 --- a/setup.py +++ b/setup.py @@ -36,7 +36,7 @@ setup( name="py-ard", - version="1.5.2", + version="1.5.3", description="ARD reduction for HLA with Python", long_description=readme, long_description_content_type="text/markdown",