Skip to main content

Access Token

Mendapatkan Token

Melakukan proses autentikasi untuk mendapatkan akses token yang akan dipakai pada setiap request ReST API SehatMu selanjutnya.

Request

URL

https://istanbul.muhammadiyah.or.id/oauth/token

HTTP Verb/Method

POST

Request

Parameters

Nama ParameterTipe DataKeterangan
*Content-TypestringMime type dari payload data yang akan dikirimkan dalam bentuk URL Encoded, WAJIB diisi dengan application/x-www-form-urlencoded.

Query String

Parameters

Nama ParameterTipe DataKeterangan
*grant_typestringTipe permintaan akses (grant) Oauth2, WAJIB diisi dengan client_credentials.

Body (application/x-www-form-urlencoded)

Parameters

Nama ParameterTipe DataKeterangan
*client_idstringNilai client ID yang telah didapatkan dari Pusat Data dan Teknologi Informasi - Digital Transformation Office (DTO) Kementerian Kesehatan Republik Indonesia setelah melakukan pengajuan via email, WAJIB diisi. Nilai ini bisa disamakan seperti username yang akan digunakan untuk akses aplikasi.
*client_secretstringNilai client secret yang telah didapatkan dari Pusat Data dan Teknologi Informasi - Digital Transformation Office (DTO) Kementerian Kesehatan Republik Indonesia setelah melakukan pengajuan via email, WAJIB diisi. Nilai ini bisa disamakan seperti kata sandi (password) yang akan digunakan untuk akses aplikasi.

Contoh Data

Setiap nilai yang dicontohkan atau ditampilkan di dokumentasi ini adalah nilai yang tidak sebenarnya dan tidak dapat dipakai. Nilai-nilai tersebut hanya untuk keperluan contoh saja, tidak untuk dipakai.

client_id: 0d8d0652-3a1d-47c3-97a6-d5a513c5f285.sehatmu.client
client_secret: 906959aa4211487066072588249854ac1ca54e06a54940bc35b3311fc594ed2a

Response

Hasil response, dengan HTTP Status Code berpola 2xx atau 4xx, yang dikembalikan dari server mempunyai parameter Content-Type dengan nilai application/json di salah satu parameter header-nya.

2xx Success

Dari hasil response ini, PERLU disimpan nilai akses token yang didapat dari properti access_token, dimana tipe token (lihat properti token_type) tersebut adalah BearerToken. Nilai akses token tersebut WAJIB selalu digunakan sebagai nilai dari header Authorization: Bearer <access_token> saat melakukan request lainnya dari ReST API SehatMu.

Struktur Data

{
accessToken: number
accessTokenExpiresAt: string
clientId: string
client: object
userId: string
user: object
}
  1. Respon yang diterima berupa object.
  2. Properti developer.email bertipe string, berisi informasi akun kredensial (email) pengguna pada API SehatMu.
  3. Properti issued_at bertipe string, berisi informasi waktu pembuatan access_token.
  4. Properti client_id bertipe string, berisi nilai akses API SehatMu yang dapat dilihat pada website SehatMu.kemkes.go.id/platf
  5. orm.
  6. Properti access_token bertipe string, berisi nilai bearer token untuk digunakan di header authorization pada pemanggilan API SAT
  7. USEHAT.
  8. Properti expires_in bertipe number, berisi informasi durasi waktu access_token dapat digunakan (dalam satuan detik).

Contoh Data

{
"accessToken": "718d19c515f12c68dcfce7a97b7510c160c4678f",
"accessTokenExpiresAt": "2023-12-17T05:31:48.002Z",
"clientId": "3310fd56-10fb-4319-8044-9c0eb570a25f.sehatmu.client",
"client": {
"name": "John Doe System",
"email": "[email protected]"
},
"userId": "64eb3286e34e01fa5887d9b6",
"user": {
"id": "64eb3286e34e01fa5887d9b6",
"email": "[email protected]",
"name": "John Doe System"
}
}

4xx Client Error

Sistem akan mengembalikan pesan error bila client belum melakukan autentikasi (Unauthorized), tidak memiliki akses, menggunakan HTTP method yang tidak tepat, atau mengirimkan data dengan format atau ketentuan yang tidak sesuai.

Struktur Data

{ (1)
*resourceType: string (2)
*issue: [{ (3)
*severity: string
*code: string
*details: {
*text: string
}
}
]
}
  1. Respon yang diterima berupa object.
  2. Properti resourceType bertipe string, berisi nilai OperationOutcome (Resource FHIR untuk informasi hasil pemrosesan sistem).
  3. Properti issue bertipe array of objects, berisi informasi "The user or system was not able to be authenticated (either client_id or client_secret combination is unacceptable)" (Ada kesalahan pengisian client_id atau client_secret pada body request) atau "Authentication temporarily cannot be performed due to the rate limit policy. Rate limit: 1 request per minute after a failed attempt." (Setiap client_id, hanya boleh salah pengisian client_secret 1x dalam 1 menit, atau terlalu sering melakukan generate token baru dalam 1 menit).

Contoh Data

{
"resourceType": "OperationOutcome",
"issue": [
{
"severity": "invalid",
"code": "value",
"details": {
"text": "The user or system was not able to be authenticated (either client_id or client_secret combination is unacceptable)"
}
}
]
}

5xx Server Error (Content-Type: text/plain)

Sistem akan mengembalikan pesan error bila terjadi kesalahan pada sisi server saat memproses data yang telah dikirimkan.

Contoh Data

Gateway Timeout

Contoh Pengunaan

cURL (Windows)

--insecure --location \
--header "Content-Type: application/x-www-form-urlencoded" ^
--data-urlencode "client_id=oGt4MwoRp35O6Bg3LaWwXuIPQGj9FmXvKUGezvwXr4fuJicF" ^
--data-urlencode "client_secret=tFb3el8LGjW08mWcGLyBDdiJp1hwymrAb9qrmhapuV7WcDhVq2u9n9diBVGfMRfD" ^
--request POST ^
"https://istanbul.muhammadiyah.or.id/oauth/token"

cURL (Linux)

--insecure --location \

--header 'Content-Type: application/x-www-form-urlencoded' \
--data-urlencode 'client_id=oGt4MwoRp35O6Bg3LaWwXuIPQGj9FmXvKUGezvwXr4fuJicF' \
--data-urlencode 'client_secret=tFb3el8LGjW08mWcGLyBDdiJp1hwymrAb9qrmhapuV7WcDhVq2u9n9diBVGfMRfD' \
--request POST \
'https://istanbul.muhammadiyah.or.id/oauth/token'

Postman

  1. Buat request baru menggunakan New > HTTP Request, atau klik + untuk buat tab request baru.

  2. Masukkan request URL:

https://istanbul.muhammadiyah.or.id/oauth/token
  1. Lalu pilih request method POST.

  2. Pada tab Params, di bagian Query Params: a. Masukkan nilai grant_type pada kotak masukan pada kolom KEY, b. Lalu masukkan nilai client_credentials pada kotak masukan pada kolom VALUE.

  3. Pada tab Body: a. Pilih x-www-form-urlencoded, b. Masukkan nilai client_id pada kotak masukan pada kolom KEY, c. Lalu masukkan nilai client ID yang sudah didapatkan dari Pusat Data dan Teknologi Informasi - Digital Transformation Office (DTO) Kementerian Kesehatan Republik Indonesia pada kotak masukan pada kolom VALUE, d. Selanjutnya masukkan nilai client_secret pada kotak masukan pada kolom KEY, e. Terakhir masukkan nilai client secret yang sudah didapatkan dari Pusat Data dan Teknologi Informasi - Digital Transformation Office (DTO) Kementerian Kesehatan Republik Indonesia pada kotak masukan pada kolom VALUE.

  4. Klik tombol Send.

  5. Hasil response akan ditampilkan di bagian Response.