Trigger pomocníka Azure OpenAI pro Azure Functions
Důležité
Rozšíření Azure OpenAI pro Azure Functions je aktuálně ve verzi Preview.
Trigger pomocníka Azure OpenAI umožňuje spustit kód na základě vlastního chatovacího robota nebo žádosti o dovednosti vytvořené asistentem.
Informace o nastavení a konfiguraci rozšíření Azure OpenAI najdete v tématu Rozšíření Azure OpenAI pro Azure Functions. Další informace o asistentech Azure OpenAI najdete v tématu Rozhraní API pomocníků Azure OpenAI.
Poznámka:
Odkazy a příklady jsou k dispozici pouze pro model Node.js v4.
Poznámka:
Odkazy a příklady jsou k dispozici pouze pro model Pythonu v2.
Poznámka:
I když jsou podporovány oba modely procesu jazyka C#, jsou k dispozici pouze příklady izolovaného modelu pracovního procesu .
Příklad
Tento příklad ukazuje, jak vytvořit asistenta, který do databáze přidá nový úkol úkolů. Trigger má statický popis Create a new todo task
používaný modelem. Samotná funkce přebírá řetězec, který představuje nový úkol, který se má přidat. Po spuštění funkce přidá úkol jako novou položku úkolu do vlastního úložiště položek a vrátí odpověď z úložiště.
[Function(nameof(AddTodo))]
public Task AddTodo([AssistantSkillTrigger("Create a new todo task")] string taskDescription)
{
if (string.IsNullOrEmpty(taskDescription))
{
throw new ArgumentException("Task description cannot be empty");
}
this.logger.LogInformation("Adding todo: {task}", taskDescription);
string todoId = Guid.NewGuid().ToString()[..6];
return this.todoManager.AddTodoAsync(new TodoItem(todoId, taskDescription));
}
Tento příklad ukazuje, jak vytvořit asistenta, který do databáze přidá nový úkol úkolů. Trigger má statický popis Create a new todo task
používaný modelem. Samotná funkce přebírá řetězec, který představuje nový úkol, který se má přidat. Po spuštění funkce přidá úkol jako novou položku úkolu do vlastního úložiště položek a vrátí odpověď z úložiště.
@FunctionName("AddTodo")
public void addTodo(
@AssistantSkillTrigger(
name = "assistantSkillCreateTodo",
functionDescription = "Create a new todo task"
) String taskDescription,
final ExecutionContext context) {
if (taskDescription == null || taskDescription.isEmpty()) {
throw new IllegalArgumentException("Task description cannot be empty");
}
context.getLogger().info("Adding todo: " + taskDescription);
String todoId = UUID.randomUUID().toString().substring(0, 6);
TodoItem todoItem = new TodoItem(todoId, taskDescription);
todoManager.addTodo(todoItem);
}
Tento příklad ukazuje, jak vytvořit asistenta, který do databáze přidá nový úkol úkolů. Trigger má statický popis Create a new todo task
používaný modelem. Samotná funkce přebírá řetězec, který představuje nový úkol, který se má přidat. Po spuštění funkce přidá úkol jako novou položku úkolu do vlastního úložiště položek a vrátí odpověď z úložiště.
const { app, trigger } = require("@azure/functions");
const { TodoItem, CreateTodoManager } = require("../services/todoManager");
const { randomUUID } = require('crypto');
const todoManager = CreateTodoManager()
app.generic('AddTodo', {
trigger: trigger.generic({
type: 'assistantSkillTrigger',
functionDescription: 'Create a new todo task'
}),
handler: async (taskDescription, context) => {
if (!taskDescription) {
throw new Error('Task description cannot be empty')
}
context.log(`Adding todo: ${taskDescription}`)
const todoId = randomUUID().substring(0, 6)
return todoManager.AddTodo(new TodoItem(todoId, taskDescription))
}
})
import { InvocationContext, app, trigger } from "@azure/functions"
import { TodoItem, ITodoManager, CreateTodoManager } from "../services/todoManager"
import { randomUUID } from 'crypto';
const todoManager: ITodoManager = CreateTodoManager()
app.generic('AddTodo', {
trigger: trigger.generic({
type: 'assistantSkillTrigger',
functionDescription: 'Create a new todo task'
}),
handler: async (taskDescription: string, context: InvocationContext) => {
if (!taskDescription) {
throw new Error('Task description cannot be empty')
}
context.log(`Adding todo: ${taskDescription}`)
const todoId = randomUUID().substring(0, 6)
return todoManager.AddTodo(new TodoItem(todoId, taskDescription))
}
Tento příklad ukazuje, jak vytvořit asistenta, který do databáze přidá nový úkol úkolů. Trigger má statický popis Create a new todo task
používaný modelem. Samotná funkce přebírá řetězec, který představuje nový úkol, který se má přidat. Po spuštění funkce přidá úkol jako novou položku úkolu do vlastního úložiště položek a vrátí odpověď z úložiště.
Tady je soubor function.json pro přidání todo:
{
"bindings": [
{
"name": "TaskDescription",
"type": "assistantSkillTrigger",
"dataType": "string",
"direction": "in",
"functionDescription": "Create a new todo task"
}
]
}
Další informace o function.json vlastnosti souboru naleznete v části Konfigurace .
using namespace System.Net
param($TaskDescription, $TriggerMetadata)
$ErrorActionPreference = "Stop"
if (-not $TaskDescription) {
throw "Task description cannot be empty"
}
Write-Information "Adding todo: $TaskDescription"
$todoID = [Guid]::NewGuid().ToString().Substring(0, 5)
Add-Todo $todoId $TaskDescription
Tento příklad ukazuje, jak vytvořit asistenta, který do databáze přidá nový úkol úkolů. Trigger má statický popis Create a new todo task
používaný modelem. Samotná funkce přebírá řetězec, který představuje nový úkol, který se má přidat. Po spuštění funkce přidá úkol jako novou položku úkolu do vlastního úložiště položek a vrátí odpověď z úložiště.
@skills.function_name("AddTodo")
@skills.assistant_skill_trigger(arg_name="taskDescription", function_description="Create a new todo task")
def add_todo(taskDescription: str) -> None:
if not taskDescription:
raise ValueError("Task description cannot be empty")
logging.info(f"Adding todo: {taskDescription}")
todo_id = str(uuid.uuid4())[0:6]
todo_manager.add_todo(TodoItem(id=todo_id, task=taskDescription))
return
Atributy
Pomocí atributu AssistantSkillTrigger
definujte trigger asistenta, který podporuje tyto parametry:
Parametr | Popis |
---|---|
FunctionDescription | Získá popis funkce asistenta, která je poskytována modelu. |
FunctionName | Volitelné. Získá nebo nastaví název funkce volaného asistentem. |
ParametrDescriptionJson | Volitelné. Získá nebo nastaví json popis parametru funkce, který je poskytnut modelu. Další informace najdete v tématu Využití. |
Model | Volitelné. Získá nebo nastaví nasazení modelu chatu OpenAI pro použití s výchozí hodnotou gpt-3.5-turbo . |
Poznámky
Poznámka AssistantSkillTrigger
umožňuje definovat trigger pomocníka, který podporuje tyto parametry:
Element (Prvek) | Popis |
---|---|
Jméno | Získá nebo nastaví název vstupní vazby. |
functionDescription | Získá popis funkce asistenta, která je poskytována modelu. |
functionName | Volitelné. Získá nebo nastaví název funkce volaného asistentem. |
parameterDescriptionJson | Volitelné. Získá nebo nastaví json popis parametru funkce, který je poskytnut modelu. Další informace najdete v tématu Využití. |
model | Volitelné. Získá nebo nastaví nasazení modelu chatu OpenAI pro použití s výchozí hodnotou gpt-3.5-turbo . |
Dekoratéry
Během náhledu definujte vstupní vazbu jako generic_trigger
vazbu typu assistantSkillTrigger
, která podporuje tyto parametry:
Parametr | Popis |
---|---|
function_description | Získá popis funkce asistenta, která je poskytována modelu. |
function_name | Volitelné. Získá nebo nastaví název funkce volanou asistentem. |
parameterDescriptionJson | Volitelné. Získá nebo nastaví json popis parametru funkce, který je poskytnut modelu. Další informace najdete v tématu Využití. |
model | Volitelné. Získá nebo nastaví nasazení modelu chatu OpenAI pro použití s výchozí hodnotou gpt-3.5-turbo . |
Konfigurace
Vazba podporuje tyto vlastnosti konfigurace, které jste nastavili v souboru function.json.
Vlastnost | Popis |
---|---|
type | Musí být AssistantSkillTrigger . |
direction | Musí být in . |
Jméno | Název triggeru. |
functionName | Získá nebo nastaví název funkce volaného asistentem. |
functionDescription | Získá popis funkce asistenta, která je poskytována LLM |
parameterDescriptionJson | Volitelné. Získá nebo nastaví json popis parametru funkce, který je poskytnut modelu. Další informace najdete v tématu Využití. |
model | Volitelné. Získá nebo nastaví nasazení modelu chatu OpenAI pro použití s výchozí hodnotou gpt-3.5-turbo . |
Konfigurace
Vazba podporuje tyto vlastnosti, které jsou definovány v kódu:
Vlastnost | Popis |
---|---|
type | Musí být AssistantSkillTrigger . |
Jméno | Název triggeru. |
functionName | Získá nebo nastaví název funkce volaného asistentem. |
functionDescription | Získá popis funkce asistenta, která je poskytována LLM |
parameterDescriptionJson | Volitelné. Získá nebo nastaví json popis parametru funkce, který je poskytnut modelu. Další informace najdete v tématu Využití. |
model | Volitelné. Získá nebo nastaví nasazení modelu chatu OpenAI pro použití s výchozí hodnotou gpt-3.5-turbo . |
Kompletní příklady najdete v části Příklad.
Využití
Pokud parameterDescriptionJson
není zadaná hodnota JSON, automaticky se vygeneruje. Další informace o syntaxi tohoto objektu najdete v dokumentaci k rozhraní OpenAI API.