Eine liveChatMessage-Ressource stellt eine Chatnachricht in einem YouTube-Livechat dar. Die Ressource kann Details zu verschiedenen Arten von Nachrichten enthalten, z. B. zu einer neu geposteten Textnachricht oder einer Fan-Finanzierungsveranstaltung.
Die Livechat-Funktion ist standardmäßig für Livestreams aktiviert und während der Liveveranstaltung verfügbar. Nach dem Ende der Veranstaltung ist der Livechat für diese Veranstaltung nicht mehr verfügbar.
Methoden
Die API unterstützt die folgenden Methoden für liveChatMessages-Ressourcen:
- list
- Listet Livechat-Nachrichten für einen bestimmten Chat auf. Hier kannst du die Funktion ausprobieren.
- streamList
- Ermöglicht eine Server-Streaming-Verbindung zum Empfangen von Livechat-Nachrichten für einen bestimmten Chat mit geringer Latenz. Hier kannst du die Funktion ausprobieren.
- insert
- Fügt einem Livechat eine Nachricht oder eine Umfrage hinzu. Hier kannst du die Funktion ausprobieren.
- transition
- Ändert den Status einer Livebenachrichtigung. Hier kannst du die Funktion ausprobieren.
- Delete
- Löscht eine Chatnachricht. Die API-Anfrage muss vom Kanalinhaber oder einem Moderator des Livechats autorisiert werden. Hier kannst du die Funktion ausprobieren.
Ressourcendarstellung
Die folgende JSON-Struktur zeigt das Format einer liveChatMessages-Ressource:
{
"kind": "youtube#liveChatMessage",
"etag": etag,
"id": string,
"snippet": {
"type": string,
"liveChatId": string,
"authorChannelId": string,
"publishedAt": datetime,
"hasDisplayContent": boolean,
"displayMessage": string,
"fanFundingEventDetails": {
"amountMicros": unsigned long,
"currency": string,
"amountDisplayString": string,
"userComment": string
},
"textMessageDetails": {
"messageText": string
},
"messageDeletedDetails": {
"deletedMessageId": string
},
"userBannedDetails": {
"bannedUserDetails": {
"channelId": string,
"channelUrl": string,
"displayName": string,
"profileImageUrl": string
},
"banType": string,
"banDurationSeconds": unsigned long
},
"memberMilestoneChatDetails": {
"userComment": string,
"memberMonth": unsigned integer,
"memberLevelName": string
},
"newSponsorDetails": {
"memberLevelName": string,
"isUpgrade": bool
},
"superChatDetails": {
"amountMicros": unsigned long,
"currency": string,
"amountDisplayString": string,
"userComment": string,
"tier": unsigned integer
},
"superStickerDetails": {
"superStickerMetadata": {
"stickerId": string,
"altText": string,
"language": string
},
"amountMicros": unsigned long,
"currency": string,
"amountDisplayString": string,
"tier": unsigned integer
},
"pollDetails": {
"metadata": {
"options": {
"optionText": string,
"tally": string,
},
"questionText": string,
"status": enum
},
},
"membershipGiftingDetails": {
"giftMembershipsCount": integer,
"giftMembershipsLevelName": string
},
"giftMembershipReceivedDetails": {
"memberLevelName": string,
"gifterChannelId": string,
"associatedMembershipGiftingMessageId": string
},
},
"authorDetails": {
"channelId": string,
"channelUrl": string,
"displayName": string,
"profileImageUrl": string,
"isVerified": boolean,
"isChatOwner": boolean,
"isChatSponsor": boolean,
"isChatModerator": boolean
},
}Attribute
In der folgenden Tabelle werden die Attribute definiert, die in dieser Ressource enthalten sind:
| Attribute | |
|---|---|
kind |
stringGibt den Typ der API-Ressource an. Der Wert ist youtube#liveChatMessage. |
etag |
etagDas ETag dieser Ressource. |
id |
stringDie ID, die YouTube zur eindeutigen Identifizierung der Nachricht zuweist. |
snippet |
objectDas snippet-Objekt enthält die wichtigsten Details zur Chatnachricht. |
snippet.type |
stringDer Typ der Nachricht. Diese Eigenschaft ist immer vorhanden und ihr Wert bestimmt, welche Felder in der Ressource vorhanden sind. Gültige Werte für diese Eigenschaft sind:
|
snippet.liveChatId |
stringDie ID, die den Livechat, mit dem die Nachricht verknüpft ist, eindeutig identifiziert. Die mit einer Übertragung verknüpfte Livechat-ID wird in der snippet.liveChatId-Eigenschaft der liveBroadcast-Ressource zurückgegeben. |
snippet.authorChannelId |
stringDie ID des Nutzers, der die Nachricht verfasst hat. Dieses Feld wird nur für die folgenden Nachrichtentypen ausgefüllt:
|
snippet.publishedAt |
datetimeDas Datum und die Uhrzeit, zu der die Nachricht ursprünglich veröffentlicht wurde. Der Wert wird im ISO 8601-Format ( YYYY-MM-DDThh:mm:ss.sZ) angegeben. |
snippet.hasDisplayContent |
booleanGibt an, ob die Nachricht Anzeigeelemente enthält, die Nutzern präsentiert werden sollten. |
snippet.displayMessage |
stringEnthält einen String, der Nutzern angezeigt wird. Dieses Feld ist nicht vorhanden, wenn der Nachrichtentyp chatEndedEvent oder tombstone ist. |
snippet.fanFundingEventDetails |
objectHinweis: Dieses Objekt und seine untergeordneten Attribute wurden eingestellt. Ab dem 28. Februar 2017 werden in liveChatMessage-Ressourcen keine Details mehr zu Fan-Funding-Ereignissen zurückgegeben.Dieses Objekt enthält Details zum Funding-Ereignis. Ist nur vorhanden, wenn der Nachrichtentyp fanFundingEvent ist. |
snippet.fanFundingEventDetails.amountMicros |
unsigned longHinweis: Diese Eigenschaft wurde eingestellt. Der Betrag des Fonds. |
snippet.fanFundingEventDetails.currency |
stringHinweis: Diese Eigenschaft wurde eingestellt. Die Währung, in der der Fonds erstellt wurde. |
snippet.fanFundingEventDetails.amountDisplayString |
stringHinweis: Diese Property wurde eingestellt. Ein gerenderter String, in dem dem Nutzer der Betrag und die Währung des Guthabens angezeigt werden. |
snippet.fanFundingEventDetails.userComment |
stringHinweis: Diese Property wurde eingestellt. Der Kommentar, den der Nutzer diesem Fan-Funding-Ereignis hinzugefügt hat. |
snippet.textMessageDetails |
objectDieses Objekt enthält Details zur SMS. Ist nur vorhanden, wenn der Nachrichtentyp textMessageEvent ist. |
snippet.textMessageDetails.messageText |
stringDie Nachricht des Nutzers. |
snippet.messageDeletedDetails |
objectDieses Objekt enthält Details zu einer Nachricht, die von einem Chatmoderator oder vom Inhaber des Kanals der Liveübertragung gelöscht wurde. Ist nur vorhanden, wenn der Nachrichtentyp messageDeletedEvent ist. |
snippet.messageDeletedDetails.deletedMessageId |
stringDie ID, die die gelöschte Nachricht eindeutig identifiziert. Der Wert entspricht dem Eigenschaftswert id der ursprünglichen SMS. Wenn beispielsweise eine textMessageEvent den id-Attributwert 123 hat und diese Nachricht später gelöscht wird, ist der snippet.messageDeletedDetails.deletedMessageId-Wert für diese Nachricht 123.Wenn Sie Chatnachrichten nach dem Abrufen im Cache speichern, verwenden Sie den Wert dieses Attributs, um die Nachricht zu identifizieren, die nicht mehr angezeigt werden soll. |
snippet.userBannedDetails |
objectDieses Objekt enthält Details zu einem Nutzer, der aus dem Chat ausgeschlossen wurde. Sie enthält auch Details zum Ausschluss selbst. Nutzer können dauerhaft oder vorübergehend aus einem Chat ausgeschlossen werden. |
snippet.userBannedDetails.bannedUserDetails |
objectDieses Objekt enthält Informationen zum gesperrten Nutzer. |
snippet.userBannedDetails.bannedUserDetails.channelId |
stringDie YouTube-Kanal-ID des gesperrten Nutzers. |
snippet.userBannedDetails.bannedUserDetails.channelUrl |
stringDie URL des YouTube-Kanals des gesperrten Nutzers. |
snippet.userBannedDetails.bannedUserDetails.displayName |
stringDer Anzeigename des YouTube-Kanals des gesperrten Nutzers. |
snippet.userBannedDetails.bannedUserDetails.profileImageUrl |
stringDer Avatar des YouTube-Kanals des gesperrten Nutzers. |
snippet.userBannedDetails.banType |
stringDie Art des Ausschlusses. Gültige Werte für diese Eigenschaft sind:
|
snippet.userBannedDetails.banDurationSeconds |
unsigned longDie Dauer des Ausschlusses. Diese Property ist nur vorhanden, wenn der Wert der Property snippet.userBannedDetails.banType temporary ist. |
snippet.memberMilestoneChatDetails |
objectDieses Objekt enthält Details zu einem Member Milestone event (Meilensteinereignis für Mitglieder). Ist nur vorhanden, wenn der Nachrichtentyp memberMilestoneChatEvent ist. |
snippet.memberMilestoneChatDetails.userComment |
stringDer Kommentar, den das Mitglied dieser Chatnachricht für treue Mitglieder hinzugefügt hat. Dieses Feld ist für Nachrichten ohne Kommentar des Mitglieds leer. |
snippet.memberMilestoneChatDetails.memberMonth |
unsigned integerDie Gesamtzahl der Monate (aufgerundet), in denen der Zuschauer Mitglied war und dadurch diese Chatnachricht für treue Mitglieder erhalten hat. Das ist die gleiche Anzahl an Monaten, die YouTube-Nutzern angezeigt wird. |
snippet.memberMilestoneChatDetails.memberLevelName |
stringDer Name der Mitgliedschaftsstufe, in der der Zuschauer Mitglied ist. Die Namen der Mitgliedschaftsstufen werden vom YouTube-Kanal festgelegt, der die Mitgliedschaft anbietet. In einigen Fällen wird dieses Feld nicht ausgefüllt. |
snippet.newSponsorDetails |
objectDieses Objekt enthält Details zum Ereignis „New Member Announcement“ (Ankündigung neuer Mitglieder). Wird nur festgelegt, wenn der Typ newSponsorEvent ist. „Mitglied“ ist der Begriff für „Sponsor“.
|
snippet.newSponsorDetails.memberLevelName |
stringDer Name der Mitgliedschaftsstufe, in der der Zuschauer Mitglied ist. Die Namen der Mitgliedschaftsstufen werden vom YouTube-Kanal festgelegt, der die Mitgliedschaft anbietet. In einigen Fällen ist dieses Feld nicht ausgefüllt. |
snippet.newSponsorDetails.isUpgrade |
boolGibt an, ob der Zuschauer gerade von einer niedrigeren Stufe aufgestiegen ist. Bei Zuschauern, die zum Zeitpunkt des Kaufs keine Mitglieder waren, ist der Feldwert false.
|
snippet.superChatDetails |
objectDieses Objekt enthält Details zu einem Super Chat-Ereignis. Ist nur vorhanden, wenn der Nachrichtentyp superChatEvent ist. |
snippet.superChatDetails.amountMicros |
unsigned longDer Kaufbetrag in Mikroeinheiten der Kaufwährung. Wenn der Kaufbetrag beispielsweise 1 $ beträgt, ist der Wert des Attributs snippet.amountMicros gleich 1000000. |
snippet.superChatDetails.currency |
stringDie Währung, in der der Kauf erfolgte. Der Wert ist ein ISO 4217-Währungscode. |
snippet.superChatDetails.amountDisplayString |
stringEin String wie $1.00, der den Kaufbetrag und die Währung enthält. Der String ist für die Anzeige für den Nutzer vorgesehen. |
snippet.superChatDetails.userComment |
stringDer Kommentar, den der Nutzer diesem Super Chat-Ereignis hinzugefügt hat. |
snippet.superChatDetails.tier |
unsigned integerDie Stufe für die kostenpflichtige Nachricht. In einer superChatEvent-Ressource enthält das Attribut snippet.messageType diesen Wert.Die Stufe basiert auf dem Betrag, der für den Kauf der Mitteilung ausgegeben wurde. Außerdem wird dadurch die Farbe bestimmt, mit der die Nachricht in der Benutzeroberfläche des Livechats hervorgehoben wird, die maximale Nachrichtenlänge und die Zeit, die die Nachricht im Ticker angepinnt ist. Die Super Chat-Stufen sind in der YouTube-Hilfe dokumentiert. Weitere Informationen findest du im aufklappbaren Abschnitt zu Super Chat-Kaufdetails. In dieser Liste ist die Stufe mit dem niedrigsten Kaufbetrag Stufe 1, die mit dem nächstniedrigsten Betrag Stufe 2 usw. |
snippet.superStickerDetails |
objectDieses Objekt enthält Details zu einem Super Sticker-Ereignis. Ist nur vorhanden, wenn der Nachrichtentyp superStickerEvent ist. |
snippet.superStickerDetails.superStickerMetadata |
objectDetails zum Super Sticker. |
snippet.superStickerDetails.superStickerMetadata.stickerId |
stringEine eindeutige ID, die das Stickerbild identifiziert. Das Bild wird nur als Teil der Super Sticker-Nachricht angezeigt, wenn Nutzer das Chatfenster auf YouTube aufrufen. Die Bild-URL ist jedoch nicht über die API verfügbar. In dieser CSV-Datei findest du eine Übersicht, welche Sticker-IDs zu welchen Super Stickern gehören. |
snippet.superStickerDetails.superStickerMetadata.altText |
stringEin Textstring, der den Sticker beschreibt. Das Feld snippet.superStickerDetails.superStickerMetadata.language gibt die Sprache des Textes an. Legen Sie beim Aufrufen der liveChatMessages.list-Methode den Wert des Parameters hl auf die ausgewählte Sprache für den Text fest. |
snippet.superStickerDetails.superStickerMetadata.language |
stringDie Sprache des snippet.superStickerDetails.superStickerMetadata.altText-Attributwerts. |
snippet.superStickerDetails.amountMicros |
unsigned longDer Kaufbetrag in Mikroeinheiten der Kaufwährung. Wenn der Kaufbetrag beispielsweise 1 $ beträgt, ist der Wert des Attributs snippet.amountMicros gleich 1000000. |
snippet.superStickerDetails.currency |
stringDie Währung, in der der Kauf erfolgte. Der Wert ist ein ISO 4217-Währungscode. |
snippet.superStickerDetails.amountDisplayString |
stringEin String wie $1.00, der den Kaufbetrag und die Währung enthält. Der String ist für die Anzeige für den Nutzer vorgesehen. |
snippet.superStickerDetails.tier |
unsigned integerDie Stufe für die kostenpflichtige Nachricht. In einer superChatEvent-Ressource enthält das Attribut snippet.messageType diesen Wert.Die Stufe basiert auf dem Betrag, der für den Kauf der Mitteilung ausgegeben wurde. Außerdem wird dadurch die Farbe bestimmt, mit der die Nachricht in der Livechat-Benutzeroberfläche hervorgehoben wird, die maximale Nachrichtenlänge und die Zeit, die die Nachricht im Ticker angepinnt ist. Die Super Chat-Stufen, die auch Super Sticker umfassen, sind in der YouTube-Hilfe dokumentiert. Weitere Informationen findest du im aufklappbaren Abschnitt zu Super Chat-Kaufdetails. In dieser Liste ist die Stufe mit dem niedrigsten Kaufbetrag Stufe 1, die mit dem nächstniedrigsten Betrag Stufe 2 usw. |
snippet.pollDetails |
objectDieses Objekt enthält Details zu einem Umfrageereignis. Ist nur vorhanden, wenn der Nachrichtentyp pollEvent ist. |
snippet.pollDetails.metadata |
objectDetails zum Umfrageereignis. |
snippet.pollDetails.metadata.options |
objectDie Optionen in der Live-Umfrage. |
snippet.pollDetails.metadata.options.optionText |
stringDer Text der Option für die Live-Umfrage. |
snippet.pollDetails.metadata.options.tally |
stringDie Anzahl der Stimmen für die Liveumfrage-Option. Die Anzahl ist nur vorhanden, wenn die API-Anfrage vom Kanalinhaber autorisiert wurde. |
snippet.pollDetails.metadata.questionText |
stringDer Text der Frage in der Live-Umfrage. |
snippet.pollDetails.metadata.status |
enumDer Status des Live-Umfrage-Events. Gültige Werte für diese Eigenschaft sind:
|
snippet.membershipGiftingDetails |
objectDieses Objekt enthält Details zu einem Ereignis, bei dem eine Mitgliedschaft verschenkt wurde. Sie ist nur vorhanden, wenn message type membershipGiftingEvent ist. |
snippet.membershipGiftingDetails.giftMembershipsCount |
integerDie Anzahl der vom Nutzer gekauften Geschenkabos. |
snippet.membershipGiftingDetails.giftMembershipsLevelName |
stringDer Name der Stufe der vom Nutzer gekauften verschenkten Mitgliedschaften. Die Namen der Mitgliedschaftsstufen werden vom YouTube-Kanal festgelegt, der die Mitgliedschaft anbietet. In einigen Fällen ist dieses Feld nicht ausgefüllt. |
snippet.giftMembershipReceivedDetails |
objectDieses Objekt enthält Details zu einem Ereignis vom Typ „Geschenkte Mitgliedschaft erhalten“. Sie ist nur vorhanden, wenn message type giftMembershipReceivedEvent ist. |
snippet.giftMembershipReceivedDetails.memberLevelName |
stringDer Name der Mitgliedschaftsstufe, in der der Zuschauer Mitglied ist. Das entspricht dem snippet.membershipGiftingDetails.giftMembershipsLevelName der zugehörigen Nachricht zum Verschenken von Mitgliedschaften. Die Namen der Mitgliedschaftsstufen werden vom YouTube-Kanal festgelegt, der die Mitgliedschaft anbietet. In einigen Fällen ist dieses Feld nicht ausgefüllt. |
snippet.giftMembershipReceivedDetails.gifterChannelId |
stringDie ID des Nutzers, der die Mitgliedschaft verschenkt hat. Das entspricht dem snippet.authorChannelId der zugehörigen Nachricht zum Verschenken von Mitgliedschaften. |
snippet.giftMembershipReceivedDetails.associatedMembershipGiftingMessageId |
stringDie ID der Nachricht zum Verschenken von Mitgliedschaften, die sich auf diese geschenkte Mitgliedschaft bezieht. Diese ID bezieht sich immer auf eine Nachricht, deren type membershipGiftingEvent ist. |
authorDetails |
objectDas authorDetails-Objekt enthält zusätzliche Details zum Nutzer, der diese Nachricht gepostet hat. |
authorDetails.channelId |
stringDie YouTube-Kanal-ID des Autors. |
authorDetails.channelUrl |
stringDie URL des YouTube-Kanals des Autors. |
authorDetails.displayName |
stringDer Anzeigename des YouTube-Kanals des Autors. |
authorDetails.profileImageUrl |
stringDie Avatar-URL des YouTube-Kanals des Autors. |
authorDetails.isVerified |
booleanDieser Wert gibt an, ob die Identität des Autors von YouTube bestätigt wurde. |
authorDetails.isChatOwner |
booleanDieser Wert gibt an, ob der Autor der Inhaber des Livechats ist. |
authorDetails.isChatSponsor |
booleanDieser Wert gibt an, ob der Autor ein Sponsor des Livechats ist. |
authorDetails.isChatModerator |
booleanDieser Wert gibt an, ob der Autor ein Moderator des Livechats ist. |