11 KiB
Welcome to Hello World SG4 documentation
Hello World SG4 is a RESTful application that exposes operations via REST-API.
See the available REST-API docs.
Base URL
In the production environment, its current value is
Authorization
D4Science adopts state-of-the-art industry standards for authentication and authorization. Specifically, the implementation fully adopts OIDC (OpenID Connect) for authentication and UMA 2 (User-Managed Authorization) for authorization flows. JSON Web Token (JWT) Access token are used for both authentication and authorization.
Obtain your Bearer token here: https://dev.d4science.org/how-to-access-resources
Service
You can call the methods of the Web Service by writing your REST client application or using existing REST client plugins.
HTTP Statuses
Any successful operation returns a 200 OK HTTP status code. The create operation returns 201 Created. Any Background operation returns 202 Accepted. Any operation that does not provide any content returns 204 No Content.
The most common error statuses a client can obtain are:
- 400 Bad Request used to indicate a clients error https://tools.ietf.org/html/rfc7231#section-6.5.1;
- 401 Unauthorized used to indicate that the client does not provide the authorization token in the HTTP Header or the client does not have enough right to perform such request https://tools.ietf.org/html/rfc7235#section-3.1;
- 404 Not Found used to indicate that the requested instance does not exist https://tools.ietf.org/html/rfc7231#section-6.5.4;
- 405 Method Not Allowed the used HTTP method is not supported for the requested URL https://tools.ietf.org/html/rfc7231#section-6.5.5. The response contains the Allow HTTP Header indicating the supported HTTP method for such URL https://tools.ietf.org/html/rfc7231#section-7.4.1;
- 409 Conflict the request could not be completed due to a conflict with the current state of the target resource (e.g. the name of the resource already exists) https://tools.ietf.org/html/rfc7231#section-6.5.8;
- 500 Internal Server Error indicate a server failure https://tools.ietf.org/html/rfc7231#section-6.6.1.
You can find a complete list of HTTP Status at https://httpstatuses.com/
If you get a 500 Internal Server Error, please report it in the gCube ticketing system.
Please use this checklist before reporting an error:
- Replicate the request;
- The failure could be temporal due to a network error, a server issue, and many other temporal issues. For this reason, please retry the request after a certain amount of time before reporting the issue;
- indicate how to replicate the error;
- indicate the time when the error occurred (this simplifies identifying the issue).
HTTP Methods
gCat is a pure RESTful service. It uses standard HTTP Methods to perform a listing of collections and CRUD (Create Read Update Delete) operations on instances.
|
HTTP Method | URL | Success HTTP Status |
|
Idempotent |
---|---|---|---|---|---|
Supported HTTP Methods | OPTIONS | /{COLLECTION} | 204 No Content 1 |
|
|
List | GET | /{COLLECTION} | 200 OK |
|
|
Count | GET | /{COLLECTION}?count=true | 200 OK |
|
|
Exists | HEAD | /{COLLECTION} | 204 No Content |
|
|
Create | POST | /{COLLECTION} | 201 Created |
|
|
Supported HTTP Methods | OPTIONS | /{COLLECTION}/{INSTANCE_ID} | 204 No Content 2 |
|
|
Exist | HEAD | /{COLLECTION}/{INSTANCE_ID} | 204 No Content |
|
|
Read | GET | /{COLLECTION}/{INSTANCE_ID} | 200 OK |
|
|
Update | PUT | /{COLLECTION}/{INSTANCE_ID} | 200 OK |
|
|
Patch | PATCH | /{COLLECTION}/{INSTANCE_ID} | 200 OK |
|
|
Delete | DELETE | /{COLLECTION}/{INSTANCE_ID} | 204 No Content |
|
|
Purge | DELETE | /{COLLECTION}/{INSTANCE_ID}?purge=true | 204 No Content |
|
|
PURGE | /{COLLECTION}/{INSTANCE_ID} | 204 No Content |
|
|
About URL
The presented URL uses the following convention:
- {COLLECTION} is the plural name of the entity type;
- {INSTANCE_ID} is an identification that enables univocally identifying the instance in the collection.
About Safety and Idempotency properties
- A method is Safe if it does not produce any side effects. "This does not prevent an implementation from including behaviour that is potentially harmful, that is not entirely read-only, or that causes side effects while invoking a safe method" https://tools.ietf.org/html/rfc7231#section-4.2.1;
- A method is Idempotent if the same operation repeated multiple times has the same side effect as using it one time. "repeating the request will have the same intended effect, even if the original request succeeded, though the response might differ" https://tools.ietf.org/html/rfc7231#section-4.2.2.
You can find more information about HTTP Methods at https://restfulapi.net/http-methods/
Uncommon HTTP Methods
- PATCH method allows to perform a differential update (i.e. an update which provides only the differences and not the whole new representation);
- PURGE method is not a standard but is widely used in services that
require this action (e.g. Varnish,
Squid).
gCat provides support for this method, but to support a wider range of
clients, it also provides the Purge action via DELETE with the
additional get parameter
purge=true
.
Content-Type
Any request must contain an indication of the interesting content type.
The client must specify the Accept HTTP Header for any operation returning a result.
Accept: application/json
For any operation sending content to the service, it is necessary to specify the Content-Type HTTP Header.
Content-Type: application/json
The service accepts and returns only JSON objects.
Collections
Roles
Java Client
We provide the following Java Client out-of-the-box.
Tip
If you're coding in Java, it is recommended that you use this Java Client.
Maven Coordinates
groupId>org.gcube.service</groupId>
<artifactId>helloworld-client</artifactId>
<version>[1.0.0-SNAPSHOT, 2.0.0-SNAPSHOT)</version> <
Methods Result
The service exposes its methods using a standard naming approach. Moreover, they accept (in the case of HTTP POST/PUT methods) JSON objects.
Important
The result of all methods is always a JSON object as per below:
{....
}
Inputs are automatically validated before the request is served.
Usage examples
- Example 1
import org.gcube....;
Service Discovery on IS
The service can be discovered in the gCore IS as gCore Endpoint with the following parameter:
ServiceClass>org.gcube.service</ServiceClass>
<ServiceName>helloworld</ServiceName> <
The service can be discovered in the Facet-Based IS as EService with the following JSON query:
{
"@class": "EService",
"consistsOf": [
{
"@class": "IsIdentifiedBy",
"target": {
"@class": "SoftwareFacet",
"group": "org.gcube.service",
"name": "helloworld"
}
}
]
}
Service Maven Coordinates
The maven coordinates of the Hello World SG4 service are:
groupId>org.gcube.service</groupId>
<artifactId>helloworld</artifactId> <