@hitchy/plugin-auth 0.2.0 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.gitlab-ci.yml +42 -21
- package/LICENSE +21 -0
- package/api/controller/user.js +2 -29
- package/api/model/authorization/rule.js +0 -27
- package/api/model/role.js +0 -28
- package/api/model/user-to-role.js +0 -28
- package/api/model/user.js +2 -30
- package/api/policy/authentication.js +67 -64
- package/api/policy/authorization.js +0 -28
- package/api/policy/user.js +0 -28
- package/api/service/auth/manager.js +9 -28
- package/api/service/authentication/passport.js +1 -29
- package/api/service/authentication/strategies.js +176 -27
- package/api/service/authorization/node.js +0 -28
- package/api/service/authorization/policy-generator.js +0 -28
- package/api/service/authorization/tree.js +0 -28
- package/config/auth.js +5 -0
- package/coverage/base.css +224 -0
- package/coverage/block-navigation.js +79 -0
- package/coverage/favicon.png +0 -0
- package/coverage/index.html +231 -0
- package/coverage/plugin-auth/api/controller/index.html +111 -0
- package/coverage/plugin-auth/api/controller/user.js.html +368 -0
- package/coverage/plugin-auth/api/model/authorization/index.html +111 -0
- package/coverage/plugin-auth/api/model/authorization/rule.js.html +227 -0
- package/coverage/plugin-auth/api/model/index.html +141 -0
- package/coverage/plugin-auth/api/model/role.js.html +200 -0
- package/coverage/plugin-auth/api/model/user-to-role.js.html +167 -0
- package/coverage/plugin-auth/api/model/user.js.html +752 -0
- package/coverage/plugin-auth/api/policy/authentication.js.html +617 -0
- package/coverage/plugin-auth/api/policy/authorization.js.html +182 -0
- package/coverage/plugin-auth/api/policy/index.html +141 -0
- package/coverage/plugin-auth/api/policy/user.js.html +479 -0
- package/coverage/plugin-auth/api/service/auth/index.html +111 -0
- package/coverage/plugin-auth/api/service/auth/manager.js.html +863 -0
- package/coverage/plugin-auth/api/service/authentication/index.html +126 -0
- package/coverage/plugin-auth/api/service/authentication/passport.js.html +290 -0
- package/coverage/plugin-auth/api/service/authentication/strategies.js.html +860 -0
- package/coverage/plugin-auth/api/service/authorization/index.html +141 -0
- package/coverage/plugin-auth/api/service/authorization/node.js.html +944 -0
- package/coverage/plugin-auth/api/service/authorization/policy-generator.js.html +386 -0
- package/coverage/plugin-auth/api/service/authorization/tree.js.html +983 -0
- package/coverage/plugin-auth/config/auth.js.html +140 -0
- package/coverage/plugin-auth/config/index.html +111 -0
- package/coverage/plugin-auth/index.html +111 -0
- package/coverage/plugin-auth/index.js.html +344 -0
- package/coverage/prettify.css +1 -0
- package/coverage/prettify.js +2 -0
- package/coverage/sort-arrow-sprite.png +0 -0
- package/coverage/sorter.js +170 -0
- package/coverage/tmp/coverage-6744-1648396809135-0.json +1 -0
- package/docs/.vuepress/config.js +5 -2
- package/docs/api/config.md +14 -2
- package/docs/api/model/authorization-rule.md +1 -1
- package/docs/api/model/user.md +2 -2
- package/docs/api/service/authentication-passport.md +1 -1
- package/docs/guides/getting-started.md +2 -2
- package/docs/guides/idp-login.png +0 -0
- package/docs/guides/idp-saml-cert.png +0 -0
- package/docs/guides/openid-connect.md +164 -0
- package/docs/guides/readme.md +2 -0
- package/docs/guides/saml.md +161 -0
- package/docs/introduction.md +5 -5
- package/index.js +27 -50
- package/package.json +18 -13
- package/readme.md +11 -43
|
@@ -0,0 +1,752 @@
|
|
|
1
|
+
|
|
2
|
+
<!doctype html>
|
|
3
|
+
<html lang="en">
|
|
4
|
+
|
|
5
|
+
<head>
|
|
6
|
+
<title>Code coverage report for plugin-auth/api/model/user.js</title>
|
|
7
|
+
<meta charset="utf-8" />
|
|
8
|
+
<link rel="stylesheet" href="../../../prettify.css" />
|
|
9
|
+
<link rel="stylesheet" href="../../../base.css" />
|
|
10
|
+
<link rel="shortcut icon" type="image/x-icon" href="../../../favicon.png" />
|
|
11
|
+
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
12
|
+
<style type='text/css'>
|
|
13
|
+
.coverage-summary .sorter {
|
|
14
|
+
background-image: url(../../../sort-arrow-sprite.png);
|
|
15
|
+
}
|
|
16
|
+
</style>
|
|
17
|
+
</head>
|
|
18
|
+
|
|
19
|
+
<body>
|
|
20
|
+
<div class='wrapper'>
|
|
21
|
+
<div class='pad1'>
|
|
22
|
+
<h1><a href="../../../index.html">All files</a> / <a href="index.html">plugin-auth/api/model</a> user.js</h1>
|
|
23
|
+
<div class='clearfix'>
|
|
24
|
+
|
|
25
|
+
<div class='fl pad1y space-right2'>
|
|
26
|
+
<span class="strong">93.75% </span>
|
|
27
|
+
<span class="quiet">Statements</span>
|
|
28
|
+
<span class='fraction'>210/224</span>
|
|
29
|
+
</div>
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
<div class='fl pad1y space-right2'>
|
|
33
|
+
<span class="strong">78.84% </span>
|
|
34
|
+
<span class="quiet">Branches</span>
|
|
35
|
+
<span class='fraction'>41/52</span>
|
|
36
|
+
</div>
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
<div class='fl pad1y space-right2'>
|
|
40
|
+
<span class="strong">100% </span>
|
|
41
|
+
<span class="quiet">Functions</span>
|
|
42
|
+
<span class='fraction'>10/10</span>
|
|
43
|
+
</div>
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
<div class='fl pad1y space-right2'>
|
|
47
|
+
<span class="strong">93.75% </span>
|
|
48
|
+
<span class="quiet">Lines</span>
|
|
49
|
+
<span class='fraction'>210/224</span>
|
|
50
|
+
</div>
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
</div>
|
|
54
|
+
<p class="quiet">
|
|
55
|
+
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.
|
|
56
|
+
</p>
|
|
57
|
+
</div>
|
|
58
|
+
<div class='status-line high'></div>
|
|
59
|
+
<pre><table class="coverage">
|
|
60
|
+
<tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
|
|
61
|
+
<a name='L2'></a><a href='#L2'>2</a>
|
|
62
|
+
<a name='L3'></a><a href='#L3'>3</a>
|
|
63
|
+
<a name='L4'></a><a href='#L4'>4</a>
|
|
64
|
+
<a name='L5'></a><a href='#L5'>5</a>
|
|
65
|
+
<a name='L6'></a><a href='#L6'>6</a>
|
|
66
|
+
<a name='L7'></a><a href='#L7'>7</a>
|
|
67
|
+
<a name='L8'></a><a href='#L8'>8</a>
|
|
68
|
+
<a name='L9'></a><a href='#L9'>9</a>
|
|
69
|
+
<a name='L10'></a><a href='#L10'>10</a>
|
|
70
|
+
<a name='L11'></a><a href='#L11'>11</a>
|
|
71
|
+
<a name='L12'></a><a href='#L12'>12</a>
|
|
72
|
+
<a name='L13'></a><a href='#L13'>13</a>
|
|
73
|
+
<a name='L14'></a><a href='#L14'>14</a>
|
|
74
|
+
<a name='L15'></a><a href='#L15'>15</a>
|
|
75
|
+
<a name='L16'></a><a href='#L16'>16</a>
|
|
76
|
+
<a name='L17'></a><a href='#L17'>17</a>
|
|
77
|
+
<a name='L18'></a><a href='#L18'>18</a>
|
|
78
|
+
<a name='L19'></a><a href='#L19'>19</a>
|
|
79
|
+
<a name='L20'></a><a href='#L20'>20</a>
|
|
80
|
+
<a name='L21'></a><a href='#L21'>21</a>
|
|
81
|
+
<a name='L22'></a><a href='#L22'>22</a>
|
|
82
|
+
<a name='L23'></a><a href='#L23'>23</a>
|
|
83
|
+
<a name='L24'></a><a href='#L24'>24</a>
|
|
84
|
+
<a name='L25'></a><a href='#L25'>25</a>
|
|
85
|
+
<a name='L26'></a><a href='#L26'>26</a>
|
|
86
|
+
<a name='L27'></a><a href='#L27'>27</a>
|
|
87
|
+
<a name='L28'></a><a href='#L28'>28</a>
|
|
88
|
+
<a name='L29'></a><a href='#L29'>29</a>
|
|
89
|
+
<a name='L30'></a><a href='#L30'>30</a>
|
|
90
|
+
<a name='L31'></a><a href='#L31'>31</a>
|
|
91
|
+
<a name='L32'></a><a href='#L32'>32</a>
|
|
92
|
+
<a name='L33'></a><a href='#L33'>33</a>
|
|
93
|
+
<a name='L34'></a><a href='#L34'>34</a>
|
|
94
|
+
<a name='L35'></a><a href='#L35'>35</a>
|
|
95
|
+
<a name='L36'></a><a href='#L36'>36</a>
|
|
96
|
+
<a name='L37'></a><a href='#L37'>37</a>
|
|
97
|
+
<a name='L38'></a><a href='#L38'>38</a>
|
|
98
|
+
<a name='L39'></a><a href='#L39'>39</a>
|
|
99
|
+
<a name='L40'></a><a href='#L40'>40</a>
|
|
100
|
+
<a name='L41'></a><a href='#L41'>41</a>
|
|
101
|
+
<a name='L42'></a><a href='#L42'>42</a>
|
|
102
|
+
<a name='L43'></a><a href='#L43'>43</a>
|
|
103
|
+
<a name='L44'></a><a href='#L44'>44</a>
|
|
104
|
+
<a name='L45'></a><a href='#L45'>45</a>
|
|
105
|
+
<a name='L46'></a><a href='#L46'>46</a>
|
|
106
|
+
<a name='L47'></a><a href='#L47'>47</a>
|
|
107
|
+
<a name='L48'></a><a href='#L48'>48</a>
|
|
108
|
+
<a name='L49'></a><a href='#L49'>49</a>
|
|
109
|
+
<a name='L50'></a><a href='#L50'>50</a>
|
|
110
|
+
<a name='L51'></a><a href='#L51'>51</a>
|
|
111
|
+
<a name='L52'></a><a href='#L52'>52</a>
|
|
112
|
+
<a name='L53'></a><a href='#L53'>53</a>
|
|
113
|
+
<a name='L54'></a><a href='#L54'>54</a>
|
|
114
|
+
<a name='L55'></a><a href='#L55'>55</a>
|
|
115
|
+
<a name='L56'></a><a href='#L56'>56</a>
|
|
116
|
+
<a name='L57'></a><a href='#L57'>57</a>
|
|
117
|
+
<a name='L58'></a><a href='#L58'>58</a>
|
|
118
|
+
<a name='L59'></a><a href='#L59'>59</a>
|
|
119
|
+
<a name='L60'></a><a href='#L60'>60</a>
|
|
120
|
+
<a name='L61'></a><a href='#L61'>61</a>
|
|
121
|
+
<a name='L62'></a><a href='#L62'>62</a>
|
|
122
|
+
<a name='L63'></a><a href='#L63'>63</a>
|
|
123
|
+
<a name='L64'></a><a href='#L64'>64</a>
|
|
124
|
+
<a name='L65'></a><a href='#L65'>65</a>
|
|
125
|
+
<a name='L66'></a><a href='#L66'>66</a>
|
|
126
|
+
<a name='L67'></a><a href='#L67'>67</a>
|
|
127
|
+
<a name='L68'></a><a href='#L68'>68</a>
|
|
128
|
+
<a name='L69'></a><a href='#L69'>69</a>
|
|
129
|
+
<a name='L70'></a><a href='#L70'>70</a>
|
|
130
|
+
<a name='L71'></a><a href='#L71'>71</a>
|
|
131
|
+
<a name='L72'></a><a href='#L72'>72</a>
|
|
132
|
+
<a name='L73'></a><a href='#L73'>73</a>
|
|
133
|
+
<a name='L74'></a><a href='#L74'>74</a>
|
|
134
|
+
<a name='L75'></a><a href='#L75'>75</a>
|
|
135
|
+
<a name='L76'></a><a href='#L76'>76</a>
|
|
136
|
+
<a name='L77'></a><a href='#L77'>77</a>
|
|
137
|
+
<a name='L78'></a><a href='#L78'>78</a>
|
|
138
|
+
<a name='L79'></a><a href='#L79'>79</a>
|
|
139
|
+
<a name='L80'></a><a href='#L80'>80</a>
|
|
140
|
+
<a name='L81'></a><a href='#L81'>81</a>
|
|
141
|
+
<a name='L82'></a><a href='#L82'>82</a>
|
|
142
|
+
<a name='L83'></a><a href='#L83'>83</a>
|
|
143
|
+
<a name='L84'></a><a href='#L84'>84</a>
|
|
144
|
+
<a name='L85'></a><a href='#L85'>85</a>
|
|
145
|
+
<a name='L86'></a><a href='#L86'>86</a>
|
|
146
|
+
<a name='L87'></a><a href='#L87'>87</a>
|
|
147
|
+
<a name='L88'></a><a href='#L88'>88</a>
|
|
148
|
+
<a name='L89'></a><a href='#L89'>89</a>
|
|
149
|
+
<a name='L90'></a><a href='#L90'>90</a>
|
|
150
|
+
<a name='L91'></a><a href='#L91'>91</a>
|
|
151
|
+
<a name='L92'></a><a href='#L92'>92</a>
|
|
152
|
+
<a name='L93'></a><a href='#L93'>93</a>
|
|
153
|
+
<a name='L94'></a><a href='#L94'>94</a>
|
|
154
|
+
<a name='L95'></a><a href='#L95'>95</a>
|
|
155
|
+
<a name='L96'></a><a href='#L96'>96</a>
|
|
156
|
+
<a name='L97'></a><a href='#L97'>97</a>
|
|
157
|
+
<a name='L98'></a><a href='#L98'>98</a>
|
|
158
|
+
<a name='L99'></a><a href='#L99'>99</a>
|
|
159
|
+
<a name='L100'></a><a href='#L100'>100</a>
|
|
160
|
+
<a name='L101'></a><a href='#L101'>101</a>
|
|
161
|
+
<a name='L102'></a><a href='#L102'>102</a>
|
|
162
|
+
<a name='L103'></a><a href='#L103'>103</a>
|
|
163
|
+
<a name='L104'></a><a href='#L104'>104</a>
|
|
164
|
+
<a name='L105'></a><a href='#L105'>105</a>
|
|
165
|
+
<a name='L106'></a><a href='#L106'>106</a>
|
|
166
|
+
<a name='L107'></a><a href='#L107'>107</a>
|
|
167
|
+
<a name='L108'></a><a href='#L108'>108</a>
|
|
168
|
+
<a name='L109'></a><a href='#L109'>109</a>
|
|
169
|
+
<a name='L110'></a><a href='#L110'>110</a>
|
|
170
|
+
<a name='L111'></a><a href='#L111'>111</a>
|
|
171
|
+
<a name='L112'></a><a href='#L112'>112</a>
|
|
172
|
+
<a name='L113'></a><a href='#L113'>113</a>
|
|
173
|
+
<a name='L114'></a><a href='#L114'>114</a>
|
|
174
|
+
<a name='L115'></a><a href='#L115'>115</a>
|
|
175
|
+
<a name='L116'></a><a href='#L116'>116</a>
|
|
176
|
+
<a name='L117'></a><a href='#L117'>117</a>
|
|
177
|
+
<a name='L118'></a><a href='#L118'>118</a>
|
|
178
|
+
<a name='L119'></a><a href='#L119'>119</a>
|
|
179
|
+
<a name='L120'></a><a href='#L120'>120</a>
|
|
180
|
+
<a name='L121'></a><a href='#L121'>121</a>
|
|
181
|
+
<a name='L122'></a><a href='#L122'>122</a>
|
|
182
|
+
<a name='L123'></a><a href='#L123'>123</a>
|
|
183
|
+
<a name='L124'></a><a href='#L124'>124</a>
|
|
184
|
+
<a name='L125'></a><a href='#L125'>125</a>
|
|
185
|
+
<a name='L126'></a><a href='#L126'>126</a>
|
|
186
|
+
<a name='L127'></a><a href='#L127'>127</a>
|
|
187
|
+
<a name='L128'></a><a href='#L128'>128</a>
|
|
188
|
+
<a name='L129'></a><a href='#L129'>129</a>
|
|
189
|
+
<a name='L130'></a><a href='#L130'>130</a>
|
|
190
|
+
<a name='L131'></a><a href='#L131'>131</a>
|
|
191
|
+
<a name='L132'></a><a href='#L132'>132</a>
|
|
192
|
+
<a name='L133'></a><a href='#L133'>133</a>
|
|
193
|
+
<a name='L134'></a><a href='#L134'>134</a>
|
|
194
|
+
<a name='L135'></a><a href='#L135'>135</a>
|
|
195
|
+
<a name='L136'></a><a href='#L136'>136</a>
|
|
196
|
+
<a name='L137'></a><a href='#L137'>137</a>
|
|
197
|
+
<a name='L138'></a><a href='#L138'>138</a>
|
|
198
|
+
<a name='L139'></a><a href='#L139'>139</a>
|
|
199
|
+
<a name='L140'></a><a href='#L140'>140</a>
|
|
200
|
+
<a name='L141'></a><a href='#L141'>141</a>
|
|
201
|
+
<a name='L142'></a><a href='#L142'>142</a>
|
|
202
|
+
<a name='L143'></a><a href='#L143'>143</a>
|
|
203
|
+
<a name='L144'></a><a href='#L144'>144</a>
|
|
204
|
+
<a name='L145'></a><a href='#L145'>145</a>
|
|
205
|
+
<a name='L146'></a><a href='#L146'>146</a>
|
|
206
|
+
<a name='L147'></a><a href='#L147'>147</a>
|
|
207
|
+
<a name='L148'></a><a href='#L148'>148</a>
|
|
208
|
+
<a name='L149'></a><a href='#L149'>149</a>
|
|
209
|
+
<a name='L150'></a><a href='#L150'>150</a>
|
|
210
|
+
<a name='L151'></a><a href='#L151'>151</a>
|
|
211
|
+
<a name='L152'></a><a href='#L152'>152</a>
|
|
212
|
+
<a name='L153'></a><a href='#L153'>153</a>
|
|
213
|
+
<a name='L154'></a><a href='#L154'>154</a>
|
|
214
|
+
<a name='L155'></a><a href='#L155'>155</a>
|
|
215
|
+
<a name='L156'></a><a href='#L156'>156</a>
|
|
216
|
+
<a name='L157'></a><a href='#L157'>157</a>
|
|
217
|
+
<a name='L158'></a><a href='#L158'>158</a>
|
|
218
|
+
<a name='L159'></a><a href='#L159'>159</a>
|
|
219
|
+
<a name='L160'></a><a href='#L160'>160</a>
|
|
220
|
+
<a name='L161'></a><a href='#L161'>161</a>
|
|
221
|
+
<a name='L162'></a><a href='#L162'>162</a>
|
|
222
|
+
<a name='L163'></a><a href='#L163'>163</a>
|
|
223
|
+
<a name='L164'></a><a href='#L164'>164</a>
|
|
224
|
+
<a name='L165'></a><a href='#L165'>165</a>
|
|
225
|
+
<a name='L166'></a><a href='#L166'>166</a>
|
|
226
|
+
<a name='L167'></a><a href='#L167'>167</a>
|
|
227
|
+
<a name='L168'></a><a href='#L168'>168</a>
|
|
228
|
+
<a name='L169'></a><a href='#L169'>169</a>
|
|
229
|
+
<a name='L170'></a><a href='#L170'>170</a>
|
|
230
|
+
<a name='L171'></a><a href='#L171'>171</a>
|
|
231
|
+
<a name='L172'></a><a href='#L172'>172</a>
|
|
232
|
+
<a name='L173'></a><a href='#L173'>173</a>
|
|
233
|
+
<a name='L174'></a><a href='#L174'>174</a>
|
|
234
|
+
<a name='L175'></a><a href='#L175'>175</a>
|
|
235
|
+
<a name='L176'></a><a href='#L176'>176</a>
|
|
236
|
+
<a name='L177'></a><a href='#L177'>177</a>
|
|
237
|
+
<a name='L178'></a><a href='#L178'>178</a>
|
|
238
|
+
<a name='L179'></a><a href='#L179'>179</a>
|
|
239
|
+
<a name='L180'></a><a href='#L180'>180</a>
|
|
240
|
+
<a name='L181'></a><a href='#L181'>181</a>
|
|
241
|
+
<a name='L182'></a><a href='#L182'>182</a>
|
|
242
|
+
<a name='L183'></a><a href='#L183'>183</a>
|
|
243
|
+
<a name='L184'></a><a href='#L184'>184</a>
|
|
244
|
+
<a name='L185'></a><a href='#L185'>185</a>
|
|
245
|
+
<a name='L186'></a><a href='#L186'>186</a>
|
|
246
|
+
<a name='L187'></a><a href='#L187'>187</a>
|
|
247
|
+
<a name='L188'></a><a href='#L188'>188</a>
|
|
248
|
+
<a name='L189'></a><a href='#L189'>189</a>
|
|
249
|
+
<a name='L190'></a><a href='#L190'>190</a>
|
|
250
|
+
<a name='L191'></a><a href='#L191'>191</a>
|
|
251
|
+
<a name='L192'></a><a href='#L192'>192</a>
|
|
252
|
+
<a name='L193'></a><a href='#L193'>193</a>
|
|
253
|
+
<a name='L194'></a><a href='#L194'>194</a>
|
|
254
|
+
<a name='L195'></a><a href='#L195'>195</a>
|
|
255
|
+
<a name='L196'></a><a href='#L196'>196</a>
|
|
256
|
+
<a name='L197'></a><a href='#L197'>197</a>
|
|
257
|
+
<a name='L198'></a><a href='#L198'>198</a>
|
|
258
|
+
<a name='L199'></a><a href='#L199'>199</a>
|
|
259
|
+
<a name='L200'></a><a href='#L200'>200</a>
|
|
260
|
+
<a name='L201'></a><a href='#L201'>201</a>
|
|
261
|
+
<a name='L202'></a><a href='#L202'>202</a>
|
|
262
|
+
<a name='L203'></a><a href='#L203'>203</a>
|
|
263
|
+
<a name='L204'></a><a href='#L204'>204</a>
|
|
264
|
+
<a name='L205'></a><a href='#L205'>205</a>
|
|
265
|
+
<a name='L206'></a><a href='#L206'>206</a>
|
|
266
|
+
<a name='L207'></a><a href='#L207'>207</a>
|
|
267
|
+
<a name='L208'></a><a href='#L208'>208</a>
|
|
268
|
+
<a name='L209'></a><a href='#L209'>209</a>
|
|
269
|
+
<a name='L210'></a><a href='#L210'>210</a>
|
|
270
|
+
<a name='L211'></a><a href='#L211'>211</a>
|
|
271
|
+
<a name='L212'></a><a href='#L212'>212</a>
|
|
272
|
+
<a name='L213'></a><a href='#L213'>213</a>
|
|
273
|
+
<a name='L214'></a><a href='#L214'>214</a>
|
|
274
|
+
<a name='L215'></a><a href='#L215'>215</a>
|
|
275
|
+
<a name='L216'></a><a href='#L216'>216</a>
|
|
276
|
+
<a name='L217'></a><a href='#L217'>217</a>
|
|
277
|
+
<a name='L218'></a><a href='#L218'>218</a>
|
|
278
|
+
<a name='L219'></a><a href='#L219'>219</a>
|
|
279
|
+
<a name='L220'></a><a href='#L220'>220</a>
|
|
280
|
+
<a name='L221'></a><a href='#L221'>221</a>
|
|
281
|
+
<a name='L222'></a><a href='#L222'>222</a>
|
|
282
|
+
<a name='L223'></a><a href='#L223'>223</a>
|
|
283
|
+
<a name='L224'></a><a href='#L224'>224</a>
|
|
284
|
+
<a name='L225'></a><a href='#L225'>225</a></td><td class="line-coverage quiet"><span class="cline-any cline-yes">1x</span>
|
|
285
|
+
<span class="cline-any cline-yes">1x</span>
|
|
286
|
+
<span class="cline-any cline-yes">1x</span>
|
|
287
|
+
<span class="cline-any cline-yes">1x</span>
|
|
288
|
+
<span class="cline-any cline-yes">1x</span>
|
|
289
|
+
<span class="cline-any cline-yes">1x</span>
|
|
290
|
+
<span class="cline-any cline-yes">1x</span>
|
|
291
|
+
<span class="cline-any cline-yes">1x</span>
|
|
292
|
+
<span class="cline-any cline-yes">1x</span>
|
|
293
|
+
<span class="cline-any cline-yes">1x</span>
|
|
294
|
+
<span class="cline-any cline-yes">18x</span>
|
|
295
|
+
<span class="cline-any cline-yes">18x</span>
|
|
296
|
+
<span class="cline-any cline-yes">18x</span>
|
|
297
|
+
<span class="cline-any cline-yes">18x</span>
|
|
298
|
+
<span class="cline-any cline-yes">18x</span>
|
|
299
|
+
<span class="cline-any cline-yes">18x</span>
|
|
300
|
+
<span class="cline-any cline-yes">18x</span>
|
|
301
|
+
<span class="cline-any cline-yes">18x</span>
|
|
302
|
+
<span class="cline-any cline-yes">18x</span>
|
|
303
|
+
<span class="cline-any cline-yes">18x</span>
|
|
304
|
+
<span class="cline-any cline-yes">18x</span>
|
|
305
|
+
<span class="cline-any cline-yes">18x</span>
|
|
306
|
+
<span class="cline-any cline-yes">18x</span>
|
|
307
|
+
<span class="cline-any cline-yes">18x</span>
|
|
308
|
+
<span class="cline-any cline-yes">18x</span>
|
|
309
|
+
<span class="cline-any cline-yes">18x</span>
|
|
310
|
+
<span class="cline-any cline-yes">18x</span>
|
|
311
|
+
<span class="cline-any cline-yes">18x</span>
|
|
312
|
+
<span class="cline-any cline-yes">18x</span>
|
|
313
|
+
<span class="cline-any cline-yes">18x</span>
|
|
314
|
+
<span class="cline-any cline-yes">18x</span>
|
|
315
|
+
<span class="cline-any cline-yes">18x</span>
|
|
316
|
+
<span class="cline-any cline-yes">18x</span>
|
|
317
|
+
<span class="cline-any cline-yes">18x</span>
|
|
318
|
+
<span class="cline-any cline-yes">18x</span>
|
|
319
|
+
<span class="cline-any cline-yes">18x</span>
|
|
320
|
+
<span class="cline-any cline-yes">34x</span>
|
|
321
|
+
<span class="cline-any cline-yes">34x</span>
|
|
322
|
+
<span class="cline-any cline-yes">34x</span>
|
|
323
|
+
<span class="cline-any cline-yes">34x</span>
|
|
324
|
+
<span class="cline-any cline-yes">34x</span>
|
|
325
|
+
<span class="cline-any cline-yes">32x</span>
|
|
326
|
+
<span class="cline-any cline-yes">34x</span>
|
|
327
|
+
<span class="cline-any cline-yes">34x</span>
|
|
328
|
+
<span class="cline-any cline-yes">34x</span>
|
|
329
|
+
<span class="cline-any cline-yes">12x</span>
|
|
330
|
+
<span class="cline-any cline-yes">12x</span>
|
|
331
|
+
<span class="cline-any cline-yes">12x</span>
|
|
332
|
+
<span class="cline-any cline-no"> </span>
|
|
333
|
+
<span class="cline-any cline-no"> </span>
|
|
334
|
+
<span class="cline-any cline-yes">34x</span>
|
|
335
|
+
<span class="cline-any cline-yes">34x</span>
|
|
336
|
+
<span class="cline-any cline-yes">34x</span>
|
|
337
|
+
<span class="cline-any cline-yes">34x</span>
|
|
338
|
+
<span class="cline-any cline-yes">18x</span>
|
|
339
|
+
<span class="cline-any cline-yes">18x</span>
|
|
340
|
+
<span class="cline-any cline-yes">18x</span>
|
|
341
|
+
<span class="cline-any cline-yes">34x</span>
|
|
342
|
+
<span class="cline-any cline-yes">22x</span>
|
|
343
|
+
<span class="cline-any cline-yes">22x</span>
|
|
344
|
+
<span class="cline-any cline-yes">34x</span>
|
|
345
|
+
<span class="cline-any cline-yes">34x</span>
|
|
346
|
+
<span class="cline-any cline-yes">18x</span>
|
|
347
|
+
<span class="cline-any cline-yes">18x</span>
|
|
348
|
+
<span class="cline-any cline-yes">18x</span>
|
|
349
|
+
<span class="cline-any cline-yes">6x</span>
|
|
350
|
+
<span class="cline-any cline-yes">6x</span>
|
|
351
|
+
<span class="cline-any cline-yes">6x</span>
|
|
352
|
+
<span class="cline-any cline-yes">18x</span>
|
|
353
|
+
<span class="cline-any cline-yes">18x</span>
|
|
354
|
+
<span class="cline-any cline-yes">18x</span>
|
|
355
|
+
<span class="cline-any cline-yes">18x</span>
|
|
356
|
+
<span class="cline-any cline-yes">18x</span>
|
|
357
|
+
<span class="cline-any cline-yes">18x</span>
|
|
358
|
+
<span class="cline-any cline-yes">18x</span>
|
|
359
|
+
<span class="cline-any cline-yes">18x</span>
|
|
360
|
+
<span class="cline-any cline-yes">18x</span>
|
|
361
|
+
<span class="cline-any cline-yes">18x</span>
|
|
362
|
+
<span class="cline-any cline-yes">18x</span>
|
|
363
|
+
<span class="cline-any cline-yes">70x</span>
|
|
364
|
+
<span class="cline-any cline-yes">70x</span>
|
|
365
|
+
<span class="cline-any cline-yes">1x</span>
|
|
366
|
+
<span class="cline-any cline-yes">1x</span>
|
|
367
|
+
<span class="cline-any cline-yes">69x</span>
|
|
368
|
+
<span class="cline-any cline-yes">70x</span>
|
|
369
|
+
<span class="cline-any cline-yes">23x</span>
|
|
370
|
+
<span class="cline-any cline-yes">23x</span>
|
|
371
|
+
<span class="cline-any cline-yes">23x</span>
|
|
372
|
+
<span class="cline-any cline-yes">46x</span>
|
|
373
|
+
<span class="cline-any cline-yes">46x</span>
|
|
374
|
+
<span class="cline-any cline-yes">70x</span>
|
|
375
|
+
<span class="cline-any cline-yes">70x</span>
|
|
376
|
+
<span class="cline-any cline-yes">70x</span>
|
|
377
|
+
<span class="cline-any cline-yes">70x</span>
|
|
378
|
+
<span class="cline-any cline-yes">16x</span>
|
|
379
|
+
<span class="cline-any cline-yes">70x</span>
|
|
380
|
+
<span class="cline-any cline-yes">30x</span>
|
|
381
|
+
<span class="cline-any cline-yes">30x</span>
|
|
382
|
+
<span class="cline-any cline-yes">46x</span>
|
|
383
|
+
<span class="cline-any cline-yes">70x</span>
|
|
384
|
+
<span class="cline-any cline-yes">70x</span>
|
|
385
|
+
<span class="cline-any cline-no"> </span>
|
|
386
|
+
<span class="cline-any cline-no"> </span>
|
|
387
|
+
<span class="cline-any cline-no"> </span>
|
|
388
|
+
<span class="cline-any cline-no"> </span>
|
|
389
|
+
<span class="cline-any cline-no"> </span>
|
|
390
|
+
<span class="cline-any cline-no"> </span>
|
|
391
|
+
<span class="cline-any cline-yes">70x</span>
|
|
392
|
+
<span class="cline-any cline-yes">70x</span>
|
|
393
|
+
<span class="cline-any cline-yes">46x</span>
|
|
394
|
+
<span class="cline-any cline-yes">46x</span>
|
|
395
|
+
<span class="cline-any cline-yes">46x</span>
|
|
396
|
+
<span class="cline-any cline-yes">46x</span>
|
|
397
|
+
<span class="cline-any cline-yes">46x</span>
|
|
398
|
+
<span class="cline-any cline-yes">46x</span>
|
|
399
|
+
<span class="cline-any cline-no"> </span>
|
|
400
|
+
<span class="cline-any cline-yes">46x</span>
|
|
401
|
+
<span class="cline-any cline-yes">46x</span>
|
|
402
|
+
<span class="cline-any cline-yes">46x</span>
|
|
403
|
+
<span class="cline-any cline-yes">46x</span>
|
|
404
|
+
<span class="cline-any cline-yes">70x</span>
|
|
405
|
+
<span class="cline-any cline-yes">70x</span>
|
|
406
|
+
<span class="cline-any cline-no"> </span>
|
|
407
|
+
<span class="cline-any cline-yes">70x</span>
|
|
408
|
+
<span class="cline-any cline-yes">70x</span>
|
|
409
|
+
<span class="cline-any cline-yes">70x</span>
|
|
410
|
+
<span class="cline-any cline-yes">70x</span>
|
|
411
|
+
<span class="cline-any cline-yes">70x</span>
|
|
412
|
+
<span class="cline-any cline-yes">70x</span>
|
|
413
|
+
<span class="cline-any cline-yes">70x</span>
|
|
414
|
+
<span class="cline-any cline-yes">70x</span>
|
|
415
|
+
<span class="cline-any cline-yes">70x</span>
|
|
416
|
+
<span class="cline-any cline-yes">115x</span>
|
|
417
|
+
<span class="cline-any cline-yes">115x</span>
|
|
418
|
+
<span class="cline-any cline-yes">115x</span>
|
|
419
|
+
<span class="cline-any cline-yes">85x</span>
|
|
420
|
+
<span class="cline-any cline-yes">85x</span>
|
|
421
|
+
<span class="cline-any cline-yes">85x</span>
|
|
422
|
+
<span class="cline-any cline-yes">39x</span>
|
|
423
|
+
<span class="cline-any cline-yes">39x</span>
|
|
424
|
+
<span class="cline-any cline-yes">39x</span>
|
|
425
|
+
<span class="cline-any cline-yes">39x</span>
|
|
426
|
+
<span class="cline-any cline-yes">39x</span>
|
|
427
|
+
<span class="cline-any cline-yes">39x</span>
|
|
428
|
+
<span class="cline-any cline-yes">39x</span>
|
|
429
|
+
<span class="cline-any cline-yes">39x</span>
|
|
430
|
+
<span class="cline-any cline-yes">39x</span>
|
|
431
|
+
<span class="cline-any cline-yes">39x</span>
|
|
432
|
+
<span class="cline-any cline-yes">39x</span>
|
|
433
|
+
<span class="cline-any cline-yes">39x</span>
|
|
434
|
+
<span class="cline-any cline-no"> </span>
|
|
435
|
+
<span class="cline-any cline-no"> </span>
|
|
436
|
+
<span class="cline-any cline-yes">39x</span>
|
|
437
|
+
<span class="cline-any cline-yes">39x</span>
|
|
438
|
+
<span class="cline-any cline-yes">39x</span>
|
|
439
|
+
<span class="cline-any cline-yes">39x</span>
|
|
440
|
+
<span class="cline-any cline-yes">85x</span>
|
|
441
|
+
<span class="cline-any cline-yes">76x</span>
|
|
442
|
+
<span class="cline-any cline-yes">76x</span>
|
|
443
|
+
<span class="cline-any cline-yes">115x</span>
|
|
444
|
+
<span class="cline-any cline-yes">70x</span>
|
|
445
|
+
<span class="cline-any cline-yes">70x</span>
|
|
446
|
+
<span class="cline-any cline-yes">70x</span>
|
|
447
|
+
<span class="cline-any cline-yes">70x</span>
|
|
448
|
+
<span class="cline-any cline-yes">70x</span>
|
|
449
|
+
<span class="cline-any cline-yes">70x</span>
|
|
450
|
+
<span class="cline-any cline-yes">70x</span>
|
|
451
|
+
<span class="cline-any cline-yes">70x</span>
|
|
452
|
+
<span class="cline-any cline-yes">70x</span>
|
|
453
|
+
<span class="cline-any cline-yes">30x</span>
|
|
454
|
+
<span class="cline-any cline-yes">30x</span>
|
|
455
|
+
<span class="cline-any cline-no"> </span>
|
|
456
|
+
<span class="cline-any cline-yes">30x</span>
|
|
457
|
+
<span class="cline-any cline-yes">30x</span>
|
|
458
|
+
<span class="cline-any cline-yes">30x</span>
|
|
459
|
+
<span class="cline-any cline-yes">30x</span>
|
|
460
|
+
<span class="cline-any cline-yes">30x</span>
|
|
461
|
+
<span class="cline-any cline-yes">70x</span>
|
|
462
|
+
<span class="cline-any cline-yes">70x</span>
|
|
463
|
+
<span class="cline-any cline-yes">70x</span>
|
|
464
|
+
<span class="cline-any cline-yes">70x</span>
|
|
465
|
+
<span class="cline-any cline-yes">70x</span>
|
|
466
|
+
<span class="cline-any cline-yes">70x</span>
|
|
467
|
+
<span class="cline-any cline-yes">70x</span>
|
|
468
|
+
<span class="cline-any cline-yes">70x</span>
|
|
469
|
+
<span class="cline-any cline-yes">30x</span>
|
|
470
|
+
<span class="cline-any cline-yes">30x</span>
|
|
471
|
+
<span class="cline-any cline-no"> </span>
|
|
472
|
+
<span class="cline-any cline-yes">30x</span>
|
|
473
|
+
<span class="cline-any cline-yes">30x</span>
|
|
474
|
+
<span class="cline-any cline-yes">30x</span>
|
|
475
|
+
<span class="cline-any cline-yes">30x</span>
|
|
476
|
+
<span class="cline-any cline-yes">30x</span>
|
|
477
|
+
<span class="cline-any cline-yes">18x</span>
|
|
478
|
+
<span class="cline-any cline-yes">18x</span>
|
|
479
|
+
<span class="cline-any cline-yes">18x</span>
|
|
480
|
+
<span class="cline-any cline-yes">18x</span>
|
|
481
|
+
<span class="cline-any cline-yes">18x</span>
|
|
482
|
+
<span class="cline-any cline-yes">18x</span>
|
|
483
|
+
<span class="cline-any cline-yes">18x</span>
|
|
484
|
+
<span class="cline-any cline-yes">18x</span>
|
|
485
|
+
<span class="cline-any cline-yes">18x</span>
|
|
486
|
+
<span class="cline-any cline-yes">24x</span>
|
|
487
|
+
<span class="cline-any cline-yes">24x</span>
|
|
488
|
+
<span class="cline-any cline-yes">24x</span>
|
|
489
|
+
<span class="cline-any cline-yes">24x</span>
|
|
490
|
+
<span class="cline-any cline-yes">24x</span>
|
|
491
|
+
<span class="cline-any cline-yes">18x</span>
|
|
492
|
+
<span class="cline-any cline-yes">18x</span>
|
|
493
|
+
<span class="cline-any cline-yes">18x</span>
|
|
494
|
+
<span class="cline-any cline-yes">18x</span>
|
|
495
|
+
<span class="cline-any cline-yes">18x</span>
|
|
496
|
+
<span class="cline-any cline-yes">18x</span>
|
|
497
|
+
<span class="cline-any cline-yes">18x</span>
|
|
498
|
+
<span class="cline-any cline-yes">18x</span>
|
|
499
|
+
<span class="cline-any cline-yes">18x</span>
|
|
500
|
+
<span class="cline-any cline-yes">18x</span>
|
|
501
|
+
<span class="cline-any cline-yes">12x</span>
|
|
502
|
+
<span class="cline-any cline-yes">12x</span>
|
|
503
|
+
<span class="cline-any cline-yes">12x</span>
|
|
504
|
+
<span class="cline-any cline-yes">18x</span>
|
|
505
|
+
<span class="cline-any cline-yes">18x</span>
|
|
506
|
+
<span class="cline-any cline-yes">18x</span>
|
|
507
|
+
<span class="cline-any cline-yes">1x</span>
|
|
508
|
+
<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">"use strict";
|
|
509
|
+
|
|
510
|
+
const crypto = require( "crypto" );
|
|
511
|
+
|
|
512
|
+
/**
|
|
513
|
+
* Defines user model.
|
|
514
|
+
*
|
|
515
|
+
* @returns {Hitchy.Plugin.Odem.ModelSchema} definition of user model
|
|
516
|
+
*/
|
|
517
|
+
module.exports = function() {
|
|
518
|
+
const api = this;
|
|
519
|
+
const { services, models } = api.runtime;
|
|
520
|
+
|
|
521
|
+
/**
|
|
522
|
+
* Implements model of a user suitable for authenticating as.
|
|
523
|
+
*
|
|
524
|
+
* @property {string} name unique name of user
|
|
525
|
+
* @property {string} role name of user's role (user-role relationship is 1:n)
|
|
526
|
+
* @property {string} password hash of user's password required for authenticating as
|
|
527
|
+
* @property {string} strategy name of passport strategy used for authentication
|
|
528
|
+
* @property {string} strategyData additional information specific to strategy used
|
|
529
|
+
*
|
|
530
|
+
* @name Hitchy.Plugin.Auth.User
|
|
531
|
+
*/
|
|
532
|
+
return {
|
|
533
|
+
props: {
|
|
534
|
+
name: {
|
|
535
|
+
required: true,
|
|
536
|
+
unique: true,
|
|
537
|
+
},
|
|
538
|
+
password: {},
|
|
539
|
+
strategy: {},
|
|
540
|
+
strategyData: {},
|
|
541
|
+
},
|
|
542
|
+
hooks: {
|
|
543
|
+
afterValidate( errors ) {
|
|
544
|
+
if ( !errors.length ) {
|
|
545
|
+
const strategy = this.strategy || services.AuthenticationStrategies.defaultStrategy();
|
|
546
|
+
|
|
547
|
+
switch ( strategy ) {
|
|
548
|
+
case "local" :
|
|
549
|
+
if ( this.password ) break;
|
|
550
|
+
|
|
551
|
+
// falls through
|
|
552
|
+
default :
|
|
553
|
+
if ( !api.config.auth.strategies[strategy].passwordRequired <span class="branch-0 cbranch-no" title="branch not covered" >|| this.password </span>) {
|
|
554
|
+
break;
|
|
555
|
+
}
|
|
556
|
+
<span class="cstat-no" title="statement not covered" ><span class="branch-0 cbranch-no" title="branch not covered" ></span></span>
|
|
557
|
+
<span class="cstat-no" title="statement not covered" > errors.push( new TypeError( "password required" ) );</span>
|
|
558
|
+
}
|
|
559
|
+
}
|
|
560
|
+
|
|
561
|
+
return errors;
|
|
562
|
+
},
|
|
563
|
+
|
|
564
|
+
async beforeSave( existsAlready, record ) {
|
|
565
|
+
if ( record.password ) {
|
|
566
|
+
record.password = await this.hashPassword( record.password ); // eslint-disable-line no-param-reassign
|
|
567
|
+
}
|
|
568
|
+
|
|
569
|
+
return record;
|
|
570
|
+
},
|
|
571
|
+
|
|
572
|
+
async afterRemove() {
|
|
573
|
+
const associations = await models.UserToRole.find( { eq: { name: "user", value: this.$uuid } } );
|
|
574
|
+
|
|
575
|
+
await Promise.all( associations.map( association => association.remove() ) );
|
|
576
|
+
},
|
|
577
|
+
},
|
|
578
|
+
methods: {
|
|
579
|
+
/**
|
|
580
|
+
* Derives salted hash from provided password.
|
|
581
|
+
*
|
|
582
|
+
* @param {Buffer|string} cleartext cleartext password to be hashed
|
|
583
|
+
* @param {Buffer|string} previous previously derived hash containing salt to use again for comparing results
|
|
584
|
+
* @returns {Promise<string>} promise for salted hash of provided cleartext password
|
|
585
|
+
*/
|
|
586
|
+
async hashPassword( cleartext, previous = null ) {
|
|
587
|
+
const normalized = Buffer.isBuffer( cleartext ) <span class="branch-0 cbranch-no" title="branch not covered" >? cleartext.toString( "utf8" ) </span>: typeof cleartext === "string" ? cleartext : null;
|
|
588
|
+
if ( !normalized ) {
|
|
589
|
+
throw new TypeError( "missing or invalid cleartext password to be hashed" );
|
|
590
|
+
}
|
|
591
|
+
|
|
592
|
+
if ( parseHashed( cleartext ) ) {
|
|
593
|
+
// `cleartext` is actually some previously derived hash already -> pass
|
|
594
|
+
return cleartext;
|
|
595
|
+
}
|
|
596
|
+
|
|
597
|
+
const parsedPrevious = parseHashed( previous );
|
|
598
|
+
const algorithmName = parsedPrevious && parsedPrevious.algorithm;
|
|
599
|
+
let salt;
|
|
600
|
+
|
|
601
|
+
if ( parsedPrevious && parsedPrevious.salt ) {
|
|
602
|
+
salt = parsedPrevious.salt;
|
|
603
|
+
} else {
|
|
604
|
+
salt = await randomOctets( await randomNumber( 16, 32 ) );
|
|
605
|
+
}
|
|
606
|
+
|
|
607
|
+
switch ( algorithmName || "SCRYPT" ) {
|
|
608
|
+
<span class="branch-0 cbranch-no" title="branch not covered" > case "SSHA512" : {</span>
|
|
609
|
+
<span class="cstat-no" title="statement not covered" > const hash = crypto.createHash( "SHA512" );</span>
|
|
610
|
+
<span class="cstat-no" title="statement not covered" > hash.update( normalized );</span>
|
|
611
|
+
<span class="cstat-no" title="statement not covered" > hash.update( salt );</span>
|
|
612
|
+
<span class="cstat-no" title="statement not covered" ></span>
|
|
613
|
+
<span class="cstat-no" title="statement not covered" > return "{SSHA512}" + Buffer.concat( [ hash.digest(), salt ] ).toString( "base64" );</span>
|
|
614
|
+
<span class="cstat-no" title="statement not covered" > }</span>
|
|
615
|
+
|
|
616
|
+
case "SCRYPT" :
|
|
617
|
+
return await new Promise( ( resolve, reject ) => crypto.scrypt( normalized, salt, 64, {
|
|
618
|
+
cost: 16384,
|
|
619
|
+
blockSize: 8,
|
|
620
|
+
parallelization: 1,
|
|
621
|
+
}, ( error, hash ) => {
|
|
622
|
+
if ( error ) <span class="branch-0 cbranch-no" title="branch not covered" >{</span>
|
|
623
|
+
<span class="cstat-no" title="statement not covered" > reject( error );</span>
|
|
624
|
+
} else {
|
|
625
|
+
resolve( "{SCRYPT}" + Buffer.concat( [ hash, salt ] ).toString( "base64" ) );
|
|
626
|
+
}
|
|
627
|
+
} ) );
|
|
628
|
+
|
|
629
|
+
<span class="branch-0 cbranch-no" title="branch not covered" > default :</span>
|
|
630
|
+
<span class="cstat-no" title="statement not covered" > throw new TypeError( `unsupported keyword hashing algorithm: ${algorithmName}` );</span>
|
|
631
|
+
}
|
|
632
|
+
|
|
633
|
+
/**
|
|
634
|
+
* Extracts elements of provided hash.
|
|
635
|
+
*
|
|
636
|
+
* @param {string|Buffer} input some hash to be parsed
|
|
637
|
+
* @returns {object} extracted elements of provided hash, nullish if extraction failed
|
|
638
|
+
*/
|
|
639
|
+
function parseHashed( input ) {
|
|
640
|
+
const _input = Buffer.isBuffer( input ) <span class="branch-0 cbranch-no" title="branch not covered" >? input.toString( "utf8" ) </span>: typeof input === "string" ? input : null;
|
|
641
|
+
|
|
642
|
+
if ( _input ) {
|
|
643
|
+
const match = /^{([a-z0-9]+)}/i.exec( _input );
|
|
644
|
+
|
|
645
|
+
if ( match ) {
|
|
646
|
+
const algorithm = match[1].toUpperCase();
|
|
647
|
+
const raw = Buffer.from( _input.slice( algorithm.length + 2 ), "base64" );
|
|
648
|
+
let hash, salt; // eslint-disable-line no-shadow
|
|
649
|
+
|
|
650
|
+
switch ( algorithm ) {
|
|
651
|
+
<span class="branch-0 cbranch-no" title="branch not covered" > case "SSHA512" :</span>
|
|
652
|
+
case "SCRYPT" :
|
|
653
|
+
hash = raw.slice( 0, 64 );
|
|
654
|
+
salt = raw.slice( 64 );
|
|
655
|
+
break;
|
|
656
|
+
|
|
657
|
+
<span class="branch-0 cbranch-no" title="branch not covered" > default :</span>
|
|
658
|
+
<span class="cstat-no" title="statement not covered" > hash = raw;</span>
|
|
659
|
+
<span class="cstat-no" title="statement not covered" > salt = null;</span>
|
|
660
|
+
}
|
|
661
|
+
|
|
662
|
+
return { algorithm, raw, hash, salt, compiled: `{${algorithm}` + raw.toString( "base64" ) };
|
|
663
|
+
}
|
|
664
|
+
}
|
|
665
|
+
|
|
666
|
+
return null;
|
|
667
|
+
}
|
|
668
|
+
|
|
669
|
+
/**
|
|
670
|
+
* Promises random integer in selected range.
|
|
671
|
+
*
|
|
672
|
+
* @param {number} min minimum value (inclusive)
|
|
673
|
+
* @param {number} max maximum value (exclusive)
|
|
674
|
+
* @returns {Promise<number>} promise for random integer in selected range
|
|
675
|
+
*/
|
|
676
|
+
function randomNumber( min, max ) {
|
|
677
|
+
return new Promise( ( resolve, reject ) => crypto.randomInt( min, max, ( error, number ) => {
|
|
678
|
+
if ( error ) <span class="branch-0 cbranch-no" title="branch not covered" >{</span>
|
|
679
|
+
<span class="cstat-no" title="statement not covered" > reject( error );</span>
|
|
680
|
+
} else {
|
|
681
|
+
resolve( number );
|
|
682
|
+
}
|
|
683
|
+
} ) );
|
|
684
|
+
}
|
|
685
|
+
|
|
686
|
+
/**
|
|
687
|
+
* Promises selected number of octets with random values.
|
|
688
|
+
*
|
|
689
|
+
* @param {number} size number of octets to generate
|
|
690
|
+
* @returns {Promise<Buffer>} promise for selected number of random octets
|
|
691
|
+
*/
|
|
692
|
+
function randomOctets( size ) {
|
|
693
|
+
return new Promise( ( resolve, reject ) => crypto.randomBytes( size, ( error, octets ) => {
|
|
694
|
+
if ( error ) <span class="branch-0 cbranch-no" title="branch not covered" >{</span>
|
|
695
|
+
<span class="cstat-no" title="statement not covered" > reject( error );</span>
|
|
696
|
+
} else {
|
|
697
|
+
resolve( octets );
|
|
698
|
+
}
|
|
699
|
+
} ) );
|
|
700
|
+
}
|
|
701
|
+
},
|
|
702
|
+
|
|
703
|
+
/**
|
|
704
|
+
* Derives and saves salted hash from provided password.
|
|
705
|
+
*
|
|
706
|
+
* @param {string} password cleartext password to be hashed and saved
|
|
707
|
+
* @return {Promise<string>} promises derived hash set as password
|
|
708
|
+
*/
|
|
709
|
+
async setPassword( password ) {
|
|
710
|
+
const hashed = await this.hashPassword( password );
|
|
711
|
+
|
|
712
|
+
this.password = hashed;
|
|
713
|
+
|
|
714
|
+
return hashed;
|
|
715
|
+
},
|
|
716
|
+
|
|
717
|
+
/**
|
|
718
|
+
* Derives and compares salted hash from provided password with
|
|
719
|
+
* saved password.
|
|
720
|
+
*
|
|
721
|
+
* @param {string} password cleartext password to be hashed and verified with saved one
|
|
722
|
+
* @return {Promise<boolean>} promises true if password hashes match
|
|
723
|
+
*/
|
|
724
|
+
async verifyPassword( password ) {
|
|
725
|
+
await this.load();
|
|
726
|
+
|
|
727
|
+
return this.password === await this.hashPassword( password, this.password );
|
|
728
|
+
},
|
|
729
|
+
},
|
|
730
|
+
};
|
|
731
|
+
};
|
|
732
|
+
</pre></td></tr></table></pre>
|
|
733
|
+
|
|
734
|
+
<div class='push'></div><!-- for sticky footer -->
|
|
735
|
+
</div><!-- /wrapper -->
|
|
736
|
+
<div class='footer quiet pad2 space-top1 center small'>
|
|
737
|
+
Code coverage generated by
|
|
738
|
+
<a href="https://istanbul.js.org/" target="_blank">istanbul</a>
|
|
739
|
+
at Sun Mar 27 2022 18:00:09 GMT+0200 (Mitteleuropäische Sommerzeit)
|
|
740
|
+
</div>
|
|
741
|
+
</div>
|
|
742
|
+
<script src="../../../prettify.js"></script>
|
|
743
|
+
<script>
|
|
744
|
+
window.onload = function () {
|
|
745
|
+
prettyPrint();
|
|
746
|
+
};
|
|
747
|
+
</script>
|
|
748
|
+
<script src="../../../sorter.js"></script>
|
|
749
|
+
<script src="../../../block-navigation.js"></script>
|
|
750
|
+
</body>
|
|
751
|
+
</html>
|
|
752
|
+
|