From 2127b1bdd73ecd2423e443992da4b442f5a3c1a3 Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Wed, 04 Feb 2026 21:19:25 +0000
Subject: [PATCH] =Major overhaul of MetaManager.php -> Meta.php and RestRouteManager.php -> Rest.php. Seems to work for JakeVan

---
 inc/managers/LoginManager.php |  220 ++++++++++++++++++++++++++++--------------------------
 1 files changed, 115 insertions(+), 105 deletions(-)

diff --git a/inc/managers/LoginManager.php b/inc/managers/LoginManager.php
index 05bfe83..26700e2 100644
--- a/inc/managers/LoginManager.php
+++ b/inc/managers/LoginManager.php
@@ -1,11 +1,9 @@
 <?php
 namespace JVBase\managers;
 
-use JVBase\blocks\CustomBlocks;
 use JVBase\forms\TaxonomySelector;
-use JVBase\meta\MetaManager;
-use JVBase\meta\MetaForm;
-use JVBase\managers\AjaxRateLimiter;
+use JVBase\meta\Form;
+
 use JVBase\utility\Features;
 use WP_Error;
 use WP_User;
@@ -17,8 +15,8 @@
 class LoginManager
 {
 	protected Features $siteFeatures;
-	protected ?MetaForm $metaForm = null;
-	protected CacheManager $cache;
+	protected ?Form $form = null;
+	protected Cache $cache;
 
 
 	protected array $forms =[];
@@ -43,7 +41,7 @@
 		$this->siteFeatures = Features::forSite();
 
 
-		$this->cache = CacheManager::for('login');
+		$this->cache = Cache::for('login');
 
 		// Initialize magic link support if enabled
 		if ($this->siteFeatures->has('magicLink')) {
@@ -64,6 +62,7 @@
 		add_action('wp_login', [$this, 'handleSuccessfulLogin'], 10, 2);
 
 		add_filter( 'login_url', [$this, 'loginUrl'], 10, 3 );
+		add_filter( 'logout_url', [$this, 'logoutUrl'], 10, 2 );
 		// Allow other features to register handlers
 		do_action('jvbLoginManagerInit', $this);
 		add_action('user_register', array($this, 'saveRegistrationFields'), 999, 2);
@@ -226,12 +225,14 @@
 						'type' => 'email',
 						'label' => __('Email Address', 'jvb'),
 						'required' => true,
+						'autocomplete'	=> 'email',
 						'placeholder' => 'look@me.com',
 					],
 					'user_password' => [
 						'type' => 'text',
 						'subtype'=> 'password',
 						'label' => __('Password', 'jvb'),
+						'autocomplete' => 'current-password',
 						'required' => true,
 					],
 					'remember_me' => [
@@ -303,6 +304,20 @@
 		}
 		return $login_url;
 	}
+
+	public function logoutUrl(string $logout_url, string $redirect): string
+{
+	// Build custom logout URL
+	$logout_url = site_url('/login/', 'login');
+	$logout_url = add_query_arg('action', 'logout', $logout_url);
+
+	if (!empty($redirect)) {
+		$logout_url = add_query_arg('redirect_to', urlencode($redirect), $logout_url);
+	}
+
+	// Add nonce for security
+	return wp_nonce_url($logout_url, 'log-out');
+}
 	public function getLoginPage():int|false
 	{
 		return (int)get_option(BASE.'login_page');
@@ -384,7 +399,7 @@
 	protected function setup():void
 	{
 		$this->action = $this->getAction();
-		if (in_array($this->action, ['logout']) || array_key_exists('loggedout', $_GET)) {
+		if ($this->action == 'logout' || array_key_exists('loggedout', $_GET)) {
 			wp_logout();
 			wp_redirect(esc_attr($_GET['redirect_to'] ?? get_home_url()));
 			exit;
@@ -516,7 +531,6 @@
 
 	protected function renderForms():void
 	{
-		$this->metaForm = new MetaForm();
 		$form = $this->action.'form';
 		?>
 		<section class="login-box col btw">
@@ -535,7 +549,7 @@
 				do_action('jvb_add_token_inputs', $this->action);
 
 				foreach ($this->fields as $name => $config) {
-					$this->metaForm->render($name, '', $config);
+					echo Form::render($name, '', $config);
 				}
 
 				$this->maybeTurnstile();
@@ -844,115 +858,111 @@
 		SCRIPTS
 	************************************************************************/
 	public function enqueueScripts(): void
-	{
-		if (!$this->isLoginPage()) {
-			return;
-		}
+{
+    if (!$this->isLoginPage()) {
+        return;
+    }
 
-		$this->maybeTurnstileScripts();
-		wp_enqueue_script('jvb-form');
-		$action = $this->getAction();
-		ob_start();
-		?>
+    $this->maybeTurnstileScripts();
+    wp_enqueue_script('jvb-form');
+    $action = $this->getAction();
 
-		document.addEventListener('DOMContentLoaded', () => {
-			const form = document.querySelector('.login form');
-			if (!form) return;
+    $redirect_to = isset($_GET['redirect_to']) ? esc_url_raw($_GET['redirect_to']) : '';
+    $has_turnstile = Features::hasIntegration('cloudflare');
 
-			if (!window.jvbForm) {
-				console.error('jvbForm not loaded');
-				return;
-			}
+    ob_start();
+    ?>
 
-			window.LoginController = new window.jvbForm();
-			window.LoginController.registerForm(form, {
-				autosave: false,
-				endpoint: <?= "'{$action}'" ?>,
-				formStatus: false,
-				cache: false,
-			});
+	document.addEventListener('DOMContentLoaded', async function () {
+		const hasTurnstile = <?= json_encode($has_turnstile) ?>;
+		const redirectTo = <?= json_encode($redirect_to) ?>;
 
-			window.LoginController.subscribe((event, data) => {
-				if (event === 'form-submit') {
-					handleFormSubmission(data);
-				}
-			});
+		window.auth.subscribe(event => {
+			if (event === 'auth-loaded') {
+				const form = document.querySelector('.login form');
+				if (!form || !window.jvbForm) return;
 
-
-			async function handleFormSubmission(data) {
-			let realFormData = data.fullData;
-			const { formId, config, data: formData } = data;
-
-
-			const form = config.element;
-
-			const submit = form.querySelector('[type=submit]');
-			let oldText = submit.textContent;
-
-
-			window.LoginController.showFormStatus(formId, 'uploading');
-
-			try {
-				submit.disabled = true;
-				submit.textContent = 'Loading...';
-				const response = await fetch(`${jvbSettings.api}<?=($action === 'magic') ? $action : 'auth/'.$action?>`, {
-					method: 'POST',
-					headers: {
-                		'Content-Type': 'application/json',
-						'X-WP-Nonce': window.auth.getNonce()
-					},
-					body: JSON.stringify(realFormData)
+				window.jvbForm.registerForm(form, {
+					autosave: false,
+					endpoint: '<?= $action ?>',
+					formStatus: false,
+					cache: false,
 				});
 
-					const result = await response.json();
+				window.jvbForm.subscribe((event, data) => {
+					if (event === 'form-submit') {
+						const { config } = data;
+						const formElement = config.element;
 
-					// Handle errors
-					if (!response.ok) {
-						window.LoginController.showFormStatus(formId, 'error');
-						window.LoginController.handleFormError(form, result);
-						return;
+						// Collect current form data
+						const formData = new FormData(formElement);
+						const formObject = Object.fromEntries(formData.entries());
+
+						// Add redirect_to from URL
+						if (redirectTo) {
+							formObject.redirect_to = redirectTo;
+						}
+
+						const submit = formElement.querySelector('[type=submit]');
+						const oldText = submit.textContent;
+
+						window.jvbForm.showFormStatus(config.id, 'uploading');
+
+						submit.disabled = true;
+						submit.textContent = 'Loading...';
+
+						window.auth.fetch(`${jvbSettings.api}auth/<?= $action ?>`, {
+							method: 'POST',
+							body: JSON.stringify(formObject)
+						})
+						.then(response => response.json().then(result => ({ response, result })))
+						.then(({ response, result }) => {
+							if (!response.ok) {
+								window.jvbForm.showFormStatus(config.id, 'error');
+								window.jvbForm.handleFormError(formElement, result);
+								return;
+							}
+
+							window.jvbForm.showFormStatus(config.id, 'submitted');
+
+							if (result.message) {
+								window.jvbForm.handleFormSuccess(formElement, result);
+							}
+
+							if (window.auth?.handleLogin && result.auth) {
+								return window.auth.handleLogin(result.auth).then(() => {
+									if (result.redirect) {
+										setTimeout(() => {
+											window.location.href = result.redirect;
+										}, 100);
+									}
+								});
+							} else if (result.redirect) {
+								setTimeout(() => {
+									window.location.href = result.redirect;
+								}, 100);
+							}
+						})
+						.catch(error => {
+							console.error('Form submission error:', error);
+							window.jvbForm.showFormStatus(config.id, 'error');
+							window.jvbForm.handleFormError(formElement, {
+								message: 'Network error. Please check your connection and try again.',
+								code: 'network_error'
+							});
+						})
+						.finally(() => {
+							submit.textContent = oldText;
+							submit.disabled = false;
+						});
 					}
-
-					// Handle success
-					window.LoginController.showFormStatus(formId, 'submitted');
-
-					// Show success message briefly before redirect
-					if (result.message) {
-						window.LoginController.handleFormSuccess(form, result);
-					}
-
-					if (window.auth && typeof window.auth.handleLogin === 'function' && Object.hasOwn(result, 'auth')) {
-						console.log('Awaiting Auth...');
-						await window.auth.handleLogin(result.auth); // Pass the full result
-					}
-
-					// Handle redirect
-					if (result.redirect) {
-						setTimeout(() => {
-							window.location.href = result.redirect;
-						}, 200); // Brief delay to show success message
-					}
-
-				} catch (error) {
-					console.error('Form submission error:', error);
-					window.LoginController.showFormStatus(formId, 'error');
-					window.LoginController.handleFormError(form, {
-						message: 'Network error. Please check your connection and try again.',
-						code: 'network_error'
-					});
-				} finally {
-					submit.textContent = oldText;
-					submit.disabled = false;
-				}
+				});
 			}
-
 		});
+	});
 
-
-
-		<?php
+	<?php
 		$script = ob_get_clean();
-
 		wp_add_inline_script('jvb-form', $script);
 	}
 

--
Gitblit v1.10.0