Menulis Data Glukosa Darah

Aplikasi Anda dapat merekam data glukosa darah dengan menulis ke jenis data com.google.blood_glucose. Dalam jenis data ini, setiap titik data merepresentasikan satu pembacaan glukosa darah instan. Titik data berisi kolom untuk konsentrasi glukosa darah, hubungan temporal dengan makanan dan tidur, serta sumber spesimen yang diukur. Semua kolom kecuali konsentrasi glukosa darah bersifat opsional.

Membuat sumber data

Android

Untuk menulis titik data glukosa darah, buat DataSource TYPE_BLOOD_GLUCOSE baru, seperti yang ditunjukkan dalam contoh berikut:

val bloodGlucoseSource = DataSource.Builder()
    .setDataType(TYPE_BLOOD_GLUCOSE)
    // ...
    .build()

REST

Untuk menulis titik data glukosa darah, buat sumber data baru.

Metode HTTP

POST

URL permintaan

https://www.googleapis.com/fitness/v1/users/me/dataSources

Isi permintaan

{
  "dataStreamName": "BloodGlucose",
  "type": "raw",
  "application": {
    "detailsUrl": "http://example.com",
    "name": "My Example App",
    "version": "1"
  },
  "dataType": {
    "name": "com.google.blood_glucose"
   }
}

Respons

Jika sumber data berhasil dibuat, responsnya adalah kode status 200 OK. Isi respons berisi representasi JSON sumber data, termasuk properti datasource.dataStreamId yang dapat Anda gunakan sebagai ID sumber data untuk permintaan berikutnya.

Perintah CURL

$ curl --header "Authorization: Bearer ya29.yourtokenvalue --request POST \
  --header "Content-Type: application/json;encoding=utf-8" --data @blood-glucose-ds.json \
  https://www.googleapis.com/fitness/v1/users/me/dataSources

Menambahkan data

Android

Untuk menambahkan data ke sumber yang dibuat di atas, buat titik data untuk sumber data ini, yang dapat disisipkan menggunakan History API:

val bloodGlucose = DataPoint.builder(bloodGlucoseSource)
    .setTimestamp(timestamp, TimeUnit.MILLISECONDS)
    .setField(FIELD_BLOOD_GLUCOSE_LEVEL, 5.0f) // 90 mg/dL
    .setField(FIELD_TEMPORAL_RELATION_TO_MEAL, FIELD_TEMPORAL_RELATION_TO_MEAL_BEFORE_MEAL)
    .setField(FIELD_MEAL_TYPE, MEAL_TYPE_BREAKFAST)
    .setField(FIELD_TEMPORAL_RELATION_TO_SLEEP, TEMPORAL_RELATION_TO_SLEEP_ON_WAKING)
    .setField(FIELD_BLOOD_GLUCOSE_SPECIMEN_SOURCE, BLOOD_GLUCOSE_SPECIMEN_SOURCE_CAPILLARY_BLOOD)
    .build()

REST

Contoh ini menunjukkan penambahan data glukosa darah menggunakan sumber data yang dibuat di atas.

Metode HTTP

PATCH

URL permintaan

https://www.googleapis.com/fitness/v1/users/me/dataSources/datasource.dataStreamId/datasets/1574159699023000000-1574159699023000000

Isi permintaan

Agar lebih jelas, isi JSON yang ditampilkan di bawah diberi anotasi dengan komentar, untuk menunjukkan penggunaan konstanta kolom status. Meskipun Fit API saat ini akan menghapus komentar, sangat disarankan agar Anda menghapusnya dari kode Anda, karena JSON tidak secara resmi mendukung komentar.

{
  "minStartTimeNs": 1574159699023000000,
  "maxEndTimeNs": 1574159699023000000,
  "dataSourceId": "datasource.dataStreamId",
  "point": [
    {
      "startTimeNanos": 1574159699023000000,
      "endTimeNanos": 1574159699023000000,
      "dataTypeName": "com.google.blood_glucose",
      "value": [
        {
          // Blood glucose level, 90 mg/dL
          "fpVal": 5.0
        },
        {
          // FIELD_TEMPORAL_RELATION_TO_MEAL_BEFORE_MEAL
          "intVal": 3
        },
        {
          // MEAL_TYPE_BREAKFAST
          "intVal": 1
        },
        {
          // TEMPORAL_RELATION_TO_SLEEP_ON_WAKING
          "intVal": 3
        },
        {
          // BLOOD_GLUCOSE_SPECIMEN_SOURCE_CAPILLARY_BLOOD
          "intVal": 2
        }
      ]
    }
  ]
}

Respons

Jika data glukosa darah berhasil ditambahkan, responsnya adalah kode status 200 OK. Isi respons berisi representasi JSON dari data glukosa darah yang telah ditambahkan.

Perintah CURL

$ curl --header "Authorization: Bearer ya29.yourtokenvalue --request PATCH \
    --header "Content-Type: application/json;encoding=utf-8" --data @blood-glucose-data.json \
    https://www.googleapis.com/fitness/v1/users/me/dataSources/datasource.dataStreamId/datasets/1574159699023000000-1574159699023000000