Request Tracking Api
The purpose of this projects is to manage apis for request tracking.
Prerequisites
- Node.js (v8.11.2) - https://nodejs.org/en/download/
npm install -g lsc
- Makes sure your
config.json
has a billing object with akey
offacilityID
and a value of the enviorment you will work in such asmyrtb-ci
- The facilityID's can be
myrtb-ci
,myrtb-qa
, andmyrtb
- The facilityID's can be
Example config.json:
{
"storage": {
"proxy": "auto"
},
"session": {
"facilityPath":"/"
},
"facility": {
"ServiceUrl": "https://example.exam.nih.gov/v3",
"facilityPath": "/",
"spfacility": {
"User": "aws\\ExampleUser",
"Password": "Password12345",
"Strategy": "hybrid",
"CustomStrategyPrefix": "i:0ǵ.t",
"Site": "https://myrtb-ci-default.aws.labshare.org",
"CustomStrategyName": "labshare"
},
"FacilityDB": "@labshare/spfacility",
"Facilities": {
"Type": "file",
"Settings": {
"Path": "./facilities.json"
}
}
},
"shell": {
"LoadServices": true,
"Auth": {
"Url": "https://a.labshare.org/_api"
}
},
"billing": {
"facilityID": "myrtb-ci"
}
}
Running
To run the project, simply run the following command from the root of the repository:
$ lsc start services
Billing Api
Every endpoint other than the /billing
endpoint needs this request body.
{
"chargeList": String,
"section":[{
"sectionName":String,
"listNames": [String]
}],
"endDate": String,
"status": String
}
Example:
{
"chargeList": "RTB-Charges-FY18",
"section":[{
"sectionName":"myrtb-ci-bis",
"listNames": ["Reservations","PosterPrinter"]
},{
"sectionName":"myrtb-ci-fcs",
"listNames": ["charges","reservations","flowjo billing"]
}],
"endDate": "10/31/2019",
"status": "readytobill"
}
Note if section
is an empty array it will run though all billing sections and lists.