first commit
This commit is contained in:
81
backend/loginFirstTime.php
Executable file
81
backend/loginFirstTime.php
Executable file
@@ -0,0 +1,81 @@
|
||||
<?php
|
||||
// ============================================================
|
||||
// loginFirstTime.php — توكن التسجيل الأول (الراكب)
|
||||
// ============================================================
|
||||
|
||||
require_once __DIR__ . '/core/bootstrap.php';
|
||||
|
||||
header('Content-Type: application/json');
|
||||
header('Access-Control-Allow-Origin: https://intaleqapp.com');
|
||||
header('Access-Control-Allow-Methods: POST, OPTIONS');
|
||||
header('Access-Control-Allow-Headers: Content-Type, Authorization');
|
||||
|
||||
if ($_SERVER['REQUEST_METHOD'] === 'OPTIONS') {
|
||||
http_response_code(200);
|
||||
exit;
|
||||
}
|
||||
|
||||
try {
|
||||
$limiter = new RateLimiter($redis);
|
||||
$limiter->enforce(RateLimiter::identifier(), 'register');
|
||||
|
||||
$id = filterRequest('id');
|
||||
$password = filterRequest('password');
|
||||
$audience = filterRequest('aud');
|
||||
$fingerprint = filterRequest('fingerprint') ?? filterRequest('fingerPrint');
|
||||
|
||||
$allowed1 = getenv('allowed1');
|
||||
$allowed2 = getenv('allowed2');
|
||||
$allowedAudiences = array_values(array_filter([$allowed1, $allowed2]));
|
||||
$passwordnewpassenger = getenv('passwordnewpassenger');
|
||||
|
||||
if (empty($id) || empty($password) || empty($audience)) {
|
||||
jsonError('Missing input fields.', 400);
|
||||
}
|
||||
|
||||
if (!in_array($audience, $allowedAudiences, true)) {
|
||||
jsonError('Invalid audience', 400);
|
||||
}
|
||||
|
||||
if (!password_verify($password, $passwordnewpassenger)) {
|
||||
securityLog("FirstTime login failed (password)", ['id' => $id]);
|
||||
jsonError('Invalid password.', 401);
|
||||
}
|
||||
|
||||
$jwtService = new JwtService($redis);
|
||||
|
||||
// استخدام override للـ TTL في الـ Access Token (نحتاج 150 ثانية فقط)
|
||||
// لتوليد التوكن بتفاصيل خاصة، نستخدم الدالة generateAccessToken لكن بتعديل إن لزم،
|
||||
// أو نولد التوكن يدوياً هنا للسرعة كما كان:
|
||||
$fpPepper = getenv('FP_PEPPER') ?: '';
|
||||
$fpHash = (!empty($fingerprint) && !empty($fpPepper))
|
||||
? hash('sha256', $fingerprint . $fpPepper)
|
||||
: null;
|
||||
|
||||
$payload = [
|
||||
'user_id' => 'new',
|
||||
'sub' => $id,
|
||||
'token_type' => 'registration',
|
||||
'exp' => time() + 150, // 150 ثانية
|
||||
'iat' => time(),
|
||||
'iss' => 'Tripz',
|
||||
'aud' => $audience,
|
||||
'jti' => bin2hex(random_bytes(16)),
|
||||
];
|
||||
|
||||
if ($fpHash !== null) {
|
||||
$payload['fingerPrint'] = $fpHash;
|
||||
}
|
||||
|
||||
$secretKey = trim(file_get_contents('/home/intaleq-api/.secret_key'));
|
||||
$jwt = Firebase\JWT\JWT::encode($payload, $secretKey, 'HS256');
|
||||
|
||||
jsonSuccess([
|
||||
'jwt' => $jwt,
|
||||
'expires_in' => 150,
|
||||
]);
|
||||
|
||||
} catch (Exception $e) {
|
||||
securityLog("LoginFirstTime Error", ['msg' => $e->getMessage()]);
|
||||
jsonError('Server error', 500);
|
||||
}
|
||||
Reference in New Issue
Block a user