-
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": "5d4e55f7-8329-4f4f-8a08-bd762691f6d9", "message_id": "1d72add8-926a-4437-878e-d7bcb3551f0d" }
- Error:
{ error_message: "Descriptive Message about why it failed to run" }
-
List All packages
-
GET request
-
NOTE:
Actual response depends on how we decide to handle the database schema. -
Request Params:
limit: xxx, //for pagination. How may results to return page: xxx, //for pagination. Which page are we looking at. i.e. beginning of returned set. Note: If "start" would be easier to implement, we can do that. order: xxx, //sort order of results search: xxx //place holder for if we decide to implement filtering or search
-
Response:
//will return an array of objects [ { package_id: "234221134", name: "Xnet Communities Package", author: "CADRE Team", created_date: "2019-08-22 13:37:15", tools: [ //Array of all tools and associated metadata. We do not want to have to query the tool set separately { tool_id: "11234221126", name: "xnet2_communities", author: "CADRE Team", description: "Sends query to xnet package.", output_files: ["result.xnet", ...] //example filenames. *May not be necessary in the future }, ... ], input_files: ["/dataset.csv", "/dataset_edges.csv", ...] //filenames/descriptions of packaged data sets }, .... ]
-
Response Codes:
- 200 - Success
- 400 - malformed request (missing field, etc)
- 401 - not logged in (request does not include auth headers)
- 404 - query returns 0 results
- 500 - server error
-
List all tools
-
GET request
-
NOTE:
Actual response depends on how we decide to handle the database schema. Virtually the same as the get packages endpoint. -
Request Params:
limit: xxx, //for pagination. How may results to return page: xxx, //for pagination. Which page are we looking at. i.e. beginning of returned set. Note: If "start" would be easier to implement, we can do that. order: xxx, //sort order of results search: xxx //place holder for if we decide to implement filtering or search
-
Response:
//will return an array of objects [ { tool_id: "11234221126", name: "xnet2_communities", author: "CADRE Team", description: "Sends query to xnet package.", output_files: ["result.xnet", ...] //example filenames. *May not be necessary in the future }, ... ]
-
Response Codes:
- 200 - Success
- 400 - malformed request (missing field, etc)
- 401 - not logged in (request does not include auth headers)
- 404 - query returns 0 results
- 500 - server error
- Gets list of all files/folder that a user has in his notebook. Includes package and query builder results.
- GET request
- Note: Only gets a single user's files based on header token
- Request Params: Note
- Response example:
[ { path: "/query-results", type: "folder" }, { path: "/query-results/JOBID1234.csv", type: "file", download_url: "https://xxxxxxxxxxx" //S3 bucket path or custom proxy url for downloading... however we decide to implement downloads }, { path: "/query-results/JOBID2345.csv", type: "file", download_url: "https://xxxxxxxxxxx" //S3 bucket path or custom proxy url for downloading... however we decide to implement downloads }, { path: "/packages", type: "folder" }, ... ]
- 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.