Estendere il portale per sviluppatori con widget personalizzati
SI APPLICA A: Sviluppatore | Basic | Standard | Premium
Il portale per sviluppatori di Gestione API include un editor visivo e widget predefiniti, in modo da poter personalizzare e definire lo stile dell'aspetto del portale. Tuttavia, potrebbe essere necessario personalizzare ulteriormente il portale per sviluppatori con funzionalità personalizzate. Ad esempio, è possibile integrare il portale per sviluppatori con un sistema di supporto che prevede l'aggiunta di un'interfaccia personalizzata. Questo articolo illustra i modi in cui aggiungere funzionalità personalizzate, ad esempio widget personalizzati, al portale per sviluppatori di Gestione API.
Nella tabella seguente, sono riepilogate due opzioni, con collegamenti ad altri dettagli.
metodo | Descrizione |
---|---|
Widget di codice HTML personalizzato | - Soluzione leggera per gli editori di API per aggiungere logica personalizzata per i casi d'uso di base - Copiando e incollando il codice HTML personalizzato in un modulo, il portale per sviluppatori ne esegue il rendering in un iframe |
Creare e caricare un widget personalizzato | - Soluzione per sviluppatori per casi d'uso di widget più avanzati - Richiede l'implementazione locale in React, Vue o TypeScript normale - Scaffolding di widget e strumenti forniti per aiutare gli sviluppatori a creare widget ed eseguire il caricamento nel portale per sviluppatori - La creazione, il test e la distribuzione dei widget possono essere inseriti nello script tramite il React Component Toolkit open source - Supporta i flussi di lavoro per il controllo del codice sorgente, il controllo delle versioni e il riutilizzo del codice |
Nota
L'hosting automatico del portale per sviluppatori è un'opzione di estendibilità per i clienti che devono personalizzare il codice sorgente dell'intero core del portale. Offre una flessibilità completa per personalizzare l'esperienza del portale, ma richiede una configurazione avanzata. Con l’hosting automatico, il cliente è responsabile della gestione del ciclo di vita completo del codice: codebase fork, sviluppo, distribuzione, hosting, patch e aggiornamento.
Suggerimento
Un'altra opzione per personalizzare il portale per sviluppatori consiste nell'usare un plug-in del portale per sviluppatori open source per Wordpress. Sfruttare le funzionalità del sito in WordPress per localizzare il contenuto, personalizzare i menù, applicare fogli di stile personalizzati e altro ancora nel portale per sviluppatori.
Usare il widget di codice HTML personalizzato
Il portale per sviluppatori gestito include un widget di codice HTML personalizzato in cui è possibile inserire codice HTML per piccole personalizzazioni del portale. Ad esempio, è possibile usare codice HTML personalizzato per incorporare un video o per aggiungere un modulo. Il portale esegue il rendering del widget personalizzato in un frame inline (iframe).
Nell'interfaccia amministrativa del portale per sviluppatori, passare alla pagina o alla sezione in cui si vuole inserire il widget.
Selezionare l'icona grigia "più" (+) che viene visualizzata quando si passa il puntatore del mouse sulla pagina.
Nella finestra Aggiungi widget, selezionare Codice HTML personalizzato.
Selezionare l'icona "matita" per personalizzare il widget.
Immettere Larghezza e Altezza (in pixel) per il widget.
Per ereditare gli stili dal portale per sviluppatori (scelta consigliata), selezionare Applica stili del portale per sviluppatori.
Nota
Se questa impostazione non è selezionata, gli elementi incorporati saranno controlli HTML semplici, senza gli stili del portale per sviluppatori.
Sostituire il codice HTML di esempio con il contenuto personalizzato.
Al termine della configurazione, chiudere la finestra.
Salvare le modifiche e ripubblicare il portale.
Nota
Microsoft non supporta il codice HTML aggiunto nel widget di codice HTML personalizzato.
Creare e caricare un widget personalizzato
Per casi d'uso più avanzati, è possibile creare e caricare un widget personalizzato nel portale per sviluppatori. Gestione API fornisce uno scaffolding del codice che consente agli sviluppatori di creare widget personalizzati in React, Vue o TypeScript normale. Lo scaffolding include strumenti che consentono di sviluppare e distribuire il widget nel portale per sviluppatori.
Prerequisiti
- Installare Node.js runtime in locale
- Conoscenza di base della programmazione e dello sviluppo Web
Creare il widget
Avviso
Il codice del widget personalizzato viene archiviato nell'archivio BLOB pubblico di Azure associato all'istanza di Gestione API. Quando si aggiunge un widget personalizzato al portale per sviluppatori, il codice viene letto da questa risorsa di archiviazione tramite un endpoint che non richiede l'autenticazione, anche se il portale per sviluppatori o una pagina con il widget personalizzato sono accessibili solo agli utenti autenticati. Non includere informazioni sensibili o segreti nel codice del widget personalizzato.
Nell'interfaccia amministrativa del portale per sviluppatori, selezionare Widget personalizzati>Crea nuovo widget personalizzato.
Immettere un nome di widget e scegliere una Tecnologia. Per altre informazioni, vedere Modelli di widget più avanti in questo articolo.
Selezionare Crea widget.
Aprire un terminale, passare al percorso in cui si vuole salvare il codice del widget ed eseguire il comando seguente per scaricare lo scaffold del codice:
npx @azure/api-management-custom-widgets-scaffolder
Passare alla cartella appena creata contenente lo scaffold del codice del widget.
cd <name-of-widget>
Aprire la cartella nell'editor di codice preferito, ad esempio Visual Studio Code.
Installare le dipendenze e avviare il progetto:
npm install npm start
Il browser dovrebbe aprire una nuova scheda con il portale per sviluppatori connesso al widget in modalità di sviluppo.
Nota
Se la scheda non si apre, eseguire le operazioni seguenti:
- Assicurarsi che il server di sviluppo sia stato avviato. A tale scopo, verificare l'output nella console in cui è stato avviato il server nel passaggio precedente. Questo dovrebbe mostrare la porta in cui è in esecuzione il server (ad esempio,
http://127.0.0.1:3001
). - Passare al servizio Gestione API nel portale di Azure e aprire il portale per sviluppatori con l'interfaccia amministrativa.
- Aggiungi
/?MS_APIM_CW_localhost_port=3001
all'URL. Modificare il numero di porta se il server viene eseguito su una porta diversa.
- Assicurarsi che il server di sviluppo sia stato avviato. A tale scopo, verificare l'output nella console in cui è stato avviato il server nel passaggio precedente. Questo dovrebbe mostrare la porta in cui è in esecuzione il server (ad esempio,
Implementare il codice del widget e testarlo in locale. Il codice del widget si trova nella cartella
src
, nelle sottocartelle seguenti:app
- Codice per il componente widget che i visitatori del portale per sviluppatori pubblicato vedono e con cui interagisconoeditor
- Codice per il componente widget usato nell'interfaccia amministrativa del portale per sviluppatori per modificare le impostazioni del widget
Il file
values.ts
contiene i valori predefiniti e i tipi di proprietà personalizzate del widget che è possibile abilitare alla modifica.Le proprietà personalizzate consentono di modificare i valori nell'istanza del widget personalizzato dall'interfaccia utente amministrativa del portale per sviluppatori, senza modificare il codice o ridistribuire il widget personalizzato. Questo oggetto deve essere passato ad alcune delle funzioni di supporto dei widget.
Distribuire il widget personalizzato nel portale per sviluppatori
Specificare i valori seguenti nel file
deploy.js
che si trova nella radice del progetto:resourceId
- ID risorsa del servizio Gestione API, nel formato seguente:subscriptions/<subscription-id>/resourceGroups/<resource-group-name>/providers/Microsoft.ApiManagement/service/<api-management service-name>
managementApiEndpoint
- Endpoint dell'API di gestione di Azure (dipende dall'ambiente in uso, in generemanagement.azure.com
)apiVersion
- (Facoltativo) da usare per eseguire l'override della versione predefinita dell'API di gestione
Esegui questo comando:
npm run deploy
Se richiesto, accedere all'account di Azure.
Nota
Quando viene richiesto di eseguire l'accesso, è necessario usare un account membro dal tenant Microsoft Entra ID associato alla sottoscrizione di Azure in cui risiede il servizio Gestione API. L'account non deve essere un account guest o federato e deve disporre dell'autorizzazione appropriata per accedere all'interfaccia amministrativa del portale.
Il widget personalizzato viene ora distribuito nel portale per sviluppatori. Usando l'interfaccia amministrativa del portale, è possibile aggiungerlo nelle pagine del portale per sviluppatori e impostare i valori per le proprietà personalizzate configurate nel widget.
Pubblicare il portale per sviluppatori
Dopo aver configurato il widget nell'interfaccia amministrativa, ripubblicare il portale per rendere il widget disponibile nell'ambiente di produzione.
Nota
- Se si distribuisce il codice del widget aggiornato in un secondo momento, il widget usato nell'ambiente di produzione non viene aggiornato fino a quando non viene ripubblicato il portale per sviluppatori.
- Il codice compilato del widget è associato a una revisione specifica del portale. Se si imposta una revisione precedente del portale come corrente, viene usato il widget personalizzato associato a tale revisione.
Modelli di widget
Sono disponibili modelli per le tecnologie seguenti da poter usare per il widget:
- TypeScript (implementazione pura senza framework)
- React
- Vue
Tutti i modelli sono basati sul linguaggio di programmazione TypeScript.
Il modello React contiene hook personalizzati preparati nel file hooks.ts
e provider stabiliti per la condivisione del contesto tramite l'albero dei componenti con hook useSecrets
, useValues
e useEditorValues
dedicati.
Usare il pacchetto @azure/api-management-custom-widgets-tools
Questo pacchetto npm contiene le funzioni seguenti per sviluppare il widget personalizzato e offre funzionalità tra cui la comunicazione tra il portale per sviluppatori e il widget:
Funzione | Descrizione |
---|---|
getValues | Restituisce un oggetto JSON contenente i valori impostati nell'editor del widget in combinazione con i valori predefiniti |
getEditorValues | Restituisce un oggetto JSON contenente solo i valori impostati nell'editor del widget |
buildOnChange | Accetta un tipo TypeScript e restituisce una funzione per aggiornare i valori del widget. La funzione restituita accetta come parametro un oggetto JSON con valori aggiornati e non restituisce nulla. Usato internamente nell'editor del widget |
askForSecrets | Restituisce una promessa JavaScript, che dopo la risoluzione restituisce un oggetto JSON dei dati necessari per comunicare con il back-end |
deployNodeJs | Distribuisce il widget nell'archivio BLOB |
getWidgetData | Restituisce tutti i dati passati al widget personalizzato dal portale per sviluppatori Usato internamente nei modelli |
@azure/api-management-custom-widgets-tools/getValues
Funzione che restituisce un oggetto JSON contenente i valori impostati nell'editor del widget in combinazione con i valori predefiniti, passati come argomento.
Import {getValues} from "@azure/api-management-custom-widgets-tools/getValues"
import {valuesDefault} from "./values"
const values = getValues(valuesDefault)
È progettata per essere usata nella parte di runtime (app
) del widget.
@azure/api-management-custom-widgets-tools/getEditorValues
Funzione che agisce allo stesso modo di getValues
, ma restituisce solo i valori impostati nell'editor.
È progettata per essere usata nell'editor del widget, ma funziona anche in fase di runtime.
@azure/api-management-custom-widgets-tools/buildOnChange
Nota
Questa funzione deve essere usata solo nell'editor del widget.
Accetta un tipo TypeScript e restituisce una funzione per aggiornare i valori del widget. La funzione restituita accetta come parametro un oggetto JSON con valori aggiornati e non restituisce nulla.
import {Values} from "./values"
const onChange = buildOnChange<Values>()
onChange({fieldKey: 'newValue'})
@azure/api-management-custom-widgets-tools/askForSecrets
Questa funzione restituisce una promessa JavaScript, che dopo la risoluzione restituisce un oggetto JSON dei dati necessari per comunicare con il back-end. token
è necessario per l'autenticazione. userId
è necessario per eseguire query su risorse specifiche dell'utente. Questi valori potrebbero non essere definiti quando il portale viene visualizzato da un utente anonimo. L'oggetto Secrets
contiene anche managementApiUrl
, ovvero l'URL del back-end del portale, e apiVersion
, che è l'apiVersion attualmente usata dal portale per sviluppatori.
Attenzione
Gestire e usare attentamente il token. Chiunque lo detenga può accedere ai dati nel servizio Gestione API.
@azure/api-management-custom-widgets-tools/deployNodeJs
Questa funzione distribuisce il widget nell'archivio BLOB. In tutti i modelli, è preconfigurata nel file deploy.js
.
Accetta tre argomenti per impostazione predefinita:
serviceInformation
- Informazioni sul servizio di Azure:resourceId
- ID risorsa del servizio Gestione API, nel formato seguente:subscriptions/<subscription-id>/resourceGroups/<resource-group-name>/providers/Microsoft.ApiManagement/service/<api-management service-name>
managementApiEndpoint
- Endpoint dell'API di gestione di Azure (dipende dall'ambiente in uso, in generemanagement.azure.com
)
ID del widget: nome del widget in formato "PC-friendly" (caratteri alfanumerici latini in minuscolo e trattini;
Contoso widget
diventacontoso-widget
). È possibile trovarlo inpackage.json
sotto la chiavename
.fallbackConfigPath
- Percorso del file localeconfig.msapim.json
, ad esempio./static/config.msapim.json
@azure/api-management-custom-widgets-tools/getWidgetData
Nota
Questa funzione viene usata internamente nei modelli. Nella maggior parte delle implementazioni non è necessaria in altri casi.
Questa funzione restituisce tutti i dati passati al widget personalizzato dal portale per sviluppatori. Contiene altri dati che potrebbero essere utili per il debug o in scenari più avanzati. Questa API dovrebbe subire potenziali modifiche di rilievo. Restituisce un oggetto JSON che contiene le chiavi seguenti:
values
- Tutti i valori impostati nell'editor, lo stesso oggetto restituito dagetEditorData
instanceId
- ID di questa istanza del widget
Aggiungere o rimuovere proprietà personalizzate
Le proprietà personalizzate consentono di modificare i valori nel codice del widget personalizzato dall'interfaccia utente amministrativa del portale per sviluppatori, senza modificare il codice o ridistribuire il widget personalizzato. Per impostazione predefinita, vengono definiti i campi di input per quattro proprietà personalizzate. È possibile aggiungere o rimuovere altre proprietà personalizzate in base alle esigenze.
Avviso
Non archiviare valori segreti o sensibili nelle proprietà personalizzate.
Per aggiungere una proprietà personalizzata:
- Nel file
src/values.ts
, aggiungere al tipoValues
il nome della proprietà e il tipo di dati che verranno salvati. - Nello stesso file, aggiungere un valore predefinito per lo stesso.
- Passare al file
editor.html
oeditor/index
(il percorso esatto dipende dal framework scelto) e duplicare un input esistente o aggiungerne uno manualmente. - Assicurarsi che il campo di input restituisca il valore modificato alla funzione
onChange
, che è possibile ottenere dabuildOnChange
.
(Facoltativo) Usare un altro framework
Per implementare il widget usando altri framework e librerie dell'interfaccia utente JavaScript, è necessario configurare il progetto manualmente attenendosi alle linee guida seguenti:
- Nella maggior parte dei casi, è consigliabile iniziare dal modello TypeScript.
- Installare le dipendenze come in qualsiasi altro progetto npm.
- Se il framework preferito non è compatibile con lo strumento di compilazione Vite, configurarlo in modo che abbia come output i file compilati nella cartella
./dist
. Facoltativamente, ridefinire la posizione dei file compilati specificando un percorso relativo come quarto argomento per la funzionedeployNodeJs
. - Per lo sviluppo locale, il file
config.msapim.json
deve essere accessibile all'URLlocalhost:<port>/config.msapim.json
quando il server è in esecuzione.
Creare widget personalizzati con React Component Toolkit open source
React Component Toolkit open source offre una suite di script di pacchetti npm che consentono di convertire un'applicazione React nel framework widget personalizzato, testarla e distribuire il widget personalizzato nel portale per sviluppatori. Se si ha accesso a un servizio OpenAI di Azure, il toolkit può anche creare un widget da una descrizione di testo specificata.
Attualmente, è possibile usare il toolkit in due modi per distribuire un widget personalizzato:
- Manualmente, installando il toolkit ed eseguendo gli script del pacchetto npm in locale. Gli script vengono eseguiti in sequenza per creare, testare e distribuire un componente React come widget personalizzato nel portale per sviluppatori.
- Usando un modello dell'interfaccia della riga di comando per sviluppatori di Azure (azd) per una distribuzione end-to-end. Il modello
azd
distribuisce un'istanza di Gestione API di Azure e un'istanza OpenAI di Azure. Dopo il provisioning delle risorse, uno script interattivo consente di creare, testare e distribuire un widget personalizzato nel portale per sviluppatori da una descrizione specificata.
Nota
Il modello di esempio di React Component Toolkit e dell'interfaccia della riga di comando per sviluppatori di Azure sono progetti open source. Il supporto viene fornito solo tramite problemi GitHub nei rispettivi repository.
Contenuto correlato
Altre informazioni sul portale per sviluppatori: