In qualità di product owner, potremmo ritrovarci nella condizione di dover monitorare l'avanzamento dei lavori su più repository contemporaneamente. Le issue di GitHub sono suddivise, per l'appunto, per repository, ma creando un Project e configurandolo opportunamente, è possibile avere una visione d'insieme di tutti i miei progetti e creare all'occorrenza anche nuove issue, direttamente da quella vista, senza dover cambiare ogni volta pagina.
Queste stesse informazioni, possono essere poi esportate in qualche tool di analytics, come Power BI, per esempio, così che si possano analizzare metriche come il tempo di burndown, la velocity dei team, impedimenti, e così via. Grazie a GraphQL è molto semplice recuperare le informazioni:
gh api graphql -F projectId="$projectId" -f query=' query($projectId: ID!) { node(id: $projectId) { ... on ProjectV2 { items(first: 10) { nodes{ id content{ ...on Issue { id number title repository { name } assignees(first: 5) { nodes { name } } projectItems(first: 50) { edges { node { effort: fieldValueByName(name: "Effort") { ... on ProjectV2ItemFieldNumberValue { number } } } } } } } } } } } }'
Abbiamo infatti solo chiamato la CLI di GitHub, per comodità, per invocare una chiamata all'endpoint GraphQL, passando l'ID del Project creato in GitHub, che raggruppa tutte le issue che ci interessano.
A questo punto, parte fondamentale della query sta nel recuperare i nodi, ovvero le proprietà, contenute nell'oggetto Issue. E' qui che poi possiamo ottenere le informazioni base come il titolo, la descrizione e l'ID dell'item stesso, piuttosto che proprietà più complesse, come il repository (che di fatto arriva da un altro oggetto), o gli assegnatari di quell'attività specifica (che arrivano da un altro oggetto GraphQL e che sono un array di elementi, perchè l'assegnazione può essere multipla). Allo stesso tempo, grazie alla funzione di fieldValueByName, possiamo ottenere anche valori custom, come ad esempio l'effort, che fa parte del project ma non del work item.
Questi dati, una volta recuperati, ci forniranno un JSON, che potrà essere in seguito analizzato con tutti gli strumenti del caso.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Documentare i servizi REST con Swagger e OpenAPI con .NET 9
Recuperare gli audit log in Azure DevOps
Recuperare le subissue e il loro stato di completamento in GitHub
Fornire parametri ad un Web component HTML
Integrare un servizio esterno con .NET Aspire
Eliminare una project wiki di Azure DevOps
Integrare SQL Server in un progetto .NET Aspire
Conoscere il rendering Server o WebAssembly a runtime in Blazor
Inference di dati strutturati da testo con Semantic Kernel e ASP.NET Core Web API
Creare una libreria CSS universale: Nav menu
Utilizzare la funzione EF.Parameter per forzare la parametrizzazione di una costante con Entity Framework
Sfruttare GPT-4o realtime su Azure Open AI per conversazioni vocali
I più letti di oggi
- Usare i settings di serializzazione/deserializzazione di System.Text.Json di ASP.NET all'interno di un'applicazione non web
- .NET Conference Italia 2025 - Milano
- The Agentic Day - Milano
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Documentare i servizi REST con Swagger e OpenAPI con .NET 9
- Tutorial LINQ
- Gestione ciclo di vita in .NET Aspire