Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added OpenAPI specification from Calycopis-broker #91

Merged
merged 1 commit into from
Nov 21, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
80 changes: 75 additions & 5 deletions ExecutionBroker.tex
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
\newcommand{\http} {HTTP}
\newcommand{\rest} {REST}

\newcommand{\openapi} {OpenAPI}
\newcommand{\datamodel} {data~model}
\newcommand{\webservice} {web service}
\newcommand{\webbrowser} {web browser}
Expand Down Expand Up @@ -265,7 +266,7 @@ \subsection{Role within the VO Architecture}
In response to the increasing size and complexity of the next generation of science \dataset{s}
a number of \ivoa{} members are developing intergrated \scienceplatform{s} which bring
together the \dataset{s} co-located with the compute resources needed to analyse
them.\footurl{https://data.lsst.cloud/}\footurl{https://rsp.lsst.io/index.html}
them.\footurl{https://data.lsst.cloud/}\footurl{https://rsp.lsst.io/}

These \scienceplatform{s} make extensive use of the \ivoa{} data models and
vocabularies to describe their \dataset{s}, and use the \ivoa{} data access
Expand All @@ -283,10 +284,79 @@ \subsection{Role within the VO Architecture}
resource allocation and execution scheduling across a heterogeneous federation
of execution platforms.

\ivoa{} \executionbroker{} services may use the
\ivoa{} Single-Sign-On standard \citep{2017ivoa.spec.0524T}
for authentication (see section xx) %\ref{subsec:authentication}
and the
\subsection{Supplementary documents}
\label{supplementary-documents}

\subsubsection{\openapi{} specification}
\label{openapi-specification}

This document is designed to read in combination with the \openapi{}
\footurl{https://www.openapis.org/} \footurl{https://swagger.io/specification/}
specification published alongside this document.

The \openapi{} specification defines the technical details of the
\executionbroker{} \webservice{} interface and the schema for the
\executionbroker{} \datamodel{}.
This document compliments the technical specification by using use cases
and specific examples to describe the intended service behaviour and
explain the reasoning behind some of the design choices.

The two documents are intended to be read together.
The machine-readable \openapi{} spcification defining the \textit{what},
and the human-readable text document describing the \textit{why}.

The \openapi{} specification associated with this document is
published in the following files:
\begin{itemize}
\item \codeword{openapi.yaml} - The main service specification, including
the \executionbroker{} service API and the core data model.
\item \codeword{messages.yaml} - a supplimentary data model for INFO, WARN,
and DEBUG messages embedded in the service responses.
\item \codeword{utils.yaml} - a supplimentary data model for re-usable
components such as ISO date formats, min/max pairs, and name-value maps.
\end{itemize}

This text document may include small examples of \openapi{} schema to
explain specific points, but these are for information only. Unless otherwise
specified, the \openapi{} specification itself should be assumed to be the
definitive source and this text document should be considered as secondary.

\subsubsection{IVOA profiles}
\label{ivoa-profiles}

This specification refers to the following documents
to cover the details of how an \executionbroker{} \webservice{}
should use the following protocols and data formats:
\begin{itemize}
\item The \ivoa{} \rest{} profile, describing a common pattern
for \ivoa{} \webservice{s} that implement
\rest{}\footurl{https://en.wikipedia.org/wiki/REST}
webservices.
\item The \ivoa{} \http{} profile, describing how \ivoa{} \webservice{s}
should use aspects of the \http{} protocol, including \http{} parameters,
message content, content negotiation, and \http{} return codes.
\item The \ivoa{} error messages profile, describing a common format
for \ivoa{} \webservice{s} to format error messages.
\item The \ivoa{} \json{} profile, describing how \ivoa{} \webservice{s}
should serialize message content using the
\json{}\footurl{https://www.json.org/json-en.html} data format.
\item The \ivoa{} \yaml{} profile, describing how \ivoa{} \webservice{s}
should serialize message content using the
\yaml{}\footurl{https://yaml.org/} data format.
\item The \ivoa{} \xml{} profile, describing how \ivoa{} \webservice{s}
should serialize message content using the
\xml{}\footurl{https://www.w3.org/XML/} data format.
\end{itemize}

Unless otherwise specified, an \executionbroker{} \webservice{} implementation
should follow the guidelines outined in these documents.

\subsubsection{IVOA Single-Sign-On}
\label{ivoa-sso}

In addition, an \ivoa{} \executionbroker{} service may use parts of the
\ivoa{} Single-Sign-On standard\citep{2017ivoa.spec.0524T}
for authentication, and the
\ivoa{} Credential Delegation Protocol \citep{2010ivoa.spec.0218P}
for delegating credentials to other services.

Expand Down
39 changes: 39 additions & 0 deletions openapi/components/components.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
#
# <meta:header>
# <meta:licence>
# Copyright (c) 2024, Manchester University (http://www.manchester.ac.uk/)
#
# This work is made available under the Creative Commons
# Attribution-ShareAlike 4.0 International licence.
#
# For details of the licence terms see:
# https://creativecommons.org/licenses/by-sa/4.0/
# </meta:licence>
# </meta:header>
#
# AIMetrics: [
# {
# "name": "ChatGPT",
# "contribution": {
# "value": 5,
# "units": "%"
# }
# }
# ]
#

openapi: 3.1.0
info:
title: IVOA ExecutionBroker abstract components
version: "0.8"
summary: IVOA ExecutionBroker abstract components
description: >
Abstract components used in the IVOA ExecutionBroker data model
contact:
name: Zarquan
url: https://github.com/Zarquan

components:
schemas:


95 changes: 95 additions & 0 deletions openapi/components/messages.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,95 @@
#
# <meta:header>
# <meta:licence>
# Copyright (c) 2024, Manchester University (http://www.manchester.ac.uk/)
#
# This work is made available under the Creative Commons
# Attribution-ShareAlike 4.0 International licence.
#
# For details of the licence terms see:
# https://creativecommons.org/licenses/by-sa/4.0/
# </meta:licence>
# </meta:header>
#
# AIMetrics: [
# {
# "name": "ChatGPT",
# "contribution": {
# "value": 5,
# "units": "%"
# }
# }
# ]
#

openapi: 3.1.0
info:
title: IVOA ExecutionBroker log messages
version: "1.0"
summary: IVOA ExecutionBroker log messages
description: >
Log messages used in IVOA ExecutionBroker responses
contact:
name: Zarquan
url: https://github.com/Zarquan

components:
schemas:

MessageItem:
description: >
A log message based on the Message Templates standard.
https://messagetemplates.org/
type: object
title: MessageItem
xml:
name: message
properties:
type:
description: >
The message type identifier.
Typically a URL pointing to a human readable description of the message.
type: string
time:
description: >
The date and time of the message.
type: string
format: date-time
level:
description: >
The message level.
type: string
enum:
- "DEBUG"
- "WARN"
- "ERROR"
- "INFO"
- "OTHER"
template:
description: >
The message template.
type: string
values:
description: >
A map of name->value properties.
xml:
name: values
$ref: './utils.yaml#/components/schemas/NameValueMap'
message:
description: >
The resulting message.
type: string

MessageList:
description: >
A list of log messages.
xml:
name: messages
type: array
title: MessageList
items:
$ref: '#/components/schemas/MessageItem'
xml:
name: message


Loading
Loading