Proseguiamo questa serie di script relativi a Event Grid MQTT per scoprire tutte le possibilità che il servizio ci offre. Abbiamo, visto come creare il servizio e come creare gruppi di client ed infine come dare i permessi, affinché i client possano inviare e ricevere messaggi. Poiché è fondamentale avere un controllo granulare dei topic, affinché i client non possano sottoscrivere o pubblicare messaggi non di loro competenza, è necessario uno strumento che non ci obblighi ad indicare i client uno per uno, ma che ci permetta di definire delle regole applicabili globalmente.
I client group già ci aiutano in questo senso, anche se come visto sono limitati nel numero. Il vero strumento dedicato a questo scopo sono i topic space. Sotto uno di questo possiamo indicare fino a 10 topic template, cioè un'espressione per indicare il topic. Oltre all'utilizzo dei wildcard classici di MQTT, + (più) per indicare un segmento, o # (cancelletto) per indicare tutti i segmenti successivi, possiamo anche utilizzare delle espressioni da risolvere sulla base del client e dei suoi attribuiti. Come visto quindi nei client group per identificare i gruppi, possiamo utilizzare le stesse informazioni per circoscrivere il margine di manovra di un client in pubblicazione e sottoscrizione in base al permission binding che abbiamo dato.
Proviamo quindi a creare un topic space come mostrato nella figura seguente, dove utilizziamo la sintassi ${} per indicare l'espressione.

Come possiamo vedere, creiamo due template. Il primo crea un segmento sulla base dell'attributo type, perciò già questo delimita l'ambito del topic sul quale client può operare. Inoltre, definiamo un topic dove caricare i messaggi dedicato al client stesso. Nella seconda espressione, invece, definiamo un topic comune dove tutti i client di tipo iot possono andare a pubblicare o scrivere. Infine, dobbiamo dare un permission binding di pubblicazione e scrittura su questo topic e sul gruppo di client che vogliamo.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Esporre workflow come server MCP con Azure Logic Apps
Centralizzare e governare MCP server e Skill con Azure API Center
Impostare il tipo di supporto dei campi Json in Entity Framework con Sql Server
Welcome to Future Dev Day 2026
Ottimizzare la content-visibility in CSS specificando lo spazio da occupato dall'area non renderizzata
Nuova modale riconnessione Blazor
Azure SQL Database per dev: tutte le novità da non perdere
Filtrare i dati in ASP.NET Core usando OpenTelemetry su Azure Monitor
Escludere alcuni file da GitHub Copilot
Utilizzo del persistent state di Blazor nel prerendering
Abilitare il rolling update su Azure Functions flex consumption
Evitare la compressione degli artefatti in un workflow di GitHub


