openhim-core
Version:
The OpenHIM core application that provides logging and routing of http requests
1,376 lines • 57.4 kB
HTML
<!doctype html>
<html lang="en">
<head>
<title>Code coverage report for src/middleware/router.coffee</title>
<meta charset="utf-8" />
<link rel="stylesheet" href="../../prettify.css" />
<link rel="stylesheet" href="../../base.css" />
<meta name="viewport" content="width=device-width, initial-scale=1">
<style type='text/css'>
.coverage-summary .sorter {
background-image: url(../../sort-arrow-sprite.png);
}
</style>
</head>
<body>
<div class='wrapper'>
<div class='pad1'>
<h1>
<a href="../../index.html">All files</a> / <a href="index.html">src/middleware</a> router.coffee
</h1>
<div class='clearfix'>
<div class='fl pad1y space-right2'>
<span class="strong">19.23% </span>
<span class="quiet">Statements</span>
<span class='fraction'>40/208</span>
</div>
<div class='fl pad1y space-right2'>
<span class="strong">0% </span>
<span class="quiet">Branches</span>
<span class='fraction'>0/71</span>
</div>
<div class='fl pad1y space-right2'>
<span class="strong">0% </span>
<span class="quiet">Functions</span>
<span class='fraction'>0/45</span>
</div>
<div class='fl pad1y space-right2'>
<span class="strong">19.61% </span>
<span class="quiet">Lines</span>
<span class='fraction'>40/204</span>
</div>
</div>
</div>
<div class='status-line low'></div>
<pre><table class="coverage">
<tr><td class="line-count quiet">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
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488</td><td class="line-coverage quiet"><span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">util = require 'util'
zlib = require 'zlib'
http = require 'http'
https = require 'https'
net = require 'net'
tls = require 'tls'
Q = require 'q'
config = require '../config/config'
config.mongo = config.get 'mongo'
config.router = config.get 'router'
logger = require 'winston'
cookie = require 'cookie'
fs = require 'fs'
utils = require '../utils'
messageStore = require '../middleware/messageStore'
events = require '../middleware/events'
stats = require "../stats"
statsdServer = config.get 'statsd'
application = config.get 'application'
SDC = require 'statsd-client'
os = require 'os'
domain = "#{os.hostname()}.#{application.name}.appMetrics"
sdc = new SDC statsdServer
isRouteEnabled = <span class="fstat-no" title="function not covered" >(</span>route) -> not route.status? or route.status is 'enabled'
exports.numberOfPrimaryRoutes = numberOfPrimaryRoutes = <span class="fstat-no" title="function not covered" >(</span>routes) ->
<span class="cstat-no" title="statement not covered" > numPrimaries = 0</span>
<span class="cstat-no" title="statement not covered" > for route in routes</span>
<span class="cstat-no" title="statement not covered" ></span> numPrimaries++ if isRouteEnabled(route) and route.primary
<span class="cstat-no" title="statement not covered" > return n</span>umPrimaries
containsMultiplePrimaries = <span class="fstat-no" title="function not covered" >(</span>routes) -> numberOfPrimaryRoutes(routes) > 1
setKoaResponse = <span class="fstat-no" title="function not covered" >(</span>ctx, response) ->
# Try and parse the status to an int if it is a string
if typeof response.status is 'string'
<span class="cstat-no" title="statement not covered" > try</span>
<span class="cstat-no" title="statement not covered" > response.status = parseInt response.status</span>
catch <span class="cstat-no" title="statement not covered" >err</span>
<span class="cstat-no" title="statement not covered" > logger.error err</span>
<span class="cstat-no" title="statement not covered" > ctx.response.status = response.s</span>tatus
<span class="cstat-no" title="statement not covered" > ctx.response.timestamp = response.t</span>imestamp
<span class="cstat-no" title="statement not covered" > ctx.response.body = response.b</span>ody
if not ctx.response.header
<span class="cstat-no" title="statement not covered" > ctx.response.header = {}</span>
if ctx.request?.header?["X-OpenHIM-TransactionID"]
<span class="cstat-no" title="statement not covered" > if response?.headers?</span>
<span class="cstat-no" title="statement not covered" > response.headers["X-OpenHIM-TransactionID"] = ctx.request.header["X-OpenHIM-TransactionID"]</span>
<span class="cstat-no" title="statement not covered" > for key, value of response.headers</span>
<span class="cstat-no" title="statement not covered" > switch key.toLowerCase()</span>
when <span class="cstat-no" title="statement not covered" >'set-cookie' then setCookiesOnContext ctx, value</span>
when <span class="cstat-no" title="statement not covered" >'location'</span>
if response.status >= 300 and response.status < 400
ctx.response.redirect value
else
ctx.response.set key, value
when <span class="cstat-no" title="statement not covered" >'content-type' then ctx.response.type = value</span>
else
try
# Strip the content and transfer encoding headers
<span class="cstat-no" title="statement not covered" > if key != 'content-encoding' and key != 'transfer-encoding'</span>
ctx.response.set key, value
catch <span class="cstat-no" title="statement not covered" >err</span>
logger.error err
if process.env.NODE_ENV == "test"
exports.setKoaResponse = setKoaResponse
setCookiesOnContext = <span class="fstat-no" title="function not covered" >(</span>ctx, value) ->
<span class="cstat-no" title="statement not covered" > logger.info 'Setting cookies on context'</span>
<span class="cstat-no" title="statement not covered" > for c_key,c_value in value</span>
c_opts = {path:false,httpOnly:false} #clear out default values in cookie module
<span class="cstat-no" title="statement not covered" > c_vals = {</span>}
<span class="cstat-no" title="statement not covered" > for p_key,p_val of cookie.parse c_key</span>
<span class="cstat-no" title="statement not covered" > p_key_l = p</span>_key.toLowerCase()
<span class="cstat-no" title="statement not covered" > switch p_key_l</span>
when <span class="cstat-no" title="statement not covered" >'max-age' then <span class="cstat-no" title="statement not covered" >c_opts['maxage'] = p</span>arseInt p_val, 10</span>
when <span class="cstat-no" title="statement not covered" >'expires' then <span class="cstat-no" title="statement not covered" >c_opts['expires'] = new D</span>ate p_val</span>
when 'path','domain','secure','signed',<span class="cstat-no" title="statement not covered" >'overwrite' then <span class="cstat-no" title="statement not covered" >c_opts[p_key_l] = p</span>_val</span>
when <span class="cstat-no" title="statement not covered" >'httponly' then <span class="cstat-no" title="statement not covered" >c_opts['httpOnly'] = p</span>_val</span>
else <span class="cstat-no" title="statement not covered" >c_vals[p_key] = p</span>_val
<span class="cstat-no" title="statement not covered" > for p_key,p_val of c_vals</span>
ctx.cookies.set p_key,p_val,c_opts
handleServerError = <span class="fstat-no" title="function not covered" >(</span>ctx, err, route) ->
<span class="cstat-no" title="statement not covered" > ctx.autoRetry = t</span>rue
if route
<span class="cstat-no" title="statement not covered" > route.error =</span>
message: err.message
stack: err.stack if err.stack
else
<span class="cstat-no" title="statement not covered" > ctx.response.status = 5</span>00
<span class="cstat-no" title="statement not covered" > ctx.response.timestamp = new D</span>ate()
<span class="cstat-no" title="statement not covered" > ctx.response.body = "</span>An internal server error occurred"
# primary route error
<span class="cstat-no" title="statement not covered" > ctx.error =</span>
message: err.message
stack: err.stack if err.stack
<span class="cstat-no" title="statement not covered" > logger.error "[#{ctx.transactionId?.toString()}] Internal server error occured: #{err}"</span>
logger.error "#{err.stack}" if err.stack
sendRequestToRoutes = <span class="fstat-no" title="function not covered" >(</span>ctx, routes, next) ->
<span class="cstat-no" title="statement not covered" > promises = [</span>]
<span class="cstat-no" title="statement not covered" > promise = {</span>}
<span class="cstat-no" title="statement not covered" > ctx.timer = new D</span>ate
if containsMultiplePrimaries routes
<span class="cstat-no" title="statement not covered" > return next new Error "Cannot route transaction: Channel contains multiple primary routes and only one primary is allowed"</span>
utils.getKeystore <span class="fstat-no" title="function not covered" >(</span>err, keystore) ->
<span class="cstat-no" title="statement not covered" > for route in routes</span>
do <span class="fstat-no" title="function not covered" >(</span>route) ->
i</span>f not isRouteEnabled route then <span class="cstat-no" title="statement not covered" >return #continue
<span class="cstat-no" title="statement not covered" > path = g</span>etDestinationPath route, ctx.path
options =
hostname: route.host
port: route.port
path: path
method: ctx.request.method
headers: ctx.request.header
agent: false
rejectUnauthorized: true
key: keystore.key
cert: keystore.cert.data
secureProtocol: 'TLSv1_method'
if route.cert?
<span class="cstat-no" title="statement not covered" > options.ca = keystore.ca.id(route.cert).data</span>
if ctx.request.querystring
<span class="cstat-no" title="statement not covered" > options.path += '?' + ctx.request.querystring</span>
if options.headers and options.headers.authorization and not route.forwardAuthHeader
<span class="cstat-no" title="statement not covered" > delete options.headers.authorization</span>
if route.username and route.password
<span class="cstat-no" title="statement not covered" > options.auth = route.username + ":" + route.password</span>
if options.headers && options.headers.host
<span class="cstat-no" title="statement not covered" > delete options.headers.host</span>
if route.primary
<span class="cstat-no" title="statement not covered" > ctx.primaryRoute = r</span>oute
<span class="cstat-no" title="statement not covered" > promise = sendRequest(ctx, route, options)</span>
.then <span class="fstat-no" title="function not covered" >(</span>response) ->
<span class="cstat-no" title="statement not covered" > logger.info "executing primary route : #{route.name}"</span>
if response.headers?['content-type']?.indexOf('application/json+openhim') > -1
# handle mediator reponse
<span class="cstat-no" title="statement not covered" > responseObj = J</span>SON.parse response.body
<span class="cstat-no" title="statement not covered" > ctx.mediatorResponse = r</span>esponseObj
if responseObj.error?
<span class="cstat-no" title="statement not covered" > ctx.autoRetry = t</span>rue
<span class="cstat-no" title="statement not covered" > ctx.error = responseObj.error</span>
# then set koa response from responseObj.response
setKoaResponse ctx, responseObj.response
else
setKoaResponse ctx, response
.then <span class="fstat-no" title="function not covered" ></span>->
<span class="cstat-no" title="statement not covered" > logger.info "primary route completed"</span>
next()
.fail <span class="fstat-no" title="function not covered" >(</span>reason) ->
# on failure
<span class="cstat-no" title="statement not covered" > handleServerError ctx, reason</span>
next()
else
<span class="cstat-no" title="statement not covered" > logger.info "executing non primary: #{route.name}"</span>
<span class="cstat-no" title="statement not covered" > promise = buildNonPrimarySendRequestPromise(ctx, route, options, path)</span>
.then <span class="fstat-no" title="function not covered" >(</span>routeObj) ->
<span class="cstat-no" title="statement not covered" > logger.info "Storing non primary route responses #{route.name}"</span>
try
if not routeObj?.name?
<span class="cstat-no" title="statement not covered" > routeObj =</span>
name: route.name
if not routeObj?.response?
<span class="cstat-no" title="statement not covered" > routeObj.response =</span>
status: 500
timestamp: ctx.requestTimestamp
if not routeObj?.request?
<span class="cstat-no" title="statement not covered" > routeObj.request =</span>
host: options.hostname
port: options.port
path: path
headers: ctx.request.header
querystring: ctx.request.querystring
method: ctx.request.method
timestamp: ctx.requestTimestamp
messageStore.storeNonPrimaryResponse ctx, routeObj, <span class="fstat-no" title="function not covered" ></span>->
stats.nonPrimaryRouteRequestCount ctx, routeObj, <span class="fstat-no" title="function not covered" ></span>->
stats.nonPrimaryRouteDurations ctx, routeObj, <span class="fstat-no" title="function not covered" ></span>->
catch <span class="cstat-no" title="statement not covered" >err</span>
logger.error err
promises.push promise
(Q.all promises).then <span class="fstat-no" title="function not covered" ></span>->
messageStore.setFinalStatus ctx, <span class="fstat-no" title="function not covered" ></span>->
<span class="cstat-no" title="statement not covered" > logger.info "All routes completed for transaction: #{ctx.transactionId.toString()}"</span>
if ctx.routes
<span class="cstat-no" title="statement not covered" > logger.debug "Storing route events for transaction: #{ctx.transactionId}"</span>
<span class="cstat-no" title="statement not covered" > done = <span class="fstat-no" title="function not covered" >(</span></span>err) -> logger.error err if err
<span class="cstat-no" title="statement not covered" > trxEvents = [</span>]
<span class="cstat-no" title="statement not covered" > events.createSecondaryRouteEvents trxEvents, ctx.transactionId, ctx.requestTimestamp, ctx.authorisedChannel, ctx.routes, ctx.currentAttempt</span>
events.saveEvents trxEvents, done
# function to build fresh promise for transactions routes
buildNonPrimarySendRequestPromise = <span class="fstat-no" title="function not covered" >(</span>ctx, route, options, path) ->
sendRequest ctx, route, options
.then <span class="fstat-no" title="function not covered" >(</span>response) ->
<span class="cstat-no" title="statement not covered" > routeObj = {</span>}
<span class="cstat-no" title="statement not covered" > routeObj.name = route.n</span>ame
routeObj.request =
host: options.hostname
port: options.port
path: path
headers: ctx.request.header
querystring: ctx.request.querystring
method: ctx.request.method
timestamp: ctx.requestTimestamp
if response.headers?['content-type']?.indexOf('application/json+openhim') > -1
# handle mediator reponse
<span class="cstat-no" title="statement not covered" > responseObj = J</span>SON.parse response.body
<span class="cstat-no" title="statement not covered" > routeObj.mediatorURN = responseObj['</span>x-mediator-urn']
<span class="cstat-no" title="statement not covered" > routeObj.orchestrations = responseObj.o</span>rchestrations
<span class="cstat-no" title="statement not covered" > routeObj.properties = responseObj.p</span>roperties
<span class="cstat-no" title="statement not covered" ></span> routeObj.metrics = responseObj.metrics if responseObj.metrics
<span class="cstat-no" title="statement not covered" > routeObj.response = responseObj.response</span>
else
<span class="cstat-no" title="statement not covered" > routeObj.response = response</span>
<span class="cstat-no" title="statement not covered" ></span> ctx.routes = [] if not ctx.routes
<span class="cstat-no" title="statement not covered" > ctx.routes.push routeObj</span>
<span class="cstat-no" title="statement not covered" > return r</span>outeObj
.fail <span class="fstat-no" title="function not covered" >(</span>reason) ->
# on failure
<span class="cstat-no" title="statement not covered" > routeObj = {</span>}
<span class="cstat-no" title="statement not covered" > routeObj.name = route.n</span>ame
<span class="cstat-no" title="statement not covered" > handleServerError ctx, reason, routeObj</span>
<span class="cstat-no" title="statement not covered" > return r</span>outeObj
sendRequest = <span class="fstat-no" title="function not covered" >(</span>ctx, route, options) ->
if route.type is 'tcp' or route.type is 'mllp'
<span class="cstat-no" title="statement not covered" > logger.info 'Routing socket request'</span>
<span class="cstat-no" title="statement not covered" > return sendSocketRequest ctx, route, options</span>
else
<span class="cstat-no" title="statement not covered" > logger.info 'Routing http(s) request'</span>
<span class="cstat-no" title="statement not covered" > return sendHttpRequest ctx, route, options</span>
obtainCharset = <span class="fstat-no" title="function not covered" >(</span>headers) ->
<span class="cstat-no" title="statement not covered" > contentType = headers['content-type'] || '</span>'
<span class="cstat-no" title="statement not covered" > matches = c</span>ontentType.match(/charset=([^;,\r\n]+)/i)
if (matches && matches[1])
<span class="cstat-no" title="statement not covered" > return matches[1]</span>
<span class="cstat-no" title="statement not covered" > return '</span>utf-8'
###
# A promise returning function that send a request to the given route and resolves
# the returned promise with a response object of the following form:
# response =
# status: <http_status code>
# body: <http body>
# headers: <http_headers_object>
# timestamp: <the time the response was recieved>
###
sendHttpRequest = <span class="fstat-no" title="function not covered" >(</span>ctx, route, options) ->
<span class="cstat-no" title="statement not covered" > defered = Q</span>.defer()
<span class="cstat-no" title="statement not covered" > response = {</span>}
<span class="cstat-no" title="statement not covered" > gunzip = z</span>lib.createGunzip()
<span class="cstat-no" title="statement not covered" > inflate = z</span>lib.createInflate()
<span class="cstat-no" title="statement not covered" > method = h</span>ttp
if route.secured
<span class="cstat-no" title="statement not covered" > method = https</span>
<span class="cstat-no" title="statement not covered" > routeReq = m</span>ethod.request options, <span class="fstat-no" title="function not covered" >(</span>routeRes) ->
<span class="cstat-no" title="statement not covered" > response.status = routeRes.s</span>tatusCode
<span class="cstat-no" title="statement not covered" > response.headers = routeRes.h</span>eaders
<span class="cstat-no" title="statement not covered" > uncompressedBodyBufs = [</span>]
if routeRes.headers['content-encoding'] == 'gzip' #attempt to gunzip
<span class="cstat-no" title="statement not covered" > routeRes.pipe gunzip</span>
<span class="cstat-no" title="statement not covered" > gunzip.on "data", <span class="fstat-no" title="function not covered" >(</span>data) -></span>
<span class="cstat-no" title="statement not covered" > uncompressedBodyBufs.push data</span>
return
if routeRes.headers['content-encoding'] == 'deflate' #attempt to inflate
<span class="cstat-no" title="statement not covered" > routeRes.pipe inflate</span>
<span class="cstat-no" title="statement not covered" > inflate.on "data", <span class="fstat-no" title="function not covered" >(</span>data) -></span>
<span class="cstat-no" title="statement not covered" > uncompressedBodyBufs.push data</span>
return
<span class="cstat-no" title="statement not covered" > bufs = [</span>]
<span class="cstat-no" title="statement not covered" > routeRes.on "data", <span class="fstat-no" title="function not covered" >(</span>chunk) -></span>
bufs.push chunk
# See https://www.exratione.com/2014/07/nodejs-handling-uncertain-http-response-compression/
routeRes.on "end", <span class="fstat-no" title="function not covered" ></span>->
<span class="cstat-no" title="statement not covered" > response.timestamp = new D</span>ate()
<span class="cstat-no" title="statement not covered" > charset = o</span>btainCharset(routeRes.headers)
if routeRes.headers['content-encoding'] == 'gzip'
gunzip.on "end", <span class="fstat-no" title="function not covered" ></span>->
<span class="cstat-no" title="statement not covered" > uncompressedBody = B</span>uffer.concat uncompressedBodyBufs
<span class="cstat-no" title="statement not covered" > response.body = u</span>ncompressedBody.toString charset
if not defered.promise.isRejected()
<span class="cstat-no" title="statement not covered" > defered.resolve response</span>
return
else if routeRes.headers['content-encoding'] == 'deflate'
inflate.on "end", <span class="fstat-no" title="function not covered" ></span>->
<span class="cstat-no" title="statement not covered" > uncompressedBody = B</span>uffer.concat uncompressedBodyBufs
<span class="cstat-no" title="statement not covered" > response.body = u</span>ncompressedBody.toString charset
if not defered.promise.isRejected()
<span class="cstat-no" title="statement not covered" > defered.resolve response</span>
return
else
<span class="cstat-no" title="statement not covered" > response.body = B</span>uffer.concat bufs
<span class="cstat-no" title="statement not covered" > if not defered.promise.isRejected()</span>
defered.resolve response
<span class="cstat-no" title="statement not covered" > routeReq.on "error", <span class="fstat-no" title="function not covered" >(</span>err) -> defered.reject err</span>
<span class="cstat-no" title="statement not covered" > routeReq.on "clientError", <span class="fstat-no" title="function not covered" >(</span>err) -> defered.reject err</span>
<span class="cstat-no" title="statement not covered" > routeReq.setTimeout config.router.timeout, <span class="fstat-no" title="function not covered" ></span>-> defered.reject "Request Timed Out"</span>
if ctx.request.method == "POST" || ctx.request.method == "PUT"
<span class="cstat-no" title="state