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
Visualizzare le change sul plan di Terraform tramite le GitHub Actions
Migrare una service connection a workload identity federation in Azure DevOps
Sfruttare gli embedding e la ricerca vettoriale con Azure SQL Database
Applicare un filtro per recuperare alcune issue di GitHub
Garantire la provenienza e l'integrità degli artefatti prodotti su GitHub
Migrate and Modernize your .NET Applications on Azure
Utilizzare Tailwind CSS all'interno di React: primi componenti
Creare una libreria CSS universale: Immagini
Gestire gli accessi con Token su Azure Container Registry
Utilizzare un numero per gestire la concorrenza ottimistica con SQL Server ed Entity Framework
Utilizzare i primary constructor di C# per inizializzare le proprietà
Potenziare Azure AI Search con la ricerca vettoriale