Dana Subscription

Create Dana Subscription

Panduan membuat langganan (subscription) DANA via API Paylabs.

Request URL

URL: ${ROOT_URL}/dana/v1/sub/createsub

HTTPMethod: POST

EndpointUrl: /dana/v1/sub/createsub

Create Subscription Request Parameters

Cara Membuat Signature

Field NameTypeValueRequired
Content-TypeString(30)Isi dengan nilai "application/json;charset=utf-8"Yes
X-TIMESTAMPString(29)Waktu saat ini, dengan format 2022-09-16T16:58:47.964+07:00Yes
X-SIGNATUREString(64)Signature. Untuk selengkapnya cekYes
X-PARTNER-IDString(20)Merchant IDYes
X-REQUEST-IDString(64)ID unik merepresentasikan setiap request yang dikirimYes

Body

ParameterTypeRequiredRemarks
requestIdString(64)YesID unik untuk setiap request
merchantIdString(20)YesID unik yang disediakan oleh payment gateway ke merchant
storeIdString(30)NoJika Merchant memiliki cabang dan ingin membuat order dengan ID cabang
paymentTypeString(20)YesTipe Pembayaran, silahkan lihat Tipe Pembayaran
requestAmountdecimal(12,2)YesNominal pada saat permintaan
feeTypeString(3)NoJenis pengurangan biaya layanan:BEN�OUR. Standarnya BEN. Ketika OUR dipilih, biaya layanan akan ditambahkan ke nominal order secara otomatis.
merchantTradeNoString(32)YesKode unik yang dibuat oleh Merchant untuk setiap transaksi
notifyUrlString(200)NoURL untuk menerima pengingat pembayaran, pembatalan, atau pemberitahuan penyelesaian.
returnUrlString(200)NoURL pengembalian frontend untuk langganan awal.
subTitleString(128)YesJudul langganan, ditampilkan kepada pengguna.
subMessageString(256)NoDeskripsi langganan, ditampilkan kepada pengguna.
+subIntervalObjectYesDAILY: Harian, WEEKLY: Mingguan, MONTHLY: Bulanan.
a?OtypeString(10)YesDAILY: Day, WEEKLY: Week, MONTHLY: Month
a?OvalueNumber(2)YesInterval value, from 1 to 99
+productInfoObjectYesRincian produk/layanan untuk pembayaran berulang.
a?OidString(10)YesProduct ID
a?OnameString(32)YesProduct Name
a?Opricedecimal(12,2)YesNilai dalam Rupiah, mendukung dua angka belakang koma
a?OtypeString(20)YesProduct Type
a?OurlString(200)NoProduct URL
a?OquantityNumber(4)YesProduct Quantity

paymentType

Payment TypeCode
DANA E-Wallet (supports refund)StaticDanaSub,DynamicDanaSub

Create Subscription Response Parameters

Header

Cara Membuat Signature

Field NameTypeValueRequired
Content-TypeString(30)Isi dengan nilai "application/json;charset=utf-8"Yes
X-TIMESTAMPString(29)Waktu saat ini, dengan format 2022-09-16T16:58:47.964+07:00Yes
X-SIGNATUREString(64)Signature. Untuk selengkapnya cekYes
X-PARTNER-IDString(20)Merchant IDYes
X-REQUEST-IDString(64)ID unik merepresentasikan setiap request yang dikirimYes

Body

Kode Error

ParameterTypeRequiredRemarks
requestIdString(64)YesID unik untuk setiap request
errCodeString(32)Yes0 adalah sukses, untuk lainnya bisa lihat tabel
errCodeDesString(128)NoDeskripsi terkait error
merchantIdString(20)YesID unik yang disediakan oleh payment gateway ke merchant
storeIdString(30)NoJika Merchant memiliki cabang dan ingin membuat order dengan ID cabang
paymentTypeString(20)YesTipe Pembayaran, silahkan lihat Tipe Pembayaran
requestAmountDecimal(12,2)NoJumlah pembayaran
amountdecimal(12,2)YesJumlah dalam Rupiah Indonesia, dengan 2 angka desimal
merchantTradeNoString(32)YesNomor Transaksi Merchant, unique subscription ID
createTimeString(16)NoyyyyMMddHHmmss
statusString(32)No01: Subscription created 02: Payment successful 06: Subscription canceled 09: Subscription creation failed
checkoutUrlString(variable)NoURL bagi pengguna untuk menyelesaikan langganan
expiredTimeString(v)NoyyyyMMddHHmmss (setelah kedaluwarsa, checkoutUrl tidak dapat digunakan lagi)

Example

Request

POST  /dana/v1/sub/createsub
# HTTP Header
Content-Type: application/json;charset=utf-8
X-TIMESTAMP: 2022-09-16T16:58:47.964+07:00
X-SIGNATURE: xxxxxxxxx
X-PARTNER-ID: 010001
X-REQUEST-ID: xxxxxxxxxxxxxxxxxxxxxxxx

# HTTP Body
{
  "requestId": "PYeb8699ac-f46b-491f-a415-c894e9a5bca7",
  "merchantId": "010001",
  "paymentType": "StaticDanaSub",
  "requestAmount": 15000,
  "feeType": "BEN",
  "merchantSubId": "PY-1763012574.0645576",
  "notifyUrl": "https://merchant-domain.com/xxx",
  "redirectUrl": "https://paylabs.co.id/home.html",
  "subTitle": "test subTitle",
  "subMessage": "test subMessage",
  "subInterval": {
    "type": "WEEKLY",
    "value": "1"
  },
  "productInfo": {
    "id": "1",
    "name": "test",
    "price": 15000,
    "type": "1",
    "quantity": 1
  }
}

Response

POST /dana/v1/sub/createsub
# HTTP Header
Content-Type: application/json;charset=utf-8
X-TIMESTAMP: 2022-09-16T16:58:47.964+07:00
X-SIGNATURE: xxxxxxxxx
X-PARTNER-ID: 010001
X-REQUEST-ID: xxxxxxxxxxxxxxxxxxxxxxxx

# HTTP Body
{
  "merchantId": "010001",
  "requestId": "PYeb8699ac-f46b-491f-a415-c894e9a5bca7",
  "errCode": "0",
  "paymentType": "StaticDanaSub",
  "requestAmount": 15000,
  "amount": 15000,
  "merchantSubId": "PY-1763012574.0645576",
  "createTime": "20251113124254",
  "status": "01",
  "checkoutUrl": "https://xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
  "expiredTime": "20251113125254"
}