Nella tua app web, puoi ricevere risposte alle tue domande sotto forma di risposte in streaming. Questo documento mostra come utilizzare l'API REST per ottenere risposte. Se vuoi utilizzare l'app web Gemini Enterprise, consulta Chattare con l'assistente.
Panoramica di StreamAssist
StreamAssist offre un modo potente e interattivo per gestire le query degli utenti. Funziona in streaming, consentendo interazioni in tempo reale.
Le funzionalità principali dell'API includono:
Mantenimento del contesto conversazionale: utilizza le sessioni per mantenere il contesto conversazionale, assicurandosi di comprendere le query successive nell'ambito delle interazioni precedenti.
Incorporazione dei file forniti: include i file allegati come contesto per risposte più informate e pertinenti.
Integrazione perfetta: si integra con vari agenti e strumenti per soddisfare un'ampia gamma di richieste degli utenti.
Prima di iniziare
Assicurati di disporre di quanto segue:
L'API Discovery Engine abilitata per il tuo Google Cloud. Puoi abilitarla nella pagina API Discovery Engine della console Google Cloud .
Un ruolo Discovery Engine a cui è assegnata l'autorizzazione
discoveryengine.assistants.assist.Un'app Gemini Enterprise esistente. Per creare un'app, vedi Crea un'app.
Ottenere risultati di ricerca
Puoi utilizzare il metodo streamAssist
per eseguire query e ottenere risposte da
Gemini Enterprise. Il seguente comando curl elenca i campi obbligatori.
REST
curl -X POST \
-H "Authorization: Bearer $(gcloud auth print-access-token)" \
-H "Content-Type: application/json" \
"https://ENDPOINT_LOCATION-discoveryengine.googleapis.com/v1/projects/PROJECT_ID/locations/LOCATION/collections/default_collection/engines/APP_ID/assistants/default_assistant:streamAssist" \
-d '
{
"query": {
"text": "QUERY_TEXT_1"
}
}'
Sostituisci quanto segue:
- ENDPOINT_LOCATION-: la multiregione per la tua richiesta API. Assegna uno dei seguenti valori:
us-per la multiregione Stati Unitieu-per la multiregione EUglobal-per la località globale
- PROJECT_ID: l'ID del tuo Google Cloud progetto.
- APP_ID: l'identificatore univoco dell'app Gemini Enterprise.
- LOCATION: la multiregione del datastore:
global,usoeu - QUERY_TEXT_1: il testo della query di ricerca.
Per ulteriori informazioni sui campi e su ciò che viene restituito, consulta Corpo della risposta.
Ottenere risultati di ricerca utilizzando la stessa sessione
Per continuare una conversazione e ricevere risposte da Gemini Enterprise all'interno di una sessione esistente, utilizza il metodo streamAssist. Il seguente
esempio di codice mostra i campi obbligatori:
REST
curl -X POST \
-H "Authorization: Bearer $(gcloud auth print-access-token)" \
-H "Content-Type: application/json" \
"https://ENDPOINT_LOCATION-discoveryengine.googleapis.com/v1/projects/PROJECT_ID/locations/LOCATION/collections/default_collection/engines/APP_ID/assistants/default_assistant:streamAssist" \
-d '
{
"session": "projects/PROJECT_ID/locations/global/collections/default_collection/engines/APP_ID/sessions/SESSION_ID",
"query": {
"text": "QUERY_TEXT_2"
}
}'
Sostituisci quanto segue:
- ENDPOINT_LOCATION-: la multiregione per la tua richiesta API. Assegna uno dei seguenti valori:
us-per la multiregione Stati Unitieu-per la multiregione EUglobal-per la località globale
- PROJECT_ID: l'ID del tuo Google Cloud progetto.
- APP_ID: l'identificatore univoco dell'app Gemini Enterprise.
- LOCATION: la multiregione del datastore:
global,usoeu - QUERY_TEXT_2: il testo della query di ricerca.
- SESSION_ID: l'ID di una sessione di una conversazione o query precedente.
Per ulteriori informazioni sui campi e su ciò che viene restituito, consulta Corpo della risposta.
Caricare un file e ottenere risultati di ricerca (anteprima)
Per fornire più contesto all'assistente, carica un file in una sessione e poi interroga i suoi contenuti. Segui questi passaggi:
Carica un file in una sessione utilizzando il metodo
addContextFile.REST
curl -X POST \ -H "Authorization: Bearer $(gcloud auth print-access-token)" \ -H "Content-Type: application/json" \ "https://ENDPOINT_LOCATION-discoveryengine.googleapis.com/v1/projects/PROJECT_ID/locations/LOCATION/collections/default_collection/engines/APP_ID/sessions/SESSION_ID:addContextFile" \ -d ' { "fileName": "FILE_NAME", "mimeType": "MIME_TYPE", "fileContents": "BASE64_ENCODED_FILE" }'Sostituisci quanto segue:
- ENDPOINT_LOCATION-: la multiregione per la tua richiesta API. Assegna uno dei seguenti valori:
us-per la multiregione Stati Unitieu-per la multiregione EUglobal-per la località globale
- PROJECT_ID: l'ID del tuo Google Cloud progetto.
- LOCATION: la multiregione del datastore:
global,usoeu - APP_ID: l'identificatore univoco dell'app Gemini Enterprise.
- SESSION_ID: l'ID di una sessione di una conversazione o query precedente.
- FILE_NAME: il nome del file.
- MIME_TYPE: il tipo MIME del file, ad esempio
text/plainoapplication/pdf. Per saperne di più sui diversi tipi di contenuti multimediali, consulta Tipi di contenuti multimediali. - BASE64_ENCODED_FILE: la rappresentazione codificata in base64 del file.
Per ulteriori informazioni sui campi e su ciò che viene restituito, consulta Corpo della risposta.
- ENDPOINT_LOCATION-: la multiregione per la tua richiesta API. Assegna uno dei seguenti valori:
Utilizza la stessa sessione per porre una domanda sul file che hai caricato utilizzando il metodo
streamAssist.REST
curl -X POST \ -H "Authorization: Bearer $(gcloud auth print-access-token)" \ -H "Content-Type: application/json" \ "https://ENDPOINT_LOCATION-discoveryengine.googleapis.com/v1alpha/projects/PROJECT_ID/locations/LOCATION/collections/default_collection/engines/APP_ID/assistants/default_assistant:streamAssist" \ -d ' { "session": "projects/PROJECT_ID/locations/global/collections/default_collection/engines/APP_ID/sessions/SESSION_ID", "fileIds": ["FILE_ID"], "query": { "text": "QUERY_TEXT_3" } }'Sostituisci quanto segue:
- ENDPOINT_LOCATION-: la multiregione per la tua richiesta API. Assegna uno dei seguenti valori:
us-per la multiregione Stati Unitieu-per la multiregione EUglobal-per la località globale
- PROJECT_ID: l'ID del tuo Google Cloud progetto.
- APP_ID: l'identificatore univoco dell'app Gemini Enterprise.
- LOCATION: la multiregione del datastore:
global,usoeu - QUERY_TEXT_3: il testo della query di ricerca.
- SESSION_ID: l'ID di una sessione di una conversazione o query precedente.
- FILE_ID: l'ID del file che hai caricato nell'assistente.
Per ulteriori informazioni sui campi e su ciò che viene restituito, consulta Corpo della risposta.
- ENDPOINT_LOCATION-: la multiregione per la tua richiesta API. Assegna uno dei seguenti valori: