LiveChatMessages

Resource liveChatMessage mewakili pesan chat dalam live chat YouTube. Resource ini dapat berisi detail tentang beberapa jenis pesan, termasuk pesan teks yang baru diposting atau acara Fan Funding.

Fitur live chat diaktifkan secara default untuk live streaming dan tersedia saat live streaming aktif. (Setelah acara berakhir, live chat tidak lagi tersedia untuk acara tersebut.)

Metode

API ini mendukung metode berikut untuk resource liveChatMessages:

list
Mencantumkan pesan live chat untuk chat tertentu. Coba sekarang.
sisipkan
Menambahkan pesan ke live chat. Coba sekarang.
hapus
Menghapus pesan chat. Permintaan API harus mendapatkan izin dari pemilik channel atau moderator live chat. Coba sekarang.

Representasi resource

Struktur JSON berikut menunjukkan format resource liveChatMessages:

{
  "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
    },
    "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
  }
}

Properti

Tabel berikut menentukan properti yang muncul di resource ini:

Properti
kind string
Mengidentifikasi jenis resource API. Nilainya akan berupa youtube#liveChatMessage.
etag etag
Etag referensi ini.
id string
ID yang ditetapkan YouTube untuk mengidentifikasi pesan secara unik.
snippet object
Objek snippet berisi detail inti tentang pesan chat.
snippet.type string
Jenis pesan. Properti ini selalu ada, dan nilainya menentukan kolom yang ada di resource.

Nilai yang valid untuk properti ini adalah:
  • chatEndedEvent – Chat telah berakhir dan pesan lain tidak dapat disisipkan setelah ini. Hal ini akan terjadi secara alami beberapa saat setelah siaran berakhir. Perlu diperhatikan bahwa jenis pesan ini saat ini tidak dikirim untuk live chat di siaran default channel.
  • messageDeletedEvent – Pesan telah dihapus oleh moderator. Kolom author berisi detail moderator. Acara ini tidak memiliki konten tampilan apa pun.
  • sponsorOnlyModeEndedEvent – Chat tidak lagi dalam mode khusus sponsor, yang berarti pengguna yang bukan sponsor kini dapat mengirim pesan. Acara ini tidak memiliki konten tampilan apa pun.
  • sponsorOnlyModeStartedEvent – Chat telah memasuki mode khusus sponsor, yang berarti hanya sponsor yang dapat mengirim pesan. Acara ini tidak memiliki konten tampilan.
  • newSponsorEvent – Pengguna baru telah mensponsori channel yang memiliki live chat. Kolom author berisi detail sponsor baru.
  • memberMilestoneChatEvent – Pengguna telah mengirim Chat Pencapaian Pelanggan.
  • superChatEvent – Pengguna telah membeli Super Chat.
  • superStickerEvent – Pengguna telah membeli Super Stickers.
  • textMessageEvent – Pengguna telah mengirim SMS.
  • tombstone – Tombstone menandakan bahwa pesan sebelumnya ada dengan ID ini dan waktu publikasi, tetapi telah dihapus. Pesan tidak akan dikirim setelah pesan dihapus, tetapi ditampilkan untuk menunjukkan lokasi pesan sebelum dihapus. Hanya kolom snippet.liveChatId, snippet.type, dan snippet.publishedAt yang ada dalam jenis pesan ini.
  • userBannedEvent – Pengguna telah diblokir oleh moderator. Kolom author berisi detail moderator.
  • membershipGiftingEvent – Pengguna telah membeli langganan untuk penonton lain.
  • giftMembershipReceivedEvent – Pengguna telah menerima hadiah langganan.
snippet.liveChatId string
ID yang secara unik mengidentifikasi live chat yang terkait dengan pesan. ID live chat yang terkait dengan siaran ditampilkan di properti snippet.liveChatId resource liveBroadcast.
snippet.authorChannelId string
ID pengguna yang menulis pesan. Kolom ini hanya diisi untuk jenis pesan berikut:
  • Jika jenis pesan adalah textMessageEvent, nilai properti akan mengidentifikasi pengguna yang menulis pesan tersebut.
  • Jika jenis pesan adalah fanFundingEvent, nilai properti akan mengidentifikasi pengguna yang mendanai siaran.
  • Jika jenis pesan adalah messageDeletedEvent, nilai properti akan mengidentifikasi moderator yang menghapus pesan tersebut.
  • Jika jenis pesannya adalah newSponsorEvent, nilai properti mengidentifikasi pengguna yang baru saja menjadi sponsor.
  • Jika jenis pesan adalah memberMilestoneChatEvent, nilai properti akan mengidentifikasi anggota yang mengirim pesan.
  • Jika jenis pesan adalah userBannedEvent, nilai properti akan mengidentifikasi moderator yang memblokir pengguna.
  • Jika jenis pesannya adalah membershipGiftingEvent, nilai properti akan mengidentifikasi pengguna yang melakukan pembelian hadiah langganan.
  • Jika jenis pesannya adalah giftMembershipReceivedEvent, nilai properti akan mengidentifikasi pengguna yang menerima hadiah langganan.
snippet.publishedAt datetime
Tanggal dan waktu saat pesan pertama kali dipublikasikan. Nilai ditentukan dalam format ISO 8601 (YYYY-MM-DDThh:mm:ss.sZ).
snippet.hasDisplayContent boolean
Menunjukkan apakah pesan memiliki konten tampilan yang harus ditampilkan kepada pengguna.
snippet.displayMessage string
Berisi string yang ditampilkan kepada pengguna. Kolom ini tidak ada jika jenis pesan adalah chatEndedEvent atau tombstone.
snippet.fanFundingEventDetails object
Catatan: Objek ini dan properti turunannya sudah tidak digunakan lagi. Mulai 28 Februari 2017, resource liveChatMessage tidak lagi menampilkan detail acara Fan Funding.

Objek ini berisi detail tentang acara pendanaan. Pesan ini hanya ada jika jenis pesan adalah fanFundingEvent.
snippet.fanFundingEventDetails.amountMicros unsigned long
Catatan: Properti ini tidak digunakan lagi.

Jumlah dana.
snippet.fanFundingEventDetails.currency string
Catatan: Properti ini sudah tidak digunakan lagi.

Mata uang yang digunakan untuk melakukan pendanaan.
snippet.fanFundingEventDetails.amountDisplayString string
Catatan: Properti ini sudah tidak digunakan lagi.

String yang dirender yang menampilkan jumlah dana dan mata uang kepada pengguna.
snippet.fanFundingEventDetails.userComment string
Catatan: Properti ini tidak digunakan lagi.

Komentar yang ditambahkan oleh pengguna ke acara fan funding ini.
snippet.textMessageDetails object
Objek ini berisi detail tentang pesan teks. Pesan ini hanya ada jika jenis pesan adalah textMessageEvent.
snippet.textMessageDetails.messageText string
Pesan pengguna.
snippet.messageDeletedDetails object
Objek ini berisi detail tentang pesan yang dihapus oleh moderator chat atau pemilik channel live streaming. Pesan ini hanya ada jika jenis pesan adalah messageDeletedEvent.
snippet.messageDeletedDetails.deletedMessageId string
ID yang secara unik mengidentifikasi pesan yang dihapus. Nilainya sama dengan nilai properti id pesan teks asli. Misalnya, jika textMessageEvent memiliki nilai properti id sebesar 123, dan pesan tersebut kemudian dihapus, nilai snippet.messageDeletedDetails.deletedMessageId akan menjadi 123 untuk pesan tersebut.

Jika Anda menyimpan pesan chat ke dalam cache setelah mengambilnya, gunakan nilai properti ini untuk mengidentifikasi pesan yang seharusnya tidak ditampilkan lagi.
snippet.userBannedDetails object
Objek ini berisi detail tentang pengguna yang telah diblokir dari chat. Halaman ini juga berisi detail tentang pencekalan itu sendiri. Pengguna dapat diblokir dari chat secara permanen atau sementara.
snippet.userBannedDetails.bannedUserDetails object
Objek ini berisi informasi tentang pengguna yang diblokir.
snippet.userBannedDetails.bannedUserDetails.channelId string
ID channel YouTube milik pengguna yang diblokir.
snippet.userBannedDetails.bannedUserDetails.channelUrl string
URL channel YouTube milik pengguna yang diblokir.
snippet.userBannedDetails.bannedUserDetails.displayName string
Nama tampilan channel YouTube pengguna yang diblokir.
snippet.userBannedDetails.bannedUserDetails.profileImageUrl string
Avatar channel YouTube pengguna yang diblokir.
snippet.userBannedDetails.banType string
Jenis pemblokiran. Nilai yang valid untuk properti ini adalah:
  • permanen
  • sementara
snippet.userBannedDetails.banDurationSeconds unsigned long
Durasi pemblokiran. Properti ini hanya ada jika nilai properti snippet.userBannedDetails.banType adalah temporary.
snippet.memberMilestoneChatDetails object
Objek ini berisi detail tentang peristiwa Pencapaian Pelanggan. Pesan ini hanya ada jika jenis pesan adalah memberMilestoneChatEvent.
snippet.memberMilestoneChatDetails.userComment string
Komentar yang ditambahkan oleh pelanggan ke Chat Pencapaian Pelanggan ini. Bidang ini kosong untuk pesan tanpa komentar dari anggota.
snippet.memberMilestoneChatDetails.memberMonth unsigned integer
Jumlah total bulan (dibulatkan) penonton telah menjadi pelanggan dan memberi mereka Chat Pencapaian Pelanggan ini. Jumlah bulan ini sama dengan yang ditampilkan kepada pengguna YouTube.
snippet.memberMilestoneChatDetails.memberLevelName string
Nama Level tempat penonton menjadi pelanggan. Nama Level ditentukan oleh channel YouTube yang menawarkan Langganan. Terkadang, kolom ini tidak diisi.
snippet.newSponsorDetails object
Objek ini berisi detail tentang acara Pengumuman Anggota Baru. Ini hanya disetel jika jenisnya newSponsorEvent. Harap diperhatikan bahwa "anggota" adalah istilah baru untuk "sponsor".
snippet.newSponsorDetails.memberLevelName string
Nama Level tempat penonton menjadi pelanggan. Nama Level ditentukan oleh channel YouTube yang menawarkan Langganan. Terkadang, kolom ini tidak diisi.
snippet.newSponsorDetails.isUpgrade bool
Menunjukkan apakah penonton baru saja mengupgrade dari Level lebih rendah. Untuk penonton yang bukan pelanggan pada saat pembelian, nilai kolomnya adalah false.
snippet.superChatDetails object
Objek ini berisi detail tentang peristiwa Super Chat. Pesan ini hanya ada jika jenis pesan adalah superChatEvent.
snippet.superChatDetails.amountMicros unsigned long
Jumlah pembelian, dalam mikro mata uang pembelian. Misalnya, jika jumlah pembelian adalah satu dolar, nilai properti snippet.amountMicros adalah 1000000.
snippet.superChatDetails.currency string
Mata uang yang digunakan untuk melakukan pembelian. Nilainya berupa kode mata uang ISO 4217.
snippet.superChatDetails.amountDisplayString string
String, seperti $1.00, yang berisi jumlah pembelian dan mata uang. String ini dimaksudkan untuk ditampilkan kepada pengguna.
snippet.superChatDetails.userComment string
Komentar yang ditambahkan oleh pengguna ke acara Super Chat ini.
snippet.superChatDetails.tier unsigned integer
Tingkat untuk pesan berbayar. Perhatikan bahwa di resource superChatEvent, properti snippet.messageType berisi nilai ini.

Tingkat didasarkan pada jumlah uang yang dibelanjakan untuk membeli pesan. Fitur ini juga menentukan warna yang digunakan untuk menandai pesan di UI live chat, panjang pesan maksimum, dan durasi pesan untuk disematkan di ticker.

Tingkat Super Chat didokumentasikan di Pusat Bantuan YouTube. (Lihat bagian yang dapat diluaskan tentang detail pembelian Super Chat.) Dalam daftar tersebut, tingkat dengan jumlah pembelian terendah adalah tingkat 1, jumlah terendah berikutnya adalah tingkat 2, dan seterusnya.
snippet.superStickerDetails object
Objek ini berisi detail tentang peristiwa Super Stickers. Pesan ini hanya ada jika jenis pesan adalah superStickerEvent.
snippet.superStickerDetails.superStickerMetadata object
Detail tentang Super Stickers.
snippet.superStickerDetails.superStickerMetadata.stickerId string
ID unik yang mengidentifikasi gambar stiker. Perhatikan bahwa gambar hanya ditampilkan sebagai bagian dari pesan Super Stickers saat pengguna melihat jendela chat di YouTube. Namun, URL gambar tidak tersedia melalui API. Sebagai referensi, Anda dapat menemukan ID Stiker yang berkaitan dengan Super Stickers di file CSV ini.
snippet.superStickerDetails.superStickerMetadata.altText string
String teks yang mendeskripsikan stiker. Kolom snippet.superStickerDetails.superStickerMetadata.language mengidentifikasi bahasa teks. Saat memanggil metode liveChatMessages.list, setel nilai parameter hl ke bahasa yang diinginkan untuk teks.
snippet.superStickerDetails.superStickerMetadata.language string
Bahasa dari nilai properti snippet.superStickerDetails.superStickerMetadata.altText.
snippet.superStickerDetails.amountMicros unsigned long
Jumlah pembelian, dalam mikro mata uang pembelian. Misalnya, jika jumlah pembelian adalah satu dolar, nilai properti snippet.amountMicros adalah 1000000.
snippet.superStickerDetails.currency string
Mata uang yang digunakan untuk melakukan pembelian. Nilainya berupa kode mata uang ISO 4217.
snippet.superStickerDetails.amountDisplayString string
String, seperti $1.00, yang berisi jumlah pembelian dan mata uang. String ini dimaksudkan untuk ditampilkan kepada pengguna.
snippet.superStickerDetails.tier unsigned integer
Tingkat untuk pesan berbayar. Perhatikan bahwa di resource superChatEvent, properti snippet.messageType berisi nilai ini.

Tingkat didasarkan pada jumlah uang yang dibelanjakan untuk membeli pesan. Fitur ini juga menentukan warna yang digunakan untuk menandai pesan di UI live chat, panjang pesan maksimum, dan durasi pesan disematkan di ticker.

Tingkat Super Chat, yang juga mencakup Super Stickers, didokumentasikan di Pusat Bantuan YouTube. (Lihat bagian yang dapat diluaskan tentang detail pembelian Super Chat.) Dalam daftar tersebut, tingkat dengan jumlah pembelian terendah adalah tingkat 1, jumlah terendah berikutnya adalah tingkat 2, dan seterusnya.
snippet.membershipGiftingDetails object
Objek ini berisi detail tentang acara Hadiah Langganan. Elemen ini hanya ada jika message type adalah membershipGiftingEvent.
snippet.membershipGiftingDetails.giftMembershipsCount integer
Jumlah hadiah langganan yang dibeli oleh pengguna.
snippet.membershipGiftingDetails.giftMembershipsLevelName string
Nama Level hadiah langganan yang dibeli oleh pengguna. Nama level ditentukan oleh channel YouTube yang menawarkan Langganan. Terkadang, kolom ini tidak diisi.
snippet.giftMembershipReceivedDetails object
Objek ini berisi detail tentang peristiwa Hadiah Langganan Diterima. Elemen ini hanya ada jika message type adalah giftMembershipReceivedEvent.
snippet.giftMembershipReceivedDetails.memberLevelName string
Nama Level tempat penonton menjadi pelanggan. Nilai ini cocok dengan snippet.membershipGiftingDetails.giftMembershipsLevelName pesan hadiah langganan terkait. Nama level ditentukan oleh channel YouTube yang menawarkan Langganan. Terkadang, kolom ini tidak diisi.
snippet.giftMembershipReceivedDetails.gifterChannelId string
ID pengguna yang melakukan pembelian hadiah langganan. Nilai ini cocok dengan snippet.authorChannelId pesan hadiah langganan terkait.
snippet.giftMembershipReceivedDetails.associatedMembershipGiftingMessageId string
ID pesan hadiah langganan yang terkait dengan hadiah langganan ini. ID ini akan selalu merujuk ke pesan yang type-nya adalah membershipGiftingEvent.
authorDetails object
Objek authorDetails berisi detail tambahan tentang pengguna yang memposting pesan ini.
authorDetails.channelId string
ID channel YouTube penulis.
authorDetails.channelUrl string
URL channel YouTube penulis.
authorDetails.displayName string
Nama tampilan channel YouTube penulis.
authorDetails.profileImageUrl string
URL avatar channel YouTube penulis.
authorDetails.isVerified boolean
Nilai ini menunjukkan apakah identitas penulis telah diverifikasi oleh YouTube atau belum.
authorDetails.isChatOwner boolean
Nilai ini menunjukkan apakah penulis adalah pemilik live chat.
authorDetails.isChatSponsor boolean
Nilai ini menunjukkan apakah penulis adalah sponsor live chat.
authorDetails.isChatModerator boolean
Nilai ini menunjukkan apakah penulis adalah moderator live chat.