Pengiriman OTP Kustom
Jika Anda ingin membuat kode verifikasi sendiri tanpa melalui platform EngageLab, Anda dapat memanggil endpoint ini.
Endpoint ini khusus untuk mengirim kode verifikasi yang telah dibuat sebelumnya, dan tidak membuat kode verifikasi sendiri. Setelah mengirim kode verifikasi, Anda tidak perlu memanggil endpoint verifikasi untuk pemeriksaan.
Jika Anda ingin platform EngageLab membuat kode verifikasi, Anda dapat memanggil endpoint Pengiriman OTP EngageLab.
Endpoint
POST https://otp.api.engagelab.cc/v1/codes
Autentikasi
Lihat Autentikasi untuk memahami cara melakukan autentikasi API.
Contoh request
Header request
POST /v1/codes HTTP/1.1
Content-Type: application/json
Authorization: Basic amlndWFuZ2RldjpkZXZfc2VjcmV0
Body request
{
"to": "+6591234567",
"code":"398210",
"template":{
"id":"test-template-1",
"language": "default",
"params": {
"key1": "value1",
"key2": "value2"
}
}
}
Parameter request
Objek request dinyatakan dalam format JSON, sehingga header request perlu menyertakan Content-Type: application/json.
| Parameter | Tipe | Opsi | Keterangan |
|---|---|---|---|
| to | String | Wajib | Target pengiriman, nomor ponsel atau alamat email, +6598765432, support@engagelab.com |
| code | String | Wajib | Kode verifikasi kustom yang akan dikirim |
| template | JSON Object | Wajib | Informasi template, parameter tingkat kedua di dalamnya lihat di bawah |
| |_ id | String | Wajib | ID template |
| |_ language | String | Opsional | Bahasa template, mendukung beberapa bahasa berikut: default bahasa default zh_CN Mandarin Sederhana zh_HK Mandarin Tradisional en Inggris ja Jepang th Thai es Spanyol jika tidak diisi maka default adalah default (bahasa default) |
| |_ params | JSON Object | Opsional | Nilai dari Key variabel template kustom |
| Jika Anda mendefinisikan variabel saat membuat template, isikan nilainya di sini; jika tidak diisi, maka akan dikirim langsung sebagai Key variabel, seperti {{var}} |
Penjelasan tentang params
- Untuk field preset template seperti from_id, jika nilai field params tidak diteruskan, maka saat pengiriman pesan akan digunakan from_id preset template;
- Jika nilai field params diteruskan, seperti
params:{"from_id":"12345"}, maka saat pengiriman pesan, from_id template akan diganti menjadi 12345; - Selain itu, untuk field variabel kustom dalam konten template saat pembuatan template, nilainya juga diisi melalui params, misalnya konten template
Hi {{name}}, your verify code is {{code}}, maka perlu mengisi parameterparams:{"name":"Bob"} - Variabel khusus channel Email: Untuk channel Email, mendukung penimpaan dinamis subjek email (
subject), nama pengirim (from_name), email pengirim (from_mail), dan lainnya melaluiparams. Untuk penggunaan lanjutan yang lebih detail, lihat Buat Template - Penggunaan lanjutan variabel template Email.
Parameter respons
Respons sukses
| Field | Tipe | Opsi | Deskripsi |
|---|---|---|---|
| message_id | String | Wajib | ID pesan, mengidentifikasi secara unik suatu pesan |
| send_channel | String | Wajib | Menunjukkan channel pengiriman saat ini, nilainya whatsapp/sms/email/voice |
{
"message_id": "1725407449772531712",
"send_channel": "sms"
}
Perhatikan, nilai**send_channel**yang dikembalikan tidak mewakili channel akhir yang sampai ke pengguna, melainkan hanya mewakili channel yang digunakan pada tahap saat ini; jika strategi template mengonfigurasi channel WhatsApp dan pengirimannya gagal lalu otomatis dikirim ulang melalui channel SMS, maka respons endpoint akan mengembalikan nilai whatsapp, dan setelah beberapa waktu ketika kegagalan terdeteksi, sistem akan menggunakan channel SMS untuk mengirim
Respons gagal
Status code HTTP adalah 4xx atau 5xx, body respons berisi field sebagai berikut:
| Field | Tipe | Opsi | Deskripsi |
|---|---|---|---|
| code | int | Wajib | Kode error, lihat penjelasan kode error |
| message | String | Wajib | Detail error |
{
"code": 5001,
"message": "sms send fail"
}
Kode error
| Kode error | http code | Keterangan |
|---|---|---|
| 1000 | 500 | Error internal |
| 2001 | 401 | Autentikasi gagal, tidak menyertakan token yang benar |
| 2002 | 401 | Autentikasi gagal, token telah kedaluwarsa atau dinonaktifkan |
| 2004 | 403 | Tidak memiliki izin untuk memanggil API ini |
| 3001 | 400 | Format parameter request tidak valid, harap periksa apakah konten JSON sesuai dengan format parameter |
| 3002 | 400 | Parameter request salah, harap periksa apakah parameter request memenuhi persyaratan |
| 3003 | 400 | Parameter request salah, validasi bisnis terkait gagal, lihat detail pada deskripsi error di field message |
| 3004 | 400 | Melebihi batas frekuensi, untuk template dan target pengguna yang sama, tidak dapat mengirim ulang dalam masa berlaku kode verifikasi |
| 4001 | 400 | Resource terkait tidak ada, seperti penggunaan template yang tidak ada saat mengirim pesan template |
| 5001 | 400 | Pengiriman gagal (umum/lainnya) |
| 5011 | 400 | Format nomor ponsel tidak valid |
| 5012 | 400 | Target tidak dapat dijangkau |
| 5013 | 400 | Nomor masuk daftar hitam (blacklist) |
| 5014 | 400 | Konten tidak sesuai ketentuan |
| 5015 | 400 | Pesan diblokir/ditolak |
| 5016 | 400 | Error internal pengiriman |
| 5017 | 400 | Tidak memiliki izin pengiriman ke wilayah Tiongkok |
| 5018 | 400 | Ponsel bermasalah (mati/nonaktif) |
| 5019 | 400 | Pengguna telah berhenti berlangganan |
| 5020 | 400 | Nomor tidak terdaftar/nomor kosong |










