mirror of
				https://github.com/spring-projects/spring-security.git
				synced 2025-10-25 03:38:43 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			109 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			109 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /*
 | |
|  * Copyright 2002-2024 the original author or authors.
 | |
|  *
 | |
|  * Licensed under the Apache License, Version 2.0 (the "License");
 | |
|  * you may not use this file except in compliance with the License.
 | |
|  * You may obtain a copy of the License at
 | |
|  *
 | |
|  *      https://www.apache.org/licenses/LICENSE-2.0
 | |
|  *
 | |
|  * Unless required by applicable law or agreed to in writing, software
 | |
|  * distributed under the License is distributed on an "AS IS" BASIS,
 | |
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
|  * See the License for the specific language governing permissions and
 | |
|  * limitations under the License.
 | |
|  */
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| import webauthn from "./webauthn-core.js";
 | |
| 
 | |
| function setVisibility(element, value) {
 | |
|   if (!element) {
 | |
|     return;
 | |
|   }
 | |
|   element.style.display = value ? "block" : "none";
 | |
| }
 | |
| 
 | |
| function setError(ui, msg) {
 | |
|   resetPopups(ui);
 | |
|   const error = ui.getError();
 | |
|   if (!error) {
 | |
|     return;
 | |
|   }
 | |
|   error.textContent = msg;
 | |
|   setVisibility(error, true);
 | |
| }
 | |
| 
 | |
| function setSuccess(ui) {
 | |
|   resetPopups(ui);
 | |
|   const success = ui.getSuccess();
 | |
|   if (!success) {
 | |
|     return;
 | |
|   }
 | |
|   setVisibility(success, true);
 | |
| }
 | |
| 
 | |
| function resetPopups(ui) {
 | |
|   const success = ui.getSuccess();
 | |
|   const error = ui.getError();
 | |
|   setVisibility(success, false);
 | |
|   setVisibility(error, false);
 | |
| }
 | |
| 
 | |
| async function submitDeleteForm(contextPath, form, headers) {
 | |
|   const options = {
 | |
|     method: "DELETE",
 | |
|     headers: {
 | |
|       "Content-Type": "application/json",
 | |
|       ...headers,
 | |
|     },
 | |
|   };
 | |
|   await fetch(form.action, options);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  *
 | |
|  * @param headers headers added to the credentials creation POST request, typically CSRF
 | |
|  * @param contextPath the contextPath from which the app is served
 | |
|  * @param ui contains getRegisterButton(), getSuccess(), getError(), getLabelInput(), getDeleteForms()
 | |
|  * @returns {Promise<void>}
 | |
|  */
 | |
| export async function setupRegistration(headers, contextPath, ui) {
 | |
|   resetPopups(ui);
 | |
| 
 | |
|   if (!window.PublicKeyCredential) {
 | |
|     setError(ui, "WebAuthn is not supported");
 | |
|     return;
 | |
|   }
 | |
| 
 | |
|   const queryString = new URLSearchParams(window.location.search);
 | |
|   if (queryString.has("success")) {
 | |
|     setSuccess(ui);
 | |
|   }
 | |
| 
 | |
|   ui.getRegisterButton().addEventListener("click", async () => {
 | |
|     resetPopups(ui);
 | |
|     const label = ui.getLabelInput().value;
 | |
|     try {
 | |
|       await webauthn.register(headers, contextPath, label);
 | |
|       window.location.href = `${contextPath}/webauthn/register?success`;
 | |
|     } catch (err) {
 | |
|       setError(ui, err.message);
 | |
|       console.error(err);
 | |
|     }
 | |
|   });
 | |
| 
 | |
|   ui.getDeleteForms().forEach((form) =>
 | |
|     form.addEventListener("submit", async function (e) {
 | |
|       e.preventDefault();
 | |
|       try {
 | |
|         await submitDeleteForm(contextPath, form, headers);
 | |
|         window.location.href = `${contextPath}/webauthn/register?success`;
 | |
|       } catch (err) {
 | |
|         setError(ui, err.message);
 | |
|       }
 | |
|     }),
 | |
|   );
 | |
| }
 |