Project
A Project is the main resource of the Accounting System. The first step a user m ust follow is to create a project under which the metric data will belong.
Currently, we support only projects that are available in the EU database. Basi cally, we register information about a particular Project in our system using th e unique ID that every European Project has for its identification.
[POST] - Associate Providers with a specific Project
To be able to register Metrics in an installation, first you must associate a Pr oject with one or more Providers. The following action is responsible for gener ating a hierarchical relationship between a Project and one or more Providers:
POST /accounting-system/projects/{project_id}/associate
Content-Type: application-json
Authorization: Bearer {token}
{
"providers":[
"bioexcel",
"osmooc",
"grnet",
"sites"
]
}
The response is:
Success Response 200 OK
{
"code": 200,
"message": "The following providers [bioexcel, osmooc, grnet, sites] have bee
n associated with Project {project_id}"
}
[POST] - Dissociate Providers from a Project
You can also dissociate one or more Providers from a Project:
POST /accounting-system/projects/{project_id}/dissociate
Content-Type: application-json
Authorization: Bearer {token}
{
"providers":[
"grnet"
]
}
The response is :
Success Response 200 OK
{
"code": 200,
"message": "The following providers [grnet] have been dissociated from Projec
t {project_id}"
}
If there are Installations registered to Provider, the dissociation is not allow ed:
Error Response 409 CONFLICT
{
"code": 409,
"message": "Dissociation is not allowed. There are registered Installations t
o {project_id, provider_id}"
}
[GET] - Project Hierarchical Structure
You can retrieve the Providers and Installations associated with a specific proj ect:
GET /accounting-system/projects/{project_id}
Authorization: Bearer {token}
Basically, the hierarchical structure of a Project is returned:
Success Response 200 OK
{
"id": "725025",
"acronym": "AgeConsolidate",
"title": "The Missing Link of Episodic Memory Decline in Aging: The Role of
Inefficient Systems Consolidation",
"start_date": "2017-05-01",
"end_date": "2022-10-31",
"call_identifier": "ERC-2016-COG",
"providers": [
{
"id": "sites",
"name": "Swedish Infrastructure for Ecosystem Science",
"website": "https://www.fieldsites.se/en-GB",
"abbreviation": "SITES",
"logo": "https://dst15js82dk7j.cloudfront.net/231546/95187636-P5q11.png",
"installations": [
{
"id": "6350f13072dda00a3ce5f0cb",
"infrastructure": "infra-grnet-test",
"installation": "installation-grnet",
"unit_of_access": "6350f12772dda00a3ce5f0ca"
}
]
},
{
"id": "carlzeissm",
"name": "Carl Zeiss Microscopy",
"website": "https://www.zeiss.com/",
"abbreviation": "Carl Zeiss",
"logo": "https://images.zeiss.com/corporate-new/about-zeiss/history/images/logo/logo_heute.ts-1537187631211.jpg?auto=compress%2Cformat&fm=png&ixlib=java-1.1.11&w=640&s=982838e7e4ea9f38fde897b6a61a544b",
"installations": []
}
]
}
[GET] - Fetch all Projects
You can retrieve all Projects assigned to you by executing the following GET req uest:
GET /accounting-system/projects
Authorization: Bearer {token}
By default, the first page of 10 Projects will be returned. You can tune the def ault values by using the query parameters page and size as shown in the example below.
GET /accounting-system/projects?page=2&size=5
Authorization: Bearer {token}
Success Response 200 OK
{
"size_of_page": 10,
"number_of_page": 1,
"total_elements": 15,
"total_pages": 2,
"content": [
{
"id": "888743",
"acronym": "DABAT",
"title": "DNA-sensing by AIM2 in activated B cells: novel targets to
improve allogeneic haematopoietic stem cell
transplantation",
"start_date": "2020-10-01",
"end_date": "2023-09-30",
"call_identifier": "H2020-MSCA-IF-2019",
"providers": [
{
"id": "sites",
"name": "Swedish Infrastructure for Ecosystem Science",
"website": "https://www.fieldsites.se/en-GB",
"abbreviation": "SITES",
"logo": "https://dst15js82dk7j.cloudfront.net/231546/95187636-P5q11.png",
"installations": [
{
"id": "6351002527962d7967919fa7",
"infrastructure": "infra-grnet-test",
"installation": "installation-grnet",
"unit_of_access": "6351002027962d7967919fa6"
}
]
},
{
"id": "carlzeissm",
"name": "Carl Zeiss Microscopy",
"website": "https://www.zeiss.com/",
"abbreviation": "Carl Zeiss",
"logo": "https://images.zeiss.com/corporate-new/about-zeiss/history/images/logo/logo_heute.ts-1537187631211.jpg?auto=compress%2Cformat&fm=png&ixlib=java-1.1.11&w=640&s=982838e7e4ea9f38fde897b6a61a544b",
"installations": []
}
]
},
{
"id": "709328",
"acronym": "IN VIVO MOSSY",
"title": "Is the hippocampal mossy fiber synapse a detonator in
vivo?",
"start_date": "2016-04-01",
"end_date": "2018-03-31",
"call_identifier": "H2020-MSCA-IF-2015",
"providers": []
},
{
"id": "895916",
"acronym": "MXTRONICS",
"title": "MXene Nanosheets For Future Optoelectronic Devices",
"start_date": "2020-11-01",
"end_date": "2022-10-31",
"call_identifier": "H2020-MSCA-IF-2019",
"providers": [
{
"id": "ubora",
"name": "Open Biomedical Engineering e-platform for
Innovation through Education",
"website": "http://ubora-biomedical.org/",
"abbreviation": "UBORA",
"logo": "http://ubora-biomedical.org/wp-content/uploads/2017/01/UBORA-Logo-Final-JPEGb.jpg",
"installations": []
}
]
},
{
"id": "887530",
"acronym": "NONORMOPERA",
"title": "Sexual and Gender Non-Normativity in Opera after the
Second World War",
"start_date": "2020-11-01",
"end_date": "2024-05-02",
"call_identifier": "H2020-MSCA-IF-2019",
"providers": []
},
{
"id": "843702",
"acronym": "LCxLCProt",
"title": "Comprehensive two-dimensional liquid chromatography for
the characterization of protein biopharmaceuticals at
the protein level",
"start_date": "2020-01-01",
"end_date": "2020-12-31",
"call_identifier": "H2020-MSCA-IF-2018",
"providers": []
},
{
"id": "894897",
"acronym": "DEFORM",
"title": "Dead or Alive: Finding the Origin of Caldera Unrest
using Magma Reservoir Models",
"start_date": "2020-11-01",
"end_date": "2022-10-31",
"call_identifier": "H2020-MSCA-IF-2019",
"providers": []
},
{
"id": "895478",
"acronym": "ANACLETO",
"title": "Noise and drag reduction by riblets.",
"start_date": "2020-07-01",
"end_date": "2022-06-30",
"call_identifier": "H2020-MSCA-IF-2019",
"providers": []
},
{
"id": "894921",
"acronym": "PlaGE",
"title": "Playing at the Gateways of Europe: theatrical languages
and performatives practices in the Migrants' Reception
Centres of the Mediterranean Area",
"start_date": "2020-10-01",
"end_date": "2023-09-30",
"call_identifier": "H2020-MSCA-IF-2019",
"providers": []
},
{
"id": "654496",
"acronym": "NanoCytox",
"title": "Development of Novel Analytical Methods to assess
Nanoparticle cytotoxicity",
"start_date": "2015-11-01",
"end_date": "2017-10-31",
"call_identifier": "H2020-MSCA-IF-2014",
"providers": []
},
{
"id": "701538",
"acronym": "TransIt",
"title": "Translating science in the long Italian
Eighteenth-Century. The role of translators and publishers
as “cultural mediators” (1760-1790s)",
"start_date": "2017-02-01",
"end_date": "2019-01-31",
"call_identifier": "H2020-MSCA-IF-2015",
"providers": []
}
],
"links": [
{
"href": "http://localhost:8080/accounting-system/projects?page=1&size=10",
"rel": "first"
},
{
"href": "http://localhost:8080/accounting-system/projects?page=2&size=10",
"rel": "last"
},
{
"href": "http://localhost:8080/accounting-system/projects?page=1&size=10",
"rel": "self"
},
{
"href": "http://localhost:8080/accounting-system/projects?page=2&size=10",
"rel": "next"
}
]
}
[POST] - Access Control Entry for a specific Project
The general endpoint that is responsible for creating an Access Control entry fo r a Project is as follows:
POST /accounting-system/projects/{project_id}/acl/{who}
Content-Type: application/json
Authorization: Bearer {token}
{
"roles":[
{role_name}
]
}
where {who}
is the client ID in which the roles will be assigned.
The response is :
Success Response 200 OK
{
"code": 200,
"message": "Project Access Control was successfully created."
}
One client can have different roles at different Projects. For instance, in one Project can be an admin executing all the Project operations while in another it can only read the Project Metrics. Consequently, any client can have different responsibilities at different Projec ts. The actions the client can perform at each Project are determined by the rol e, and the permissions it has.
Keep in mind that to execute the above operation, you must have been assigne d a role containing the Project Acl permission.
[POST] - Search for Projects
You can search on Projects, to find the ones corresponding to the given search c riteria. Projects can be searched by executing the following request:
POST accounting-system/projects/search
Content-Type: application/json
Example 1
{
"type": "query",
"field": "title",
"values": "Functional and Molecular Characterisation of Breast Cancer Stem
Cells",
"operand": "eq"
}
Example 2
{
"type": "filter",
"operator": "OR",
"criteria": [
{
"type": "query",
"field": "title",
"values": "Functional and Molecular Characterisation of Breast Cancer Stem
Cells",
"operand": "eq"
},
{
"type": "query",
"field": "acronym",
"values": "El_CapiTun",
"operand": "eq"
}
]
}
The context of the request should be a JSON object. The syntax of the JSON object is described here. If the operation is successful, you get a list of projects
{
"size_of_page": 1,
"number_of_page": 1,
"total_elements": 1,
"total_pages": 1,
"content": [
{
"id": "655710",
"acronym": "CONRICONF",
"title": "Contentious Rights: A Comparative Study of International
Human Rights Norms and their Effects on Domestic Social
Conflict",
"start_date": "2016-01-17",
"end_date": "2020-02-08",
"call_identifier": "H2020-MSCA-IF-2014",
"providers": [
{
"id": "msw",
"name": "MyScienceWork",
"website": "https://www.mysciencework.com",
"abbreviation": "MSW",
"logo": "https://www.mysciencework.com/bundles/home/images/logo-secondary-medium.png?202012111405-56",
"installations": [
{
"id": "635111fcbc140d44766be86b",
"infrastructure": "okeanos-knossos-5",
"installation": "GRNET-KNS-5",
"unit_of_access": "635111dabc140d44766be86a"
}
]
},
{
"id": "meeo",
"name": "Meteorological Environmental Earth Observation",
"website": "https://www.meeo.it/",
"abbreviation": "MEEO",
"logo": "https://www.meeo.it/wp-content/uploads/2020/09/logo-meeo-dark2.svg",
"installations": []
}
]
}
],
"links": []
}
Otherwise, an empty response will be returned.
Errors
Please refer to section Errors to see all possible Errors.