Erweitertes Tutorial zum Erstellen einer API-basierten Nachrichtenerweiterung
Hinweis
API-basierte Nachrichtenerweiterungen unterstützen nur Suchbefehle.
Nachrichtenerweiterungen, die mit der API (API-basiert) erstellt wurden, verbessern die Funktionalität Ihrer Teams-Apps erheblich, indem sie ihnen die Interaktion mit externen Diensten ermöglichen. API-basierte Nachrichtenerweiterungen können dazu beitragen, Workflows zu optimieren, indem sie die Notwendigkeit reduzieren, zwischen verschiedenen Anwendungen zu wechseln.
Sie können API-basierte Nachrichtenerweiterungen verwenden, um externe Dienste zu integrieren, die häufig im Geschäftsworkflow verwendet werden. Beispielsweise könnte ein Unternehmen, das häufig ein CRM-System für die Kundenverwaltung verwendet, eine Nachrichtenerweiterung verwenden, um Kundendaten direkt aus Teams abzurufen und anzuzeigen. Diese App hilft dabei, Zeit zu sparen und die Effizienz zu verbessern, indem sie die Notwendigkeit reduziert, zwischen verschiedenen Anwendungen zu wechseln. Dieses Feature wird auf allen Plattformen unterstützt, auf denen Teams verfügbar ist, einschließlich Desktop, Web und Mobilgeräte.
Voraussetzungen
Hier finden Sie eine Liste der Tools, die Sie zum Erstellen und Bereitstellen Ihrer Apps benötigen.
Installieren | Zum Benutzen... |
---|---|
Microsoft Teams | Microsoft Teams für die Zusammenarbeit mit allen Personen, mit denen Sie arbeiten, über Apps für Chats, Besprechungen oder Anrufe – alles an einem Ort. |
Microsoft Edge (empfohlen) oder Google Chrome | Ein Browser mit Entwicklertools. |
Visual Studio Code | Build-Umgebungen für JavaScript, TypeScript oder SharePoint Framework (SPFx). Verwenden Sie Version 1.55 oder höher. |
Microsoft 365-Entwicklerkonto | Zugriff auf das Teams-Konto mit den entsprechenden Berechtigungen zum Installieren einer App. |
Azure-Konto | Zugriff auf Azure-Ressourcen. |
OAD-Dokument (OpenAPI Description) | Ein Dokument, in dem die Funktionen Ihrer API beschrieben werden. Weitere Informationen finden Sie unter OpenAPI-Beschreibung. |
Einrichten Ihres Teams-Entwicklungsmandanten
Ein Mandant ist wie ein Raum oder ein Container für Ihre organization in Teams, in dem Sie chatten, Dateien freigeben und Besprechungen ausführen. Dieser Bereich ist auch der Ort, an dem Sie Ihre benutzerdefinierte App hochladen und testen. Lassen Sie uns überprüfen, ob Sie bereit sind, mit dem Mandanten zu entwickeln.
Überprüfen auf benutzerdefinierte App-Uploadoption
Nachdem Sie die App erstellt haben, müssen Sie ihre App in Teams laden, ohne sie zu verteilen. Dieser Vorgang wird als benutzerdefinierter App-Upload bezeichnet. Melden Sie sich bei Ihrem Microsoft 365-Konto an, um diese Option anzuzeigen.
Hinweis
Ein benutzerdefinierter App-Upload ist für die Vorschau und das Testen von Apps in der lokalen Teams-Umgebung erforderlich. Wenn sie nicht aktiviert ist, können Sie Ihre App in der lokalen Teams-Umgebung nicht in der Vorschau anzeigen und testen.
Verfügen Sie bereits über einen Mandanten und über Administratorzugriff? Lassen Sie uns überprüfen, ob Sie dies wirklich tun!
Überprüfen Sie, ob Sie eine benutzerdefinierte App in Teams hochladen können:
Wählen Sie im Teams-Client das Symbol Apps aus.
Wählen Sie Verwalten Ihrer Apps aus.
Wählen Sie App hochladen aus.
Suchen Sie nach der Option Hochladen einer benutzerdefinierten App. Wenn die Option angezeigt wird, ist der benutzerdefinierte App-Upload aktiviert.
Hinweis
Wenden Sie sich an Ihren Teams-Administrator, wenn Sie die Option zum Hochladen einer benutzerdefinierten App nicht finden.
Erstellen eines kostenlosen Teams-Entwicklermandanten (optional)
Wenn Sie nicht über ein Teams-Entwicklerkonto verfügen, können Sie es kostenlos erhalten. Nehmen Sie am Microsoft 365-Entwicklerprogramm teil!
Gehen Sie zu Microsoft 365-Entwicklerprogramm.
Wählen Sie Jetzt beitreten aus, und folgen Sie den Anweisungen auf dem Bildschirm.
Wählen Sie auf der Willkommensseite E5-Abonnement einrichten aus.
Einrichten Ihres Administratorkontos. Nachdem Sie fertig sind, wird der folgende Bildschirm angezeigt.
Melden Sie sich bei Teams mit dem Administratorkonto an, das Sie gerade eingerichtet haben. Vergewissern Sie sich, dass Sie über die Option Benutzerdefinierte App hochladen in Teams verfügen.
Abrufen eines kostenlosen Azure-Kontos
Wenn Sie Ihre App hosten oder auf Ressourcen in Azure zugreifen möchten, benötigen Sie ein Azure-Abonnement. Erstellen Sie ein kostenloses Konto , bevor Sie beginnen.
Sie verfügen über alle Tools zum Einrichten Ihres Kontos. Richten Sie als Nächstes Ihre Entwicklungsumgebung ein, und beginnen Sie mit dem Erstellen! Wählen Sie zuerst die App aus, die Sie erstellen möchten.
Erstellen eines OpenAPI-Beschreibungsdokuments
OpenAPI-Beschreibung
OpenAPI Description (OAD) ist die Branchenstandardspezifikation, die beschreibt, wie OpenAPI-Dateien strukturiert und umrissen werden. Es handelt sich um ein sprachunabhängiges, für Menschen lesbares Format zum Beschreiben von APIs. Es ist sowohl für Menschen als auch für Computer einfach zu lesen und zu schreiben. Das Schema ist maschinenlesbar und wird entweder in YAML oder JSON dargestellt.
Für die Interaktion mit den APIs ist ein OpenAPI-Beschreibungsdokument erforderlich. Das OpenAPI-Beschreibungsdokument muss die folgenden Kriterien erfüllen:
- Die
auth
-Eigenschaft darf nicht angegeben werden. - JSON und YAML sind die unterstützten Formate.
- OpenAPI-Versionen 2.0 und 3.0.x werden unterstützt.
- Teams unterstützt die Konstrukte oneOf, anyOf, allOf und nicht (swagger.io).
- Das Erstellen von Arrays für die Anforderung wird nicht unterstützt, geschachtelte Objekte in einem JSON-Anforderungstext werden jedoch unterstützt.
- Falls vorhanden, muss der Anforderungstext application/JSON sein, um die Kompatibilität mit einer Vielzahl von APIs sicherzustellen.
- Definieren Sie eine HTTPS-Protokollserver-URL für die
servers.url
-Eigenschaft. - Die Suche mit nur einem Parameter wird unterstützt.
- Nur ein erforderlicher Parameter ohne Standardwert ist zulässig.
- Nur DIE HTTP-Methoden POST und GET werden unterstützt.
- Das OpenAPI-Beschreibungsdokument muss über einen verfügen
operationId
. - Der Vorgang darf keine Header- oder Cookie-Parameter ohne Standardwerte erfordern.
- Ein Befehl muss genau einen Parameter aufweisen.
- Stellen Sie sicher, dass im Dokument OpenAPI Description keine Remoteverweise vorhanden sind.
- Ein erforderlicher Parameter mit einem Standardwert wird als optional betrachtet.
Wir haben die folgende OpenAPI-Beschreibung als Beispiel für dieses Tutorial verwendet:
OpenAPI-Beschreibung
openapi: 3.0.1
info:
title: OpenTools Plugin
description: A plugin that allows the user to find the most appropriate AI tools for their use cases, with their pricing information.
version: 'v1'
servers:
- url: https://gptplugin.opentools.ai
paths:
/tools:
get:
operationId: searchTools
summary: Search for AI Tools
parameters:
- in: query
name: search
required: true
schema:
type: string
description: Used to search for AI tools by their category based on the keywords. For example, a search for "tool to create music" provides a list of tools that can create music.
responses:
"200":
description: OK
content:
application/json:
schema:
$ref: '#/components/schemas/searchToolsResponse'
"400":
description: Search Error
content:
application/json:
schema:
$ref: '#/components/schemas/searchToolsError'
components:
schemas:
searchToolsResponse:
required:
- search
type: object
properties:
tools:
type: array
items:
type: object
properties:
name:
type: string
description: The name of the tool.
opentools_url:
type: string
description: The URL to access the tool.
main_summary:
type: string
description: A summary of what the tool is.
pricing_summary:
type: string
description: A summary of the pricing of the tool.
categories:
type: array
items:
type: string
description: The categories assigned to the tool.
platforms:
type: array
items:
type: string
description: The platforms that this tool is available on.
description: The list of AI tools.
searchToolsError:
type: object
properties:
message:
type: string
description: Message of the error.
Hinweis
Stellen Sie sicher, dass die required: true
Eigenschaft nur für einen Parameter verfügbar ist. Wenn mehrere erforderliche Parameter vorhanden sind, können Sie die erforderliche Eigenschaft required: false
für die anderen Parameter auf aktualisieren.
Sie können überprüfen, ob das OpenAPI-Beschreibungsdokument gültig ist. Führen Sie die folgenden Schritte aus, um dies zu überprüfen:
Wechseln Sie zum Swagger/OpenAPI-Validierungssteuerelement , und überprüfen Sie das Dokument Zur OpenAPI-Beschreibung.
Speichern Sie das OpenAPI-Beschreibungsdokument.
Wechseln Sie zu Swagger Editor.
Fügen Sie im linken Bereich die OpenAPI-Beschreibung in den Editor ein.
Wählen Sie im rechten Bereich GET aus.
Wählen Sie Ausprobieren aus.
Geben Sie die Werte für den Suchparameter als Tool zum Erstellen von Musik ein.
Wählen Sie Ausführen aus. Der Swagger-Editor zeigt eine Antwort mit einer Liste von Produkten an.
Wechseln Sie zuAntworttext der Serverantwort>.
Kopieren Sie unter
products
das erste Produkt aus der Liste, und speichern Sie es zur späteren Referenz.
Erstellen einer Antwortrenderingvorlage
Ein OpenAPI-Beschreibungsdokument erfordert eine Antwortrenderingvorlage, damit die App auf die GET- oder POST-Anforderungen reagieren kann. Die Antwortrenderingvorlage besteht aus einer Vorlage für adaptive Karten, einer Vorschauvorlage Karte und Metadaten.
Vorlage für adaptive Karten
Führen Sie die folgenden Schritte aus, um eine Vorlage für adaptive Karten zu erstellen:
Wechseln Sie zu ChatGPT, und stellen Sie die folgende Abfrage im Bereich zum Verfassen von Nachrichten:
Create an Adaptive Card Template that binds to the following response: "categories": [ "Music Generation", "AI Detection" ], "chatbot_short_url": "https://goto.opentools.ai/c/ai-music-generator", "main_summary": "AI Music Generator is an AI-powered music composing tool that allows users to create original and personalized music for various purposes. It can generate melodies, harmonies, and rhythms tailored to specific needs and preferences, with customization options such as genre, mood, length, and instrumentation. The tool is designed for creative individuals, from beginners to professionals, and can produce high-quality music in seconds. Every generated piece of music is royalty-free and can be used instantly, with no limitations on beat creation. With advanced AI technology, AI Music Generator makes music production accessible to everyone.", "name": "AI Music Generator", "opentools_url": "https://goto.opentools.ai/ai-music-generator", "platforms": [ "Web", "App", "API" ]
Wählen Sie Nachricht senden aus.
ChatGPT generiert eine Antwort mit einer Vorlage für adaptive Karten, die an die Beispieldaten gebunden ist. Speichern Sie die Vorlage für adaptive Karten zur späteren Referenz.
Es folgt ein Beispiel für die Vorlage für adaptive Karten:
Vorlage für adaptive Karten
{ "$schema": "http://adaptivecards.io/schemas/adaptive-card.json", "type": "AdaptiveCard", "version": "1.4", "body": [ { "type": "TextBlock", "text": "AI Music Generator", "weight": "Bolder", "size": "Large" }, { "type": "TextBlock", "text": "Categories", "size": "Medium" }, { "type": "TextBlock", "text": "Music Generation, AI Detection", "wrap": true }, { "type": "TextBlock", "text": "Description", "size": "Medium" }, { "type": "TextBlock", "text": "AI Music Generator is an AI-powered music composing tool that allows users to create original and personalized music for various purposes. It can generate melodies, harmonies, and rhythms tailored to specific needs and preferences, with customization options such as genre, mood, length, and instrumentation. The tool is designed for creative individuals, from beginners to professionals, and can produce high-quality music in seconds. Every generated piece of music is royalty-free and can be used instantly, with no limitations on beat creation. AI Music Generator is powered by advanced AI technology, and it makes music production accessible to everyone.", "wrap": true }, { "type": "TextBlock", "text": "Platform", "size": "Medium" }, { "type": "TextBlock", "text": "Web, App, API", "wrap": true } ], "actions": [ { "type": "Action.OpenUrl", "title": "Learn More", "url": "https://goto.opentools.ai/ai-music-generator" }, { "type": "Action.OpenUrl", "title": "Try It", "url": "https://goto.opentools.ai/c/ai-music-generator" } ] }
Führen Sie die folgenden Schritte aus, um zu überprüfen, ob die generierte adaptive Karte an die Beispieldaten gebunden ist:
Wechseln Sie zu adaptiver Karte Designer.
Wechseln Sie zu Host-App auswählen, und wählen Sie dann microsoft Teams aus der Dropdownliste aus.
Wechseln Sie zum KARTENNUTZLAST-EDITOR , und fügen Sie den Vorlagencode für adaptive Karten ein.
Wechseln Sie zum BEISPIELDATEN-EDITOR , und fügen Sie die GET-API-Antwort ein, die Sie zuvor gespeichert haben.
Wählen Sie Vorschaumodus aus. Der Designer für adaptive Karten zeigt eine adaptive Karte mit den Daten an, die die Antwort an die Vorlage binden.
Erstellen einer Vorschauvorlage Karte
Die Vorschauversion Karte Vorlage kann die title
Eigenschaften , subtitle
und image
enthalten. Wenn die API-Antwort kein Bild enthält, können Sie die Imageeigenschaft entfernen.
Im Folgenden sehen Sie ein Beispiel für eine Vorschau Karte Vorlage:
Vorschau Karte Vorlage
"previewCardTemplate": {
"title": "${if(name, name, 'N/A')}",
"subtitle": "$${if(price, price, 'N/A')}",
}
Erstellen Sie eine if-Bedingung für und title
subtitle
, wobei:
- Wenn name vorhanden ist, verwendet der Bot den Namen.
- Wenn der Name nicht vorhanden ist, verwendet der Bot NA.
Beispiel: "title": "Name: ${if(name, name, 'N/A')}"
.
Speichern Sie die Vorschauvorlage Karte zur späteren Referenz.
Antwortrenderingvorlage
Die Antwortrenderingvorlage muss dem schema entsprechen, das unter gehostet wird https://developer.microsoft.com/json-schemas/teams/vDevPreview/MicrosoftTeams.ResponseRenderingTemplate.schema.json
.
Führen Sie die folgenden Schritte aus, um eine Antwortrenderingvorlage zu erstellen:
Erstellen Sie eine JSON-Datei, und fügen Sie der Datei den folgenden Code hinzu:
{ "version": "1.0.0", "$schema": "<URL_REFERENCE_TO_SCHEMA>", "jsonPath": "", "responseLayout": "", "responseCardTemplate": { }, "previewCardTemplate": { } }
Aktualisieren Sie die Eigenschaften in der Antwortrenderingvorlage wie folgt:
"version"
:"1.0.0"
"$schema"
:"http://adaptivecards.io/schemas/adaptive-card.json"
"jsonPath"
:"tools"
jsonPath
ist der Pfad zu einem oder mehreren Ergebnissen in der JSON-Antwortantwort. Fügen Sie denjsonPath
relevanten Daten/Arrays aus der Produktliste in der API-Antwort hinzu. In diesem Fall handelt es sich umjsonPath
Tools. Weitere Informationen zum Bestimmen des JSON-Pfads finden Sie unter Abfragen von JSON mit JSON-Pfad."responseLayout"
:"list"
responseLayout
gibt das Layout der Anlagen an. Wird für Antworten vom Typ Ergebnis verwendet. Unterstützte Typen sind List und Grid. Wenn der Antworttext ein Objekt mit mehreren Elementen wie Text, Titel und Bild enthält, muss das Antwortlayout auflist
festgelegt werden. Wenn die API-Antwort nur Bilder oder Miniaturansichten enthält, muss das Antwortlayout aufgrid
festgelegt werden."responseCardTemplate"
: Fügen Sie den Vorlagencode für adaptive Karten ein, den Sie zuvor gespeichert haben.responseCardTemplate
ist eine Vorlage für adaptive Karten zum Zuordnen der JSON-Antwort zu einer adaptiven Karte."previewCardTemplate"
: Fügen Sie die Vorschauversion Karte Vorlagencode ein, den Sie zuvor gespeichert haben.previewCardTemplate
ist eine Vorschau Karte Vorlage verwendet wird, um eine Vorschau der Ergebnisse im Nachrichtenerweiterungs-Flyout anzuzeigen.
Speichern Sie die Antwortrenderingvorlage im selben Ordner, in dem Sie das OpenAPI-Beschreibungsdokument gespeichert haben.
Der folgende Code ist ein Beispiel für eine Antwortrenderingvorlage:
Antwortrenderingvorlage
{
"version": "devPreview",
"jsonPath": "tools",
"responseLayout": "list",
"responseCardTemplate": {
"$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
"type": "AdaptiveCard",
"version": "1.4",
"body": [
{
"type": "TextBlock",
"text": "AI Music Generator",
"weight": "Bolder",
"size": "Large"
},
{
"type": "TextBlock",
"text": "Categories",
"size": "Medium"
},
{
"type": "TextBlock",
"text": "Music Generation, AI Detection",
"wrap": true
},
{
"type": "TextBlock",
"text": "Description",
"size": "Medium"
},
{
"type": "TextBlock",
"text": "AI Music Generator is an AI-powered music composing tool that allows users to create original and personalized music for various purposes. It can generate melodies, harmonies, and rhythms tailored to specific needs and preferences, with customization options such as genre, mood, length, and instrumentation. The tool is designed for creative individuals, from beginners to professionals, and can produce high-quality music in seconds. Every generated piece of music is royalty-free and can be used instantly, with no limitations on beat creation. With advanced AI technology, AI Music Generator makes music production accessible to everyone.",
"wrap": true
},
{
"type": "TextBlock",
"text": "Platform",
"size": "Medium"
},
{
"type": "TextBlock",
"text": "Web, App, API",
"wrap": true
}
],
"actions": [
{
"type": "Action.OpenUrl",
"title": "Learn More",
"url": "https://goto.opentools.ai/ai-music-generator"
},
{
"type": "Action.OpenUrl",
"title": "Try It",
"url": "https://goto.opentools.ai/c/ai-music-generator"
}
]
},
"previewCardTemplate": {
"title": "${if(name, name, 'N/A')}",
"subtitle": "$${if(price, price, 'N/A')}",
}
}
Erstellen eines App-Manifests
Jetzt müssen Sie ein App-Manifest erstellen (zuvor als Teams-App-Manifest bezeichnet). Das App-Manifest beschreibt, wie Ihre App in das Microsoft Teams-Produkt integriert wird.
Erstellen eines Teams-App-Manifests
Führen Sie die folgenden Schritte aus, um das Manifest zu erstellen:
Erstellen Sie eine neue JSON-Datei. Ihr App-Manifest muss dem Schema entsprechen, das im Manifestschema der öffentlichen Entwicklervorschau definiert ist.
Fügen Sie der JSON-Datei den folgenden Code hinzu:
App-Manifest
{ "$schema": "https://developer.microsoft.com/json-schemas/teams/vDevPreview/MicrosoftTeams.schema.json", "manifestVersion": "devPreview", "version": "1.0.3", "id": "<<YOUR-MICROSOFT-APP-ID>>", "packageName": "com.microsoft.teams.extension", "developer": { "name": "Teams App, Inc.", "websiteUrl": "https://www.example.com", "privacyUrl": "https://www.example.com/termofuse", "termsOfUseUrl": "https://www.example.com/privacy" }, "icons": { "color": "color.png", "outline": "outline.png" }, "name": { "short": "Search ME API", "full": "Search ME API full" }, "description": { "short": "product app for testing API Message Extensions", "full": "product app for testing API Message Extensions" }, "accentColor": "#FFFFFF", "composeExtensions": [ { "composeExtensionType": "", "apiSpecificationFile": "", "commands": [ { "context": [ "compose" ], "type": "query", "title": "API for fetching Klarna.", "id": "", "parameters": [ { "name": "", "title": "", "description": "" } ], "description": "", "apiResponseRenderingTemplateFile": "" } ] } ], "permissions": [ "identity", "messageTeamMembers" ], "validDomains": [] }
Aktualisieren Sie die App-Manifesteigenschaften wie folgt:
- Ersetzen Sie durch
<<YOUR-MICROSOFT-APP-ID>>
die Microsoft App-ID des Bots. - Aktualisieren Sie den Wert für in
composeExtensionType
apiBased
. - Aktualisieren Sie den Wert für in
apiSpecificationFile
den Pfad Ihrer OpenAPI-Beschreibungsdatei. - Aktualisieren Sie den Wert für in
commands.id
searchTools
. - Aktualisieren Sie den Wert für in
commands.title
Search for AI Tools
. - Aktualisieren Sie den Wert für in
commands.description
Search for AI Tools
. - Aktualisieren Sie den Wert für in
parameters.name
search
. Wenn keine Parameter vorhanden sind, müssen die Werte Abfrageparameter sein oderproperties.name
auf eine Eigenschaft im Anforderungstextschema verweisen. - Aktualisieren Sie in
apiResponseRenderingTemplateFile
den Pfad Ihrer Antwortrenderingvorlagendatei. - Aktualisieren Sie den Wert für auf
validDomains
den Endpunkt, derservice URL
in der OpenAPI-Beschreibungsdatei definiert ist.
- Ersetzen Sie durch
Speichern Sie das Teams-App-Manifest in demSelben Ordner, in dem Sie das OpenAPI-Beschreibungsdokument und die Antwortrenderingvorlage gespeichert haben.
- Sie benötigen ein Farbbild und ein Gliederungsbild. Diese Bilder sollten im Ordner enthalten sein und in Ihrem Teams-App-Manifest referenziert werden.
- Zippen Sie den Inhalt des Ordners. Die ZIP-Datei muss die folgenden Dateien enthalten:
- OpenAPI-Beschreibungsdokument
- Antwortrenderingvorlage
- App-Manifest
- Farbsymbol
- Kontursymbol
Hochladen einer benutzerdefinierten App in Teams
Melden Sie sich bei der Teams-Testumgebung an, um Ihre App in Teams zu testen. Führen Sie die folgenden Schritte aus, um eine benutzerdefinierte App in Teams hochzuladen:
Wechseln Sie zu Microsoft Teams, und melden Sie sich mit Ihren Testmandantenanmeldeinformationen an.
Wechseln Sie zu Apps>App verwalten>App hochladen.
Wählen Sie Angepasste App hochladen aus.
Wählen Sie die erstellte ZIP-Datei und dann Öffnen aus.
Klicken Sie auf Hinzufügen.
Klicken Sie auf Öffnen.
Wechseln Sie zu einem Chat, wählen Sie + dann im Bereich Zum Verfassen von Nachrichten aus, und suchen Sie nach Ihrer App.
Wählen Sie die App aus, und erstellen Sie eine Suchabfrage.
Die App antwortet mit einer adaptiven Karte im Chatfenster.
Wählen Sie Senden aus.
Herzlichen Glückwunsch!
Du hast es geschafft! Sie haben gelernt, eine API-basierte Nachrichtenerweiterung mithilfe des OpenAPI-Beschreibungsdokuments zu erstellen.
Liegt ein Problem mit diesem Abschnitt vor? Wenn ja, senden Sie uns Feedback, damit wir den Abschnitt verbessern können.