🔐 EasyStream Authentication System Examples

VSecurity::postParam('username', 'string'), 'email' => VSecurity::postParam('email', 'email'), 'password' => $_POST['password'] ?? '' ]; $result = $auth->register($userData); $message = $result['message']; $messageType = $result['success'] ? 'success' : 'error'; } else { $message = 'Invalid CSRF token'; $messageType = 'error'; } break; case 'login': if (VSecurity::validateCSRFFromPost('login')) { $identifier = VSecurity::postParam('identifier', 'string'); $password = $_POST['password'] ?? ''; $rememberMe = VSecurity::postParam('remember_me', 'boolean', false); $result = $auth->login($identifier, $password, $rememberMe); $message = $result['message']; $messageType = $result['success'] ? 'success' : 'error'; } else { $message = 'Invalid CSRF token'; $messageType = 'error'; } break; case 'logout': if (VSecurity::validateCSRFFromPost('logout')) { $result = $auth->logout(); $message = $result['message']; $messageType = $result['success'] ? 'success' : 'error'; } else { $message = 'Invalid CSRF token'; $messageType = 'error'; } break; case 'verify_email': $token = VSecurity::postParam('token', 'string'); $result = $auth->verifyEmail($token); $message = $result['message']; $messageType = $result['success'] ? 'success' : 'error'; break; case 'request_reset': if (VSecurity::validateCSRFFromPost('password_reset')) { $email = VSecurity::postParam('email', 'email'); $result = $auth->requestPasswordReset($email); $message = $result['message']; $messageType = $result['success'] ? 'success' : 'error'; } else { $message = 'Invalid CSRF token'; $messageType = 'error'; } break; case 'reset_password': if (VSecurity::validateCSRFFromPost('password_reset')) { $token = VSecurity::postParam('token', 'string'); $password = $_POST['password'] ?? ''; $result = $auth->resetPassword($token, $password); $message = $result['message']; $messageType = $result['success'] ? 'success' : 'error'; } else { $message = 'Invalid CSRF token'; $messageType = 'error'; } break; } } // Display message if ($message) { echo "
{$message}
"; } // Check authentication status $isAuthenticated = $auth->isAuthenticated(); $currentUser = $auth->getCurrentUser(); ?>
Authentication Status: ✅ Authenticated as ❌ Not authenticated

Current User Information

User ID:

Username:

Email:

Role:

🚪 Logout

📝 User Registration

Must contain: uppercase, lowercase, number, and special character

🔑 User Login

📧 Email Verification

If you registered but haven't verified your email, enter your verification token here:

🔄 Password Reset

Request Password Reset

Reset Password with Token

Must contain: uppercase, lowercase, number, and special character

🔧 API Examples

The authentication system also provides a REST API at /api/auth.php

Available Endpoints:

Example JavaScript Usage:

// Get CSRF token
const tokenResponse = await fetch('/api/auth.php?action=csrf_token&for=login');
const tokenData = await tokenResponse.json();

// Login user
const loginResponse = await fetch('/api/auth.php?action=login', {
    method: 'POST',
    headers: { 'Content-Type': 'application/json' },
    body: JSON.stringify({
        identifier: 'username',
        password: 'password',
        csrf_token: tokenData.token,
        remember_me: true
    })
});

const loginResult = await loginResponse.json();
console.log(loginResult);

🛡️ Security Features