Integrasikan Dodo Payments ke dalam aplikasi PHP Anda dengan SDK yang modern dan sesuai dengan PSR-4
SDK PHP menyediakan cara yang kuat dan fleksibel untuk mengintegrasikan Dodo Payments ke dalam aplikasi PHP Anda. Dibangun mengikuti standar PHP modern dengan autoloading PSR-4, ini menawarkan cakupan pengujian yang luas dan dokumentasi yang mendetail.
Perpustakaan API PHP Dodo Payments saat ini dalam beta. Kami sangat senang Anda dapat bereksperimen dengan ini! Silakan bagikan saran, laporan bug, atau permintaan fitur dengan mengajukan masalah.
Simpan kunci API Anda dengan aman menggunakan variabel lingkungan. Jangan pernah mengeksposnya dalam basis kode Anda atau mengkomitnya ke kontrol versi.
SDK menggunakan parameter bernama untuk menentukan argumen opsional. Anda dapat menginisialisasi objek nilai menggunakan konstruktor statis with:
Salin
<?phpuse Dodopayments\Customers\AttachExistingCustomer;// Recommended: Use static 'with' constructor with named parameters$customer = AttachExistingCustomer::with(customerID: "customer_id");
Builder juga tersedia sebagai pola alternatif:
Salin
<?phpuse Dodopayments\Customers\AttachExistingCustomer;// Alternative: Use builder pattern$customer = (new AttachExistingCustomer)->withCustomerID("customer_id");
Kesalahan tertentu secara otomatis dicoba ulang 2 kali secara default dengan backoff eksponensial yang singkat. Kesalahan berikut memicu percobaan ulang otomatis:
Kesalahan koneksi (masalah konektivitas jaringan)
408 Permintaan Timeout
409 Konflik
429 Batas Laju
500+ Kesalahan Internal
Timeout
Konfigurasikan perilaku ulang secara global atau per permintaan:
Salin
<?phpuse Dodopayments\Client;use Dodopayments\RequestOptions;// Configure default for all requests (disable retries)$client = new Client(maxRetries: 0);// Or, configure per-request$result = $client->checkoutSessions->create( productCart: [["productID" => "product_id", "quantity" => 1]], requestOptions: RequestOptions::with(maxRetries: 5),);
$page = $client->payments->list();var_dump($page);// Fetch items from the current pageforeach ($page->getItems() as $item) { var_dump($item->brand_id);}// Auto-paginate: fetch items from all pagesforeach ($page->pagingEachItem() as $item) { var_dump($item->brand_id);}
Ketika perpustakaan tidak dapat terhubung ke API atau menerima kode status non-sukses (4xx atau 5xx), subclass dari APIException dilempar:
Salin
<?phpuse Dodopayments\Core\Exceptions\APIConnectionException;use Dodopayments\Core\Exceptions\RateLimitException;use Dodopayments\Core\Exceptions\APIStatusException;try { $checkoutSessionResponse = $client->checkoutSessions->create( productCart: [["productID" => "product_id", "quantity" => 1]] );} catch (APIConnectionException $e) { echo "The server could not be reached", PHP_EOL; var_dump($e->getPrevious());} catch (RateLimitException $_) { echo "A 429 status code was received; we should back off a bit.", PHP_EOL;} catch (APIStatusException $e) { echo "Another non-200-range status code was received", PHP_EOL; echo $e->getMessage();}
Selalu bungkus panggilan API dalam blok try-catch untuk menangani kesalahan yang mungkin terjadi dengan baik dan memberikan umpan balik yang berarti kepada pengguna.