From 1561d74519a3300951aa7a7d988d9098f77b1e06 Mon Sep 17 00:00:00 2001 From: tschaffter Date: Thu, 25 Feb 2021 15:51:37 -0800 Subject: [PATCH 1/5] Update README and package.json --- README.md | 5 ++--- docker-compose.yml | 2 +- package.json | 3 ++- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/README.md b/README.md index 2e25e62..c4756b1 100644 --- a/README.md +++ b/README.md @@ -5,7 +5,6 @@ [![GitHub License](https://img.shields.io/github/license/nlpsandbox/date-annotator-example-java.svg?color=94398d&labelColor=555555&logoColor=ffffff&style=for-the-badge&logo=github)](https://github.com/nlpsandbox/date-annotator-example-java/blob/develop/LICENSE) [![Docker Pulls](https://img.shields.io/docker/pulls/nlpsandbox/date-annotator-example-java.svg?color=94398d&labelColor=555555&logoColor=ffffff&style=for-the-badge&label=pulls&logo=docker)](https://hub.docker.com/r/nlpsandbox/date-annotator-example-java) [![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/date-annotator/leaderboards "View the performance of this NLP Tool on nlpsandbox.io") Example implementation of the [NLP Sandbox Date Annotator] @@ -18,8 +17,8 @@ and outputs a list of predicted date annotations found in the clinical note. ### Specification -- Date Annotator API version: 1.0.0 -- Tool version: 1.0.0 +- Date Annotator API version: 1.0.1 +- Tool version: 1.0.1 - Docker image: [nlpsandbox/date-annotator-example-java] ## Model diff --git a/docker-compose.yml b/docker-compose.yml index 89395b7..a0a9505 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -2,7 +2,7 @@ version: "3.8" services: date-annotator: - image: nlpsandbox/date-annotator-example-java:1.0.0 + image: nlpsandbox/date-annotator-example-java:1.0.1 build: context: server dockerfile: Dockerfile diff --git a/package.json b/package.json index d89778b..d2667a5 100644 --- a/package.json +++ b/package.json @@ -3,6 +3,7 @@ "@openapitools/openapi-generator-cli": "2.1.23" }, "scripts": { - "generate:server": "openapi-generator-cli generate -g spring -o server -i $npm_config_specification" + "generate:server": "openapi-generator-cli generate -g spring -o server -i $npm_config_specification", + "generate:server:latest": "openapi-generator-cli generate -g spring -o server -i https://nlpsandbox.github.io/nlpsandbox-schemas/physical-address-annotator/latest/openapi.json" } } From d4588639cbcc2bd29ace35db40eb260a9aee40bd Mon Sep 17 00:00:00 2001 From: tschaffter Date: Thu, 25 Feb 2021 15:53:18 -0800 Subject: [PATCH 2/5] Fix new npm run script --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index d2667a5..4423100 100644 --- a/package.json +++ b/package.json @@ -4,6 +4,6 @@ }, "scripts": { "generate:server": "openapi-generator-cli generate -g spring -o server -i $npm_config_specification", - "generate:server:latest": "openapi-generator-cli generate -g spring -o server -i https://nlpsandbox.github.io/nlpsandbox-schemas/physical-address-annotator/latest/openapi.json" + "generate:server:latest": "openapi-generator-cli generate -g spring -o server -i https://nlpsandbox.github.io/nlpsandbox-schemas/date-annotator/latest/openapi.json" } } From d9fd5f537be924128207c327b0d65e62ca361743 Mon Sep 17 00:00:00 2001 From: tschaffter Date: Thu, 25 Feb 2021 15:57:04 -0800 Subject: [PATCH 3/5] Re-generate tool for API version 1.0.1 --- server/pom.xml | 2 +- .../java/org/openapitools/api/HealthCheckApiController.java | 2 +- .../openapitools/api/TextDateAnnotationsApiController.java | 2 +- .../main/java/org/openapitools/api/ToolApiController.java | 2 +- .../configuration/OpenAPIDocumentationConfig.java | 6 +++--- server/src/main/java/org/openapitools/model/Error.java | 2 +- .../src/main/java/org/openapitools/model/HealthCheck.java | 2 +- server/src/main/java/org/openapitools/model/License.java | 4 +++- server/src/main/java/org/openapitools/model/Note.java | 2 +- .../main/java/org/openapitools/model/TextAnnotation.java | 5 +++-- .../java/org/openapitools/model/TextDateAnnotation.java | 5 +++-- .../org/openapitools/model/TextDateAnnotationAllOf.java | 2 +- .../org/openapitools/model/TextDateAnnotationRequest.java | 2 +- .../org/openapitools/model/TextDateAnnotationResponse.java | 2 +- server/src/main/java/org/openapitools/model/Tool.java | 2 +- .../main/java/org/openapitools/model/ToolDependencies.java | 2 +- 16 files changed, 24 insertions(+), 20 deletions(-) diff --git a/server/pom.xml b/server/pom.xml index 08af9c9..4e29c00 100644 --- a/server/pom.xml +++ b/server/pom.xml @@ -4,7 +4,7 @@ openapi-spring jar openapi-spring - 1.0.0 + 1.0.1 1.8 ${java.version} diff --git a/server/src/main/java/org/openapitools/api/HealthCheckApiController.java b/server/src/main/java/org/openapitools/api/HealthCheckApiController.java index a40e80b..60b195f 100644 --- a/server/src/main/java/org/openapitools/api/HealthCheckApiController.java +++ b/server/src/main/java/org/openapitools/api/HealthCheckApiController.java @@ -4,7 +4,7 @@ import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.context.request.NativeWebRequest; import java.util.Optional; -@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-12T21:49:56.981797-08:00[America/Los_Angeles]") +@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-25T15:53:35.186246-08:00[America/Los_Angeles]") @Controller @RequestMapping("${openapi.nLPSandboxDateAnnotator.base-path:/api/v1}") public class HealthCheckApiController implements HealthCheckApi { diff --git a/server/src/main/java/org/openapitools/api/TextDateAnnotationsApiController.java b/server/src/main/java/org/openapitools/api/TextDateAnnotationsApiController.java index e0fe5bf..a091334 100644 --- a/server/src/main/java/org/openapitools/api/TextDateAnnotationsApiController.java +++ b/server/src/main/java/org/openapitools/api/TextDateAnnotationsApiController.java @@ -4,7 +4,7 @@ import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.context.request.NativeWebRequest; import java.util.Optional; -@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-12T21:49:56.981797-08:00[America/Los_Angeles]") +@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-25T15:53:35.186246-08:00[America/Los_Angeles]") @Controller @RequestMapping("${openapi.nLPSandboxDateAnnotator.base-path:/api/v1}") public class TextDateAnnotationsApiController implements TextDateAnnotationsApi { diff --git a/server/src/main/java/org/openapitools/api/ToolApiController.java b/server/src/main/java/org/openapitools/api/ToolApiController.java index e2ea623..11627b5 100644 --- a/server/src/main/java/org/openapitools/api/ToolApiController.java +++ b/server/src/main/java/org/openapitools/api/ToolApiController.java @@ -4,7 +4,7 @@ import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.context.request.NativeWebRequest; import java.util.Optional; -@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-12T21:49:56.981797-08:00[America/Los_Angeles]") +@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-25T15:53:35.186246-08:00[America/Los_Angeles]") @Controller @RequestMapping("${openapi.nLPSandboxDateAnnotator.base-path:/api/v1}") public class ToolApiController implements ToolApi { diff --git a/server/src/main/java/org/openapitools/configuration/OpenAPIDocumentationConfig.java b/server/src/main/java/org/openapitools/configuration/OpenAPIDocumentationConfig.java index f0a4b94..1b58375 100644 --- a/server/src/main/java/org/openapitools/configuration/OpenAPIDocumentationConfig.java +++ b/server/src/main/java/org/openapitools/configuration/OpenAPIDocumentationConfig.java @@ -17,7 +17,7 @@ import javax.servlet.ServletContext; -@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-14T20:17:34.317816-08:00[America/Los_Angeles]") +@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-25T15:53:35.186246-08:00[America/Los_Angeles]") @Configuration @EnableSwagger2 public class OpenAPIDocumentationConfig { @@ -25,11 +25,11 @@ public class OpenAPIDocumentationConfig { ApiInfo apiInfo() { return new ApiInfoBuilder() .title("NLP Sandbox Date Annotator API") - .description("# Overview This NLP tool detects references of dates in the clinical note given as input and returns a list of date annotations. # Examples - [NLP Sandbox Date Annotator (Python)](https://github.com/nlpsandbox/date-annotator-example) - [NLP Sandbox Date Annotator (Java)](https://github.com/nlpsandbox/date-annotator-example-java) ") + .description("# Introduction The Date Annotator is one of the first type of NLP Tools that can be benchmarked on [nlpsandbox.io](https://nlpsandbox.io). A Date Annotator takes as input a clinical note and outputs a list of predicted date annotations found in the clinical note. This OpenAPI document describes the specification of a Date 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/date-annotator-example](https://github.com/nlpsandbox/date-annotator-example) provides a simple example implementation of a Python-Flask Date Annotator. By the end of the tutorial available in this repository, you will have built a Docker image for a simple Date 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 Date 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 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 - [Date Annotator Example (Python)](https://github.com/nlpsandbox/date-annotator-example) - [Date Annotator Example (Java)](https://github.com/nlpsandbox/date-annotator-example-java) ") .license("Apache 2.0") .licenseUrl("https://github.com/nlpsandbox/nlpsandbox-schemas/blob/develop/LICENSE") .termsOfServiceUrl("https://nlpsandbox.io") - .version("1.0.0") + .version("1.0.1") .contact(new Contact("","", "thomas.schaffter@sagebionetworks.org")) .build(); } diff --git a/server/src/main/java/org/openapitools/model/Error.java b/server/src/main/java/org/openapitools/model/Error.java index 7ee852c..e7e68b5 100644 --- a/server/src/main/java/org/openapitools/model/Error.java +++ b/server/src/main/java/org/openapitools/model/Error.java @@ -13,7 +13,7 @@ * Problem details (tools.ietf.org/html/rfc7807) */ @ApiModel(description = "Problem details (tools.ietf.org/html/rfc7807)") -@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-14T20:17:34.317816-08:00[America/Los_Angeles]") +@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-25T15:53:35.186246-08:00[America/Los_Angeles]") public class Error { @JsonProperty("title") private String title; diff --git a/server/src/main/java/org/openapitools/model/HealthCheck.java b/server/src/main/java/org/openapitools/model/HealthCheck.java index 4f36a53..d703620 100644 --- a/server/src/main/java/org/openapitools/model/HealthCheck.java +++ b/server/src/main/java/org/openapitools/model/HealthCheck.java @@ -14,7 +14,7 @@ * Represents the health of a service */ @ApiModel(description = "Represents the health of a service") -@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-14T20:17:34.317816-08:00[America/Los_Angeles]") +@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-25T15:53:35.186246-08:00[America/Los_Angeles]") public class HealthCheck { /** * Indicates whether the service status is acceptable or not diff --git a/server/src/main/java/org/openapitools/model/License.java b/server/src/main/java/org/openapitools/model/License.java index 2a8a2af..df4ffd4 100644 --- a/server/src/main/java/org/openapitools/model/License.java +++ b/server/src/main/java/org/openapitools/model/License.java @@ -80,7 +80,9 @@ public enum License { UNLICENSE("unlicense"), - ZLIB("zlib"); + ZLIB("zlib"), + + NONE("none"); private String value; diff --git a/server/src/main/java/org/openapitools/model/Note.java b/server/src/main/java/org/openapitools/model/Note.java index 8762206..dc6e29d 100644 --- a/server/src/main/java/org/openapitools/model/Note.java +++ b/server/src/main/java/org/openapitools/model/Note.java @@ -13,7 +13,7 @@ * A clinical note */ @ApiModel(description = "A clinical note") -@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-14T20:17:34.317816-08:00[America/Los_Angeles]") +@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-25T15:53:35.186246-08:00[America/Los_Angeles]") public class Note { @JsonProperty("identifier") private String identifier; diff --git a/server/src/main/java/org/openapitools/model/TextAnnotation.java b/server/src/main/java/org/openapitools/model/TextAnnotation.java index c395644..1f26309 100644 --- a/server/src/main/java/org/openapitools/model/TextAnnotation.java +++ b/server/src/main/java/org/openapitools/model/TextAnnotation.java @@ -13,7 +13,7 @@ * An annotation in a text */ @ApiModel(description = "An annotation in a text") -@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-14T20:17:34.317816-08:00[America/Los_Angeles]") +@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-25T15:53:35.186246-08:00[America/Los_Angeles]") public class TextAnnotation { @JsonProperty("start") private Integer start; @@ -101,7 +101,8 @@ public TextAnnotation confidence(Float confidence) { * maximum: 100 * @return confidence */ - @ApiModelProperty(value = "The confidence in the accuracy of the annotation") + @ApiModelProperty(required = true, value = "The confidence in the accuracy of the annotation") + @NotNull @DecimalMin("0") @DecimalMax("100") public Float getConfidence() { diff --git a/server/src/main/java/org/openapitools/model/TextDateAnnotation.java b/server/src/main/java/org/openapitools/model/TextDateAnnotation.java index 2864ee0..2b5f53c 100644 --- a/server/src/main/java/org/openapitools/model/TextDateAnnotation.java +++ b/server/src/main/java/org/openapitools/model/TextDateAnnotation.java @@ -15,7 +15,7 @@ * A date annotation in a text */ @ApiModel(description = "A date annotation in a text") -@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-14T20:17:34.317816-08:00[America/Los_Angeles]") +@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-25T15:53:35.186246-08:00[America/Los_Angeles]") public class TextDateAnnotation { @JsonProperty("start") private Integer start; @@ -106,7 +106,8 @@ public TextDateAnnotation confidence(Float confidence) { * maximum: 100 * @return confidence */ - @ApiModelProperty(value = "The confidence in the accuracy of the annotation") + @ApiModelProperty(required = true, value = "The confidence in the accuracy of the annotation") + @NotNull @DecimalMin("0") @DecimalMax("100") public Float getConfidence() { diff --git a/server/src/main/java/org/openapitools/model/TextDateAnnotationAllOf.java b/server/src/main/java/org/openapitools/model/TextDateAnnotationAllOf.java index a0ef024..7025214 100644 --- a/server/src/main/java/org/openapitools/model/TextDateAnnotationAllOf.java +++ b/server/src/main/java/org/openapitools/model/TextDateAnnotationAllOf.java @@ -12,7 +12,7 @@ /** * TextDateAnnotationAllOf */ -@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-14T20:17:34.317816-08:00[America/Los_Angeles]") +@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-25T15:53:35.186246-08:00[America/Los_Angeles]") public class TextDateAnnotationAllOf { @JsonProperty("dateFormat") private String dateFormat; diff --git a/server/src/main/java/org/openapitools/model/TextDateAnnotationRequest.java b/server/src/main/java/org/openapitools/model/TextDateAnnotationRequest.java index d508cc5..3737c43 100644 --- a/server/src/main/java/org/openapitools/model/TextDateAnnotationRequest.java +++ b/server/src/main/java/org/openapitools/model/TextDateAnnotationRequest.java @@ -14,7 +14,7 @@ * A request to annotate dates in a clinical note */ @ApiModel(description = "A request to annotate dates in a clinical note") -@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-14T20:17:34.317816-08:00[America/Los_Angeles]") +@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-25T15:53:35.186246-08:00[America/Los_Angeles]") public class TextDateAnnotationRequest { @JsonProperty("note") private Note note; diff --git a/server/src/main/java/org/openapitools/model/TextDateAnnotationResponse.java b/server/src/main/java/org/openapitools/model/TextDateAnnotationResponse.java index 0d1d5b2..875cc74 100644 --- a/server/src/main/java/org/openapitools/model/TextDateAnnotationResponse.java +++ b/server/src/main/java/org/openapitools/model/TextDateAnnotationResponse.java @@ -16,7 +16,7 @@ * The response to a dates annotation request */ @ApiModel(description = "The response to a dates annotation request") -@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-14T20:17:34.317816-08:00[America/Los_Angeles]") +@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-25T15:53:35.186246-08:00[America/Los_Angeles]") public class TextDateAnnotationResponse { @JsonProperty("textDateAnnotations") @Valid diff --git a/server/src/main/java/org/openapitools/model/Tool.java b/server/src/main/java/org/openapitools/model/Tool.java index 2a7f35e..82531ae 100644 --- a/server/src/main/java/org/openapitools/model/Tool.java +++ b/server/src/main/java/org/openapitools/model/Tool.java @@ -15,7 +15,7 @@ * Information about an NLP tool */ @ApiModel(description = "Information about an NLP tool") -@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-14T20:17:34.317816-08:00[America/Los_Angeles]") +@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-25T15:53:35.186246-08:00[America/Los_Angeles]") public class Tool { @JsonProperty("name") private String name; diff --git a/server/src/main/java/org/openapitools/model/ToolDependencies.java b/server/src/main/java/org/openapitools/model/ToolDependencies.java index d8f3244..ceedd2d 100644 --- a/server/src/main/java/org/openapitools/model/ToolDependencies.java +++ b/server/src/main/java/org/openapitools/model/ToolDependencies.java @@ -16,7 +16,7 @@ * A list of tool dependencies */ @ApiModel(description = "A list of tool dependencies") -@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-14T20:17:34.317816-08:00[America/Los_Angeles]") +@javax.annotation.Generated(value = "org.openapitools.codegen.languages.SpringCodegen", date = "2021-02-25T15:53:35.186246-08:00[America/Los_Angeles]") public class ToolDependencies { @JsonProperty("toolDependencies") @Valid From e6a8db8eb31b99bade9cbb5d4da4beb2672678e3 Mon Sep 17 00:00:00 2001 From: tschaffter Date: Thu, 25 Feb 2021 15:57:49 -0800 Subject: [PATCH 4/5] Update API and tool version in Tool object --- server/src/main/java/org/openapitools/api/ToolApi.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/server/src/main/java/org/openapitools/api/ToolApi.java b/server/src/main/java/org/openapitools/api/ToolApi.java index 87946d6..098a91d 100644 --- a/server/src/main/java/org/openapitools/api/ToolApi.java +++ b/server/src/main/java/org/openapitools/api/ToolApi.java @@ -56,7 +56,7 @@ default Optional getRequest() { default ResponseEntity getTool() { Tool tool = new Tool() .name("date-annotator-example-java") - .version("1.0.0") + .version("1.0.1") .license(License.APACHE_2_0) .repository("github:nlpsandbox/date-annotator-example-java") .description("Example implementation of the NLP Sandbox Date Annotator") @@ -64,7 +64,7 @@ default ResponseEntity getTool() { .authorEmail("thomas.schaffter@sagebionetworks.org") .url(URI.create("https://github.com/nlpsandbox/date-annotator-example-java")) .toolType("nlpsandbox:date-annotator") - .toolApiVersion("1.0.0"); + .toolApiVersion("1.0.1"); return new ResponseEntity(tool, HttpStatus.OK); } From bf6311d276c75c8b6c21268511b416c85bc2670e Mon Sep 17 00:00:00 2001 From: tschaffter Date: Thu, 25 Feb 2021 16:04:24 -0800 Subject: [PATCH 5/5] Update tool version in Dockerfile and remove info.description in openapi.yaml --- server/Dockerfile | 2 +- .../openapitools/configuration/OpenAPIDocumentationConfig.java | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/server/Dockerfile b/server/Dockerfile index 0ceda3a..cf22ac3 100644 --- a/server/Dockerfile +++ b/server/Dockerfile @@ -1,7 +1,7 @@ FROM python:3.9.1-slim-buster ENV APP_DIR=/opt/app -ENV APP_VERSION="1.0.0" +ENV APP_VERSION="1.0.1" SHELL ["/bin/bash", "-euxo", "pipefail", "-c"] diff --git a/server/src/main/java/org/openapitools/configuration/OpenAPIDocumentationConfig.java b/server/src/main/java/org/openapitools/configuration/OpenAPIDocumentationConfig.java index 1b58375..4210d08 100644 --- a/server/src/main/java/org/openapitools/configuration/OpenAPIDocumentationConfig.java +++ b/server/src/main/java/org/openapitools/configuration/OpenAPIDocumentationConfig.java @@ -25,7 +25,7 @@ public class OpenAPIDocumentationConfig { ApiInfo apiInfo() { return new ApiInfoBuilder() .title("NLP Sandbox Date Annotator API") - .description("# Introduction The Date Annotator is one of the first type of NLP Tools that can be benchmarked on [nlpsandbox.io](https://nlpsandbox.io). A Date Annotator takes as input a clinical note and outputs a list of predicted date annotations found in the clinical note. This OpenAPI document describes the specification of a Date 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/date-annotator-example](https://github.com/nlpsandbox/date-annotator-example) provides a simple example implementation of a Python-Flask Date Annotator. By the end of the tutorial available in this repository, you will have built a Docker image for a simple Date 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 Date 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 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 - [Date Annotator Example (Python)](https://github.com/nlpsandbox/date-annotator-example) - [Date Annotator Example (Java)](https://github.com/nlpsandbox/date-annotator-example-java) ") + .description("") .license("Apache 2.0") .licenseUrl("https://github.com/nlpsandbox/nlpsandbox-schemas/blob/develop/LICENSE") .termsOfServiceUrl("https://nlpsandbox.io")