Menyiapkan JavaScript Consumer SDK

Dengan JavaScript Consumer SDK, aplikasi konsumen Anda dapat menampilkan lokasi kendaraan dan lokasi menarik lainnya yang dilacak di Fleet Engine pada peta berbasis web. Dengan demikian, pengguna konsumen Anda dapat melihat progres pengiriman mereka. Panduan ini mengasumsikan bahwa Anda telah menyiapkan Fleet Engine dengan project Google Cloud dan kunci API terkait. Lihat Fleet Engine untuk mengetahui detailnya.

Anda menyiapkan JavaScript Consumer SDK dengan mengikuti langkah-langkah berikut:

  1. Aktifkan Maps JavaScript API.
  2. Siapkan otorisasi.

Aktifkan Maps JavaScript API

Aktifkan Maps JavaScript API di project Konsol Google Cloud yang Anda gunakan untuk instance Fleet Engine. Untuk mengetahui detail selengkapnya, lihat Mengaktifkan API di dokumentasi Maps JavaScript API.

Menyiapkan otorisasi

Fleet Engine mewajibkan penggunaan Token Web JSON (JWT) untuk panggilan metode API dari lingkungan dengan tingkat kepercayaan rendah: smartphone dan browser.

JWT berasal dari server Anda, ditandatangani, dienkripsi, dan diteruskan ke klien untuk interaksi server berikutnya hingga masa berlakunya habis atau tidak lagi valid.

Detail utama

Aplikasi konsumen Anda harus mengautentikasi pengguna akhir Anda dengan peran delivery_consumer dari project Google Cloud Anda untuk menampilkan hanya informasi khusus konsumen. Dengan cara ini, Fleet Engine memfilter dan menyamarkan semua informasi lain dalam respons. Misalnya, selama tugas tidak tersedia, tidak ada informasi lokasi yang dibagikan kepada pengguna akhir. Lihat Peran akun layanan untuk tugas terjadwal.

Bagaimana cara kerja otorisasi?

Otorisasi dengan data Fleet Engine melibatkan penerapan sisi server dan sisi klien.

Otorisasi sisi server

Sebelum Anda menyiapkan autentikasi dan otorisasi di aplikasi berbasis web, server backend Anda harus dapat menerbitkan Token Web JSON ke aplikasi berbasis web Anda untuk akses ke Fleet Engine. Aplikasi berbasis web Anda mengirimkan JWT ini dengan permintaannya sehingga Fleet Engine mengenali permintaan tersebut sebagai permintaan yang diautentikasi dan diizinkan untuk mengakses data dalam permintaan. Untuk mengetahui petunjuk tentang penerapan JWT di sisi server, lihat Menerbitkan Token Web JSON di bagian Dasar-Dasar Fleet Engine.

Khususnya, perhatikan hal berikut untuk JavaScript Consumer SDK dalam melacak pengiriman:

Otorisasi sisi klien

Saat Anda menggunakan JavaScript Consumer SDK, SDK tersebut akan meminta token dari server menggunakan pengambil token otorisasi. Hal ini dilakukan saat salah satu kondisi berikut terpenuhi:

  • Tidak ada token yang valid, seperti saat SDK belum memanggil fetcher pada pemuatan halaman baru, atau saat fetcher belum menampilkan token.

  • Masa berlaku token telah berakhir.

  • Masa berlaku token akan berakhir dalam waktu satu menit.

Jika tidak, JavaScript Consumer SDK akan menggunakan token valid yang dikeluarkan sebelumnya dan tidak memanggil fetcher.

Membuat pengambilan token otorisasi

Buat pengambilan token otorisasi Anda menggunakan panduan berikut:

  • Pengambilan data harus menampilkan struktur data dengan dua kolom, yang di-wrap dalam Promise sebagai berikut:

    • String token.

    • Angka expiresInSeconds. Masa berlaku token akan berakhir setelah jangka waktu ini setelah pengambilan. Pengambil token autentikasi harus meneruskan waktu berakhir dalam detik, dari waktu pengambilan ke library seperti yang ditunjukkan dalam contoh.

  • Pengambil harus memanggil URL di server Anda untuk mengambil token. URL ini--SERVER_TOKEN_URL--bergantung pada penerapan backend Anda. URL contoh berikut adalah untuk backend aplikasi contoh di GitHub:

    • https://SERVER_URL/token/delivery_consumer/TRACKING_ID

Contoh - Membuat pengambilan token autentikasi

Contoh berikut menunjukkan cara membuat pengambilan token otorisasi:

JavaScript

async function authTokenFetcher(options) {
  // options is a record containing two keys called
  // serviceType and context. The developer should
  // generate the correct SERVER_TOKEN_URL and request
  // based on the values of these fields.
  const response = await fetch(SERVER_TOKEN_URL);
  if (!response.ok) {
    throw new Error(response.statusText);
  }
  const data = await response.json();
  return {
    token: data.Token,
    expiresInSeconds: data.ExpiresInSeconds
  };
}

TypeScript

function authTokenFetcher(options: {
  serviceType: google.maps.journeySharing.FleetEngineServiceType,
  context: google.maps.journeySharing.AuthTokenContext,
}): Promise<google.maps.journeySharing.AuthToken> {
  // The developer should generate the correct
  // SERVER_TOKEN_URL based on options.
  const response = await fetch(SERVER_TOKEN_URL);
  if (!response.ok) {
    throw new Error(response.statusText);
  }
  const data = await response.json();
  return {
    token: data.token,
    expiresInSeconds: data.ExpiresInSeconds,
  };
}

Langkah berikutnya