Tutorial ini menyediakan kode implementasi contoh untuk aplikasi Node.js/Express. Anda dapat memodifikasi kode ini untuk kerangka kerja spesifik Anda (Next.js, React, Vue, dll.) dan menyesuaikan antarmuka pengguna sesuai dengan kebutuhan aplikasi Anda.
- Membuat produk langganan dengan penetapan harga berdasarkan kursi
- Mengatur add-on untuk kursi tambahan
- Menghasilkan tautan pembayaran dengan jumlah add-on kustom
- Menangani sesi checkout dengan jumlah kursi dinamis
Apa yang Kita Bangun
Mari kita buat model penetapan harga berdasarkan kursi:- Rencana Dasar: $49/bulan untuk hingga 5 anggota tim
- Add-on Kursi: $2/bulan per kursi tambahan
- Tautan Pembayaran: Checkout dinamis dengan jumlah kursi kustom
Sebelum kita mulai, pastikan Anda memiliki:
- Akun Dodo Payments
- Pemahaman dasar tentang TypeScript/Node.js
Langkah 1: Buat Add-On Kursi Anda
Sekarang kita perlu membuat add-on yang mewakili kursi tambahan. Add-on ini akan dilampirkan pada langganan dasar kita dan memungkinkan pelanggan untuk membeli kursi tambahan.
1
Navigasi ke Add-Ons
- Di dasbor Dodo Payments Anda, tetap di bagian Produk
- Klik pada tab Add-Ons
- Klik Buat Add-On
2
Masukkan detail add-on
Isi nilai-nilai ini untuk add-on kursi kita:Nama Add-On:
Additional Team SeatDeskripsi: Add extra team members to your workspace with full access to all featuresHarga: Masukkan → 2.00Mata Uang: Harus sesuai dengan mata uang langganan dasar AndaKategori Pajak: Pilih kategori yang sesuai untuk produk Anda.3
Simpan add-on Anda
- Tinjau semua pengaturan Anda:
- Nama: Kursi Tim Tambahan
- Harga: $2.00/bulan
- Klik Buat Add-On
Add-on dibuat! Add-on kursi Anda sekarang tersedia untuk dilampirkan pada langganan.
Langkah 2: Buat Produk Langganan Dasar Anda
Kita akan mulai dengan membuat produk langganan dasar yang mencakup 5 anggota tim. Ini akan menjadi dasar dari model penetapan harga berdasarkan kursi kita.
1
Navigasi ke Produk
- Masuk ke dasbor Dodo Payments Anda
- Klik pada Produk di sidebar kiri
- Klik tombol Buat Produk
- Pilih Langganan sebagai jenis produk
2
Isi detail langganan
Sekarang kita akan memasukkan detail spesifik untuk rencana dasar kita:Nama Produk:
MotionDeskripsi: Where your team's documentation lives.Harga Berulang: Masukkan → 49.00Siklus Penagihan: Pilih → MonthlyMata Uang: Pilih mata uang yang Anda inginkan (misalnya, USD)Langkah 3: Hubungkan Add-On ke Langganan
Sekarang kita perlu mengaitkan add-on kursi kita dengan langganan dasar agar pelanggan dapat membeli kursi tambahan selama checkout.1
Lampirkan add-on kursi

- Gulir ke bawah ke bagian Add-Ons
- Klik Tambahkan Add-Ons
- Dari dropdown, pilih add-on kursi Anda
- Konfirmasi bahwa itu muncul dalam konfigurasi langganan Anda
2
Simpan perubahan langganan
- Tinjau pengaturan lengkap langganan Anda:
- Rencana dasar: $49/bulan untuk 5 kursi
- Add-on: $2/bulan per kursi tambahan
- Uji coba gratis: 14 hari
- Klik Simpan Perubahan
Penetapan harga berdasarkan kursi telah dikonfigurasi! Pelanggan sekarang dapat membeli rencana dasar Anda dan menambahkan kursi tambahan sesuai kebutuhan.
Langkah 4: Hasilkan Tautan Pembayaran dengan Jumlah Add-On Kustom
Sekarang mari kita buat aplikasi Express.js yang menghasilkan tautan pembayaran dengan jumlah add-on kustom. Di sinilah kekuatan nyata dari penetapan harga berdasarkan kursi muncul - Anda dapat secara dinamis membuat sesi checkout dengan jumlah kursi tambahan yang diinginkan.1
Siapkan proyek Anda
Buat proyek Node.js baru dan instal dependensi yang diperlukan:Buat file
tsconfig.json:2
Buat file lingkungan Anda
Buat file
.env dengan kunci API Dodo Payments Anda:3
Implementasikan pembuatan sesi checkout
Buat file
src/server.ts dengan kode berikut:4
Tambahkan antarmuka web sederhana
Buat file
public/index.html untuk pengujian yang mudah:Antarmuka web dibuat! Anda sekarang memiliki UI sederhana untuk menguji berbagai jumlah kursi.
5
Layani file statis
Tambahkan ini ke
src/server.ts Anda untuk melayani file HTML:File statis dikonfigurasi! Kunjungi
http://localhost:3000 untuk melihat antarmuka demo Anda.Langkah 5: Uji Implementasi Anda
Mari kita uji implementasi penetapan harga berdasarkan kursi kita untuk memastikan semuanya berfungsi dengan benar.1
Mulai server Anda
- Pastikan Anda memiliki file
.envdengan kunci API yang benar - Perbarui ID produk dan add-on dalam kode Anda dengan nilai aktual dari dasbor Dodo Payments Anda
- Mulai server Anda:
Server Anda harus mulai dengan sukses dan menunjukkan “Server berjalan di http://localhost:3000”
2
Uji antarmuka web

- Buka browser Anda dan pergi ke
http://localhost:3000 - Anda seharusnya melihat antarmuka demo penetapan harga berdasarkan kursi
- Coba jumlah kursi yang berbeda (0, 3, 10, dll.)
- Klik “Hasilkan Tautan Checkout” untuk setiap jumlah
- Verifikasi bahwa URL checkout dihasilkan dengan benar
3
Uji sesi checkout
- Hasilkan tautan checkout dengan 3 kursi tambahan
- Klik URL checkout untuk membuka checkout Dodo Payments
- Verifikasi bahwa checkout menunjukkan:
- Rencana dasar: $49/bulan
- Kursi tambahan: 3 × 2 dolar = $6/bulan
- Selesaikan pembelian uji coba
Checkout harus menampilkan rincian harga yang benar dan memungkinkan Anda menyelesaikan pembelian.
4
Dengarkan webhook dan perbarui DB Anda
Untuk menjaga database Anda tetap sinkron dengan perubahan langganan dan kursi, Anda perlu mendengarkan peristiwa webhook dari Dodo Payments. Webhook memberi tahu backend Anda ketika seorang pelanggan menyelesaikan checkout, memperbarui langganan mereka, atau mengubah jumlah kursi.Ikuti panduan webhook resmi Dodo Payments untuk instruksi langkah demi langkah tentang cara mengatur endpoint webhook dan menangani peristiwa:
Dokumentasi Webhook Dodo Payments
Pelajari cara menerima dan memproses peristiwa webhook dengan aman untuk manajemen langganan dan kursi.
Pemecahan Masalah
Masalah umum dan solusinya:Pembuatan checkout gagal
Pembuatan checkout gagal
Kemungkinan penyebab:
- ID produk atau ID add-on tidak valid
- Kunci API tidak memiliki izin yang cukup
- Add-on tidak terhubung dengan benar ke langganan
- Masalah konektivitas jaringan
- Verifikasi bahwa ID produk dan add-on ada di dasbor Dodo Payments Anda
- Periksa bahwa add-on terlampir dengan benar ke langganan
- Pastikan kunci API memiliki izin untuk pembuatan sesi checkout
- Uji konektivitas API dengan permintaan GET sederhana
Selamat! Anda Telah Menerapkan Penetapan Harga Berdasarkan Kursi
Anda telah berhasil membuat sistem penetapan harga berdasarkan kursi dengan Dodo Payments! Berikut adalah apa yang telah Anda capai:Langganan Dasar
Membuat produk langganan dengan 5 kursi yang termasuk seharga $49/bulan
Add-on Kursi
Mengonfigurasi add-on untuk kursi tambahan seharga $2/bulan per kursi
Checkout
Membangun API yang menghasilkan sesi checkout dengan jumlah kursi kustom
Antarmuka Web
Membuat antarmuka web sederhana untuk menguji berbagai jumlah kursi
Contoh ini hanya menunjukkan implementasi minimal dari penetapan harga berdasarkan kursi. Untuk penggunaan produksi, Anda harus menambahkan penanganan kesalahan yang kuat, otentikasi, validasi data, langkah-langkah keamanan, dan menyesuaikan logika agar sesuai dengan kebutuhan aplikasi Anda.