Skip to content

API Standard

Krisan Alfa Timur edited this page May 15, 2017 · 4 revisions

FLIPBOX API STANDARD

Last Update Time : 20 Februari 2017

Seluruh deskripsi di bawah merupakan standar dari API yang dibuat oleh Flipbox dan telah melewati diskusi bersama.

KETENTUAN UMUM

  • Menggunakan versi dalam URLnya | contohnya http://example.com/api/android/v1
  • URL dibuat dengan menggunakan kebab-case | contohnya http://example.com/api/ios/v1/sample-api-url
  • Menggunakan singular form | contohnya http://example.com/api/android/v1/table atau http://example.com/api/ios/v1/city
  • Menggunakan id untuk mengakses child object | contohnya http://example.com/api/android/v1/country/{id}/city
  • Menggunakan pagination untuk mengakses kumpulan object | contohnya http://example.com/api/ios/v1/city?page=1
  • Memisahkan URL untuk setiap platform yang akan menggunakan API tsb | contohnya http://example.com/api/android/v1/city?page=1
  • URL publik harus dilindungi dengan menggunakan X-APP-TOKEN ( dikirimkan via Header )
  • API harus memiliki discovery URL
  • Private Token harus dikirimkan melalui Header
  • Menggunakan raw parameter berisi JSON untuk non multipart request
  • Maksimal waktu response API adalah 250ms untuk data umum / detail dan 400ms untuk kumpulan data

KETENTUAN PENGEMBALIAN DATA

  • Data yang dikembalikan harus menggunakan transformer untuk memastikan konsistensi struktur data

    • Sebaiknya 1 Transformer digunakan untuk 1 endpoint untuk menghindari perubahan struktur / key yang akan mengubah endpoint lain
  • Nilai data yang dikembalikan harus sesuai dengan tipenya ( apabila tipenya DOUBLE jangan mengembalikan STRING, apabila tipenya OBJECT jangan mengembalikan ARRAY dll )

  • Hindari pengembalian null value apabila sangat tidak terpaksa

List Request

  • Data HARUS di-paging, ukuran record-per-page dapat menyesuaikan dengan kondisi yang berjalan
  • next pointer link HARUS berupa string, jika current pointer adalah pointer terakhir dari daftar pointer, maka backend cukup mengembalikan string kosong: "".

Contoh kembalian data dari List

{
    "data": [],
    "meta": {
        "links": {
            "next": "/relative/url/to/resource",
            "prev": "/relative/url/to/resource"
        },
        "total_data": 100,
        "count": 2,
        "per_page": 10,
        "current_page": 10,
        "total_page": 10
    },
}

READ Request

  • Menggunakan HTTP GET Method
  • Mengembalikan HTTP Status Code 200 untuk return value dengan data, dan HTTP Status Code 204 untuk return value tanpa data.

Contoh kembalian data READ

{
    "data": {},
    "message": "get data xxx success"
}

CREATE Request

  • Menggunakan HTTP PUT / POST Method
  • Mengembalikan HTTP Status Code 201 apabila data berhasil dibuat

UPDATE Request

  • Menggunakan HTTP PUT / PATCH Method
  • Mengembalikan HTTP Status Code 200 apabila data berhasil diperbarui

DELETE Request

  • Menggunakan HTTP DELETE Method
  • Mengembalikan HTTP Status Code 200 apabila data berhasil dihapus

Contoh kembalian data untuk CREATE UPDATE & DELETE

{
    "message": "pesan yang bersesuaian dengan aksi"
}

RESPONSE UNTUK ERROR

  • Error Autentikasi

Harus mengembalikan HTTP Status Code 401 dengan error data sbb

{
    "code": 401.5,
    "message": "error message"
}
  • Error Validasi

Harus mengembalikan HTTP Status Code 422 dengan error data sbb

{
    "message": "error message",
    "errors": [{
        "field": "foo",
        "message": ["pesan error 1", "pesan error 2"]
    }, {
        "field": "bar",
        "message": ["pesan error 1", "pesan error 2"]
    }]
}
  • Error URL Tidak Ditemukan

Harus mengembalikan HTTP Status Code 404 dengan error data sbb

{
    "message": "pesan yang bersesuaian dengan error"
}
  • Error Server

Harus mengembalikan HTTP Status Code 500 dengan error data sbb

{
    "message": "error message",
    "trace": "string formatted stack trace"
}

trace hanya ditampilkan pada saat aplikasi run di staging environment, pada saat aplikasi run di production environment, trace HARUS disembunyikan.

Untuk kondisi lain

Apabila dijumpai kondisi yang tidak diprediksi, silahkan menggunakan data

{
    "message": "pesan yang bersesuaian kondisi"
}

dengan HTTP Status Code yang sesuai dengan situasi