mirror of
https://github.com/zitadel/zitadel.git
synced 2025-05-06 20:26:46 +00:00

* start v2 * start * run * some cleanup * remove v2 pkg again * simplify * webauthn * remove unused config * fix login path in Dockerfile * fix asset_generator.go * health handler * fix grpc web * refactor * merge * build new main.go * run new main.go * update logging pkg * fix error msg * update logging * cleanup * cleanup * go mod tidy * change localDevMode * fix customEndpoints * update logging * comments * change local flag to external configs * fix location generated go code * fix Co-authored-by: fforootd <florian@caos.ch>
41 lines
1.7 KiB
JavaScript
41 lines
1.7 KiB
JavaScript
document.addEventListener('DOMContentLoaded', checkWebauthnSupported('btn-login', login));
|
|
|
|
function login() {
|
|
document.getElementById('wa-error').classList.add('hidden');
|
|
|
|
let makeAssertionOptions = JSON.parse(atob(document.getElementsByName('credentialAssertionData')[0].value));
|
|
makeAssertionOptions.publicKey.challenge = bufferDecode(makeAssertionOptions.publicKey.challenge);
|
|
makeAssertionOptions.publicKey.allowCredentials.forEach(function (listItem) {
|
|
listItem.id = bufferDecode(listItem.id)
|
|
});
|
|
navigator.credentials.get({
|
|
publicKey: makeAssertionOptions.publicKey
|
|
}).then(function (credential) {
|
|
verifyAssertion(credential);
|
|
}).catch(function (err) {
|
|
webauthnError(err);
|
|
});
|
|
}
|
|
|
|
function verifyAssertion(assertedCredential) {
|
|
let authData = new Uint8Array(assertedCredential.response.authenticatorData);
|
|
let clientDataJSON = new Uint8Array(assertedCredential.response.clientDataJSON);
|
|
let rawId = new Uint8Array(assertedCredential.rawId);
|
|
let sig = new Uint8Array(assertedCredential.response.signature);
|
|
let userHandle = new Uint8Array(assertedCredential.response.userHandle);
|
|
|
|
let data = JSON.stringify({
|
|
id: assertedCredential.id,
|
|
rawId: bufferEncode(rawId),
|
|
type: assertedCredential.type,
|
|
response: {
|
|
authenticatorData: bufferEncode(authData),
|
|
clientDataJSON: bufferEncode(clientDataJSON),
|
|
signature: bufferEncode(sig),
|
|
userHandle: bufferEncode(userHandle),
|
|
},
|
|
})
|
|
|
|
document.getElementsByName('credentialData')[0].value = btoa(data);
|
|
document.getElementsByTagName('form')[0].submit();
|
|
} |