In qualità di rivenditore puoi associare metadati, come un numero di telefono o un di acquisto, con ciascun dispositivo. Puoi associare i metadati chiamando l'API o caricando un file CSV nel portale della registrazione zero-touch. La tabella 1 mostra chi può associare e visualizzare i metadati:
Tabella 1. Autorizzazioni dei metadati
Attività | Rivenditori | Clienti |
---|---|---|
Associa i metadati chiamando l'API | ||
Associa i metadati caricando un file CSV nel portale della registrazione zero-touch | ||
Visualizzare i metadati del dispositivo nei risultati delle chiamate all'API | ||
Visualizza i metadati del dispositivo nel portale zero-touch |
Assegna metadati
Per associare i metadati a ogni dispositivo, chiama il metodo
partners.devices.metadata
. Puoi aggiungere
i numeri di telefono e d'ordine dei dispositivi Android usando i tasti della tabella 2
sotto:
Tabella 2. Chiavi dei metadati per i dispositivi Android
Dati | Chiave | Tipo di valore | Esempio |
---|---|---|---|
Numero di telefono | phonenumber |
Stringa | +1 (800) 555-0100 |
Numero ordine | ordernumber |
Stringa | GOOG#123/ABC-123456 |
Entrambi i valori dei metadati sono stringhe in formato libero, quindi puoi utilizzare un formato che rende per la tua organizzazione.
Per i dispositivi ChromeOS, puoi utilizzare le chiavi riportate nella tabella 3 di seguito:
Tabella 3. Chiavi dei metadati per i dispositivi ChromeOS
Dati | Chiave | Tipo di valore | Esempio |
---|---|---|---|
Numero ordine | ordernumber |
Stringa | GOOG#123/ABC-123456 |
Per assegnare metadati durante la creazione dei dispositivi, includi i metadati durante le chiamate
claimAsync
L'esempio seguente mostra l'impostazione di un
numero di telefono e numero d'ordine del dispositivo esistente TARGET_DEVICE_ID
:
Java
// Allowed metadata dictionary keys. private static String METADATA_KEY_PHONE_NUMBER = "phonenumber"; private static String METADATA_KEY_ORDER_NUMBER = "ordernumber"; // ... // Create the metadata record with the values. DeviceMetadata metadata = new DeviceMetadata(); Map<String,String> entries = new HashMap<String, String>(); entries.put(METADATA_KEY_ORDER_NUMBER, "GOOG123/ABC-#123456"); entries.put(METADATA_KEY_PHONE_NUMBER, "+1 (800) 555-0100"); metadata.setEntries(entries); // Set the metadata values on the target device. UpdateDeviceMetadataRequest body = new UpdateDeviceMetadataRequest(); body.setDeviceMetadata(metadata); DeviceMetadata response = service .partners() .devices() .metadata(PARTNER_ID, targetDeviceId, body) .execute();
.NET
// Allowed metadata dictionary keys. private static string MetadataKeyPhoneNumber = "phonenumber"; private static string MetadataKeyOrderNumber = "ordernumber"; // ... // Create the metadata record with the values. DeviceMetadata metadata = new DeviceMetadata { Entries = new Dictionary<string, string> { {MetadataKeyOrderNumber, "GOOG123/ABC-#123456"}, {MetadataKeyPhoneNumber, "+1 (800) 555-0100"} } }; // Set the metadata values on the target device. UpdateDeviceMetadataRequest body = new UpdateDeviceMetadataRequest { DeviceMetadata = metadata }; var request = service.Partners.Devices.Metadata(body, PartnerId, targetDeviceId); var results = request.Execute();
Python
# Allowed metadata dictionary keys. METADATA_KEY_ENTRIES = "entries"; METADATA_KEY_PHONE_NUMBER = "phonenumber"; METADATA_KEY_ORDER_NUMBER = "ordernumber"; # ... # Create the record with values. new_metadata = {METADATA_KEY_ENTRIES:{ \ METADATA_KEY_PHONE_NUMBER:'+1 (800) 555-0100', \ METADATA_KEY_ORDER_NUMBER:'GOOG123/ABC-#123456'}} # Set the metadata values on the target device. response = service.partners().devices().metadata( metadataOwnerId=PARTNER_ID, deviceId=target_device_id, body={'deviceMetadata':new_metadata}).execute()
Gli argomenti dei metadati sostituiscono i valori dei metadati esistenti per la stessa chiave.
Elimina metadati
Puoi eliminare i metadati dai dispositivi. Trasmettere stringhe vuote per i metadati i valori da eliminare. L'esempio seguente mostra come eliminare il telefono numero:
Java
// Create the metadata record with the values. DeviceMetadata metadata = new DeviceMetadata(); Map<String,String> entries = new HashMap<String, String>(); entries.put(METADATA_KEY_PHONE_NUMBER, ""); metadata.setEntries(entries); // Call partners().devices().metadata() to remove the phone metadata from the device...
.NET
// Create the metadata record with empty values. DeviceMetadata metadata = new DeviceMetadata { Entries = new Dictionary<string, string> { {MetadataKeyPhoneNumber, ""} } }; // Call Partners.Devices.Metadata to remove the phone metadata from the device...
Python
# Create the metadata record with empty values. metadata_to_remove = {METADATA_KEY_ENTRIES: {METADATA_KEY_PHONE_NUMBER:''}} # Call partners().devices().metadata() to remove the phone number # metadata from the device...