-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathexample-config.js
141 lines (123 loc) · 4.65 KB
/
example-config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
/**
* FHIR Date parameter to be used in the query strings below.
*/
const SINCE = "2018-01-01T05:00:00.000Z"
/**
* Client settings for Bulk Data export
*/
const bulkClient = {
baseUrl : "BULK DATA SERVER BASE URL",
clientId : "BULK DATA CLIENT ID",
tokenEndpoint : "BULK DATA AUTH SERVER TOKEN URL", // Can be found in the CapabilityStatement
privateJWKorSecret: { /* PRIVATE KEY AS JWK */ } // OR client secret string for basic auth
}
/**
* Client settings for FHIR API calls.
* NOTE: In Cerner this must be a separate client. In Epic it can be the same
* (although it can also be separate). To reuse the same client you can repeat
* the same settings or just do:
* ```
* const fhirClient = bulkClient;
* ```
*/
const fhirClient = {
baseUrl : "FHIR SERVER BASE URL",
clientId : "FHIR CLIENT ID",
tokenEndpoint : "AUTH SERVER TOKEN URL", // Can be found in the CapabilityStatement
privateJWKorSecret: { /* PRIVATE KEY AS JWK */ } // OR client secret string for basic auth
}
module.exports = {
/**
* BulkData Group ID
*/
groupId: "BULK GROUP ID",
/**
* Path to destination folder for ndjson downloads and logs. Can be absolute
* or relative to CWD
*/
destination : "PATH TO DOWNLOADS FOLDER",
/**
* Delay in milliseconds between HTTP requests (in case you need to reduce
* the load on the server)
*/
throttle: 0,
/**
* While we are waiting for the bulk export the server might send back a
* "retry-after" header. If so, we will try to respect that within a
* reasonable boundaries. Otherwise, the `poolInterval` option will be used
* to suggest after what delay to check again.
* NOTE: The value is in milliseconds.
*/
poolInterval: 5 * 60 * 1000, // 5 min
/**
* Don't allow the bulk status pool interval to be smaller than this. This
* can be useful when you want to "correct" the retry-after delay
* recommended by the server.
* NOTE: The value is in milliseconds and must be <= `poolInterval`.
*/
minPoolInterval: 100, // 100 ms
/**
* Don't allow the bulk status pool interval to be bigger than this. This
* can be useful when you want to "correct" the retry-after delay
* recommended by the server.
* NOTE: The value is in milliseconds and must be >= `poolInterval`.
*/
maxPoolInterval: 1000 * 60 * 60, // 1 hour
/**
* Downloaded files are named as `<prefix>.<ResourceType>.ndjson` where
* <prefix> start from `1`. While the file size is less then this, new lines
* will be appended to it. Once that size is reached another fille will be
* created with incremented <prefix> and the lines will be appending to it.
*/
maxFileSize : 1e9, // ~ 1 GB
/**
* Retried failed requests if they returned one of these status codes.
* NOTE: Only failed requests are retried.
*/
retryStatusCodes: [408, 413, 429, 500, 502, 503, 504, 521, 522, 524],
/**
* Wait this many milliseconds before retrying a failed request
*/
retryDelay: 1000,
/**
* How many times to retry failed requests. Set to 0 to disable retrying.
*/
retryLimit: 5,
/**
* Client settings for Bulk Data export
*/
bulkClient,
/**
* Client settings for FHIR API calls
*/
fhirClient,
/**
* Request timeout in milliseconds
*/
requestTimeout: 60000,
/**
* - `1` (or less) means serial downloads
* - `>1` means that there is one download process for each resourceType
* other than Patient, but not more than this number.
* For example (if this is set to 10):
* 1. If you are downloading 5 resource types, setting this to 10 is the
* same as setting it to 5.
* 2. If you are downloading 50 resource types the first 10 will be started
* immediately and work in parallel and the rest will start whenever a
* worker becomes available.
*/
parallel: 10,
/**
* Map of resource types we want to download and their corresponding query
* string. This does not include `Patient` resources which are downloaded
* via bulk data export.
* NOTE: #{patientId} will be replaced with the current patient ID
*/
resources: {
Encounter : `?patient=#{patientId}&date=gt${SINCE}`,
Condition : `?patient=#{patientId}`,
DocumentReference: `?patient=#{patientId}&date=gt${SINCE}&category=clinical-note`,
MedicationRequest: `?patient=#{patientId}`,
Observation : `?patient=#{patientId}&date=gt${SINCE}&category=laboratory,vital-signs,social-history`,
}
}