Contoh : Langkah Penggunaan API Accurate Online
Setiap HTTP request yang dikirimkan untuk mengakses API Accurate Online (AOL) harus menyertakan HTTP Header (Bearer) yang berisi Access Token yang sudah didapatkan pada tahap sebelumnya. Pada saat melakukan integrasi pertama kali dengan AOL, aplikasi pihak ke-3 harus mengetahui terlebih dahulu akan terhubung dengan database AOL yang mana. Oleh karena itu apabila sudah memperoleh Access Token pertama kali, aplikasi pihak ke-3 harus melakukan 2 tahap berikut ini:
Menampilkan Daftar Database AOL yang dapat diakses oleh Access Token terkait
Menyimpan informasi Database AOL yang dipilih oleh pengguna (id dan alias database) dan melakukan Open Database untuk mendapatkan informasi host dan session untuk disimpan dan digunakan untuk mengakses data didalam database tersebut
Ke-2 tahap diatas hanya perlu dilakukan 1x saja saat aplikasi pihak ke-3 belum mengetahui akan terhubung ke database AOL yang mana.
Sebagai contoh, berikut adalah informasi aplikasi yang akan digunakan:
|
Pastikan Anda telah memiliki Akses Token yang bisa didapatkan lewat proses OAuth. Sebagai contoh, berikut adalah Akses Token yang sudah didapatkan:
Pengguna | john@example.com |
---|---|
Akses Token | e8446369-bd56-4731-acea-c0a9e0cc46fa |
Skope | item_view item_save sales_invoice_view |
Cara membaca dokumentasi Daftar API Accurate Online
Setelah terdaftar sebagai pengembang AOL, Anda dapat melihat daftar dan dokumentasi API AOL di:
https://account.accurate.id/developer/api-docs.do
API AOL terbagi menjadi 2 jenis yaitu:
- API Dasar
Berisi API untuk operasi diluar data pengguna, misalnya: melihat daftar database, membuka database, dll - API Accurate
Berisi API untuk membaca, menulis, merubah ataupun menghapus data pada database pengguna AOL, misalnya: menambahkan barang/jasa baru, membuat faktur penjualan, dll. Untuk mengakses API Accurate, perlu ditambahkan header X-Session-ID yang berisi kode session database yang berhasil didapatkan dari pemanggilan API /api/open-db.do.
Pada dokumentasi, Anda dapat mengetahui URL Endpoint untuk mengakses API AOL beserta dengan parameter yang dapat digunakan
Cara mengetahui URL Endpoint API AOL
Contoh pada API Dasar berikut ini:
Untuk mendapatkan URL API, Anda dapat menggabungkan informasi yang di beri kotak diatas. Misalnya untuk mengakses API Db List (daftar database), berarti URL Endpoint API nya yaitu:
https://account.accurate.id/api/db-list.do
Sekarang kita coba mendapatkan URL Endpoint untuk menyimpan/mengedit data Cabang di database AOl :
Dari gambar diatas, kita bisa mendapatkan URL Endpoint untuk API Cabang yaitu:
https://xyz.accurate.id/accurate/api/branch/save.do
Namun untuk jenis API Accurate, prefix URL yang diberi tanda merah diatas perlu diganti dengan response parameter host yang didapatkan saat mengakses API Open DB. Contoh apabila response parameter host yang didapat dari API Open DB adalah: https://public.accurate.id, maka URL Endpoint yang digunakan untuk mengakases API Cabang untuk database tersebut adalah:
https://public.accurate.id/accurate/api/branch/save.do
Cara mengetahui parameter yang dapat digunakan pada API AOL
Pada dokumentasi Daftar API, dapat dilihat parameter yang dapat digunakan saat mengakses API terkait, lengkap dengan tipe data, contoh dan keterangannya, seperti berikut ini:
Parameter yang digunakan yaitu HTTP Parameter biasa (disarankan menggunakan HTTP POST method). Kolom Nama Parameter pada dokumentasi merupakan nama HTTP parameter yang dapat digunakan. Untuk mengubah/edit data yang sudah ada di AOL, harus menyertakan parameter id yang berisi id record yang ingin dirubah.
Untuk API yang memiliki tipe data yang kompleks, misalnya faktur penjualan, dimana 1 faktur penjualan bisa memiliki beberapa item, pada dokumentasi nama parameter diberi tambahan [n] dimana n adalah index angka urut mulai dari 0 (nol). Contoh sbb:
Misalnya:
detailItem[0].itemNo=ITM0001
detailItem[1].itemNo=ITM0002
Mendapatkan daftar database Accurate Online
Untuk mendapatkan daftar database yang dapat dibuka oleh pengguna john@example.com, gunakan API Db List seperti berikut:
URL | https://account.accurate.id/api/db-list.do |
---|---|
Method | HTTP GET |
Header | |
Authorization | Bearer e8446369-bd56-4731-acea-c0a9e0cc46fa |
Hasil dari request tersebut adalah daftar database seperti berikut:
|
Jika Anda tidak mendapatkan hasil seperti di atas, silakan melihat halaman Penjelasan Informasi Kesalahan pada API.
Mendapatkan session dan host dari Database
Untuk dapat membaca dan menulis ke database diperlukan informasi session dan host untuk database tersebut. Misalkan Anda ingin menggunakan database PT Demo Example maka session dan host dapat didapatkan menggunakan API Open Db dengan mengirimkan id dari database tersebut sebagai parameter sbb:
URL | https://account.accurate.id/api/open-db.do |
---|---|
Method | HTTP GET |
Header | |
Authorization | Bearer e8446369-bd56-4731-acea-c0a9e0cc46fa |
Request Parameter | |
id | 1156 |
Hasil dari request tersebut adalah sebagai berikut:
|
Dari hasil berikut didapatkan session 7ff842b6-53e2-4d7b-8038- 09e3f8318f1b dan host https://public.accurate.id yang dapat digunakan untuk mengakses data pada database terkait sesuai dengan scope yang diminta. Informasi host ini akan menentukan prefix URL untuk mengakses API Accurate.
Menulis data kedalam Database AOL
Berikutnya kita sudah dapat menulis ke database. Misalkan kita ingin menyimpan data barang baru, maka kita bisa lihat dari Daftar API, dan maka bisa menggunakan API /api/item seperti berikut:
URL | https://public.accurate.id/accurate/api/item/save.do |
---|---|
Method | HTTP POST |
Header | |
Authorization | Bearer e8446369-bd56-4731-acea-c0a9e0cc46fa |
X-Session-ID | 7ff842b6-53e2-4d7b-8038-09e3f8318f1b |
Request Body | |
name | Test Item |
itemType | INVENTORY |
Hasil dari request tersebut adalah sebagai berikut:
|
Membaca daftar data dari Database
Untuk melihat daftar barang yang ada, bisa menggunakan API /item/list seperti berikut:
URL | https://public.accurate.id/accurate/api/item/list.do |
---|---|
Method | HTTP GET |
Header | |
Authorization | Bearer e8446369-bd56-4731-acea-c0a9e0cc46fa |
X-Session-ID | 7ff842b6-53e2-4d7b-8038-09e3f8318f1b |
Request Parameter | |
fields | id,name,no |
filter.itemType | INVENTORY |
Hasil dari request tersebut adalah sebagai berikut :
|
Membaca rincian data dari Database
Untuk mendapatkan data barang yang lebih rinci bisa menggunakan API /item/detail seperti berikut:
URL | https://public.accurate.id/accurate/api/item/detail.do |
---|---|
Method | HTTP GET |
Header | |
Authorization | Bearer e8446369-bd56-4731-acea-c0a9e0cc46fa |
X-Session-ID | 7ff842b6-53e2-4d7b-8038-09e3f8318f1b |
Request Parameter | |
id | 1250 |
Hasil dari request tersebut adalah informasi data barang yang rinci seperti berikut:
|
Daftar API yang dapat digunakan dapat dilhat pada halaman developer https://account.accurate.id/developer pada bagian Daftar API. Anda juga dapat mencoba mencoba Public API Accurate Online secara interaktif tanpa harus membuat code terlebih dahulu melalui Swagger Hub berikut ini:
https://app.swaggerhub.com/apis/cpssoft/accurate-online_public_api/
Jika Anda mengalami kendala dalam penggunaan silakan lihat halaman Penjelasan Informasi Kesalahan pada API.