-
Notifications
You must be signed in to change notification settings - Fork 0
API Endpoints
Return a 403 if the user performing the action does not have access to a particular data set
All endpoints should accept auth-token headers that can be validated by the authenticate-token auth endpoint
Errors (e.g. 403, 500, etc) should be accompanied by a json response body including an "error message" field
NOTE: Endpoints marked with * are not yet implemented
All endpoints found in https://github.com/iuni-cadre/cadre-login
- Request:
- Headers:
auth-token: token... auth-username: username
- Body:
{"username":"xxxxx"}
- Headers:
- Response:
- Headers:
x-cadre-auth-token
- Body
{ "user_id": ###, "roles": [ "role1", "role2" ] }
- Headers:
- Logs user out of CADRE system (not cilogin or cognito)
- Request:
- Headers:
auth-token: token...
- Body:
{"username":"xxxxx"}
- Headers:
- Response:
- 200
{'message': "Logout successful.", "username": "username"}
- 422
{'Error': 'Logout failed.'}
- 401
{'Error': 'Invalid user name provided'}
- 500
- 200
- from
login.cadre.iu.edu
- Callback from cognito for successful login
- Called after /auth/logout in order to log user out of cognito
Defined in middleware of https://github.com/iuni-cadre/cadre-data
- Request: Same as
/api/data/publications-sync
- Response:
{ "job_id": "5d4e55f7-8329-4f4f-8a08-bd762691f6d9", "message_id": "1d72add8-926a-4437-878e-d7bcb3551f0d" }
- Used for Preview queries
- Request:
- Headers
auth-token auth-username
- Body
{ dataset: "wos", // or "mag" etc filters: [ { field: 'year', value: '2007', operation: "AND" //or OR etc }, { field: 'author', value: 'Smith', operation: "" }, ... ], output: [ { type: 'single', field: 'paper_id' }, { type: 'single', field: 'year' }, { type: 'single', field: 'authors' }, { type: 'network', field: 'citations', degree: '2' } ] }
- Response
[ { "authors_display_name": "Thomas P. Shakespeare|Val Gebski|Val Gebski|Michael J. Veness|John Simes", "journal_display_name": "The Lancet", "original_title": "Improving interpretation of clinical studies by use of confidence levels, clinical significance curves, and risk-benefit contours", "paper_id": "2119126196", "year": "2001" }, { "authors_display_name": "Kobashi Yukari|Ebi Junsuke", "journal_display_name": null, "original_title": "ELECTRONIC DEVICE PROVIDED WITH CONTROL FUNCTION OF DIGITAL INTERFACE AND CRYPTANALYTIC FUNCTION", "paper_id": "2868304693", "year": "2001" }, ... ]
- Headers
These are all in the backend of the Interface Repo https://github.com/iuni-cadre/cadre-interface
- List Jobs for the current user
-
Runs a package by sending a job to the SQS queue
-
Request:
{ package_id: xxx, output_filename: [xxx, xxx, ...] }
-
Response:
{ job_id: xxx, job_status: xxx }
-
Error:
{ error_message: "Descriptive Message about why it failed to run" }
-
List All packages
-
NOTE: Actual response depends on how we decide to handle the database schema
-
Request:
{ limit: xxx, page: xxx, order: xxx, search: xxx }
-
Response:
[ { package_id: "xxxxx", name: "xxxxx", author: "xxxx", created_date: "2019-07-16 10:51:26", tools: ["tool 1", "tool 2"], input_files: ["/dataset.csv"] }, .... ]
- Create a new notebook server for a given user
- Proxy for the Kubernates endpoint
- Gets the status of a user's notebook
- Proxy for the Kubernates endpoint
- Get a new notebook token for a given user
- Proxy for the Kubernates endpoint
- List jobs for specific user
- Get metadata including status for a specific job
- Create a new package
- List teams for current user
- Get metadata for specific team
- Create a new team
- 403 if the user does not have access to the datasets used by the team
- 404 if the user doesn't exist
- List datasets that the current user has access to
- List current user's available notebooks (for user and team)
- Get specific user's notebooks
- Get notebooks for a specific team
- Get metadata for a specific notebook
- List data assets (query results, etc) for the current user
- Get list of assets for a specific data set (wos, mag, etc)
- Copy a data asset to a specific notebook.
- Updates list of datasets that the notebook contains
- 403 if notebook does not have access to the data set
- List all institutions
- Get metadata for specific institution, including which datasets they have access to.