Network slicing 5G

Per i dispositivi con Android 12 o versioni successive, Android supporta lo slicing della rete 5G, l'utilizzo della virtualizzazione della rete per dividere le singole connessioni di rete in più connessioni virtuali distinte che forniscono quantità diverse di risorse a diversi tipi di traffico. Il network slicing 5G consente agli operatori di rete di dedicare una parte della rete a fornire funzionalità specifiche per un particolare segmento di clienti. Android 12 introduce le seguenti funzionalità di slicing della rete aziendale 5G, che gli operatori di rete possono fornire ai propri clienti aziendali:

Suddivisione dei dispositivi aziendali per i dispositivi completamente gestiti

Per le aziende che forniscono dispositivi aziendali completamente gestiti ai propri dipendenti, i fornitori di rete possono fornire una o più sezioni di rete aziendale attive a cui viene indirizzato il traffico sui dispositivi aziendali. A partire da Android 12, Android consente agli operatori di fornire sezioni aziendali tramite regole URSP, anziché configurare le sezioni tramite APN.

Sezionamento delle app aziendali per dispositivi con profili di lavoro

Per le aziende che utilizzano la soluzione profilo di lavoro, Android 12 consente ai dispositivi di instradare il traffico di tutte le app nel profilo di lavoro a una sezione di rete aziendale. Le aziende possono attivare questa funzionalità tramite un controller dei criteri dei dispositivi (DPC).

La soluzione del profilo di lavoro fornisce un livello automatico di autenticazione e controllo dell'accesso richiesto dalle aziende per garantire che solo il traffico proveniente dalle app aziendali nel profilo di lavoro venga indirizzato alla sezione di rete aziendale. Le app nel profilo di lavoro non devono essere modificate per richiedere esplicitamente la sezione di rete aziendale.

Come funziona lo slicing della rete 5G in AOSP

Android 12 introduce il supporto del network slicing 5G tramite aggiunte al codebase di telefonia in AOSP e al modulo Tethering per incorporare le API di connettività esistenti necessarie per il network slicing.

La piattaforma di telefonia Android fornisce API HAL e di telefonia per supportare lo slicing in base alle richieste di rete inviate dal codice di networking principale e alle funzionalità di slicing 5G nel modem. La figura 1 descrive i componenti della funzionalità di sezionamento della rete 5G.

Componenti dello slicing di rete 5G

Figura 1. Architettura di slicing della rete 5G in AOSP.

La piattaforma di telefonia e connettività supporta:

  • Conversione delle richieste di rete per le categorie di slice in descrittori di traffico che vengono poi passati al modem per la corrispondenza del traffico URSP e la selezione dell'itinerario
  • Eseguire il fallback alla rete predefinita se lo slice di rete aziendale non è disponibile
  • Instradamento del traffico da tutte le app nel profilo di lavoro alla connessione corrispondente
  • Supporto del sezionamento aziendale

    • Rilevamento della presenza di un profilo di lavoro sul dispositivo
    • Controllo delle autorizzazioni o delle indicazioni stradali fornite dal DPC utilizzato dall'amministratore IT dell'azienda

Il servizio di rete principale include le seguenti modifiche al modulo Tethering in Android 12:

  • Aggiunge la maggior parte delle classi API pubbliche o di sistema di Tethering al moduloandroid.net.*
  • Espande i limiti del modulo Tethering per includere:

    • f/b/core/java/android/net/…
    • f/b/services/net/…
    • f/b/services/core/java/com/android/server/connectivity/…
    • f/b/services/core/java/com/android/server/ConnectivityService.java
    • f/b/services/core/java/com/android/server/TestNetworkService.java
  • Sposta il codice VPN dal modulo Tethering

Android 12 sposta il codice con le seguenti funzionalità nel modulo Tethering:

  • Ricezione di richieste di connessione di rete dalle app
  • Ricezione di richieste dal sistema (ad esempio "inserisci queste app in una sezione aziendale"; introdotto in Android 12)
  • Invio di richieste dal sistema al codice di telefonia che tenta di configurare reti o sezioni tramite l'API HAL e il modem
  • Comunicare a netd come instradare il traffico in base all'app (introdotto in Android 12)
  • Informare le app su cosa sta succedendo al loro traffico di rete tramite API ConnectivityManager come NetworkCallback, getActiveNetwork, getNetworkCapabilities.

Implementazione

Per supportare lo slicing 5G su un dispositivo, quest'ultimo deve avere un modem che supporti l'HAL IRadio 1.6, che include l'API setupDataCall_1_6. Questa API configura una connessione dati e include i seguenti parametri per supportare lo slicing 5G:

  • trafficDescriptor: Specifica il descrittore del traffico inviato al modem
  • sliceInfo: specifica le informazioni per lo slice di rete da utilizzare in caso di handover da EPDG a 5G
  • matchAllRuleAllowed: specifica se è consentito utilizzare una regola URSP predefinita di corrispondenza totale. Telefonia imposta questo valore su true per le reti predefinite, ma non per gli slice. La regola di corrispondenza di tutte le reti viene applicata alle reti predefinite. Quando un'app richiede una sezione specifica non disponibile, questa viene segnalata come non disponibile. Per le app aziendali, il framework Telephony può eseguire il failover sulla rete predefinita se la rete aziendale non è disponibile.

I modem devono anche implementare l'API getSlicingConfig a meno che non sia segnalata come non supportata dall'API getHalDeviceCapabilities.

Requisiti aziendali

Di seguito sono descritti i requisiti per le aziende per utilizzare lo slicing della rete 5G sui dispositivi in un deployment Android Enterprise.

  • Assicurati che i dispositivi completamente gestiti o dei dipendenti configurati con un profilo di lavoro siano compatibili con il 5G SA con modem che supportano l'API setupDataCall_1_6.
  • Collabora con il partner operatore per la configurazione e le prestazioni dello slice o le caratteristiche dello SLA.

Attivare lo slicing 5G sui dispositivi configurati con un profilo di lavoro

Per i dispositivi configurati con profili di lavoro, lo slicing della rete 5G è disattivato per impostazione predefinita in AOSP. Per attivare lo slicing di rete, gli amministratori IT aziendali possono attivare o disattivare il routing del traffico delle app del profilo di lavoro alla sezione di rete aziendale per ogni dipendente tramite il DPC EMM, che utilizza il metodo setPreferentialNetworkServiceEnabled nell'API DevicePolicyManager (DPM) (introdotta in Android 12).

I fornitori EMM con DPC personalizzati devono integrare l'API DevicePolicyManager per supportare i client aziendali.

Regole URSP

Questa sezione include informazioni per gli operatori sulla configurazione delle regole URSP per diverse categorie di slice, tra cui traffico aziendale, CBS, a bassa latenza e ad alta larghezza di banda. Quando configurano le regole URSP per diverse categorie di slice, gli operatori devono utilizzare i seguenti valori specifici per Android.

ID Valore Descrizione
OSId 97a498e3-fc92-5c94-8986-0333d06e4e47 L'OSId per Android è un UUID versione 5 generato con lo spazio dei nomi ISO OID e il nome "Android".

Gli operatori devono configurare le regole URSP per ogni slice di traffico con il componente descrittore del traffico come "ID sistema operativo + tipo di ID app sistema operativo". Ad esempio, la sezione "ENTERPRISE" deve avere un valore di 0x97A498E3FC925C9489860333D06E4E470A454E5445525052495345. Questo valore è una concatenazione di OSId, della lunghezza di OSAppId (0x0A) e di OSAppId. Per ulteriori informazioni sul tipo di componente descrittore del traffico, consulta 3GPP TS 24.526 Table 5.2.1.

La tabella seguente descrive i valori OSAppId per le diverse categorie di sezioni.

Categoria della sezione OSAppId Descrizione
ENTERPRISE 0x454E5445525052495345 OSAppId è una rappresentazione di array di byte della stringa "ENTERPRISE"
ENTERPRISE2 0x454E544552505249534532 OSAppId è una rappresentazione di array di byte della stringa "ENTERPRISE2"
ENTERPRISE3 0x454E544552505249534533 OSAppId è una rappresentazione di array di byte della stringa "ENTERPRISE3"
ENTERPRISE4 0x454E544552505249534534 OSAppId è una rappresentazione di array di byte della stringa "ENTERPRISE4"
ENTERPRISE5 0x454E544552505249534535 OSAppId è una rappresentazione di array di byte della stringa "ENTERPRISE5"
CBS 0x434253 OSAppId è una rappresentazione di array di byte della stringa "CBS"
PRIORITIZE_LATENCY 0x5052494f524954495a455f4c4154454e4359 OSAppId è una rappresentazione di array di byte della stringa "PRIORITIZE_LATENCY"
PRIORITIZE_BANDWIDTH 0x5052494f524954495a455f42414e445749445448 OSAppId è una rappresentazione di array di byte della stringa "PRIORITIZE_BANDWIDTH"

Esempi di regole URSP

Le seguenti tabelle mostrano regole URSP di esempio per traffico aziendale, CBS, a bassa latenza, a larghezza di banda elevata e predefinito.

Enterprise 1

Il supporto di Enterprise 1 è disponibile in Android 12 e versioni successive. Di seguito è riportato un esempio di regola URSP per il traffico ENTERPRISE1:

Regola URSP n. 1 (enterprise1)
Precedenza 1 (0x01)
Descrittore del traffico n. 1
Tipo di ID sistema operativo + ID app sistema operativo 0x97A498E3FC925C9489860333D06E4E470A454E5445525052495345
Descrittore di selezione del percorso n. 1
Precedenza 1 (0x01)
Componente 1: S-NSSAI SST:XX SD:YYYYYY
Componente n. 2: DNN enterprise
Descrittore di selezione del percorso n. 2
Precedenza 2 (0x02)
Componente 1: DNN enterprise

Enterprise 2

Il supporto di Enterprise 2 è disponibile in Android 13 e versioni successive. Di seguito è riportato un esempio di regola URSP per il traffico ENTERPRISE2:

Regola URSP n. 2 (enterprise2)
Precedenza 2 (0x02)
Descrittore del traffico n. 1
Tipo di ID sistema operativo + ID app sistema operativo 0x97A498E3FC925C9489860333D06E4E470B454E544552505249534532
Descrittore di selezione del percorso n. 1
Precedenza 1 (0x01)
Componente 1: S-NSSAI SST:XX SD:YYYYYY
Componente n. 2: DNN enterprise2
Descrittore di selezione del percorso n. 2
Precedenza 2 (0x02)
Componente 1: DNN enterprise2

Enterprise 3

Il supporto di Enterprise 3 è disponibile in Android 13 e versioni successive. Di seguito è riportato un esempio di regola URSP per il traffico ENTERPRISE3:

Regola URSP n. 3 (enterprise3)
Precedenza 3 (0x03)
Descrittore del traffico n. 1
Tipo di ID sistema operativo + ID app sistema operativo 0x97A498E3FC925C9489860333D06E4E470B454E544552505249534533
Descrittore di selezione del percorso n. 1
Precedenza 1 (0x01)
Componente 1: S-NSSAI SST:XX SD:YYYYYY
Componente n. 2: DNN enterprise3
Descrittore di selezione del percorso n. 2
Precedenza 2 (0x02)
Componente 1: DNN enterprise3

Enterprise 4

Il supporto di Enterprise 4 è disponibile in Android 13 e versioni successive. Di seguito è riportato un esempio di regola URSP per il traffico ENTERPRISE4:

Regola URSP n. 4 (enterprise4)
Precedenza 4 (0x04)
Descrittore del traffico n. 1
Tipo di ID sistema operativo + ID app sistema operativo 0x97A498E3FC925C9489860333D06E4E470B454E544552505249534534
Descrittore di selezione del percorso n. 1
Precedenza 1 (0x01)
Componente 1: S-NSSAI SST:XX SD:YYYYYY
Componente n. 2: DNN enterprise4
Descrittore di selezione del percorso n. 2
Precedenza 2 (0x02)
Componente 1: DNN enterprise4

Enterprise 5

Il supporto di Enterprise 5 è disponibile in Android 13 e versioni successive. Di seguito è riportato un esempio di regola URSP per il traffico ENTERPRISE5:

Regola n. 5 dell'URSP (enterprise5)
Precedenza 5 (0x05)
Descrittore del traffico n. 1
Tipo di ID sistema operativo + ID app sistema operativo 0x97A498E3FC925C9489860333D06E4E470B454E544552505249534535
Descrittore di selezione del percorso n. 1
Precedenza 1 (0x01)
Componente 1: S-NSSAI SST:XX SD:YYYYYY
Componente n. 2: DNN enterprise5
Descrittore di selezione del percorso n. 2
Precedenza 2 (0x02)
Componente 1: DNN enterprise5

CBS

Il supporto di CBS è disponibile in Android 13 e versioni successive. Di seguito è riportato un esempio di regola URSP per il traffico CBS:

Regola URSP n. 6 (CBS)
Precedenza 6 (0x06)
Descrittore del traffico n. 1
Tipo di ID sistema operativo + ID app sistema operativo 0x97A498E3FC925C9489860333D06E4E4703434253
Descrittore di selezione del percorso n. 1
Precedenza 1 (0x01)
Componente 1: S-NSSAI SST:XX SD:YYYYYY
Componente n. 2: DNN cbs
Descrittore di selezione del percorso n. 2
Precedenza 2 (0x02)
Componente 1: DNN cbs

Bassa latenza

Il supporto per la bassa latenza è disponibile in Android 13 e versioni successive. Di seguito è riportato un esempio di regola URSP per il traffico LOW_LATENCY:

Regola n. 7 dell'URSP (bassa latenza)
Precedenza 7 (0x07)
Descrittore del traffico n. 1
Tipo di ID sistema operativo + ID app sistema operativo 0x97A498E3FC925C9489860333D06E4E47125052494f524954495a455f4c4154454e4359
Descrittore di selezione del percorso n. 1
Precedenza 1 (0x01)
Componente 1: S-NSSAI SST:XX SD:YYYYYY
Componente n. 2: DNN latenza
Descrittore di selezione del percorso n. 2
Precedenza 2 (0x02)
Componente 1: DNN latenza

Larghezza di banda elevata

Il supporto della larghezza di banda elevata è disponibile in Android 13 e versioni successive. Di seguito è riportato un esempio di regola URSP per il traffico HIGH_BANDWIDTH:

Regola URSP n. 8 (larghezza di banda elevata)
Precedenza 8 (0x08)
Descrittore del traffico n. 1
Tipo di ID sistema operativo + ID app sistema operativo 97A498E3FC925C9489860333D06E4E47145052494f524954495a455f42414e445749445448
Descrittore di selezione del percorso n. 1
Precedenza 1 (0x01)
Componente 1: S-NSSAI SST:XX SD:YYYYYY
Componente n. 2: DNN per il caricamento
Descrittore di selezione del percorso n. 2
Precedenza 2 (0x02)
Componente 1: DNN per il caricamento

Predefinito

Regola URSP n. 9 (predefinita)
Precedenza 9 (0x09)
Descrittore del traffico n. 1
match-all N/D
Descrittore di selezione del percorso n. 1
Precedenza 1 (0x01)
Componente 1: S-NSSAI SST:XX SD:YYYYYY

Test

Per testare lo slicing della rete 5G, utilizza il seguente test manuale.

Per configurare un dispositivo per il test:

  1. Assicurati che il criterio URSP sia configurato con una regola non predefinita che corrisponda alla categoria aziendale e che il descrittore di selezione dell'itinerario corrispondente mappi la categoria aziendale alla sezione aziendale; e una regola predefinita che indirizzi il traffico alla sezione internet predefinita.

  2. Assicurati che sul dispositivo sia configurato un profilo di lavoro.

  3. Attivare l'utilizzo dello slicing di rete tramite il DPC

Per testare il comportamento dello slicing di rete 5G:

  1. Verifica che sia stabilita una sessione PDU con lo slice aziendale (ad esempio utilizzando un indirizzo IP specifico) e che le app nel profilo di lavoro utilizzino questa sessione PDU.
  2. Verifica che sia stabilita una sessione PDU separata con lo slice internet predefinito e che le app nel profilo personale utilizzino la sessione PDU.

Upsell dello slicing 5G

La funzionalità di upsell dello slicing 5G, disponibile a partire da Android 14-QPR1, consente agli operatori di offrire funzionalità di rete migliorate (latenza e larghezza di banda) ai propri utenti tramite lo slicing della rete 5G.

La funzionalità di upsell dello slicing 5G utilizza la risposta TS.43 del server di autorizzazione dell'operatore per guidare il flusso di acquisto. Gli operatori possono utilizzare la risposta per specificare l'URL della webview di acquisto dell'operatore, inviare dati aggiuntivi alla webview e indicare se lo slice è sottoposto a provisioning e disponibile sulla rete dell'operatore.

Gli operatori possono personalizzare il comportamento della funzionalità di upsell dello slicing 5G utilizzando le configurazioni dell'operatore, che controllano se è possibile effettuare richieste di acquisto, quando le app possono richiedere funzionalità premium e per quanto tempo il framework di telefonia attende le risposte dell'utente o della rete.

La funzionalità di upsell dello slicing 5G fornisce un'interfaccia, chiamata DataBoostWebServiceFlow, per consentire la comunicazione tra Android e la webview dell'operatore.

La figura 2 mostra il flusso di acquisto dell'upsell dello slicing 5G:

Flusso di acquisto dell'upsell dello slicing 5G

Figura 2. Flusso di acquisto dell'upsell dello slicing 5G.

TS.43 entitlement process

Quando un utente richiede funzionalità di rete avanzate, il framework Telephony richiede la configurazione dei diritti di servizio per la funzionalità premium richiesta. Se la risposta TS.43 è valida, il framework Telephony utilizza i campi della risposta HTTP per gestire la richiesta di acquisto.

Sezionare i campi degli acquisti

La configurazione dei diritti TS.43 include i seguenti campi di acquisto delle slice:

Stato diritto

Tasto: EntitlementStatus

Tipo: int

Valori supportati: 0 (disattivato), 1 (attivato), 2 (incompatibile), 3 (provisioning), 4 (incluso)

Stato del provisioning

Tasto: ProvStatus

Tipo: int

Valori supportati: 0 (non eseguito il provisioning), 1 (provisioning eseguito), 2 (non disponibile), 3 (in corso)

Il framework Telephony utilizza la combinazione dello stato dei diritti e dello stato di provisioning per determinare lo stato attuale dell'acquisto della slice. Il risultato può essere uno dei seguenti:

Se lo stato del diritto è 1 (attivato) e lo stato del provisioning è 0 (non eseguito), il framework di telefonia mostra una notifica di upsell all'utente per acquistare il potenziamento tramite la webview dell'operatore. La seguente tabella descrive il comportamento del framework Telephony per diverse combinazioni di valori di stato di provisioning e diritto.

Stato del provisioning
Non eseguito il provisioning (0) Provisioned (1) Non disponibile (2) In corso (3)
Stato del diritto Disattivato (0) Operazione non riuscita Operazione non riuscita Operazione non riuscita Operazione non riuscita
Attivato (1) Mostra WebView Già acquistato Già acquistato In corso
Incompatibile (2) Operazione non riuscita Operazione non riuscita Operazione non riuscita Operazione non riuscita
Provisioning (3) Errore dell'operatore Errore dell'operatore In corso In corso
Incluso (4) Errore dell'operatore Già acquistato Già acquistato Errore dell'operatore

Campi del flusso di servizio

La risposta TS.43 specifica l'URL, i dati utente e il tipo di contenuti da personalizzare il comportamento della webview di acquisto dell'operatore. Se il tipo di contenuti non è specificato, l'URL viene caricato come richiesta GET. Se i dati utente esistono, vengono aggiunti all'URL come parametro di ricerca (ad esempio, https://www.android.com?encodedValue=Base64EncodedUserData); se non esistono, l'URL viene utilizzato così com'è (ad esempio, https://www.android.com).
Se il tipo di contenuti è specificato in formato JSON o XML, l'URL viene caricato come richiesta POST e i dati utente (decodificati se sono codificati in Base64) vengono inviati come dati per la richiesta POST.

URL

Tasto: ServiceFlow_URL

Tipo: String

Esempio: "https://www.android.com"

Dati utente

Tasto: ServiceFlow_UserData

Tipo: String

Esempio: "encodedValue=Base64EncodedUserData"

Tipo di contenuti

Tasto: ServiceFlow_ContentsType

Tipo: String

Valori supportati: 0 (non specificato), 1 (JSON), 2 (XML)

Configurazioni dell'operatore

Di seguito sono riportate le configurazioni dell'operatore disponibili per personalizzare il comportamento della funzionalità di upsell dello slicing 5G.

KEY_SUPPORTED_PREMIUM_CAPABILITIES_INT_ARRAY

Un elenco delle funzionalità premium supportate. Questo è un array di numeri interi di TelephonyManager.PremiumCapability. Queste funzionalità premium condividono lo stesso valore della classe NetworkCapabilities.NetCapability corrispondente. Se viene richiesta una funzionalità premium e non è inclusa in questa configurazione, la richiesta di acquisto non va a buon fine e viene restituito il risultato CARRIER_DISABLED.

In Android 14 è supportato solo PREMIUM_CAPABILITY_PRIORITIZE_LATENCY.

KEY_PREMIUM_CAPABILITY_MAXIMUM_DAILY_NOTIFICATION_COUNT_INT

Il numero massimo giornaliero di volte in cui la notifica di upsell dell'acquisto viene mostrata all'utente. Se viene raggiunto il limite massimo giornaliero, la notifica di upselling non viene mostrata e le richieste di acquisto (incluse le richieste del server dei diritti) vengono limitate fino a mezzanotte del giorno successivo. Le richieste di acquisto effettuate dopo il raggiungimento del massimo giornaliero non vanno a buon fine e restituiscono il risultato PURCHASE_PREMIUM_CAPABILITY_RESULT_THROTTLED.

KEY_PREMIUM_CAPABILITY_MAXIMUM_MONTHLY_NOTIFICATION_COUNT_INT

Il numero massimo mensile di volte in cui viene mostrata la notifica di upsell dell'acquisto all'utente. Se viene raggiunto il massimo mensile, la notifica di upsell non viene mostrata e le richieste di acquisto (incluse le richieste del server dei diritti) vengono limitate fino al primo giorno del mese successivo. Le richieste di acquisto effettuate dopo il raggiungimento del limite massimo mensile non vanno a buon fine e restituiscono il risultato PURCHASE_PREMIUM_CAPABILITY_RESULT_THROTTLED.

KEY_PREMIUM_CAPABILITY_PURCHASE_URL_STRING

L'URL di acquisto dell'operatore di backup da mostrare all'utente quando fa clic sulla notifica di upselling. Se l'URL di acquisto non viene trovato nella risposta TS.43 del server dei diritti, viene utilizzato questo valore. Se né l'URL della risposta TS.43 né la configurazione dell'operatore sono validi, la richiesta di acquisto non va a buon fine e viene restituito il risultato PURCHASE_PREMIUM_CAPABILITY_RESULT_CARRIER_DISABLED.

KEY_PREMIUM_CAPABILITY_SUPPORTED_ON_LTE_BOOL

Se consentire l'acquisto di funzionalità premium quando il dispositivo è connesso a Long-Term Evolution (LTE). Se true, le richieste di acquisto possono essere effettuate sia su LTE sia su New Radio (NR). Se false, le richieste di acquisto possono essere effettuate solo su NR e le richieste effettuate su LTE non vanno a buon fine con il risultato PURCHASE_PREMIUM_CAPABILITY_RESULT_NETWORK_NOT_AVAILABLE.

KEY_PREMIUM_CAPABILITY_NOTIFICATION_DISPLAY_TIMEOUT_MILLIS_LONG

Il periodo di tempo durante il quale mostrare all'utente la notifica di upsell dell'acquisto prima che venga annullata automaticamente. Quando la notifica viene annullata, le richieste successive vengono limitate e non vanno a buon fine con il risultato PURCHASE_PREMIUM_CAPABILITY_RESULT_THROTTLED.

KEY_PREMIUM_CAPABILITY_NOTIFICATION_BACKOFF_HYSTERESIS_TIME_MILLIS_LONG

Il periodo di tempo durante il quale le successive richieste di acquisto devono essere limitate dopo un errore dovuto a timeout o annullamento da parte dell'utente. Se l'utente non fa clic sulla notifica di upsell dell'acquisto entro il timeout specificato da KEY_PREMIUM_CAPABILITY_NOTIFICATION_DISPLAY_TIMEOUT_MILLIS_LONG o se annulla o chiude la notifica, viene avviato questo timer di backoff. Mentre questo timer è attivo, le richieste di acquisto non vanno a buon fine con il risultato PURCHASE_PREMIUM_CAPABILITY_RESULT_THROTTLED.

KEY_PREMIUM_CAPABILITY_PURCHASE_CONDITION_BACKOFF_HYSTERESIS_TIME_MILLIS_LONG

Il periodo di tempo durante il quale le successive richieste di acquisto devono essere limitate dopo un errore dovuto all'operatore o alla rete. Se il controllo dei diritti non va a buon fine, l'URL non è disponibile o l'URL di acquisto dell'operatore indica un errore, viene avviato questo timer di backoff. Mentre questo timer è attivo, le richieste di acquisto non vanno a buon fine con il risultato PURCHASE_PREMIUM_CAPABILITY_RESULT_THROTTLED.

KEY_PREMIUM_CAPABILITY_NETWORK_SETUP_TIME_MILLIS_LONG

Il periodo di tempo entro il quale la rete deve configurare una configurazione di slicing per la funzionalità premium di acquisto. Durante questo periodo, le successive richieste di acquisto vengono bloccate e restituiscono il risultato PURCHASE_PREMIUM_CAPABILITY_RESULT_PENDING_NETWORK_SETUP. Se la rete non riesce a configurare una configurazione di slicing in tempo, le app possono richiedere nuovamente l'acquisto di funzionalità premium. La telefonia non considera un acquisto completato finché non viene inviata la configurazione di slicing corrispondente, indipendentemente dal fatto che l'utente abbia pagato o meno l'operatore.

Interfaccia JavaScript

Quando l'utente fa clic sulla notifica di potenziamento della rete, viene visualizzato un oggetto WebView con l'URL di acquisto dell'operatore. Gli operatori possono utilizzare le API fornite nell'interfaccia JavaScript DataBoostWebServiceFlow nel loro sito web di acquisto per comunicare con l'app di acquisto della fetta.

Il sito web dell'operatore può ottenere la funzionalità premium richiesta tramite il metodo getRequestedCapability().

Se l'acquisto va a buon fine, il sito web dell'operatore deve comunicare all'app di acquisto della porzione tramite notifyPurchaseSuccessful() o notifyPurchaseSuccessful(duration), dove duration è un parametro facoltativo che indica la durata prevista della porzione.

Se l'acquisto non va a buon fine, il sito web dell'operatore deve comunicarlo all'app di acquisto della fetta tramite il metodo notifyPurchaseFailed(code, reason), dove code è il codice di errore che indica il motivo dell'errore e reason è il motivo dell'errore leggibile, se il codice di errore è sconosciuto.

Se non viene chiamato uno di questi metodi di risposta, l'acquisto non verrà considerato completato e la richiesta di acquisto scadrà.

Di seguito sono riportati i codici di errore validi che il sito web dell'operatore può restituire in caso di errore di acquisto:

Una volta completato l'acquisto, l'operatore deve aggiornare le regole URSP con lo slice PRIORITIZE_LATENCY sul dispositivo dell'utente.