@simplewebauthn/browser 5.2.1 → 5.4.1
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/dist/bundle/index.es5.umd.min.js +2 -2
- package/dist/bundle/index.js +49 -4
- package/dist/bundle/index.umd.min.js +2 -2
- package/dist/types/helpers/base64URLStringToBuffer.d.ts +1 -1
- package/dist/types/helpers/browserSupportsWebAuthnAutofill.d.ts +1 -0
- package/dist/types/helpers/bufferToBase64URLString.d.ts +1 -1
- package/dist/types/helpers/bufferToUTF8String.d.ts +1 -1
- package/dist/types/helpers/toPublicKeyCredentialDescriptor.d.ts +1 -1
- package/dist/types/helpers/utf8StringToBuffer.d.ts +1 -1
- package/dist/types/helpers/webAuthnAbortService.d.ts +7 -0
- package/dist/types/index.d.ts +4 -3
- package/dist/types/methods/startAuthentication.d.ts +1 -1
- package/dist/types/methods/startRegistration.d.ts +1 -1
- package/jest-environment.js +4 -4
- package/package.json +4 -3
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
/* [@simplewebauthn/browser
|
|
2
|
-
!function(e,
|
|
1
|
+
/* [@simplewebauthn/browser@5.4.1] */
|
|
2
|
+
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).SimpleWebAuthnBrowser={})}(this,(function(e){"use strict";var t=function(e,r){return t=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])},t(e,r)};var r=function(){return r=Object.assign||function(e){for(var t,r=1,n=arguments.length;r<n;r++)for(var o in t=arguments[r])Object.prototype.hasOwnProperty.call(t,o)&&(e[o]=t[o]);return e},r.apply(this,arguments)};function n(e,t,r,n){return new(r||(r=Promise))((function(o,i){function a(e){try{u(n.next(e))}catch(e){i(e)}}function l(e){try{u(n.throw(e))}catch(e){i(e)}}function u(e){var t;e.done?o(e.value):(t=e.value,t instanceof r?t:new r((function(e){e(t)}))).then(a,l)}u((n=n.apply(e,t||[])).next())}))}function o(e,t){var r,n,o,i,a={label:0,sent:function(){if(1&o[0])throw o[1];return o[1]},trys:[],ops:[]};return i={next:l(0),throw:l(1),return:l(2)},"function"==typeof Symbol&&(i[Symbol.iterator]=function(){return this}),i;function l(i){return function(l){return function(i){if(r)throw new TypeError("Generator is already executing.");for(;a;)try{if(r=1,n&&(o=2&i[0]?n.return:i[0]?n.throw||((o=n.return)&&o.call(n),0):n.next)&&!(o=o.call(n,i[1])).done)return o;switch(n=0,o&&(i=[2&i[0],o.value]),i[0]){case 0:case 1:o=i;break;case 4:return a.label++,{value:i[1],done:!1};case 5:a.label++,n=i[1],i=[0];continue;case 7:i=a.ops.pop(),a.trys.pop();continue;default:if(!(o=a.trys,(o=o.length>0&&o[o.length-1])||6!==i[0]&&2!==i[0])){a=0;continue}if(3===i[0]&&(!o||i[1]>o[0]&&i[1]<o[3])){a.label=i[1];break}if(6===i[0]&&a.label<o[1]){a.label=o[1],o=i;break}if(o&&a.label<o[2]){a.label=o[2],a.ops.push(i);break}o[2]&&a.ops.pop(),a.trys.pop();continue}i=t.call(e,a)}catch(e){i=[6,e],n=0}finally{r=o=0}if(5&i[0])throw i[1];return{value:i[0]?i[1]:void 0,done:!0}}([i,l])}}}function i(e){var t,r,n=new Uint8Array(e),o="";try{for(var i=function(e){var t="function"==typeof Symbol&&Symbol.iterator,r=t&&e[t],n=0;if(r)return r.call(e);if(e&&"number"==typeof e.length)return{next:function(){return e&&n>=e.length&&(e=void 0),{value:e&&e[n++],done:!e}}};throw new TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")}(n),a=i.next();!a.done;a=i.next()){var l=a.value;o+=String.fromCharCode(l)}}catch(e){t={error:e}}finally{try{a&&!a.done&&(r=i.return)&&r.call(i)}finally{if(t)throw t.error}}return btoa(o).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function a(e){for(var t=e.replace(/-/g,"+").replace(/_/g,"/"),r=(4-t.length%4)%4,n=t.padEnd(t.length+r,"="),o=atob(n),i=new ArrayBuffer(o.length),a=new Uint8Array(i),l=0;l<o.length;l++)a[l]=o.charCodeAt(l);return i}function l(){return void 0!==(null===window||void 0===window?void 0:window.PublicKeyCredential)&&"function"==typeof window.PublicKeyCredential}function u(e){var t=e.id;return r(r({},e),{id:a(t),transports:e.transports})}function s(e){return"localhost"===e||/^([a-z0-9]+(-[a-z0-9]+)*\.)+[a-z]{2,}$/i.test(e)}var c=function(e){function r(t,r){void 0===r&&(r="WebAuthnError");var n=e.call(this,t)||this;return n.name=r,n}return function(e,r){if("function"!=typeof r&&null!==r)throw new TypeError("Class extends value "+String(r)+" is not a constructor or null");function n(){this.constructor=e}t(e,r),e.prototype=null===r?Object.create(r):(n.prototype=r.prototype,new n)}(r,e),r}(Error);var d=new(function(){function e(){}return e.prototype.createNewAbortSignal=function(){return this.controller&&this.controller.abort(),this.controller=new AbortController,this.controller.signal},e.prototype.reset=function(){this.controller=void 0},e}());function f(){return n(this,void 0,void 0,(function(){var e;return o(this,(function(t){return navigator.credentials.conditionalMediationSupported?[2,!0]:[2,void 0!==(e=window.PublicKeyCredential).isConditionalMediationAvailable&&e.isConditionalMediationAvailable()]}))}))}e.browserSupportsWebAuthnAutofill=f,e.browserSupportsWebauthn=l,e.platformAuthenticatorIsAvailable=function(){return n(this,void 0,void 0,(function(){return o(this,(function(e){return l()?[2,PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable()]:[2,!1]}))}))},e.startAuthentication=function(e,t){var p,h;return void 0===t&&(t=!1),n(this,void 0,void 0,(function(){var n,w,b,y,v,g,m,E,A;return o(this,(function(o){switch(o.label){case 0:if(!l())throw new Error("WebAuthn is not supported in this browser");return 0!==(null===(p=e.allowCredentials)||void 0===p?void 0:p.length)&&(n=null===(h=e.allowCredentials)||void 0===h?void 0:h.map(u)),w=r(r({},e),{challenge:a(e.challenge),allowCredentials:n}),b={},t?[4,f()]:[3,2];case 1:if(!o.sent())throw Error("Browser does not support WebAuthn autofill");if(document.querySelectorAll("input[autocomplete*='webauthn']").length<1)throw Error('No <input> with `"webauthn"` in its `autocomplete` attribute was detected');b.mediation="conditional",w.allowCredentials=[],o.label=2;case 2:b.publicKey=w,b.signal=d.createNewAbortSignal(),o.label=3;case 3:return o.trys.push([3,5,6,7]),[4,navigator.credentials.get(b)];case 4:return y=o.sent(),[3,7];case 5:throw function(e){var t,r=e.error,n=e.options,o=n.publicKey;if(!o)throw Error("options was missing required publicKey property");if("AbortError"===r.name){if(n.signal===(new AbortController).signal)return new c("Authentication ceremony was sent an abort signal","AbortError")}else{if("NotAllowedError"===r.name)return(null===(t=o.allowCredentials)||void 0===t?void 0:t.length)?new c("No available authenticator recognized any of the allowed credentials","NotAllowedError"):new c("User clicked cancel, or the authentication ceremony timed out","NotAllowedError");if("SecurityError"===r.name){var i=window.location.hostname;if(!s(i))return new c("".concat(window.location.hostname," is an invalid domain"),"SecurityError");if(o.rpId!==i)return new c('The RP ID "'.concat(o.rpId,'" is invalid for this domain'),"SecurityError")}else if("UnknownError"===r.name)return new c("The authenticator was unable to process the specified options, or could not create a new assertion signature","UnknownError")}return r}({error:o.sent(),options:b});case 6:return d.reset(),[7];case 7:if(!y)throw new Error("Authentication was not completed");return v=y.id,g=y.rawId,m=y.response,E=y.type,A=void 0,m.userHandle&&(S=m.userHandle,A=new TextDecoder("utf-8").decode(S)),[2,{id:v,rawId:i(g),response:{authenticatorData:i(m.authenticatorData),clientDataJSON:i(m.clientDataJSON),signature:i(m.signature),userHandle:A},type:E,clientExtensionResults:y.getClientExtensionResults(),authenticatorAttachment:y.authenticatorAttachment}]}var S}))}))},e.startRegistration=function(e){return n(this,void 0,void 0,(function(){var t,n,f,p,h,w,b,y;return o(this,(function(o){switch(o.label){case 0:if(!l())throw new Error("WebAuthn is not supported in this browser");t=r(r({},e),{challenge:a(e.challenge),user:r(r({},e.user),{id:(v=e.user.id,(new TextEncoder).encode(v))}),excludeCredentials:e.excludeCredentials.map(u)}),(n={publicKey:t}).signal=d.createNewAbortSignal(),o.label=1;case 1:return o.trys.push([1,3,4,5]),[4,navigator.credentials.create(n)];case 2:return f=o.sent(),[3,5];case 3:throw function(e){var t,r,n=e.error,o=e.options,i=o.publicKey;if(!i)throw Error("options was missing required publicKey property");if("AbortError"===n.name){if(o.signal===(new AbortController).signal)return new c("Registration ceremony was sent an abort signal","AbortError")}else if("ConstraintError"===n.name){if(!0===(null===(t=i.authenticatorSelection)||void 0===t?void 0:t.requireResidentKey))return new c("Discoverable credentials were required but no available authenticator supported it","ConstraintError");if("required"===(null===(r=i.authenticatorSelection)||void 0===r?void 0:r.userVerification))return new c("User verification was required but no available authenticator supported it","ConstraintError")}else{if("InvalidStateError"===n.name)return new c("The authenticator was previously registered","InvalidStateError");if("NotAllowedError"===n.name)return new c("User clicked cancel, or the registration ceremony timed out","NotAllowedError");if("NotSupportedError"===n.name)return 0===i.pubKeyCredParams.filter((function(e){return"public-key"===e.type})).length?new c('No entry in pubKeyCredParams was of type "public-key"',"NotSupportedError"):new c("No available authenticator supported any of the specified pubKeyCredParams algorithms","NotSupportedError");if("SecurityError"===n.name){var a=window.location.hostname;if(!s(a))return new c("".concat(window.location.hostname," is an invalid domain"),"SecurityError");if(i.rp.id!==a)return new c('The RP ID "'.concat(i.rp.id,'" is invalid for this domain'),"SecurityError")}else if("TypeError"===n.name){if(i.user.id.byteLength<1||i.user.id.byteLength>64)return new c("User ID was not between 1 and 64 characters","TypeError")}else if("UnknownError"===n.name)return new c("The authenticator was unable to process the specified options, or could not create a new credential","UnknownError")}return n}({error:o.sent(),options:n});case 4:return d.reset(),[7];case 5:if(!f)throw new Error("Registration was not completed");return p=f.id,h=f.rawId,w=f.response,b=f.type,y={id:p,rawId:i(h),response:{attestationObject:i(w.attestationObject),clientDataJSON:i(w.clientDataJSON)},type:b,clientExtensionResults:f.getClientExtensionResults(),authenticatorAttachment:f.authenticatorAttachment},"function"==typeof w.getTransports&&(y.transports=w.getTransports()),[2,y]}var v}))}))},Object.defineProperty(e,"__esModule",{value:!0})}));
|
package/dist/bundle/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/* [@simplewebauthn/browser
|
|
1
|
+
/* [@simplewebauthn/browser@5.4.1] */
|
|
2
2
|
function utf8StringToBuffer(value) {
|
|
3
3
|
return new TextEncoder().encode(value);
|
|
4
4
|
}
|
|
@@ -102,6 +102,20 @@ function identifyRegistrationError({ error, options, }) {
|
|
|
102
102
|
return error;
|
|
103
103
|
}
|
|
104
104
|
|
|
105
|
+
class WebAuthnAbortService {
|
|
106
|
+
createNewAbortSignal() {
|
|
107
|
+
if (this.controller) {
|
|
108
|
+
this.controller.abort();
|
|
109
|
+
}
|
|
110
|
+
this.controller = new AbortController();
|
|
111
|
+
return this.controller.signal;
|
|
112
|
+
}
|
|
113
|
+
reset() {
|
|
114
|
+
this.controller = undefined;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
const webauthnAbortService = new WebAuthnAbortService();
|
|
118
|
+
|
|
105
119
|
async function startRegistration(creationOptionsJSON) {
|
|
106
120
|
if (!browserSupportsWebauthn()) {
|
|
107
121
|
throw new Error('WebAuthn is not supported in this browser');
|
|
@@ -116,6 +130,7 @@ async function startRegistration(creationOptionsJSON) {
|
|
|
116
130
|
excludeCredentials: creationOptionsJSON.excludeCredentials.map(toPublicKeyCredentialDescriptor),
|
|
117
131
|
};
|
|
118
132
|
const options = { publicKey };
|
|
133
|
+
options.signal = webauthnAbortService.createNewAbortSignal();
|
|
119
134
|
let credential;
|
|
120
135
|
try {
|
|
121
136
|
credential = (await navigator.credentials.create(options));
|
|
@@ -123,6 +138,9 @@ async function startRegistration(creationOptionsJSON) {
|
|
|
123
138
|
catch (err) {
|
|
124
139
|
throw identifyRegistrationError({ error: err, options });
|
|
125
140
|
}
|
|
141
|
+
finally {
|
|
142
|
+
webauthnAbortService.reset();
|
|
143
|
+
}
|
|
126
144
|
if (!credential) {
|
|
127
145
|
throw new Error('Registration was not completed');
|
|
128
146
|
}
|
|
@@ -136,6 +154,7 @@ async function startRegistration(creationOptionsJSON) {
|
|
|
136
154
|
},
|
|
137
155
|
type,
|
|
138
156
|
clientExtensionResults: credential.getClientExtensionResults(),
|
|
157
|
+
authenticatorAttachment: credential.authenticatorAttachment,
|
|
139
158
|
};
|
|
140
159
|
if (typeof response.getTransports === 'function') {
|
|
141
160
|
credentialJSON.transports = response.getTransports();
|
|
@@ -147,6 +166,15 @@ function bufferToUTF8String(value) {
|
|
|
147
166
|
return new TextDecoder('utf-8').decode(value);
|
|
148
167
|
}
|
|
149
168
|
|
|
169
|
+
async function browserSupportsWebAuthnAutofill() {
|
|
170
|
+
if (navigator.credentials.conditionalMediationSupported) {
|
|
171
|
+
return true;
|
|
172
|
+
}
|
|
173
|
+
const globalPublicKeyCredential = window.PublicKeyCredential;
|
|
174
|
+
return (globalPublicKeyCredential.isConditionalMediationAvailable !== undefined &&
|
|
175
|
+
globalPublicKeyCredential.isConditionalMediationAvailable());
|
|
176
|
+
}
|
|
177
|
+
|
|
150
178
|
function identifyAuthenticationError({ error, options, }) {
|
|
151
179
|
var _a;
|
|
152
180
|
const { publicKey } = options;
|
|
@@ -179,7 +207,7 @@ function identifyAuthenticationError({ error, options, }) {
|
|
|
179
207
|
return error;
|
|
180
208
|
}
|
|
181
209
|
|
|
182
|
-
async function startAuthentication(requestOptionsJSON) {
|
|
210
|
+
async function startAuthentication(requestOptionsJSON, useBrowserAutofill = false) {
|
|
183
211
|
var _a, _b;
|
|
184
212
|
if (!browserSupportsWebauthn()) {
|
|
185
213
|
throw new Error('WebAuthn is not supported in this browser');
|
|
@@ -193,7 +221,20 @@ async function startAuthentication(requestOptionsJSON) {
|
|
|
193
221
|
challenge: base64URLStringToBuffer(requestOptionsJSON.challenge),
|
|
194
222
|
allowCredentials,
|
|
195
223
|
};
|
|
196
|
-
const options = {
|
|
224
|
+
const options = {};
|
|
225
|
+
if (useBrowserAutofill) {
|
|
226
|
+
if (!(await browserSupportsWebAuthnAutofill())) {
|
|
227
|
+
throw Error('Browser does not support WebAuthn autofill');
|
|
228
|
+
}
|
|
229
|
+
const eligibleInputs = document.querySelectorAll("input[autocomplete*='webauthn']");
|
|
230
|
+
if (eligibleInputs.length < 1) {
|
|
231
|
+
throw Error('No <input> with `"webauthn"` in its `autocomplete` attribute was detected');
|
|
232
|
+
}
|
|
233
|
+
options.mediation = 'conditional';
|
|
234
|
+
publicKey.allowCredentials = [];
|
|
235
|
+
}
|
|
236
|
+
options.publicKey = publicKey;
|
|
237
|
+
options.signal = webauthnAbortService.createNewAbortSignal();
|
|
197
238
|
let credential;
|
|
198
239
|
try {
|
|
199
240
|
credential = (await navigator.credentials.get(options));
|
|
@@ -201,6 +242,9 @@ async function startAuthentication(requestOptionsJSON) {
|
|
|
201
242
|
catch (err) {
|
|
202
243
|
throw identifyAuthenticationError({ error: err, options });
|
|
203
244
|
}
|
|
245
|
+
finally {
|
|
246
|
+
webauthnAbortService.reset();
|
|
247
|
+
}
|
|
204
248
|
if (!credential) {
|
|
205
249
|
throw new Error('Authentication was not completed');
|
|
206
250
|
}
|
|
@@ -220,6 +264,7 @@ async function startAuthentication(requestOptionsJSON) {
|
|
|
220
264
|
},
|
|
221
265
|
type,
|
|
222
266
|
clientExtensionResults: credential.getClientExtensionResults(),
|
|
267
|
+
authenticatorAttachment: credential.authenticatorAttachment,
|
|
223
268
|
};
|
|
224
269
|
}
|
|
225
270
|
|
|
@@ -230,4 +275,4 @@ async function platformAuthenticatorIsAvailable() {
|
|
|
230
275
|
return PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable();
|
|
231
276
|
}
|
|
232
277
|
|
|
233
|
-
export { browserSupportsWebauthn, platformAuthenticatorIsAvailable, startAuthentication, startRegistration };
|
|
278
|
+
export { browserSupportsWebAuthnAutofill, browserSupportsWebauthn, platformAuthenticatorIsAvailable, startAuthentication, startRegistration };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
/* [@simplewebauthn/browser
|
|
2
|
-
!function(e,
|
|
1
|
+
/* [@simplewebauthn/browser@5.4.1] */
|
|
2
|
+
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).SimpleWebAuthnBrowser={})}(this,(function(e){"use strict";function t(e){const t=new Uint8Array(e);let r="";for(const e of t)r+=String.fromCharCode(e);return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function r(e){const t=e.replace(/-/g,"+").replace(/_/g,"/"),r=(4-t.length%4)%4,n=t.padEnd(t.length+r,"="),o=atob(n),i=new ArrayBuffer(o.length),a=new Uint8Array(i);for(let e=0;e<o.length;e++)a[e]=o.charCodeAt(e);return i}function n(){return void 0!==(null===window||void 0===window?void 0:window.PublicKeyCredential)&&"function"==typeof window.PublicKeyCredential}function o(e){const{id:t}=e;return{...e,id:r(t),transports:e.transports}}function i(e){return"localhost"===e||/^([a-z0-9]+(-[a-z0-9]+)*\.)+[a-z]{2,}$/i.test(e)}class a extends Error{constructor(e,t="WebAuthnError"){super(e),this.name=t}}const l=new class{createNewAbortSignal(){return this.controller&&this.controller.abort(),this.controller=new AbortController,this.controller.signal}reset(){this.controller=void 0}};async function s(){if(navigator.credentials.conditionalMediationSupported)return!0;const e=window.PublicKeyCredential;return void 0!==e.isConditionalMediationAvailable&&e.isConditionalMediationAvailable()}e.browserSupportsWebAuthnAutofill=s,e.browserSupportsWebauthn=n,e.platformAuthenticatorIsAvailable=async function(){return!!n()&&PublicKeyCredential.isUserVerifyingPlatformAuthenticatorAvailable()},e.startAuthentication=async function(e,c=!1){var u,d;if(!n())throw new Error("WebAuthn is not supported in this browser");let w;0!==(null===(u=e.allowCredentials)||void 0===u?void 0:u.length)&&(w=null===(d=e.allowCredentials)||void 0===d?void 0:d.map(o));const p={...e,challenge:r(e.challenge),allowCredentials:w},h={};if(c){if(!await s())throw Error("Browser does not support WebAuthn autofill");if(document.querySelectorAll("input[autocomplete*='webauthn']").length<1)throw Error('No <input> with `"webauthn"` in its `autocomplete` attribute was detected');h.mediation="conditional",p.allowCredentials=[]}let f;h.publicKey=p,h.signal=l.createNewAbortSignal();try{f=await navigator.credentials.get(h)}catch(e){throw function({error:e,options:t}){var r;const{publicKey:n}=t;if(!n)throw Error("options was missing required publicKey property");if("AbortError"===e.name){if(t.signal===(new AbortController).signal)return new a("Authentication ceremony was sent an abort signal","AbortError")}else{if("NotAllowedError"===e.name)return(null===(r=n.allowCredentials)||void 0===r?void 0:r.length)?new a("No available authenticator recognized any of the allowed credentials","NotAllowedError"):new a("User clicked cancel, or the authentication ceremony timed out","NotAllowedError");if("SecurityError"===e.name){const e=window.location.hostname;if(!i(e))return new a(`${window.location.hostname} is an invalid domain`,"SecurityError");if(n.rpId!==e)return new a(`The RP ID "${n.rpId}" is invalid for this domain`,"SecurityError")}else if("UnknownError"===e.name)return new a("The authenticator was unable to process the specified options, or could not create a new assertion signature","UnknownError")}return e}({error:e,options:h})}finally{l.reset()}if(!f)throw new Error("Authentication was not completed");const{id:b,rawId:y,response:g,type:m}=f;let E;var v;return g.userHandle&&(v=g.userHandle,E=new TextDecoder("utf-8").decode(v)),{id:b,rawId:t(y),response:{authenticatorData:t(g.authenticatorData),clientDataJSON:t(g.clientDataJSON),signature:t(g.signature),userHandle:E},type:m,clientExtensionResults:f.getClientExtensionResults(),authenticatorAttachment:f.authenticatorAttachment}},e.startRegistration=async function(e){if(!n())throw new Error("WebAuthn is not supported in this browser");var s;const c={publicKey:{...e,challenge:r(e.challenge),user:{...e.user,id:(s=e.user.id,(new TextEncoder).encode(s))},excludeCredentials:e.excludeCredentials.map(o)}};let u;c.signal=l.createNewAbortSignal();try{u=await navigator.credentials.create(c)}catch(e){throw function({error:e,options:t}){var r,n;const{publicKey:o}=t;if(!o)throw Error("options was missing required publicKey property");if("AbortError"===e.name){if(t.signal===(new AbortController).signal)return new a("Registration ceremony was sent an abort signal","AbortError")}else if("ConstraintError"===e.name){if(!0===(null===(r=o.authenticatorSelection)||void 0===r?void 0:r.requireResidentKey))return new a("Discoverable credentials were required but no available authenticator supported it","ConstraintError");if("required"===(null===(n=o.authenticatorSelection)||void 0===n?void 0:n.userVerification))return new a("User verification was required but no available authenticator supported it","ConstraintError")}else{if("InvalidStateError"===e.name)return new a("The authenticator was previously registered","InvalidStateError");if("NotAllowedError"===e.name)return new a("User clicked cancel, or the registration ceremony timed out","NotAllowedError");if("NotSupportedError"===e.name)return 0===o.pubKeyCredParams.filter((e=>"public-key"===e.type)).length?new a('No entry in pubKeyCredParams was of type "public-key"',"NotSupportedError"):new a("No available authenticator supported any of the specified pubKeyCredParams algorithms","NotSupportedError");if("SecurityError"===e.name){const e=window.location.hostname;if(!i(e))return new a(`${window.location.hostname} is an invalid domain`,"SecurityError");if(o.rp.id!==e)return new a(`The RP ID "${o.rp.id}" is invalid for this domain`,"SecurityError")}else if("TypeError"===e.name){if(o.user.id.byteLength<1||o.user.id.byteLength>64)return new a("User ID was not between 1 and 64 characters","TypeError")}else if("UnknownError"===e.name)return new a("The authenticator was unable to process the specified options, or could not create a new credential","UnknownError")}return e}({error:e,options:c})}finally{l.reset()}if(!u)throw new Error("Registration was not completed");const{id:d,rawId:w,response:p,type:h}=u,f={id:d,rawId:t(w),response:{attestationObject:t(p.attestationObject),clientDataJSON:t(p.clientDataJSON)},type:h,clientExtensionResults:u.getClientExtensionResults(),authenticatorAttachment:u.authenticatorAttachment};return"function"==typeof p.getTransports&&(f.transports=p.getTransports()),f},Object.defineProperty(e,"__esModule",{value:!0})}));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export
|
|
1
|
+
export declare function base64URLStringToBuffer(base64URLString: string): ArrayBuffer;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function browserSupportsWebAuthnAutofill(): Promise<boolean>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export
|
|
1
|
+
export declare function bufferToBase64URLString(buffer: ArrayBuffer): string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export
|
|
1
|
+
export declare function bufferToUTF8String(value: ArrayBuffer): string;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import type { PublicKeyCredentialDescriptorJSON } from '@simplewebauthn/typescript-types';
|
|
2
|
-
export
|
|
2
|
+
export declare function toPublicKeyCredentialDescriptor(descriptor: PublicKeyCredentialDescriptorJSON): PublicKeyCredentialDescriptor;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export
|
|
1
|
+
export declare function utf8StringToBuffer(value: string): ArrayBuffer;
|
package/dist/types/index.d.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import startRegistration from './methods/startRegistration';
|
|
2
|
-
import startAuthentication from './methods/startAuthentication';
|
|
1
|
+
import { startRegistration } from './methods/startRegistration';
|
|
2
|
+
import { startAuthentication } from './methods/startAuthentication';
|
|
3
3
|
import { browserSupportsWebauthn } from './helpers/browserSupportsWebauthn';
|
|
4
4
|
import { platformAuthenticatorIsAvailable } from './helpers/platformAuthenticatorIsAvailable';
|
|
5
|
-
|
|
5
|
+
import { browserSupportsWebAuthnAutofill } from './helpers/browserSupportsWebAuthnAutofill';
|
|
6
|
+
export { startRegistration, startAuthentication, browserSupportsWebauthn, browserSupportsWebAuthnAutofill, platformAuthenticatorIsAvailable, };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import { PublicKeyCredentialRequestOptionsJSON, AuthenticationCredentialJSON } from '@simplewebauthn/typescript-types';
|
|
2
|
-
export
|
|
2
|
+
export declare function startAuthentication(requestOptionsJSON: PublicKeyCredentialRequestOptionsJSON, useBrowserAutofill?: boolean): Promise<AuthenticationCredentialJSON>;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import { PublicKeyCredentialCreationOptionsJSON, RegistrationCredentialJSON } from '@simplewebauthn/typescript-types';
|
|
2
|
-
export
|
|
2
|
+
export declare function startRegistration(creationOptionsJSON: PublicKeyCredentialCreationOptionsJSON): Promise<RegistrationCredentialJSON>;
|
package/jest-environment.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/* eslint-disable @typescript-eslint/no-var-requires */
|
|
2
|
-
|
|
2
|
+
import Environment from 'jest-environment-jsdom';
|
|
3
3
|
|
|
4
4
|
/**
|
|
5
5
|
* Set up a custom JSDOM-based test environment for Jest so we can add things JSDOM doesn't support
|
|
@@ -13,7 +13,7 @@ class CustomTestEnvironment extends Environment {
|
|
|
13
13
|
* Solved thanks to https://stackoverflow.com/a/57713960/2133271
|
|
14
14
|
*/
|
|
15
15
|
if (typeof this.global.TextEncoder === 'undefined') {
|
|
16
|
-
const { TextEncoder } =
|
|
16
|
+
const { TextEncoder } = await import('util');
|
|
17
17
|
this.global.TextEncoder = TextEncoder;
|
|
18
18
|
}
|
|
19
19
|
|
|
@@ -21,10 +21,10 @@ class CustomTestEnvironment extends Environment {
|
|
|
21
21
|
* Add support for TextDecoder to JSDOM
|
|
22
22
|
*/
|
|
23
23
|
if (typeof this.global.TextDecoder === 'undefined') {
|
|
24
|
-
const { TextDecoder } =
|
|
24
|
+
const { TextDecoder } = await import('util');
|
|
25
25
|
this.global.TextDecoder = TextDecoder;
|
|
26
26
|
}
|
|
27
27
|
}
|
|
28
28
|
}
|
|
29
29
|
|
|
30
|
-
|
|
30
|
+
export default CustomTestEnvironment;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@simplewebauthn/browser",
|
|
3
|
-
"version": "5.
|
|
3
|
+
"version": "5.4.1",
|
|
4
4
|
"description": "SimpleWebAuthn for Browsers",
|
|
5
5
|
"main": "dist/bundle/index.js",
|
|
6
6
|
"unpkg": "dist/bundle/index.umd.min.js",
|
|
@@ -32,10 +32,11 @@
|
|
|
32
32
|
"devDependencies": {
|
|
33
33
|
"@rollup/plugin-node-resolve": "^13.0.0",
|
|
34
34
|
"@rollup/plugin-typescript": "^8.2.1",
|
|
35
|
-
"@simplewebauthn/typescript-types": "^5.
|
|
35
|
+
"@simplewebauthn/typescript-types": "^5.4.0",
|
|
36
36
|
"rollup": "^2.52.1",
|
|
37
37
|
"rollup-plugin-terser": "^7.0.2",
|
|
38
38
|
"rollup-plugin-version-injector": "^1.3.3"
|
|
39
39
|
},
|
|
40
|
-
"
|
|
40
|
+
"type": "module",
|
|
41
|
+
"gitHead": "3a673b2cf940133ed8d3a68e80a95f198b1e6f9e"
|
|
41
42
|
}
|