private const API_URL = 'https://accept.paymob.com/api/';
private $api_key;
private $hmac_secret;
private $integration_id;
private $iframe_id;
public function __construct() {
// Load Paymob settings from the database
$this->api_key = osc_get_preference('paymob_api_key', 'payment');
$this->hmac_secret = osc_get_preference('paymob_hmac_secret', 'payment');
$this->integration_id = osc_get_preference('paymob_integration_id', 'payment');
$this->iframe_id = osc_get_preference('paymob_iframe_id', 'payment');
}
/**
* Step 1: Authentication Request
*/
private function getAuthToken() {
$response = $this->sendRequest('auth/tokens', 'POST', ['api_key' => $this->api_key]);
return $response->token ?? null;
}
/**
* Step 2: Order Registration
*/
private function registerOrder($authToken, $orderId, $amount, $currency, $items, $billingData) {
$data = [
'auth_token' => $authToken,
'delivery_needed' => 'false',
'merchant_order_id' => $orderId,
'amount_cents' => $amount * 100, // Amount in cents
'currency' => $currency,
'items' => $items,
'billing_data' => $billingData
];
$response = $this->sendRequest('ecommerce/orders', 'POST', $data);
return $response->id ?? null;
}
/**
* Step 3: Get Payment Key
*/
private function getPaymentKey($authToken, $orderId, $amount, $currency, $billingData) {
$data = [
'auth_token' => $authToken,
'amount_cents' => $amount * 100,
'expiration' => 3600,
'order_id' => $orderId,
'billing_data' => $billingData,
'currency' => $currency,
'integration_id' => $this->integration_id
];
$response = $this->sendRequest('acceptance/payment_keys', 'POST', $data);
return $response->token ?? null;
}
/**
* Main method to initiate a payment
*/
public function createPayment($orderId, $amount, $currency, $items, $customer) {
$authToken = $this->getAuthToken();
if (!$authToken) {
// Handle error: Could not authenticate
return null;
}
$billingData = [
"apartment" => "NA",
"email" => $customer['email'],
"floor" => "NA",
"first_name" => $customer['first_name'],
"street" => "NA",
"building" => "NA",
"phone_number" => $customer['phone'],
"shipping_method" => "NA",
"postal_code" => "NA",
"city" => "NA",
"country" => "NA",
"last_name" => $customer['last_name'],
"state" => "NA"
];
$paymobOrderId = $this->registerOrder($authToken, $orderId, $amount, $currency, $items, $billingData);
if (!$paymobOrderId) {
// Handle error: Could not register order
return null;
}
$paymentKey = $this->getPaymentKey($authToken, $paymobOrderId, $amount, $currency, $billingData);
if (!$paymentKey) {
// Handle error: Could not get payment key
return null;
}
return "https://accept.paymob.com/api/acceptance/iframes/{$this->iframe_id}?payment_token={$paymentKey}";
}
/**
* Verify HMAC for callback/webhook
*/
public function verifyHmac($data) {
$hmac = $data['hmac'];
unset($data['hmac']);
// Paymob concatenates these specific keys in alphabetical order
$concatenated = '';
$keys = [
'amount_cents', 'created_at', 'currency', 'error_occured', 'has_parent_transaction',
'id', 'integration_id', 'is_3d_secure', 'is_auth', 'is_capture', 'is_refunded',
'is_standalone_payment', 'is_voided', 'order', 'owner', 'pending', 'source_data_pan',
'source_data_sub_type', 'source_data_type', 'success'
];
// Some keys might not be present in all callbacks
$requestKeys = array_keys($data);
$sortedKeys = array_intersect($keys, $requestKeys);
sort($sortedKeys);
foreach ($sortedKeys as $key) {
// Convert boolean to string 'true' or 'false'
if (is_bool($data[$key])) {
$concatenated .= $data[$key] ? 'true' : 'false';
} else {
$concatenated .= $data[$key];
}
}
$calculatedHmac = hash_hmac('sha512', $concatenated, $this->hmac_secret);
return hash_equals($calculatedHmac, $hmac);
}
/**
* Helper to send cURL requests
*/
private function sendRequest($endpoint, $method, $data) {
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, self::API_URL . $endpoint);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, $method);
curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($data));
$headers = array();
$headers[] = 'Content-Type: application/json';
curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
$result = curl_exec($ch);
if (curl_errno($ch)) {
// Handle curl error
curl_close($ch);
return null;
}
curl_close($ch);
return json_decode($result);
}
}
الموضة والجمال - ملابس وإكسسوارات ومستحضرات تجميل - سوق الجمعة
تم العثور على 0 إعلان
الموضة والجمال
الغزيمري
شركات
تطبيق سوق الجمعة
استخدم التطبيق الآن
الموضة والجمال الغزيمري ▼
استكشف الموضة والجمال على سوق الجمعة، حيث نقدم لك مجموعة متنوعة من الملابس، الإكسسوارات، ومستحضرات التجميل التي تناسب جميع الأذواق. ابحث عن ملابس رجالي، ملابس حريمي، وإكسسوارات للعناية الشخصية لتعزيز إطلالتك وجمالك.
لم يتم العثور على إعلانات في الموضة والجمال, الغزيمري
قد يكون الإنترنت لديك بطيئًا يرجى تحديث هذه الصفحة
تحديث
الاختيارات
ترتيب حسب
الأكثر تطابقا الأحدث أولاً السعر الأدنى أولاً السعر الأعلى أولاً
اقتراحات الموقع
على بعد 1 كم
لم نتمكن من العثور على أي نتائج لبحثك...
قد تساعدك النصائح التالية في الحصول على نتائج أفضل
تجربة مصطلح بحث أكثر وضوحًا
يرجى إجراء تدقيق إملائي
جرّب تحديد الاختيارات بشكل أقل
نتائج من خارج نطاق البحث
بولاق, مصر
كيسة كمبيوتر للبيع
كيسة كمبيوتر للبيع - بسعر ممتاز فقط أداء قوي وسعر على قد الإيد! المواصفات : كيسة عملية ومناسبة للاستخدام اليومي والشغل والدراسة رامات 4 جيجا لأداء سري...
1500.00 ج.م
400.00 ج.م
السعر
قابل للتفاوض
بيجام, مصر
بيع بانر مستعمل
بانر مستعمل للبيع جميع المقاسات يصلح لجميع الاغراض تبطين وعزل اسقف من المطر والحراره للتواصل 01111390520
مجانا
متاح خدمة توصيل نعم
الغربية, مصر
غسالة الومبك اتوماتيك
الغسالة سليمه ومفيهاش اي اعطال والبودي بتاعها مفيهوش اي بارومه
5500.00 ج.م
السعر
قابل للتفاوض
5500.00 ج.م
السعر
قابل للتفاوض
الجيزة, مصر
نقدم جميع أجهزة التنفس الصناعي
جميع أجهزة التنفس جديد ومستعمل بالضمان المعتمد أجهزة التنفس أثناء النوم أجهزة التنفس الأكسجين أجهزة التنفس cpap / Bipap / ventilator Oxygen generator
1000.00 ج.م
متاح خدمة توصيل نعم
الجيزة, مصر
مايوه 4 قطع مميز وأنيق
بسم الله توكلنا على الله وصلنا فووووري مايوه 4 قطع مميز وأنيق بلوزة + بنطلون + تربون + كاش شيفون طويل مقاسات: L - XL - 2XL - 3XL خامة واتر بروف مستورد...
500.00 ج.م
امبابة, مصر
لاب HP 645 g4
لاب HP 645 g4 يحتوي علي رامة ١٦ وهارد ٥١٢ hddللتخزين وهاردssd متقسم ٨٥ عليه النسخة و٨٥ للتخزين فيه كاميرا وكيبورد مضيئ خامات بلاستيك المعالج AMD Ryzen...
8500.00 ج.م
متاح خدمة توصيل نعم
الجيزة, مصر
مايوه اللي هيخليكي ترند الصيف
مايوه خامة مستوردة ووتر بروف مقاسات: M – XXL | وزن لحد 90 كجم راحة وأناقة في كل حركة متاح لفترة محدودة… احجز الان
اتصل بالبائع
القاهرة, مصر
كولمان ثلاجة ايس بوكس جديدة أمريكية
للبيع ثلاجة كولمان جديدة لم تستعمل قط امريكية الصنع سعة 454 لتر تستوعب 63 كانز 48 كورتز اللون أزرق السعر 5900 جنيه بدلا من 9000 جنيه لسرعة البيع لاى ا...
5900.00 ج.م
السعر
قابل للتفاوض
5900.00 ج.م
السعر
قابل للتفاوض
الهرم, مصر
ثلاجة كريازي ١٤ قدم
ثلاجة كريازي ١٤ قدم ٣٤٠ لتر ديفروست شحن الشركه تعمل بحالة جيده
8000.00 ج.م
السعر
قابل للتفاوض
8000.00 ج.م
السعر
قابل للتفاوض
2100.00 ج.م
السعر
قابل للتفاوض
الإسكندرية, مصر
كيسه جيمنج
4مراوح جيمنج ssd128 هارد 1تيرا كارت شاشه rx580 جيجات 8 16 رام cori5 6500 جيل سادس ريموت تغيير الوان الكيسه بالكرتونه واللزق اللي علي الازاز متفتحش ومت...
15000.00 ج.م
السعر
قابل للتفاوض
15000.00 ج.م
السعر
قابل للتفاوض
العاشر من رمضان, مصر
لينوفو Lenovo L340
لاب توب لينوفو بحاله ممتازه Cpu:ryzen 5 3500u Ram:8g Gpu:Radeon Vega 8 2 g Hard:256 ssd بروسيسور رايزن ٥ بسرعه ٢ جيجا هرتز كارت شاشه amd ٢ جيجا فعلى و...
8500.00 ج.م
السعر
قابل للتفاوض
8500.00 ج.م
السعر
قابل للتفاوض
القاهرة الجديدة, مصر
بوكس فريم تليفونات 10خط كومتيك
بوكس تليفونات سعة 10 خط ماركة كومتيك روزيتات كورونا تدبيس سريع وسهل يعمل للشبكات الداخليه والخارجية مقاوم للعوامل الجوية والماء والغبار والحرارة معتمد...
375.00 ج.م
عرسال, لبنان
Freefire account
Free fire account for sale
150.00 ل.ل
السعر
قابل للتفاوض
150.00 ل.ل
السعر
قابل للتفاوض
شبرا, مصر
غرفة النوم الدريسنج
وصلنا اوضه النوم دريسنج حاجه بسم الله ما شاء الله عليها قشره بره وجوه خشب كونتر حاجه بسم الله ما شاء الله عليها الدولاب4 دولف تسريحه بمرايه2كومودينو س...
21000.00 ج.م
متاح خدمة توصيل نعم
القاهرة, مصر
عرض أجهزة للعرسان والعرايس
عرض عروسة تلاجة ميديا 14 قدم ضمان 10 سنين ميراكو ياباني بوتجاز فرست كوك 9060 بمروحه ضمان 7 سنين غسالة فريش فوق اتوماتيك 7 كيلو ضمان 5 سنين
مجانا
أبيدوس, مصر
محول USB
محول USBمن النوع ذكر توصيل أي شئ بي التلفون
مجانا
السعر
قابل للتفاوض
مجانا
السعر
قابل للتفاوض
الإسكندرية, مصر
استشوار للجادين فقط
استشوار بناسونك استعمال وش واحد فقط موجود صورته ف الاعلان البيع للجادين فقط لا يوجد شحن المكان باكوس 600 ج ممنوع الفصال
600.00 ج.م
القاهرة, مصر
مشد الركبه الطبي لعلاج مشاكل الركبه
رمضان كريم حافظ على راحتك مع مشد الركبة الطبي! رمضان هو وقت للتأمل والصحة ولا تنسى راحة ركبتيك! إذا كنت تعاني من آلام الركبة أو مشاكل الحركة، مشد الرك...
100.00 ج.م
متاح خدمة توصيل نعم
القاهرة, مصر
عرض 3 أجهزة بسعر تحفة
عرض العروسة ع قد الايد تلاجة يونيون اير 10 قدم ديفروست ضمان 5 سنين بوتجاز ماستر أس ستوك 8060 ضمان 5 سنين غسالة فريش نص اتوماتيك 8 كيلو ضمان 5 سنين
مجانا
عمان, الأردن
فناجين ببيونة شاي و قرفة
عرض رقم 13 فناجين ببيونة شاي و قرفة 6 فناجين + 6 صحون سعر العرض : 10 دنانير شامل التوصيل كود التاجر Ajloun للطلب والاستفسار على رسائل الصفحه
10.00 د.ا
المنوفية, مصر
عمال انتاج
مصنع في مدينه السادات المنوفيه مصنع الخضراوات و فراوله ورديه 16 ساعة فيهم ساعتين راحه متقطعين مرتب شهري ثابت 9000 وحافز 1000اجمالي 10000 السن من 20 سن...
10000.00 ج.م
1700.00 ج.م
السعر
قابل للتفاوض
متاح خدمة توصيل نعم
الزمالك, مصر
ايربودز M12 توصيل مجاني
ايربودز M12 توصيل مجاني مميزات المنتج صوت زي الفل : هتسمع كل حاجة واضحة وعالقة في دماغك بطارية تشيل معاك اليوم كله انسَ الشحن وعيش حياتك خفيفة على ودا...
420.00 ج.م
الرمل, مصر
مشاية كهرباء رياضية
مشاية كهرباء كارنيلى تريد مايلز 140كيلو موتور دى سى 12سرعة قابلة للتطبيق كونترول كامل من الجوانب للتشغيل وسرعات وبرامج سرعات لفترات زمنية للعلم ثمنها ...
10000.00 ج.م
حمل التطبيق الآن
اتصل بنا
جميع الحقوق محفوظة لـ سوق الجمعة 2025 ©