UNPKG

openhim-core

Version:

The OpenHIM core application that provides logging and routing of http requests

399 lines (387 loc) 14.7 kB
<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/api/visualizers.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/api</a> visualizers.coffee </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">24.39% </span> <span class="quiet">Statements</span> <span class='fraction'>10/41</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Branches</span> <span class='fraction'>0/2</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Functions</span> <span class='fraction'>0/5</span> </div> <div class='fl pad1y space-right2'> <span class="strong">24.39% </span> <span class="quiet">Lines</span> <span class='fraction'>10/41</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</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-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">Visualizer = require('../model/visualizer').Visualizer authorisation = require './authorisation' Q = require 'q' utils = require '../utils' logger = require 'winston' &nbsp; &nbsp; # Endpoint that returns all visualizers exports.getVisualizers = <span class="fstat-no" title="function not covered" ></span>-&gt; # Must be admin if not authorisation.inGroup 'admin', this.authenticated <span class="cstat-no" title="statement not covered" > return utils.logAndSetResponse this, 403, "User #{this.authenticated.email} is not an admin, API access to getVisualizers denied.", 'info'</span> &nbsp; try this.body = yield Visualizer.find().exec() catch <span class="cstat-no" title="statement not covered" >err</span> utils.logAndSetResponse this, 500, "Could not fetch visualizers via the API: #{err}", 'error' &nbsp; &nbsp; &nbsp; # Endpoint that returns specific visualizer by visualizerId exports.getVisualizer = <span class="fstat-no" title="function not covered" >(</span>visualizerId) -&gt; # Must be admin if not authorisation.inGroup 'admin', this.authenticated <span class="cstat-no" title="statement not covered" > return utils.logAndSetResponse this, 403, "User #{this.authenticated.email} is not an admin, API access to getVisualizer denied.", 'info'</span> <span class="cstat-no" title="statement not covered" > visualizerId = u</span>nescape visualizerId try <span class="cstat-no" title="statement not covered" > result = y</span>ield Visualizer.findById(visualizerId).exec() <span class="cstat-no" title="statement not covered" > if not result</span> <span class="cstat-no" title="statement not covered" > this.body = "Visualizer with _id #{visualizerId} </span>could not be found." this.status = 404 else this.body = result catch <span class="cstat-no" title="statement not covered" >err</span> utils.logAndSetResponse this, 500, "Could not fetch visualizer via the API: #{err}", 'error' &nbsp; &nbsp; &nbsp; # Endpoint to add new visualizer exports.addVisualizer = <span class="fstat-no" title="function not covered" ></span>-&gt; # Must be admin user if not authorisation.inGroup 'admin', this.authenticated <span class="cstat-no" title="statement not covered" > return utils.logAndSetResponse this, 403, "User #{this.authenticated.email} is not an admin, API access to addVisualizer denied.", 'info'</span> &nbsp; <span class="cstat-no" title="statement not covered" > visualizerData = this.request.b</span>ody if not visualizerData <span class="cstat-no" title="statement not covered" > return utils.logAndSetResponse this, 404, "Cannot Add Visualizer, no request object", 'info'</span> &nbsp; try <span class="cstat-no" title="statement not covered" > visualizer = new V</span>isualizer visualizerData <span class="cstat-no" title="statement not covered" > result = y</span>ield Q.ninvoke visualizer, 'save' &nbsp; <span class="cstat-no" title="statement not covered" > this.body = '</span>Visualizer successfully created' <span class="cstat-no" title="statement not covered" > this.status = 2</span>01 logger.info 'User %s created visualizer with id %s', this.authenticated.email, visualizer.id catch <span class="cstat-no" title="statement not covered" >err</span> utils.logAndSetResponse this, 500, "Could not add visualizer via the API: #{err}", 'error' &nbsp; &nbsp; &nbsp; # Endpoint to update specific visualizer by visualizerId exports.updateVisualizer = <span class="fstat-no" title="function not covered" >(</span>visualizerId) -&gt; # Must be admin if not authorisation.inGroup 'admin', this.authenticated <span class="cstat-no" title="statement not covered" > return utils.logAndSetResponse this, 403, "User #{this.authenticated.email} is not an admin, API access to updateVisualizer denied.", 'info'</span> &nbsp; <span class="cstat-no" title="statement not covered" > visualizerData = this.request.b</span>ody if not visualizerData <span class="cstat-no" title="statement not covered" > return utils.logAndSetResponse this, 404, "Cannot Update Visualizer with _id #{visualizerId}, no request object", 'info'</span> <span class="cstat-no" title="statement not covered" > visualizerId = u</span>nescape visualizerId # Ignore _id if it exists, a user shouldn't be able to update the internal id <span class="cstat-no" title="statement not covered" ></span> delete visualizerData._id if visualizerData._id try <span class="cstat-no" title="statement not covered" > result = y</span>ield Visualizer.findByIdAndUpdate(visualizerId, visualizerData).exec() if not result <span class="cstat-no" title="statement not covered" > return utils.logAndSetResponse this, 404, "Cannot Update Visualizer with _id #{visualizerId}, does not exist", 'info'</span> <span class="cstat-no" title="statement not covered" > this.body = "Successfully updated visualizer with _id #{v</span>isualizerId}" logger.info "User #{this.authenticated.email} updated visualizer with _id #{visualizerId}" catch <span class="cstat-no" title="statement not covered" >e</span> utils.logAndSetResponse this, 500, "Could not update visualizer with _id #{visualizerId} via the API #{e}", 'error' &nbsp; &nbsp; &nbsp; # Endpoint to remove specific visualizer by visualizerId exports.removeVisualizer = <span class="fstat-no" title="function not covered" >(</span>visualizerId) -&gt; # Must be admin if not authorisation.inGroup 'admin', this.authenticated <span class="cstat-no" title="statement not covered" > return utils.logAndSetResponse this, 403, "User #{this.authenticated.email} is not an admin, API access to removeVisualizer denied.", 'info'</span> &nbsp; <span class="cstat-no" title="statement not covered" > visualizerId = u</span>nescape visualizerId &nbsp; try <span class="cstat-no" title="statement not covered" > v = y</span>ield Visualizer.findByIdAndRemove(visualizerId).exec() if not v <span class="cstat-no" title="statement not covered" > return utils.logAndSetResponse this, 404, "Could not find visualizer with _id #{visualizerId}", 'info'</span> &nbsp; <span class="cstat-no" title="statement not covered" > this.body = "Successfully removed visualizer with _id #{v</span>isualizerId}" logger.info "User #{this.authenticated.email} removed visualizer with _id #{visualizerId}" catch <span class="cstat-no" title="statement not covered" >e</span> utils.logAndSetResponse this, 500, "Could not remove visualizer with _id #{visualizerId} via the API #{e}", 'error' &nbsp;</pre></td></tr> </table></pre> <div class='push'></div><!-- for sticky footer --> </div><!-- /wrapper --> <div class='footer quiet pad2 space-top1 center small'> Code coverage generated by <a href="http://istanbul-js.org/" target="_blank">istanbul</a> at Mon Oct 10 2016 13:39:22 GMT+0200 (SAST) </div> </div> <script src="../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../sorter.js"></script> </body> </html>