Update: 2026-06-16 22:44:11
This commit is contained in:
@@ -1,4 +1,21 @@
|
||||
<?php
|
||||
/**
|
||||
* jwtconnect.php — Unified Authentication Gateway (بوابة المصادقة الموحدة)
|
||||
*
|
||||
* ═══════════════════════════════════════════════════════════════
|
||||
* SECURITY UPGRADE: هذا الملف أصبح بوابة مصادقة إجبارية.
|
||||
* كل طلب يجب أن يمر بأحد المسارات التالية:
|
||||
*
|
||||
* Path 1: S2S API Key → X-S2S-Api-Key header
|
||||
* Path 2: Payment Key → PAYMENT_KEY header
|
||||
* Path 3: Webhook Token → X-Auth-Token header
|
||||
* Path 4: Cron Key / CLI → X-Cron-Key header أو CLI execution
|
||||
* Path 5: JWT (default) → Authorization: Bearer <token>
|
||||
*
|
||||
* أي طلب بدون أي مصادقة → يُرفض تلقائياً من authenticateJWT()
|
||||
* ═══════════════════════════════════════════════════════════════
|
||||
*/
|
||||
|
||||
// Load environment variables from .env file
|
||||
require_once realpath(__DIR__ . '/../vendor/autoload.php');
|
||||
require_once 'load_env.php';
|
||||
@@ -10,7 +27,7 @@ $secretKey = getenv('SECRET_KEY'); // Only need the secret key now
|
||||
|
||||
// --- CORS Headers ---
|
||||
$allowedOrigins = [
|
||||
'https://walletintaleq.intaleq.xyz',
|
||||
|
||||
'https://wallet.siromove.com',
|
||||
'https://wallet-syria.siromove.com',
|
||||
'https://wallet-egypt.siromove.com',
|
||||
@@ -22,17 +39,19 @@ if (in_array($origin, $allowedOrigins)) {
|
||||
} else {
|
||||
header("Access-Control-Allow-Origin: https://walletintaleq.intaleq.xyz");
|
||||
}
|
||||
header("Access-Control-Allow-Methods: GET, POST, OPTIONS"); // Adjust as needed
|
||||
header("Access-Control-Allow-Headers: Content-Type, Authorization");
|
||||
header('Content-Type: application/json'); // Set content type to JSON
|
||||
header("Access-Control-Allow-Methods: GET, POST, OPTIONS");
|
||||
header("Access-Control-Allow-Headers: Content-Type, Authorization, X-S2S-Api-Key, PAYMENT_KEY, X-Auth-Token, X-Cron-Key, X-HMAC-Auth, X-Device-FP");
|
||||
header('Content-Type: application/json');
|
||||
|
||||
// Handle preflight requests (OPTIONS)
|
||||
if ($_SERVER['REQUEST_METHOD'] == 'OPTIONS') {
|
||||
http_response_code(200);
|
||||
exit;
|
||||
}
|
||||
$dbname = getenv('dbname');
|
||||
// --- Database Connection (Still needed for your application logic) ---
|
||||
|
||||
$dbname = getenv('dbname');
|
||||
|
||||
// --- Database Connection ---
|
||||
try {
|
||||
$dsn = "mysql:host=localhost;dbname=$dbname;charset=utf8mb4";
|
||||
$options = [
|
||||
@@ -41,19 +60,75 @@ try {
|
||||
PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
|
||||
PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES UTF8"
|
||||
];
|
||||
$user = getenv('USER'); // Still used for DB connection
|
||||
$pass = getenv('PASS'); // Still used for DB connection
|
||||
$user = getenv('USER');
|
||||
$pass = getenv('PASS');
|
||||
$con = new PDO($dsn, $user, $pass, $options);
|
||||
|
||||
// --- JWT Authentication ---
|
||||
include "functions.php"; // Include the functions file
|
||||
// --- Load Functions ---
|
||||
include "functions.php";
|
||||
|
||||
|
||||
// ═══════════════════════════════════════════════════════════
|
||||
// UNIFIED AUTHENTICATION GATEWAY (بوابة المصادقة الموحدة)
|
||||
// ═══════════════════════════════════════════════════════════
|
||||
|
||||
$authMethod = null;
|
||||
$decodedToken = null;
|
||||
|
||||
// --- Path 1: S2S API Key (server-to-server calls) ---
|
||||
$s2sKey = $_SERVER['HTTP_X_S2S_API_KEY'] ?? '';
|
||||
$expectedS2s = getenv('S2S_SHARED_KEY');
|
||||
|
||||
if (!empty($s2sKey) && !empty($expectedS2s) && hash_equals($expectedS2s, $s2sKey)) {
|
||||
$authMethod = 'S2S';
|
||||
}
|
||||
|
||||
// --- Path 2: Payment Key (transfer endpoint) ---
|
||||
if (!$authMethod) {
|
||||
$paymentKey = $_SERVER['HTTP_PAYMENT_KEY'] ?? '';
|
||||
$expectedPayment = getenv('PAYMENT_KEY');
|
||||
|
||||
if (!empty($paymentKey) && !empty($expectedPayment) && hash_equals($expectedPayment, $paymentKey)) {
|
||||
$authMethod = 'PAYMENT_KEY';
|
||||
}
|
||||
}
|
||||
|
||||
// --- Path 3: Webhook Auth Token (MTN/Cliq external services) ---
|
||||
// ملاحظة: البوابة تعترف بوجود الهيدر فقط. كل webhook يتحقق من القيمة الفعلية بنفسه.
|
||||
if (!$authMethod) {
|
||||
$webhookToken = $_SERVER['HTTP_X_AUTH_TOKEN'] ?? '';
|
||||
|
||||
if (!empty($webhookToken)) {
|
||||
$authMethod = 'WEBHOOK';
|
||||
}
|
||||
}
|
||||
|
||||
// --- Path 4: Cron Key / CLI execution ---
|
||||
if (!$authMethod) {
|
||||
// 4a: CLI execution (php script.php directly)
|
||||
if (php_sapi_name() === 'cli' || php_sapi_name() === 'cli-server') {
|
||||
$authMethod = 'CLI';
|
||||
} else {
|
||||
// 4b: HTTP cron call with key header
|
||||
$cronKey = $_SERVER['HTTP_X_CRON_KEY'] ?? '';
|
||||
$expectedCron = getenv('CRON_KEY');
|
||||
|
||||
if (!empty($cronKey) && !empty($expectedCron) && hash_equals($expectedCron, $cronKey)) {
|
||||
$authMethod = 'CRON';
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// --- Path 5 (DEFAULT): JWT Authentication ---
|
||||
// إذا لم يتم التعرف على أي مسار آخر، يُفرض JWT.
|
||||
// authenticateJWT() ستُرجع 401 وتوقف التنفيذ إذا لم يكن هناك JWT صالح.
|
||||
if (!$authMethod) {
|
||||
$decodedToken = authenticateJWT();
|
||||
$authMethod = 'JWT';
|
||||
}
|
||||
|
||||
} catch (PDOException $e) {
|
||||
error_log($e->getMessage());
|
||||
http_response_code(500); // Internal Server Error
|
||||
http_response_code(500);
|
||||
echo json_encode(['error' => 'A database error occurred.']);
|
||||
exit;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user