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 كم
لم نتمكن من العثور على أي نتائج لبحثك...
قد تساعدك النصائح التالية في الحصول على نتائج أفضل
تجربة مصطلح بحث أكثر وضوحًا
يرجى إجراء تدقيق إملائي
جرّب تحديد الاختيارات بشكل أقل
نتائج من خارج نطاق البحث
اتصل بالبائع
السعر
قابل للتفاوض
اتصل بالبائع
السعر
قابل للتفاوض
أبلاس, اليمن
عمل عن بعد من جوالك
إذا كنت تبحث عن طريقة لتغيير حياتك وزيادة دخلك بشكل حقيقي ومستدام، دون الحاجة للاستثمار في العملات أو التداول أو التعامل مع شركات ومواقع غير موثوقة، ف...
1000.00 $
متاح خدمة توصيل نعم
مصر الجديدة, مصر
مايوهات صيفية عصرية أنيقة
من مصنع SF – شياكة وخامة ولا أروع المقاسات: M / L / XL / XXL ️ التلبيس: من 55 لـ 95 كيلو الخامة: وتربروف ضد المياه خامة مثالية للراحة والشياكة مع بعض!...
510.00 ج.م
عزبة المراغي, مصر
شقة ايجار قديم للبيع
شقة ايجار قديم بعقد مدنى59 سنه ولا تخضع لقانون الإيجار القديم الصادر 2025 الجديد ثلاث غرف مقفولين وصالة ومطبخ وحمام حوالى 90متر الدور الثالث علوى بمنز...
225000.00 ج.م
الجيزة, مصر
نقدم جميع أجهزة التنفس الصناعي
جميع أجهزة التنفس جديد ومستعمل بالضمان المعتمد أجهزة التنفس أثناء النوم أجهزة التنفس الأكسجين أجهزة التنفس cpap / Bipap / ventilator Oxygen generator
1000.00 ج.م
متاح خدمة توصيل نعم
الرحمانية, مصر
تابلت المدرسه شبه جديد
تابلت شبه جديد متصلحش ولا مره ومعاه الشاحن بتاعه الأصلي والكرتونه
4200.00 ج.م
الدقي, مصر
Fujifilm X-H2 كاميرا و مجموعة عدسات
للبيع بحالة ممتازة Fujifilm xh2 ضمان ينتهي في ٢٦مايو Shutter count 25.000 88.000 le Viltrox 13 mm f14 20.000 le Viltrox 75 mm f12 20.000 le Viltrox 33...
اتصل بالبائع
السعر
قابل للتفاوض
اتصل بالبائع
السعر
قابل للتفاوض
متاح خدمة توصيل نعم
الطالبية, مصر
كيوسيرا 5056i
لو عندك شغل كتير وعايز تعتمد على ماكينة تصوير قوية تتحمل الضغط ومشاكلها قليلة – يبقى كيوسيرا 5056i هتكون أنسب اختيار ليك صُممت هذه الماكينة لتواكب متط...
18500.00 ج.م
السعر
قابل للتفاوض
18500.00 ج.م
السعر
قابل للتفاوض
مدينة العين, الإمارات
2017 suzuki GSXR
Clean and perfect suzuki GSXR with low mileage and it has never been taken to the mechanic for more information you can contact me on WhatsApp
220000.00 د.إ
السعر
قابل للتفاوض
220000.00 د.إ
السعر
قابل للتفاوض
القاهرة, مصر
مشاية كهربائيّة رياضية
للبيع عاجل! مشاية كهربائية Jaguar T2002 - بحالة كسر الزيرو وبسعر مغري! مواصفات قوية لأداء رياضي مميز: تحمل حتى 110 كجم – مناسبة للجميع سرعة تصل إلى 14...
9000.00 ج.م
السعر
قابل للتفاوض
9000.00 ج.م
السعر
قابل للتفاوض
البساتين, مصر
Poco x3 pro للبيع
Poco x3 pro معاة شاحن و علبة 128 جيجا 8 رام علية اسكرينة هي المكسورة الشاشة سليمة عامل ريبولنيج معاة جرابين التواصل 01148595544
4800.00 ج.م
السعر
قابل للتفاوض
4800.00 ج.م
السعر
قابل للتفاوض
متاح خدمة توصيل نعم
نزلة سلام, مصر
أحدث تشكيلة مايوهات حريمي
جديد - حصرى مايوهات حريمي روعه خامات مستورده عاليه الجوده مايو وتر بروف المقاسات فري سايز تلبيس لحد 85 كيلو
اتصل بالبائع
متاح خدمة توصيل نعم
القاهرة, مصر
كوتشي أديداس رجالي موديل عصري ومريح
كوتشي أديداس رجالي موديل عصري ومريح ارتقِ بإطلالتك اليومية مع هذا الحذاء الرياضي المميز الذي يجمع بين الراحة والأناقة! تفاصيل مميزة: ️ تصميم جانبي مبت...
800.00 ج.م
كاونتر تسكام تركي – موديل حديث
كاونتر تسكام تركي – موديل حديث تصميم أنيق وجودة عالية اليوفي بديل الرخام ️ بليت 08 درجة أولى قواطع ثقيلة وثابتة ويجي وياه سلة مواعين جاهزة السعر فقط 4...
400.00 د.ع
عزبة عرب حميدة, مصر
طقم كراسي وترابيزة بيور
مواصفات الكرسي : بلاستيك بيور فرز أول كرسي بلاستيك صبه كامله و الرجل مدعمه بمعدن لزياده عصب الكرسي بيتحمل وزن لحد ٢٠٠ كيلو وزن الكرسي 6 كيلو بضمان ١٢ ...
مجانا
النزهة الجديدة, مصر
صالون مدهب
صالون مدهب يتكون من كنبة ٣ ٢ كرسي ٦ كوشن ٢ طاولات جانبيه وطاولة كبيرة جميعهم برخام امبرادور اسباني خشب زان القماش من شاتيكس
12000.00 ج.م
7000.00 ج.م
السعر
قابل للتفاوض
العلمين, مصر
شاليه للبيع في بورتو جولف مارينا
شاليه للبيع في بورتو جولف مارينا 80 متر الدور السادس مبنى 50 نموذج ب السعر 3 مليون الكود: PM2578 Deals On Seas - شركة عقارات عالبحر كما يتوفر أيضًا اس...
3000000.00 ج.م
السعر
قابل للتفاوض
3000000.00 ج.م
السعر
قابل للتفاوض
القاهرة الجديدة, مصر
موتوسكل لقطه ارخص من اى حد
موتوسكل مديل 2024 م لقطه بسعر مغري 35000 جنيه جديد ومعاه ترخيص سنتين لم يستخدم
35000.00 ج.م
الهرم, مصر
شماعة حجرة نوم
رف خشب شماعه لـ حجره النوم السعر نهائى التسليم فيصل او هرم
400.00 ج.م
العاشر من رمضان, مصر
ركنه زان للبيع
لا تحتاج اي مصروف بتتفتح سرير طوله ٥ متر علي قطعتين السعر ١٢٠٠٠ج
12000.00 ج.م
السعر
قابل للتفاوض
12000.00 ج.م
السعر
قابل للتفاوض
القاهرة, مصر
كونسول بمرآة بيضاوية
كونسول بمرآة بيضاوية يصلح لمدخل المنزل
2100.00 ج.م
السعر
قابل للتفاوض
2100.00 ج.م
السعر
قابل للتفاوض
القاهرة, مصر
HP ZBOOK 17 G2 workstation
السعر قابل للتفاوض HP ZBOOK 17 G2 workstation SSD:sata 128 GB HDD: 1TB RAM: 16 GB CPU: IntelR CoreTM 17-4810MQ 280GHz GPU1: NVIDIA QUARDO K3100M 4 GIG...
10000.00 ج.م
السعر
قابل للتفاوض
10000.00 ج.م
السعر
قابل للتفاوض
مدينة العبور, مصر
كبه تقطيع
كبه سعه ٢ لتر لتقطيع الخضروات 250 وات استعمال بسيط جدا بحاله الجديد البيع لعدم الحاجه المكان العبور او مدينه نصر السعر 400 ج
400.00 ج.م
حمل التطبيق الآن
اتصل بنا
جميع الحقوق محفوظة لـ سوق الجمعة 2025 ©