From 6fd9be3c649dce1253ab23bc2d579c63fa2c7bf5 Mon Sep 17 00:00:00 2001 From: Thomas Schaffter Date: Thu, 25 Feb 2021 19:43:33 -0800 Subject: [PATCH] Release 1.0.1 (#43) * Update README and package.json * Re-generate server for API version 1.0.1 * Update API and tool version in Tool object --- README.md | 5 ++-- package.json | 1 + .../controllers/tool_controller.py | 4 +-- server/openapi_server/models/license.py | 1 + .../openapi_server/models/text_annotation.py | 2 ++ .../models/text_person_name_annotation.py | 2 ++ server/openapi_server/openapi/openapi.yaml | 29 +++++++++++++------ 7 files changed, 30 insertions(+), 14 deletions(-) diff --git a/README.md b/README.md index 81b030b..2611dda 100644 --- a/README.md +++ b/README.md @@ -5,7 +5,6 @@ [![GitHub License](https://img.shields.io/github/license/nlpsandbox/person-name-annotator-example.svg?color=94398d&labelColor=555555&logoColor=ffffff&style=for-the-badge&logo=github)](https://github.com/nlpsandbox/person-name-annotator-example/blob/develop/LICENSE) [![Docker Pulls](https://img.shields.io/docker/pulls/nlpsandbox/person-name-annotator-example.svg?color=94398d&labelColor=555555&logoColor=ffffff&style=for-the-badge&label=pulls&logo=docker)](https://hub.docker.com/r/nlpsandbox/person-name-annotator-example) [![Discord](https://img.shields.io/discord/770484164393828373.svg?color=94398d&labelColor=555555&logoColor=ffffff&style=for-the-badge&label=Discord&logo=discord)](https://discord.gg/Zb4ymtF "Realtime support / chat with the community and the team") -[![nlpsandbox.io](https://img.shields.io/badge/OpenAPI-nlpsandbox.io-blue?color=94398d&labelColor=555555&logoColor=ffffff&style=for-the-badge&logo=&label=)](https://www.nlpsandbox.io/tools/person-name-annotator/leaderboards "View the performance of this NLP Tool on nlpsandbox.io") Example implementation of the [NLP Sandbox Person Name Annotator] @@ -19,8 +18,8 @@ found in the clinical note. ### Specification -- Person Name Annotator API version: 1.0.0 -- Tool version: 1.0.0 +- Person Name Annotator API version: 1.0.1 +- Tool version: 1.0.1 - Docker image: [nlpsandbox/person-name-annotator-example] ## Model diff --git a/package.json b/package.json index beb229d..2066979 100644 --- a/package.json +++ b/package.json @@ -4,6 +4,7 @@ }, "scripts": { "generate:server": "openapi-generator-cli generate -g python-flask -o server -i $npm_config_specification", + "generate:server:latest": "openapi-generator-cli generate -g python-flask -o server -i https://nlpsandbox.github.io/nlpsandbox-schemas/person-name-annotator/latest/openapi.json", "lint": "cd server && flake8", "test": "cd server && tox" } diff --git a/server/openapi_server/controllers/tool_controller.py b/server/openapi_server/controllers/tool_controller.py index 2c498ea..2549257 100644 --- a/server/openapi_server/controllers/tool_controller.py +++ b/server/openapi_server/controllers/tool_controller.py @@ -13,7 +13,7 @@ def get_tool(): # noqa: E501 """ tool = Tool( name="person-name-annotator-example", - version="1.0.0", + version="1.0.1", license=License.APACHE_2_0, repository="github:nlpsandbox/person-name-annotator-example", description="Example implementation of the NLP Sandbox Person " + @@ -22,7 +22,7 @@ def get_tool(): # noqa: E501 author_email="thomas.schaffter@sagebionetworks.org", url="https://github.com/nlpsandbox/person-name-annotator-example", tool_type="nlpsandbox:person-name-annotator", - tool_api_version="1.0.0" + tool_api_version="1.0.1" ) return tool, 200 diff --git a/server/openapi_server/models/license.py b/server/openapi_server/models/license.py index 8811cc7..42df981 100644 --- a/server/openapi_server/models/license.py +++ b/server/openapi_server/models/license.py @@ -52,6 +52,7 @@ class License(Model): NCSA = "ncsa" UNLICENSE = "unlicense" ZLIB = "zlib" + NONE = "none" def __init__(self): # noqa: E501 """License - a model defined in OpenAPI diff --git a/server/openapi_server/models/text_annotation.py b/server/openapi_server/models/text_annotation.py index b9bcd68..0effae4 100644 --- a/server/openapi_server/models/text_annotation.py +++ b/server/openapi_server/models/text_annotation.py @@ -152,6 +152,8 @@ def confidence(self, confidence): :param confidence: The confidence of this TextAnnotation. :type confidence: float """ + if confidence is None: + raise ValueError("Invalid value for `confidence`, must not be `None`") # noqa: E501 if confidence is not None and confidence > 100: # noqa: E501 raise ValueError("Invalid value for `confidence`, must be a value less than or equal to `100`") # noqa: E501 if confidence is not None and confidence < 0: # noqa: E501 diff --git a/server/openapi_server/models/text_person_name_annotation.py b/server/openapi_server/models/text_person_name_annotation.py index 8bb6f8e..53bd37d 100644 --- a/server/openapi_server/models/text_person_name_annotation.py +++ b/server/openapi_server/models/text_person_name_annotation.py @@ -154,6 +154,8 @@ def confidence(self, confidence): :param confidence: The confidence of this TextPersonNameAnnotation. :type confidence: float """ + if confidence is None: + raise ValueError("Invalid value for `confidence`, must not be `None`") # noqa: E501 if confidence is not None and confidence > 100: # noqa: E501 raise ValueError("Invalid value for `confidence`, must be a value less than or equal to `100`") # noqa: E501 if confidence is not None and confidence < 0: # noqa: E501 diff --git a/server/openapi_server/openapi/openapi.yaml b/server/openapi_server/openapi/openapi.yaml index 52f9c8a..9cc18b0 100644 --- a/server/openapi_server/openapi/openapi.yaml +++ b/server/openapi_server/openapi/openapi.yaml @@ -5,19 +5,28 @@ info: name: The NLP Sandbox Team url: https://nlpsandbox.io description: | - # Overview + # Introduction + The Person Name Annotator is one of the first type of NLP Tools that can be benchmarked on [nlpsandbox.io](https://nlpsandbox.io). A Person Name Annotator takes as input a clinical note and outputs a list of predicted person name annotations found in the clinical note. This OpenAPI document describes the specification of a Person Name Annotator. This specification includes the schemas of the input and output data, and the conditions that this annotator must meet if you want to benchmark its performance on [nlpsandbox.io](https://nlpsandbox.io). + # Getting Started + The GitHub repository [nlpsandbox/person-name-annotator-example](https://github.com/nlpsandbox/person-name-annotator-example) provides a simple example implementation of a Python-Flask Person Name Annotator. By the end of the tutorial available in this repository, you will have built a Docker image for a simple Person Name Annotator. You will then be able to submit this image to [nlpsandbox.io](https://nlpsandbox.io) to benchmark its performance. + # Benchmarking Requirements + The following conditions must be met by your Person Name Annotator if you want to benchmark its performance on [nlpsandbox.io](https://nlpsandbox.io). + - The endpoint `/` must redirect to `/api/v1/tool`. + - The endpoint `/ui` must redirect to the web interface (UI). + - The output of this tool must be reproducible: a given input should always + generate the same output. - This NLP tool detects references of person names in the clinical note given - as input and returns a list of person name annotations. + - This tool must not attempt to connect to remote server for reproducibility, + robustness, and security reasons. When benchmarked on [nlpsandbox.io](https://nlpsandbox.io), + this tool will not be able to connect to remote servers. # Examples - - - [NLP Sandbox Person Name Annotator (Python)](https://github.com/nlpsandbox/person-name-annotator-example) + - [Person Name Annotator Example (Python)](https://github.com/nlpsandbox/person-name-annotator-example) license: name: Apache 2.0 url: https://github.com/nlpsandbox/nlpsandbox-schemas/blob/develop/LICENSE title: NLP Sandbox Person Name Annotator API - version: 1.0.0 + version: 1.0.1 x-logo: url: https://nlpsandbox.github.io/nlpsandbox-schemas/logo.png servers: @@ -290,6 +299,7 @@ components: minimum: 0 type: number required: + - confidence - length - start - text @@ -362,6 +372,7 @@ components: - ncsa - unlicense - zlib + - none example: apache-2.0 type: string ToolType: @@ -383,7 +394,7 @@ components: authorEmail: author@example.com url: https://example.com toolType: nlpsandbox:date-annotator - toolApiVersion: 1.0.0 + toolApiVersion: 1.0.1 properties: name: description: The tool name @@ -453,7 +464,7 @@ components: authorEmail: author@example.com url: https://example.com toolType: nlpsandbox:date-annotator - toolApiVersion: 1.0.0 + toolApiVersion: 1.0.1 - name: awesome-nlp-tool version: 1.0.6 license: apache-2.0 @@ -463,7 +474,7 @@ components: authorEmail: author@example.com url: https://example.com toolType: nlpsandbox:date-annotator - toolApiVersion: 1.0.0 + toolApiVersion: 1.0.1 properties: toolDependencies: description: A list of tools