Con l'SDK Consumer JavaScript, la tua app per utenti finali può mostrare la posizione dei veicoli e altre località di interesse monitorate in Fleet Engine su una mappa basata sul web. In questo modo, i consumatori possono vedere l'avanzamento del viaggio dell'autista. Questa guida presuppone che tu abbia configurato Fleet Engine con il progetto Google Cloud e le chiavi API associati. Per maggiori dettagli, consulta Fleet Engine.
Per configurare l'SDK Consumer JavaScript:
Abilita l'API Maps JavaScript
Abilita l'API Maps JavaScript nella console Google Cloud. Per maggiori dettagli, consulta Abilitare le API nella documentazione di Google Cloud. In questo modo, l'SDK Consumer per JavaScript viene abilitato.
Configura l'autorizzazione
Fleet Engine richiede l'utilizzo di token web JSON (JWT) per le chiamate ai metodi API da ambienti a bassa attendibilità: smartphone e browser.
Un JWT ha origine sul server, viene firmato, criptato e passato al client per le successive interazioni con il server fino alla scadenza o alla perdita di validità.
Dettagli chiave
- Utilizza le credenziali predefinite dell'applicazione per l'autenticazione e l'autorizzazione in Fleet Engine.
- Utilizza un account di servizio appropriato per firmare i JWT. Consulta Ruoli dell'account di servizio di Fleet Engine in Nozioni di base su Fleet Engine.
Come funziona l'autorizzazione?
L'autorizzazione con i dati di Fleet Engine prevede l'implementazione sia lato server sia lato client.
Autorizzazione lato server
Prima di configurare l'autenticazione e l'autorizzazione nella tua applicazione web, il server di backend deve essere in grado di emettere token web JSON per la tua applicazione web per l'accesso a Fleet Engine. La tua applicazione web invia questi JWT con le sue richieste in modo che Fleet Engine riconosca le richieste come autenticate e autorizzate ad accedere ai dati nella richiesta. Per istruzioni sull'implementazione dei JWT lato server, consulta Emettere token web JSON in Nozioni di base su Fleet Engine.
In particolare, tieni presente quanto segue per l'SDK Consumer JavaScript per la condivisione dell'avanzamento del viaggio:- Linee guida generali per l'emissione di token web JSON
- Linee guida per i JWT dei viaggi on demand
- Esempio di token per un'operazione del consumatore
Autorizzazione lato client
Quando utilizzi l'SDK Consumer JavaScript, questo richiede un token dal server utilizzando un recuperatore di token di autorizzazione. Questa operazione viene eseguita quando si verifica una delle seguenti condizioni:
Non esiste un token valido, ad esempio quando l'SDK non ha chiamato il recuperatore durante un nuovo caricamento pagina o quando il recuperatore non ha restituito un token.
Il token è scaduto.
Il token scadrà entro un minuto.
In caso contrario, l'SDK Consumer JavaScript utilizza il token valido emesso in precedenza e non chiama il recuperatore.
Crea un recuperatore di token di autorizzazione
Crea il recuperatore di token di autorizzazione utilizzando queste linee guida:
Il recuperatore deve restituire una struttura di dati con due campi, racchiusi in un
Promisecome segue:Una stringa
token.Un numero
expiresInSeconds. Un token scade dopo questo periodo di tempo dopo il recupero. Il recuperatore di token di autenticazione deve passare il tempo di scadenza in secondi, dal momento del recupero alla libreria, come mostrato nell'esempio.
Il recuperatore deve chiamare un URL sul server per recuperare un token. Questo URL,
SERVER_TOKEN_URL, dipende dall'implementazione del backend. L' URL di esempio seguente è per il backend dell'app di esempio su GitHub:https://SERVER_URL/token/consumer/TRIPID
Esempio: crea un recuperatore di token di autenticazione
Gli esempi seguenti mostrano come creare un recuperatore di token di autorizzazione:
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,
};
}
Passaggi successivi
Segui un viaggio in JavaScript