guard.js.html 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. <!doctype html>
  2. <html lang="en">
  3. <head>
  4. <title>Code coverage report for nodejs-homework-API/helpers/guard.js</title>
  5. <meta charset="utf-8" />
  6. <link rel="stylesheet" href="../../prettify.css" />
  7. <link rel="stylesheet" href="../../base.css" />
  8. <link rel="shortcut icon" type="image/x-icon" href="../../favicon.png" />
  9. <meta name="viewport" content="width=device-width, initial-scale=1" />
  10. <style type='text/css'>
  11. .coverage-summary .sorter {
  12. background-image: url(../../sort-arrow-sprite.png);
  13. }
  14. </style>
  15. </head>
  16. <body>
  17. <div class='wrapper'>
  18. <div class='pad1'>
  19. <h1><a href="../../index.html">All files</a> / <a href="index.html">nodejs-homework-API/helpers</a> guard.js</h1>
  20. <div class='clearfix'>
  21. <div class='fl pad1y space-right2'>
  22. <span class="strong">100% </span>
  23. <span class="quiet">Statements</span>
  24. <span class='fraction'>11/11</span>
  25. </div>
  26. <div class='fl pad1y space-right2'>
  27. <span class="strong">100% </span>
  28. <span class="quiet">Branches</span>
  29. <span class='fraction'>5/5</span>
  30. </div>
  31. <div class='fl pad1y space-right2'>
  32. <span class="strong">100% </span>
  33. <span class="quiet">Functions</span>
  34. <span class='fraction'>2/2</span>
  35. </div>
  36. <div class='fl pad1y space-right2'>
  37. <span class="strong">100% </span>
  38. <span class="quiet">Lines</span>
  39. <span class='fraction'>11/11</span>
  40. </div>
  41. </div>
  42. <p class="quiet">
  43. Press <em>n</em> or <em>j</em> to go to the next uncovered block, <em>b</em>, <em>p</em> or <em>k</em> for the previous block.
  44. </p>
  45. </div>
  46. <div class='status-line high'></div>
  47. <pre><table class="coverage">
  48. <tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
  49. <a name='L2'></a><a href='#L2'>2</a>
  50. <a name='L3'></a><a href='#L3'>3</a>
  51. <a name='L4'></a><a href='#L4'>4</a>
  52. <a name='L5'></a><a href='#L5'>5</a>
  53. <a name='L6'></a><a href='#L6'>6</a>
  54. <a name='L7'></a><a href='#L7'>7</a>
  55. <a name='L8'></a><a href='#L8'>8</a>
  56. <a name='L9'></a><a href='#L9'>9</a>
  57. <a name='L10'></a><a href='#L10'>10</a>
  58. <a name='L11'></a><a href='#L11'>11</a>
  59. <a name='L12'></a><a href='#L12'>12</a>
  60. <a name='L13'></a><a href='#L13'>13</a>
  61. <a name='L14'></a><a href='#L14'>14</a>
  62. <a name='L15'></a><a href='#L15'>15</a>
  63. <a name='L16'></a><a href='#L16'>16</a>
  64. <a name='L17'></a><a href='#L17'>17</a>
  65. <a name='L18'></a><a href='#L18'>18</a>
  66. <a name='L19'></a><a href='#L19'>19</a>
  67. <a name='L20'></a><a href='#L20'>20</a>
  68. <a name='L21'></a><a href='#L21'>21</a>
  69. <a name='L22'></a><a href='#L22'>22</a></td><td class="line-coverage quiet"><span class="cline-any cline-yes">1x</span>
  70. <span class="cline-any cline-yes">1x</span>
  71. <span class="cline-any cline-yes">1x</span>
  72. <span class="cline-any cline-neutral">&nbsp;</span>
  73. <span class="cline-any cline-yes">1x</span>
  74. <span class="cline-any cline-yes">16x</span>
  75. <span class="cline-any cline-yes">16x</span>
  76. <span class="cline-any cline-yes">16x</span>
  77. <span class="cline-any cline-yes">5x</span>
  78. <span class="cline-any cline-neutral">&nbsp;</span>
  79. <span class="cline-any cline-neutral">&nbsp;</span>
  80. <span class="cline-any cline-neutral">&nbsp;</span>
  81. <span class="cline-any cline-neutral">&nbsp;</span>
  82. <span class="cline-any cline-neutral">&nbsp;</span>
  83. <span class="cline-any cline-neutral">&nbsp;</span>
  84. <span class="cline-any cline-yes">11x</span>
  85. <span class="cline-any cline-yes">11x</span>
  86. <span class="cline-any cline-neutral">&nbsp;</span>
  87. <span class="cline-any cline-neutral">&nbsp;</span>
  88. <span class="cline-any cline-neutral">&nbsp;</span>
  89. <span class="cline-any cline-yes">1x</span>
  90. <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">const passport = require("passport");
  91. require("../config/passport");
  92. const chalk = require("chalk");
  93. &nbsp;
  94. const guard = (req, res, next) =&gt; {
  95. passport.authenticate("jwt", { session: false }, (err, user) =&gt; {
  96. const token = req.get("Authorization")?.split(" ")[1];
  97. if (!user || err || token !== user.token) {
  98. return res.status(403).json({
  99. status: "error",
  100. code: 403,
  101. data: "Forbidden",
  102. message: "Access is denied",
  103. });
  104. }
  105. req.user = user;
  106. return next();
  107. })(req, res, next);
  108. };
  109. &nbsp;
  110. module.exports = guard;
  111. &nbsp;</pre></td></tr></table></pre>
  112. <div class='push'></div><!-- for sticky footer -->
  113. </div><!-- /wrapper -->
  114. <div class='footer quiet pad2 space-top1 center small'>
  115. Code coverage generated by
  116. <a href="https://istanbul.js.org/" target="_blank">istanbul</a>
  117. at Mon Mar 15 2021 13:23:50 GMT+0200 (GMT+02:00)
  118. </div>
  119. </div>
  120. <script src="../../prettify.js"></script>
  121. <script>
  122. window.onload = function () {
  123. prettyPrint();
  124. };
  125. </script>
  126. <script src="../../sorter.js"></script>
  127. <script src="../../block-navigation.js"></script>
  128. </body>
  129. </html>