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 selama live streaming sedang berlangsung. (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 atau polling ke live chat. Coba sekarang.
transition
Mentransisikan status pesan langsung. Coba sekarang.
hapus
Menghapus pesan chat. Permintaan API harus diizinkan oleh 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
    },
    "pollDetails": {
      "metadata": {
        "options": {
          "optionText": 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
  },
}

Properti

Tabel berikut menentukan properti yang muncul di resource ini:

Properti
kind string
Mengidentifikasi jenis resource API. Nilainya adalah youtube#liveChatMessage.
etag etag
Etag resource 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 mana yang ada dalam resource.

Nilai yang valid untuk properti ini adalah:
  • chatEndedEvent – Chat telah berakhir dan tidak ada lagi pesan yang dapat disisipkan setelah chat ini. Ini akan terjadi secara alami beberapa saat setelah siaran berakhir. Jenis pesan ini tidak dikirim untuk live chat pada 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 tersedia dalam mode khusus sponsor, yang berarti pengguna yang bukan sponsor kini dapat mengirim pesan. Acara ini tidak memiliki konten tampilan apa pun.
  • sponsorOnlyModeStartedEvent – Chat sekarang beralih ke 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 pesan teks.
  • tombstone – Tombstone menandakan bahwa sebuah pesan pernah ada dengan ID dan waktu publikasi ini, tetapi sudah dihapus. Pesan ini tidak dikirim setelah pesan dihapus, melainkan 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.
  • pollDetails – Pengguna telah membuat polling live.
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 pesannya adalah textMessageEvent, nilai properti akan mengidentifikasi pengguna yang menulis pesan tersebut.
  • Jika jenis pesannya adalah fanFundingEvent, nilai properti akan mengidentifikasi pengguna yang mendanai siaran.
  • Jika jenis pesan adalah messageDeletedEvent, nilai properti akan mengidentifikasi moderator yang menghapus pesan.
  • 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 mengidentifikasi moderator yang memblokir pengguna.
  • Jika jenis pesannya adalah membershipGiftingEvent, nilai properti akan mengidentifikasi pengguna yang melakukan pembelian hadiah langganan.
  • Jika jenis pesan adalah giftMembershipReceivedEvent, nilai properti akan mengidentifikasi pengguna yang menerima hadiah langganan.
  • Jika jenis pesan adalah pollEvent, nilai properti mengidentifikasi pengguna yang membuat polling langsung.
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 tidak digunakan lagi. Mulai 28 Februari 2017, liveChatMessage resource tidak akan lagi menampilkan detail untuk acara Fan Funding.

Objek ini berisi detail tentang acara pendanaan. Kolom 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 tidak digunakan lagi.

Mata uang yang digunakan untuk membuat dana.
snippet.fanFundingEventDetails.amountDisplayString string
Catatan: Properti ini 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 ditambahkan oleh pengguna ke acara fan funding ini.
snippet.textMessageDetails object
Objek ini berisi detail tentang pesan teks. Kolom 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. Kolom 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, yaitu 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 larangan 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 pengguna yang diblokir.
snippet.userBannedDetails.bannedUserDetails.channelUrl string
URL channel YouTube 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. Kolom ini hanya ada jika jenis pesan adalah memberMilestoneChatEvent.
snippet.memberMilestoneChatDetails.userComment string
Komentar yang ditambahkan oleh pelanggan ke Chat Pencapaian Pelanggan ini. Kolom ini kosong untuk pesan tanpa komentar dari anggota.
snippet.memberMilestoneChatDetails.memberMonth unsigned integer
Jumlah total bulan (dibulatkan) saat penonton telah menjadi pelanggan dan memberi mereka Chat Pencapaian Pelanggan ini. Ini adalah jumlah bulan yang 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 terisi.
snippet.newSponsorDetails object
Objek ini berisi detail tentang acara Pengumuman Anggota Baru. Ini hanya ditetapkan jika jenisnya newSponsorEvent. "Anggota" adalah istilah 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 yang lebih rendah. Untuk penonton yang bukan pelanggan pada saat pembelian, nilai kolomnya adalah false.
snippet.superChatDetails object
Objek ini berisi detail tentang acara Super Chat. Kolom 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 adalah 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 dalam resource superChatEvent, properti snippet.messageType berisi nilai ini.

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

Tingkatan 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 acara Super Stickers. Kolom ini hanya ada jika jenis pesan adalah superStickerEvent.
snippet.superStickerDetails.superStickerMetadata object
Detail mengenai Super Stickers.
snippet.superStickerDetails.superStickerMetadata.stickerId string
ID unik yang mengidentifikasi gambar stiker. Perlu diperhatikan bahwa gambar hanya ditampilkan sebagai bagian dari pesan Super Stickers jika pengguna melihat jendela chat di YouTube. Namun, URL gambar tidak tersedia menggunakan API. Hanya untuk referensi, Anda dapat menemukan ID Stiker mana yang terkait 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 dipilih untuk teks.
snippet.superStickerDetails.superStickerMetadata.language string
Bahasa 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 adalah 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 dalam resource superChatEvent, properti snippet.messageType berisi nilai ini.

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

Tingkatan Super Chat, yang juga meliputi 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.pollDetails object
Objek ini berisi detail tentang acara polling. Kolom ini hanya ada jika jenis pesan adalah pollEvent.
snippet.pollDetails.metadata object
Detail tentang acara polling.
snippet.pollDetails.metadata.options object
Opsi dalam polling live.
snippet.pollDetails.metadata.options.optionText string
Teks opsi polling live.
snippet.pollDetails.metadata.options.questionText string
Teks pertanyaan polling live.
snippet.pollDetails.metadata.status enum
Status acara polling live. Nilai yang valid untuk properti ini adalah:
  • unknown
  • active
  • closed
snippet.membershipGiftingDetails object
Objek ini berisi detail tentang acara Hadiah Langganan. Atribut 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 Keanggotaan Diterima. Atribut 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 yang 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 yang terkait.
snippet.giftMembershipReceivedDetails.associatedMembershipGiftingMessageId string
ID pesan hadiah langganan yang terkait dengan hadiah langganan ini. ID ini akan selalu merujuk ke pesan yang type 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.