Condividi tramite


Gestire i dashboard con le API dell'area di lavoro

Questa esercitazione illustra come gestire i dashboard usando l'API Lakeview e l'API Workspace. Ogni passaggio include una richiesta e una risposta di esempio e spiegazioni su come usare insieme gli strumenti e le proprietà dell'API. A ogni passaggio è possibile fare riferimento autonomamente. Seguire tutti i passaggi nell'ordine ti guida attraverso un flusso di lavoro completo.

Nota

Questo flusso di lavoro chiama l'API dell'area di lavoro per recuperare un dashboard AI/BI come oggetto generico dell'area di lavoro. I dashboard di intelligenza artificiale/BI erano precedentemente noti come dashboard di Lakeview. L'API Lakeview mantiene tale nome.

Prerequisiti

  • È necessario un token di accesso personale per connettersi all'area di lavoro. Vedi l'autenticazione tramite token di accesso personale di Azure Databricks .
  • È necessario l'ID dell'area di lavoro a cui si vuole accedere. Vedere nomi delle istanze dell'area di lavoro, URL e ID
  • Familiarità con il riferimento dell'API REST di Databricks.

Passaggio 1: Esplorare una directory dell'area di lavoro

L'API Elenco aree di lavoro GET /api/2.0/workspace/list consente di esplorare la struttura di directory dell'area di lavoro. Ad esempio, è possibile recuperare un elenco di tutti i file e le directory nell'area di lavoro corrente.

Nell'esempio seguente la proprietà path nella richiesta punta a una cartella denominata examples_folder archiviata nella home folder di un utente. Il nome utente viene fornito nel percorso first.last@example.com.

La risposta mostra che la cartella contiene un file di testo, una directory e un dashboard di intelligenza artificiale/BI.

GET /api/2.0/workspace/list

Query Parameters:
{
"path": "/Users/first.last@example.com/examples_folder"
}

Response:
{
  "objects": [
    {
      "object_type": "FILE",
      "path": "/Users/first.last@example.com/examples_folder/myfile.txt",
      "created_at": 1706822278103,
      "modified_at": 1706822278103,
      "object_id": 3976707922053539,
      "resource_id": "3976707922053539"
  },
  {
      "object_type": "DIRECTORY",
      "path": "/Users/first.last@example.com/examples_folder/another_folder",
      "object_id": 2514959868792596,
      "resource_id": "2514959868792596"
  },
  {
      "object_type": "DASHBOARD",
      "path": "/Users/first.last@example.com/examples_folder/mydashboard.lvdash.json",
      "object_id": 7944020886653361,
      "resource_id": "01eec14769f616949d7a44244a53ed10"
    }
  ]
}

Passaggio 2: Esportare un dashboard

L'API di esportazione dell'area di lavoro GET /api/2.0/workspace/export consente di esportare il contenuto di un dashboard come file. I file del dashboard di intelligenza artificiale/BI riflettono la versione bozza di un dashboard. La risposta negli esempi seguenti mostra il contenuto di una definizione minima del dashboard. Per esplorare e comprendere altri dettagli di serializzazione, prova a esportare alcuni dei tuoi dashboard.

Scaricare il file esportato

L'esempio seguente illustra come scaricare un file del dashboard usando l'API.

La proprietà "path" in questo esempio termina con l'estensione del tipo di file lvdash.json, un dashboard di intelligenza artificiale/BI. Il nome file, come appare nell'area di lavoro, precede tale estensione. In questo caso, è mydashboard.

Inoltre, la proprietà "direct_download" per questa richiesta è impostata su true in modo che la risposta sia il file esportato stesso e la proprietà "format" sia impostata su "AUTO".

Nota

La proprietà "displayName", visualizzata nella proprietà pages della risposta, non riflette il nome visibile del dashboard nell'area di lavoro.

GET /api/2.0/workspace/export

Query parameters:
{
  "path": "/Users/first.last@example.com/examples_folder/mydashboard.lvdash.json",
  "direct_download": true,
  "format": "AUTO"
}

Response:
{
  "pages": [
    {
      "name": "880de22a",
      "displayName": "New Page"
    }
  ]
}

Codificare il file esportato

Il codice seguente mostra una risposta di esempio in cui "direct_download" proprietà è impostata su false. La risposta contiene contenuto come stringa con codifica Base64.

GET /api/2.0/workspace/export

Query parameters:
{
    "path": "/Users/first.last@example.com/examples_folder/mydashboard.lvdash.json",
    "direct_download": false
}

Response:
{
    "content": "IORd/DYYsCNElspwM9XBZS/i5Z9dYgW5SkLpKJs48dR5p5KkIW8OmEHU8lx6CZotiCDS9hkppQG=",
    "file_type": "lvdash.json"
}

Passaggio 3: Importare un dashboard

È possibile usare l'API di importazione dell'area di lavoro POST /api/2.0/workspace/import per importare i dashboard in bozza in un'area di lavoro. Ad esempio, dopo aver esportato un file codificato, come nell'esempio precedente, è possibile importare tale dashboard in una nuova area di lavoro.

Affinché un'importazione venga riconosciuta come dashboard di intelligenza artificiale/BI, è necessario impostare due parametri:

  • "format": "AUTO" - questa impostazione consentirà al sistema di rilevare automaticamente il tipo di asset.
  • "path": deve includere un percorso di file che termina con ".lvdash.json".

Importante

Se queste impostazioni non sono configurate correttamente, l'importazione potrebbe avere esito positivo, ma il dashboard verrà considerato come un file normale.

L'esempio seguente mostra una richiesta di importazione configurata correttamente.


POST /api/2.0/workspace/import

Request body parameters:
{
        "path": "/Users/first.last@example.com/examples_folder/myseconddashboard.lvdash.json",
        "content": "IORd/DYYsCNElspwM9XBZS/i5Z9dYgW5SkLpKJs48dR5p5KkIW8OmEHU8lx6CZotiCDS9hkppQG=",
        "format": "AUTO"
}

Response:
{}

Passaggio 4: Sovrascrittura all'importazione (facoltativo)

Il tentativo di eseguire nuovamente la stessa richiesta API genera l'errore seguente:

{
        "error_code": "RESOURCE_ALREADY_EXISTS",
        "message": "Path (/Users/first.last@example.com/examples_folder/myseconddashboard.lvdash.json) already exists."
}

Se invece si desidera sovrascrivere la richiesta duplicata, impostare la proprietà "overwrite" su true come nell'esempio seguente.


POST /api/2.0/workspace/import

Request body parameters:
{
        "path": /Users/first.last@example.com/examples_folder/myseconddashboard.lvdash.json",
        "content": "IORd/DYYsCNElspwM9XBZS/i5Z9dYgW5SkLpKJs48dR5p5KkIW8OmEHU8lx6CZotiCDS9hkppQG=",
        "format": "AUTO",
        "overwrite": true
}

Response:
{}

Passaggio 5: Recuperare i metadati

È possibile recuperare i metadati per qualsiasi oggetto dell'area di lavoro, incluso un dashboard di intelligenza artificiale/BI. Vedere GET /api/2.0/workspace/get-status.

L'esempio seguente mostra una richiesta di get-status per il dashboard importato dall'esempio precedente. La risposta include dettagli che confermano che il file è stato importato correttamente come "DASHBOARD". Inoltre, è costituita da una proprietà "resource_id" che è possibile usare come identificatore con l'API Lakeview.

GET /api/2.0/workspace/get-status

Query parameters:
{
        "path": "/Users/first.last@example.com/examples_folder/myseconddashboard.lvdash.json"
}

Response:
{
        "object_type": "DASHBOARD",
        "path": "/Users/first.last@example.com/examples_folder/myseconddashboard.lvdash.json",
        "object_id": 7616304051637820,
        "resource_id": "9c1fbf4ad3449be67d6cb64c8acc730b"
}

Passaggio 6: Pubblicare un dashboard

Negli esempi precedenti è stata usata l'API Workspace, abilitando l'uso di dashboard di intelligenza artificiale/BI come oggetti di area di lavoro generici. L'esempio seguente usa l'API Lakeview per eseguire un'operazione di pubblicazione specifica per i dashboard di intelligenza artificiale/BI. Vedere POST /api/2.0/lakeview/dashboards/{dashboard_id}/published.

Il percorso dell'endpoint API include la proprietà "resource_id" restituita nell'esempio precedente. Nei parametri della richiesta "embed_credentials" è impostato su true in modo che le credenziali dell'editore siano incorporate nel dashboard. L'editore, in questo caso, è l'utente che effettua la richiesta API autorizzata. L'editore non può incorporare le credenziali di un utente diverso. Consulta Pubblicare un dashboard per comprendere come funziona l'impostazione delle credenziali di incorporamento .

L'attributo "warehouse_id" definisce il magazzino destinato al dashboard pubblicato. Se viene specificato, questa proprietà sovrascrive il magazzino specificato per la bozza del dashboard, se presente.

POST /api/2.0/lakeview/dashboards/9c1fbf4ad3449be67d6cb64c8acc730b/published

Request parameters
{
  "embed_credentials": true,
  "warehouse_id": "1234567890ABCD12"
}

Response:
{}

Al termine del comando, è possibile accedere al dashboard pubblicato tramite il browser. L'esempio seguente illustra come creare il collegamento al dashboard pubblicato.

https://<deployment-url>/dashboardsv3/<resource_id>/published

Per costruire il tuo link univoco:

  • Sostituire <deployment-url> con l'URL di distribuzione. Questo collegamento è l'indirizzo nella barra degli indirizzi del browser quando ci si trova nella home page dell'area di lavoro di Azure Databricks.
  • Sostituire <resource_id> con il valore della proprietà "resource_id" identificata in recuperare i metadati.

Passaggio 7: Eliminare un dashboard

Per eliminare un dashboard, usare l'API dell'area di lavoro. Vedere POST /api/2.0/workspace/delete.

Importante

Si tratta di un'eliminazione difficile. Al termine del comando, il dashboard viene eliminato definitivamente.

Nell'esempio seguente la richiesta include il percorso del file creato nei passaggi precedenti.

POST /api/2.0/workspace/delete

Query parameters:
{
        "path": "/Users/first.last@example.com/examples_folder/myseconddashboard.lvdash.json"
}

Response:
{}

Passaggi successivi