@fidzzhost/baileys v25.9.2
Baileys - WhatsApp API

Baileys adalah library TypeScript berbasis WebSocket untuk berinteraksi dengan WhatsApp Web API.
Penggunaan
Panduan terbaru telah dipublikasikan di https://baileys.wiki.
Penyangkalan
Proyek ini tidak berafiliasi, tidak berasosiasi, tidak diotorisasi, tidak didukung, dan tidak memiliki koneksi resmi dengan WhatsApp maupun anak perusahaan atau afiliasinya.
Situs resmi WhatsApp dapat ditemukan di whatsapp.com.
"WhatsApp" serta nama-nama, merek dagang, lambang, dan gambar terkait adalah hak milik terdaftar dari pemilik masing-masing.
Para pengelola Baileys tidak mendukung penggunaan aplikasi ini untuk praktik yang melanggar Ketentuan Layanan WhatsApp.
Kami menyerukan kepada setiap pengguna untuk menggunakan aplikasi ini secara bertanggung jawab dan sesuai tujuan awal pengembangannya.
Gunakan atas kebijakan pribadi masing-masing. Jangan gunakan untuk spam. Kami tidak mendukung penggunaan untuk stalkerware, pesan massal, ataupun automasi pesan yang bersifat mengganggu.
Lisensi
Proyek ini menggunakan lisensi MIT License, dan merupakan karya turunan dari Baileys oleh Rajeh Taher/WhiskeySockets.
Dengan menggunakan proyek ini, Anda dianggap telah menyetujui ketentuan lisensi tersebut.
Tentang Modifikasi
Proyek ini merupakan hasil modifikasi besar dari Baileys, sebuah library open-source WhatsApp Web API yang awalnya ditulis dalam TypeScript dan menggunakan format ECMAScript Module (ESM).
Modifikasi ini difokuskan untuk membuat versi yang sepenuhnya berbasis JavaScript murni dengan dukungan CommonJS (CJS). Dengan pendekatan ini, library menjadi lebih fleksibel dan mudah diintegrasikan ke dalam berbagai jenis runtime Node.js tanpa memerlukan proses transpilasi atau konfigurasi tambahan seperti "type": "module".
Poin Utama Modifikasi:
- Konversi total dari TypeScript ke JavaScript, untuk menyederhanakan proses pengembangan, debugging, dan distribusi.
- Penggunaan format module CommonJS (CJS) secara konsisten agar dapat digunakan di lingkungan Node.js manapun, termasuk proyek lama.
- Kompatibel dengan modul-modul ESM modern, melalui penggunaan dynamic import (
await import()), tanpa mengorbankan arsitektur utama CJS. - Dukungan penuh terhadap tombol interaktif
- Penyederhanaan berbagai struktur internal seperti manajemen sesi, koneksi, katalog produk, dan optimasi format media.
- File
proto(WAProto) telah di-compile secara statis menjadi JavaScript untuk menghindari dependensi waktu jalan terhadap parser.proto.
Instalasi
Gunakan salah satu manajer paket berikut untuk menginstal versi stabil:
npm install @fidzzhost/baileysyarn add @fidzzhost/baileyspnpm add @fidzzhost/baileysInformasi
Paket ini membutuhkan Node.js versi 20 atau lebih tinggi untuk berjalan.
Proyek ini secara eksplisit ditujukan untuk lingkungan modern dan tidak mendukung Node versi lama. Dukungan akan selalu mengikuti versi LTS terbaru dari Node.js untuk menjaga performa dan kompatibilitas dengan ekosistem terbaru.

Copyright © 2024 - 2025 FidzzHost
Menghubungkan Akun
Baileys mendukung koneksi ke WhatsApp melalui API multi-perangkat.
Kamu bisa menghubungkan akun dengan dua metode utama: Kode QR atau Kode Pairing.
Menghubungkan dengan Kode QR (ESM)
!TIP
Kamu bisa mengatur nama browser yang tampil di perangkat WhatsApp dengan menggunakan konstantaBrowsers.
Lihat daftar nama browser yang tersedia di dokumentasi:
https://baileys.whiskeysockets.io/types/BrowsersMap.html
import makeWASocket, { Browsers } from '@fidzzhost/baileys'
const sock = makeWASocket({
browser: Browsers.ubuntu('Safari'),
printQRInTerminal: true
})Jika koneksi berhasil, kode QR akan muncul di terminal.
Pindai kode tersebut menggunakan aplikasi WhatsApp di ponsel kamu untuk login.
Menghubungkan dengan Kode QR (CommonJS)
Jika kamu menggunakan Node.js dengan format CommonJS (require), gunakan contoh berikut:
const { default: makeWASocket, Browsers } = require('@fidzzhost/baileys')
const sock = makeWASocket({
browser: Browsers.ubuntu('Safari'),
printQRInTerminal: true
})Pastikan file kamu tidak menggunakan
"type": "module"dipackage.jsonagar mode CJS dapat berjalan dengan benar.
Memulai Socket dengan Kode Pairing
!IMPORTANT
Pairing Code bukan API Mobile. Ini adalah metode untuk terhubung ke WhatsApp Web tanpa memindai kode QR.
Metode ini hanya memungkinkan koneksi dari satu perangkat saja.
Lihat penjelasan resmi di sini
Nomor telepon tidak boleh menggunakan karakter seperti +, () atau -.
Gunakan hanya angka dan pastikan menyertakan kode negara.
import makeWASocket from '@fidzzhost/baileys'
const sock = makeWASocket({
// Konfigurasi tambahan dapat disesuaikan di sini
printQRInTerminal: false // Harus disetel ke false untuk pairing
})
if (!sock.authState.creds.registered) {
const number = '628XXXXXXXXX'
const code = await sock.requestPairingCode(number)
// atau gunakan pairing code kustom:
// const code = await sock.requestPairingCode(number, 'CODEZUMI')
console.log(code)
}Setelah pairing code berhasil dibuat, masukkan kode tersebut melalui WhatsApp Web seperti biasa untuk menyelesaikan proses autentikasi.
Menerima Riwayat Pesan Lengkap
- Atur opsi
syncFullHistoryketrue - Secara default, Baileys menggunakan konfigurasi browser Chrome.
Jika kamu ingin meniru koneksi desktop (dan menerima riwayat pesan yang lebih banyak), gunakan konfigurasi browser seperti contoh di bawah ini.
import makeWASocket, { Browsers } from '@fidzzhost/baileys'
const sock = makeWASocket({
...otherOpts,
// Kamu dapat menggunakan Windows, Ubuntu, dll.
browser: Browsers.ubuntu('Safari'),
syncFullHistory: true
})!NOTE
WhatsApp hanya mengirim riwayat pesan penuh jika koneksi yang digunakan menyerupai perangkat desktop resmi (WhatsApp Web).
Konfigurasi browser yang tepat sangat berpengaruh pada jumlah riwayat yang dikirim.
Catatan Penting Mengenai Konfigurasi Socket
Caching Metadata Grup (Direkomendasikan)
- Jika kamu menggunakan Baileys untuk mengelola grup, sangat disarankan untuk mengatur opsi
cachedGroupMetadatapada konfigurasi socket kamu. - Kamu perlu mengimplementasikan sistem cache sederhana seperti contoh berikut:
import makeWASocket from '@fidzzhost/baileys'
import NodeCache from 'node-cache'
const groupCache = new NodeCache({ stdTTL: 5 * 60, useClones: false })
const sock = makeWASocket({
cachedGroupMetadata: async (jid) => groupCache.get(jid)
})
sock.ev.on('groups.update', async ([event]) => {
const metadata = await sock.groupMetadata(event.id)
groupCache.set(event.id, metadata)
})
sock.ev.on('group-participants.update', async (event) => {
const metadata = await sock.groupMetadata(event.id)
groupCache.set(event.id, metadata)
})Dengan menggunakan cache ini, Kamu dapat mengurangi jumlah permintaan metadata yang berulang dan mempercepat proses interaksi bot dengan grup secara signifikan.
!NOTE
Kamu bisa menggantiNodeCachedengan database lain seperti Redis atau in-memory store milik framework kamu sendiri.
Konfigurasi Lengkap Socket
Kamu dapat mengatur koneksi Baileys dengan memberikan objek SocketConfig.
Berikut adalah daftar lengkap properti yang bisa Kamu sesuaikan beserta penjelasannya:
Struktur SocketConfig (dengan penjelasan)
waWebSocketUrl
URL WebSocket yang digunakan untuk terhubung ke WhatsApp (default:wss://...)connectTimeoutMs
Waktu maksimal (dalam milidetik) untuk mencoba koneksi sebelum gagal.defaultQueryTimeoutMs
Timeout default untuk permintaan/query. Jikaundefined, maka tidak ada timeout.keepAliveIntervalMs
Interval ping-pong antar koneksi WebSocket untuk menjaga koneksi tetap hidup.agent(opsional)
Proxy agent jika kamu menggunakan koneksi melalui proxy.logger
Logger yang digunakan, biasanya daripino.version
Versi WhatsApp Web yang digunakan untuk koneksi (gunakanfetchLatestBaileysVersion()untuk mendapatkan versi terbaru).browser
Konfigurasi browser yang ditiru oleh Baileys (lihatBrowsers.ubuntu(),Browsers.macOS(), dll).fetchAgent(opsional)
Agent untuk permintaan upload/download media.printQRInTerminal
Jikatrue, maka kode QR akan dicetak di terminal.emitOwnEvents
Jikatrue, event dari aksi sendiri (seperti mengirim pesan) juga akan dipancarkan oleh event handler.mediaCache(opsional)
Cache media agar tidak perlu upload ulang media yang sama.customUploadHosts
Daftar host untuk upload media secara manual.retryRequestDelayMs
Waktu jeda antara retry jika permintaan gagal.qrTimeout(opsional)
Waktu tunggu maksimal untuk menampilkan kode QR baru.auth
Objek autentikasi yang digunakan untuk menyimpan dan memuat sesi login WhatsApp.shouldSyncHistoryMessage
Fungsi kontrol untuk memilih jenis riwayat pesan yang ingin disinkronisasi dari perangkat utama.transactionOpts
Opsi untuk manajemen transaksi penyimpanan Signal key.userDevicesCache(opsional)
Cache daftar perangkat pengguna.markOnlineOnConnect
Jikatrue, akun akan terlihat online setiap kali koneksi berhasil.
Jikafalse, maka WhatsApp di ponsel tetap bisa menerima notifikasi.msgRetryCounterMap(opsional)
Penyimpanan jumlah percobaan retry pengiriman pesan.linkPreviewImageThumbnailWidth
Lebar thumbnail gambar pada link preview.syncFullHistory
Jikatrue, Baileys akan meminta riwayat pesan penuh (sangat disarankan untuk akun baru).fireInitQueries
Jikatrue, Baileys akan menjalankan kueri inisialisasi otomatis saat koneksi dimulai.generateHighQualityLinkPreview
Jikatrue, Baileys akan mengunggah thumbnail berkualitas tinggi untuk preview link.options
Opsi tambahan untuk permintaan HTTP/axios (misalnya: timeout, headers, dll).getMessage
Fungsi untuk mengambil ulang isi pesan dari penyimpanan lokal kamu.
Digunakan saat pengiriman ulang pesan gagal atau saat dekripsi polling suara.
!INFO
Kamu tidak perlu mengatur semua properti di atas.
Cukup sesuaikan yang kamu butuhkan, sisanya akan menggunakan nilai default dari Baileys.
Menangani Event
- Baileys menggunakan pola
EventEmitteruntuk menangani berbagai peristiwa (event).
Seluruh event telah diketik (typed) dengan baik, sehingga editor seperti VS Code akan memberikan dukungan Intellisense secara optimal.
!IMPORTANT
Daftar lengkap event tersedia di sini.
Sangat penting untuk memahami setiap event yang bisa digunakan.
Contoh penggunaan listener untuk menangani pesan masuk:
import makeWASocket from '@fidzzhost/baileys'
const sock = makeWASocket()
sock.ev.on('messages.upsert', ({ messages }) => {
console.log('Pesan diterima:', messages)
})Menangani Event
Baileys menggunakan sistem EventEmitter untuk menangani interaksi WhatsApp secara real-time.
Semua event yang terjadi saat koneksi aktif akan dipancarkan melalui sock.ev.on(...), dan kamu bisa menangkap serta meresponsnya sesuai kebutuhan bot kamu.
!IMPORTANT
Daftar lengkap event tersedia di sini.
Disarankan untuk memahami struktur tiap event agar integrasi kamu lebih stabil dan efisien.
Contoh: Menangani Pesan Masuk
sock.ev.on('messages.upsert', async ({ messages, type }) => {
const msg = messages[0]
if (!msg.message) return
console.log('Pesan diterima:', msg.message)
})typebisa bernilainotify,append,replace, atauremove.- Kamu biasanya hanya perlu memproses
type === 'notify'untuk pesan baru yang masuk.
Contoh: Menangani Pembaruan Koneksi
sock.ev.on('connection.update', ({ connection, lastDisconnect }) => {
if (connection === 'close') {
console.log('Koneksi terputus.')
} else if (connection === 'open') {
console.log('Terhubung ke WhatsApp!')
}
})- Event ini sangat penting untuk memantau status koneksi socket.
- Jika
connection === 'close', Kamu dapat mencoba reconnect otomatis.
Contoh: Deteksi Peserta Masuk/Keluar Grup
sock.ev.on('group-participants.update', async ({ id, participants, action }) => {
if (action === 'add') {
console.log('Anggota baru masuk:', participants)
} else if (action === 'remove') {
console.log('Anggota keluar:', participants)
}
})id: JID grupparticipants: array nomor yang terlibataction:'add' | 'remove' | 'promote' | 'demote'
Contoh: Pembaruan Metadata Grup
sock.ev.on('groups.update', async (updates) => {
for (let group of updates) {
console.log('Grup diperbarui:', group)
}
})- Bisa digunakan untuk mendeteksi perubahan nama grup, gambar, deskripsi, dll.
Tips
- Event
messages.updatedigunakan untuk mendeteksi status pesan seperti dibaca, diterima, atau gagal. - Event
messages.reactiondigunakan untuk menangkap reaksi (emoji) pada pesan kamu.
!TIP
Baileys tidak menyimpan cache pesan secara default.
Untuk menangani event dengan akurat (seperti retry atau polling), gunakangetMessage()bersamastore.
Jika kamu butuh event tambahan seperti reaction, presence, atau call offer, tinggal tambahkan listener-nya sesuai struktur BaileysEventMap.
Menyimpan & Memulihkan Sesi
Tentu kamu tidak ingin terus-menerus memindai QR code setiap kali ingin terkoneksi.
Kamu bisa menyimpan kredensial dan menggunakannya kembali saat login berikutnya:
import makeWASocket, { useMultiFileAuthState } from '@fidzzhost/baileys'
const { state, saveCreds } = await useMultiFileAuthState('auth_info_baileys')
// Akan menggunakan kredensial yang tersedia untuk koneksi ulang
// Jika kredensial valid ditemukan, akan langsung login tanpa QR
const sock = makeWASocket({ auth: state })
// Fungsi ini akan dipanggil setiap kali kredensial diperbarui
sock.ev.on('creds.update', saveCreds)!IMPORTANT
useMultiFileAuthStateadalah fungsi utilitas untuk menyimpan state autentikasi dalam satu folder.
Fungsi ini juga dapat dijadikan dasar untuk menulis sistem autentikasi dan penyimpanan kunci pada database SQL atau NoSQL — sangat direkomendasikan untuk sistem berskala produksi.
Apa Isi Folder auth_info_baileys?
Folder tersebut akan berisi beberapa file .json seperti:
creds.json— informasi kredensial utamakeys/— berisi subfile kunci Signal: pre-keys, session, senderKey, dll.
Folder ini jangan pernah dimodifikasi atau dihapus secara manual.
Perlakukan seperti file token yang sangat sensitif.
Apa yang Terjadi Jika Folder Hilang?
Jika folder auth_info_baileys dihapus:
- Kamu tidak bisa login ulang tanpa memindai QR lagi
- Semua sesi yang aktif akan invalid
- Signal akan membuat ulang semua sesi enkripsi end-to-end
Backup sangat disarankan jika kamu mengelola sesi penting.
Tips Backup & Restore
- Salin seluruh folder
auth_info_baileyssecara utuh. - Untuk restore, cukup salin folder kembali ke path yang sama sebelum memulai bot.
- Gunakan
.gitignoreagar folder ini tidak ikut di-push ke GitHub:auth_info_baileys/
Menyimpan Berdasarkan ID Pengguna (Multi-Akun)
Jika kamu mengelola banyak sesi pengguna (multi-client), buat direktori penyimpanan berdasarkan ID pengguna:
const { state, saveCreds } = await useMultiFileAuthState(`./sessions/${userId}`)Dengan cara ini, kamu bisa memisahkan sesi tiap user tanpa saling bentrok.
Rekomendasi: kombinasikan dengan database seperti MongoDB/Redis untuk mencatat mapping antara userId dan path session-nya.
Contoh untuk Memulai
!NOTE
Contoh ini juga sudah mencakup penyimpanan kredensial secara otomatis
import makeWASocket, { DisconnectReason, useMultiFileAuthState } from '@fidzzhost/baileys'
import { Boom } from '@hapi/boom'
async function connectToWhatsApp () {
const { state, saveCreds } = await useMultiFileAuthState('./auth_info_baileys')
const sock = makeWASocket({
auth: state,
printQRInTerminal: true
})
sock.ev.on('connection.update', (update) => {
const { connection, lastDisconnect } = update
if (connection === 'close') {
const shouldReconnect = (lastDisconnect.error as Boom)?.output?.statusCode !== DisconnectReason.loggedOut
console.log('Koneksi terputus karena', lastDisconnect.error, ', mencoba sambung ulang:', shouldReconnect)
if (shouldReconnect) {
connectToWhatsApp()
}
} else if (connection === 'open') {
console.log('Koneksi berhasil dibuka')
}
})
sock.ev.on('messages.upsert', async (event) => {
for (const m of event.messages) {
console.log(JSON.stringify(m, undefined, 2))
console.log('Membalas ke', m.key.remoteJid)
await sock.sendMessage(m.key.remoteJid!, { text: 'Hello World' })
}
})
// Menyimpan kredensial setiap kali diperbarui
sock.ev.on('creds.update', saveCreds)
}
connectToWhatsApp()Contoh Penggunaan useSingleFileAuthState dan useMongoFileAuthState
import makeWASocket, {
useSingleFileAuthState,
useMongoFileAuthState
} from '@fidzzhost/baileys'
// Autentikasi menggunakan file tunggal (Single File Auth)
const { state, saveState } = await useSingleFileAuthState('./auth_info_baileys.json')
const sock = makeWASocket({
auth: state,
printQRInTerminal: true
})
sock.ev.on('creds.update', saveState)// Autentikasi menggunakan MongoDB
import { MongoClient } from 'mongodb'
const connectAuth = async () => {
const client = new MongoClient('mongodb://localhost:27017')
await client.connect()
console.log('Berhasil terhubung ke MongoDB')
const collection = client.db('@fidzzhost/baileys').collection('sessions')
const { state, saveCreds } = await useMongoFileAuthState(collection)
const sock = makeWASocket({
auth: state,
printQRInTerminal: true
})
sock.ev.on('creds.update', saveCreds)
}
connectAuth()!IMPORTANT
Dalam eventmessages.upsert, sangat disarankan menggunakan perulanganfor (const message of event.messages)untuk menangani semua pesan dalam array secara individual.
Hal ini mencegah pesan terlewat dan memudahkan logging/debugging.!TIP
Kamu bisa menggabungkan pendekatan penyimpanan sesi (MultiFile,SingleFile, atauMongoDB) dengan sistem login berbasis ID pengguna, sehingga mendukung banyak akun secara paralel.
Mendekripsi Suara Polling
Secara default, suara polling di WhatsApp dienkripsi dan diproses melalui event messages.update.
import pino from 'pino'
import {
makeInMemoryStore,
getAggregateVotesInPollMessage
} from '@fidzzhost/baileys'
const logger = pino({ timestamp: () => `,"time":"${new Date().toJSON()}"` }).child({ class: 'FidzzHost' })
logger.level = 'fatal'
const store = makeInMemoryStore({ logger })
async function getMessage(key) {
if (store) {
const msg = await store.loadMessage(key.remoteJid, key.id)
return msg?.message
}
return {
conversation: 'Polling Tidak Ditemukan'
}
}
sock.ev.on('messages.update', async (chatUpdate) => {
for (const { key, update } of chatUpdate) {
if (update.pollUpdates && key.fromMe) {
const pollCreation = await getMessage(key)
if (pollCreation) {
const pollUpdate = await getAggregateVotesInPollMessage({
message: pollCreation,
pollUpdates: update.pollUpdates
})
const toCmd = pollUpdate.filter(v => v.voters.length !== 0)[0]?.name
if (!toCmd) return
console.log('Pilihan terpilih:', toCmd)
// Tambahkan aksi lanjutan di sini
}
}
}
})Penjelasan
store.loadMessage(jid, id)digunakan untuk mengambil ulang isi pesan polling (karena hasil polling hanya berisi update, bukan isi awal).getAggregateVotesInPollMessage()menggabungkan seluruhpollUpdatesdan menghasilkan daftar suara lengkap.- Sangat penting menggunakan
getMessage()yang valid. Jika kamu tidak menyimpan store, dekripsi suara tidak akan berhasil.
!TIP
Untuk polling publik, kamu tidak perlu key khusus.
Tapi untuk polling private (atau jika polling berasal dari orang lain), pastikan kamu menyimpan pesan awalnya menggunakan store atau log pesan masuk.
Ringkasan Event Saat Koneksi Pertama
- Saat socket pertama kali terkoneksi, event
connection.updateakan dipicu.
Biasanya status koneksi akan masuk ke'open'atau'close'. - Setelah itu, WhatsApp akan mengirimkan riwayat pesan (history chat) melalui event:
messaging-history.set - Riwayat tersebut berisi pesan-pesan dari sesi sebelumnya, termasuk polling yang belum terjawab.
!IMPORTANT
Untuk menangani polling, kamu wajib mengaturgetMessage()di konfigurasimakeWASocket().
Ini memastikan Baileys bisa mendekripsi hasil polling dengan benar.
const sock = makeWASocket({
auth: state,
getMessage: async (key) => await getMessage(key)
})Mengimplementasikan Data Store
Baileys tidak menyediakan sistem penyimpanan (storage) bawaan untuk chat, kontak, atau pesan.
Namun, tersedia implementasi sederhana menggunakan in-memory store. Store ini akan memantau pembaruan chat, pesan baru, dan perubahan lainnya agar data kamu tetap mutakhir.
!IMPORTANT
Sangat disarankan untuk membangun sistem penyimpanan sendiri.
Menyimpan seluruh riwayat chat di RAM akan memakan memori yang besar dan tidak efisien untuk jangka panjang.
Contoh Penggunaan Store
import makeWASocket, { makeInMemoryStore } from '@fidzzhost/baileys'
// Store akan menyimpan data koneksi WhatsApp dalam memori
const store = makeInMemoryStore({})
// Membaca data dari file (jika tersedia)
store.readFromFile('./baileys_store.json')
// Menyimpan state ke file setiap 10 detik
setInterval(() => {
store.writeToFile('./baileys_store.json')
}, 10_000)
const sock = makeWASocket({})
// Store akan mulai mendengarkan event dari socket ini
// Jika socket diganti, store masih bisa digunakan ulang
store.bind(sock.ev)
sock.ev.on('chats.upsert', () => {
// Akses semua chat tersimpan
console.log('Data chat diterima:', store.chats.all())
})
sock.ev.on('contacts.upsert', () => {
// Akses semua kontak tersimpan
console.log('Kontak diperbarui:', Object.values(store.contacts))
})Fitur Store
- Menyimpan chat, pesan, dan kontak sementara di memori.
- Mendukung pembacaan dan penulisan dari/ke file JSON.
- Bisa digunakan bersama beberapa koneksi (socket) sekaligus.
- Tersedia fungsi
loadMessages,loadMessage, danloadMessageFromContent.
Kelebihan
- Cepat dan ringan untuk penggunaan kecil-menengah.
- Ideal untuk penggunaan lokal, testing, atau bot personal.
Kekurangan
- Data hilang saat proses dihentikan jika tidak ditulis ke file.
- Tidak cocok untuk data skala besar (ribuan pesan atau kontak).
- Tidak mendukung query kompleks (karena berbasis object literal di RAM).
Rekomendasi Produksi
Untuk sistem besar atau multi-user:
- Gunakan database seperti:
- MongoDB (untuk struktur fleksibel dan load besar)
- Redis (untuk cache cepat)
- PostgreSQL (untuk struktur relasional)
- Sinkronkan event seperti
messages.upsert,chats.upsert, dancontacts.upsertke penyimpanan permanen. - Gunakan store hanya sebagai cache atau layer middleware sementara.
!TIP
Store ini sangat berguna untuk keperluan seperti:
- Menyimpan polling
- Retry pesan
- Melacak status kontak dan grup
- Menyediakan command
.listchat,.listgroup, dll. dengan data real-time
Jika kamu menggunakan custom getMessage(), store ini juga dapat dijadikan referensi lokal untuk mendekripsi polling dan mengirim ulang pesan.
Penjelasan Tentang WhatsApp ID
idatau biasa disebut jugajidadalah identitas WhatsApp dari seseorang atau grup yang menjadi tujuan pengiriman pesan.- Format ID harus sesuai dengan jenis akun tujuan:
Jenis Format ID WhatsApp
1. Pengguna Pribadi (User)
Format:
[kode negara][nomor telepon]@s.whatsapp.netContoh:
628123456789@s.whatsapp.net2. Grup WhatsApp
Format:
[timestamp grup dibuat]-[random id]@g.usContoh:
1234567890-987654321@g.us3. Broadcast (Daftar Siaran)
Format:
[timestamp]@broadcastContoh:
1685539347@broadcast4. Status (Story)
Format:
status@broadcast5. Newsletter (Channel WhatsApp)
Format:
[numeric id]@newsletterContoh:
120363025487665599@newsletterTIP:
Kamu bisa mendapatkanjiddari:
m.key.remoteJidgroupParticipantsUpdatemessages.upsert, dllCAUTION:
Jangan pernah mengubah formatjidsecara manual tanpa validasi.
Salah format bisa menyebabkan errorbad jidatau pesan tidak terkirim.
Fungsi Utilitas (Utility Functions)
Baileys menyediakan beberapa fungsi utilitas penting yang sangat membantu saat mengembangkan bot:
getContentType(message)
Mengembalikan jenis konten dari pesan (misalnya:imageMessage,conversation,buttonsMessage, dll).getDevice(jid)
Mengembalikan jenis perangkat yang digunakan pengirim (jika tersedia), contoh: Android, iPhone, Web.makeCacheableSignalKeyStore(authState)
Membungkus SignalKeyStore menjadi versi yang lebih efisien dan bisa di-cache, untuk performa autentikasi yang lebih cepat.downloadContentFromMessage(message, type)
Mengunduh media dari pesan (seperti gambar, video, dokumen).typebisa berupa'image','video','audio','document', dll.Contoh penggunaan:
const stream = await downloadContentFromMessage(msg.imageMessage, 'image') const buffer = Buffer.concat([]) for await (const chunk of stream) buffer.push(chunk)
!NOTE
Sebagian besar fungsi utilitas tidak dipanggil otomatis — Kamu harus menggunakannya sesuai kebutuhan, terutama saat menangani pesan media, format jid, atau decrypt konten.
Mengirim Pesan
- Semua jenis pesan dapat dikirim menggunakan satu fungsi saja, yaitu
sendMessage(). - Lihat daftar jenis pesan yang didukung di sini
- Dan semua opsi pengiriman pesan di sini
Contoh:
const jid = '628XXXXXXXXX@s.whatsapp.net' // tujuan
const content = { text: 'Halo, ini pesan dari bot!' } // isi pesan
const options = { quoted: null } // opsi tambahan (misalnya: balasan)
await sock.sendMessage(jid, content, options)Pesan Non-Media
Pesan Teks
await sock.sendMessage(jid, { text: 'Halo dunia' })Pesan Balasan (Quote)
await sock.sendMessage(jid, { text: 'Ini balasan pesan kamu' }, { quoted: message })Mention Pengguna (Tag)
Gunakan @nomor dalam teks dan sertakan mentions di payload.
await sock.sendMessage(
jid,
{
text: '@628XXXXXXXXX Hai Fidzz!',
mentions: ['628XXXXXXXXX@s.whatsapp.net']
}
)Meneruskan Pesan (Forward)
Butuh objek pesan (WAMessage). Bisa didapat dari store atau pesan sebelumnya.
const msg = getMessageFromStore() // Kamu buat sendiri sesuai struktur
await sock.sendMessage(jid, { forward: msg, force: true })Pesan Interaktif
Tombol Teks (Buttons)
await sock.sendMessage(jid, {
text: 'Pilih salah satu:',
buttons: [
{ buttonId: 'btn_1', buttonText: { displayText: 'Tombol 1' }, type: 1 },
{ buttonId: 'btn_2', buttonText: { displayText: 'Tombol 2' }, type: 1 }
],
footer: 'Contoh footer'
})Daftar (List Message)
await sock.sendMessage(jid, {
text: 'Pilih dari daftar berikut:',
footer: 'Contoh footer',
title: 'Judul Daftar',
buttonText: 'Buka List',
sections: [
{
title: 'Menu 1',
rows: [
{ title: 'Opsi A', rowId: 'pilih_a' },
{ title: 'Opsi B', rowId: 'pilih_b' }
]
},
{
title: 'Menu 2',
rows: [
{ title: 'Opsi C', rowId: 'pilih_c' }
]
}
]
})!TIP
Kamu bisa menggabungkan semua jenis pesan dengan opsi tambahan sepertiquoted,mentions,ephemeralExpiration, dan lainnya untuk membuat interaksi bot yang lebih kaya dan interaktif.
Lokasi Biasa
await sock.sendMessage(
jid,
{
location: {
degreesLatitude: -6.200000,
degreesLongitude: 106.816666
}
}
)Lokasi Langsung (Live Location)
await sock.sendMessage(
jid,
{
location: {
degreesLatitude: -6.200000,
degreesLongitude: 106.816666
},
live: true
}
)Kirim Kontak (vCard)
const vcard =
'BEGIN:VCARD\n' +
'VERSION:3.0\n' +
'FN:FidzzHost\n' +
'ORG:ZERO DEV;\n' +
'TEL;type=CELL;type=VOICE;waid=628XXXXXXXXX:+62 831-4366-3697\n' +
'END:VCARD'
await sock.sendMessage(
jid,
{
contacts: {
displayName: 'FidzzHost',
contacts: [{ vcard }]
}
}
)Pesan Reaksi (Reaction Message)
- Kamu perlu mengirimkan
keydari pesan yang ingin diberikan reaksi.keybisa diambil dari store atau menggunakan WAMessageKey.
await sock.sendMessage(
jid,
{
react: {
text: '🔥', // gunakan string kosong '' untuk menghapus reaksi
key: message.key
}
}
)Pin Pesan (Pin Message)
- Kamu juga perlu memberikan
keydari pesan yang ingin dipin.
Kamu dapat mengatur durasi pin berdasarkan waktu dalam detik.
| Durasi | Detik |
|---|---|
| 24 jam | 86.400 |
| 7 hari | 604.800 |
| 30 hari | 2.592.000 |
await sock.sendMessage(
jid,
{
pin: {
type: 1, // 1 untuk pin, 2 untuk unpin
time: 86400,
key: message.key
}
}
)Menandai Pesan (Keep Message)
- Untuk menyimpan pesan tertentu agar tidak terhapus otomatis.
await sock.sendMessage(
jid,
{
keep: {
key: message.key,
type: 1 // 1 = simpan, 2 = batalkan simpan
}
}
)Pesan Polling (Poll Message)
- Kirim polling ke grup atau kontak pribadi. Dapat menentukan apakah polling bersifat publik (announcement group).
await sock.sendMessage(
jid,
{
poll: {
name: 'Polling Hari Ini',
values: ['Opsi A', 'Opsi B', 'Opsi C'],
selectableCount: 1,
toAnnouncementGroup: false
}
}
)Pesan Hasil Polling (Poll Result)
- Kirim hasil polling secara manual jika dibutuhkan. Cocok untuk sistem polling terintegrasi.
await sock.sendMessage(
jid,
{
pollResult: {
name: 'Hasil Polling',
values: [
['Opsi A', 120],
['Opsi B', 350],
['Opsi C', 75]
]
}
}
)Pesan Panggilan (Call Message)
- Digunakan untuk mengirim notifikasi panggilan, bisa suara atau video.
await sock.sendMessage(
jid,
{
call: {
name: 'Hay',
type: 1 // 1 = suara, 2 = video
}
}
)Pesan Event (Event Message)
- Cocok untuk mengumumkan acara atau undangan dengan detail lokasi dan waktu.
await sock.sendMessage(
jid,
{
event: {
isCanceled: false, // true jika dibatalkan
name: 'Liburan Bareng!',
description: 'Siapa yang mau ikut?',
location: {
degreesLatitude: 24.121231,
degreesLongitude: 55.1121221,
name: 'Pantai Sanur'
},
startTime: 1715000000,
endTime: 1715086400,
extraGuestsAllowed: true // apakah boleh bawa tamu
}
}
)Pesan Pemesanan (Order Message)
- Digunakan untuk menampilkan detail pemesanan dari katalog bisnis WhatsApp.
await sock.sendMessage(
jid,
{
order: {
orderId: '574XXX',
thumbnail: 'your_thumbnail',
itemCount: 3,
status: 'INQUIRY', // atau ACCEPTED / DECLINED
surface: 'CATALOG',
message: 'Deskripsi pesanan',
orderTitle: 'Judul Pesanan',
sellerJid: '628xxx@s.whatsapp.net',
token: 'your_token',
totalAmount1000: '150000',
totalCurrencyCode: 'IDR'
}
}
)Pesan Produk (Product Message)
- Menampilkan detail produk dari katalog bisnis.
await sock.sendMessage(
jid,
{
product: {
productImage: {
url: 'https://your-image.url/image.jpg'
},
productId: 'PRD-001',
title: 'Produk Spesial',
description: 'Deskripsi lengkap produk kamu di sini',
currencyCode: 'IDR',
priceAmount1000: '50000',
retailerId: 'store-izumi', // opsional
url: 'https://linkproduk.com', // opsional
productImageCount: 1,
firstImageId: 'img-001', // opsional
salePriceAmount1000: '45000',
signedUrl: 'https://your.signed.url' // opsional
},
businessOwnerJid: '628xxx@s.whatsapp.net'
}
)Pesan Pembayaran (Payment Message)
- Digunakan untuk mengirimkan informasi pembayaran, cocok untuk chatbot belanja.
await sock.sendMessage(
jid,
{
payment: {
note: 'Hi!',
currency: 'IDR',
offset: 0,
amount: '10000',
expiry: 0,
from: '628xxxx@s.whatsapp.net',
image: {
placeholderArgb: '#222222',
textArgb: '#FFFFFF',
subtextArgb: '#AAAAAA'
}
}
}
)Pesan Undangan Pembayaran (Payment Invite Message)
- Digunakan untuk mengundang pengguna lain melakukan pembayaran.
await sock.sendMessage(
jid,
{
paymentInvite: {
type: 1, // 1 = request, 2 = accept, 3 = decline (sesuaikan sesuai konteks)
expiry: 0
}
}
)Pesan Undangan Admin Channel (Admin Invite Message)
- Meminta pengguna untuk menjadi admin di saluran (newsletter) kamu.
await sock.sendMessage(
jid,
{
adminInvite: {
jid: '123xxx@newsletter',
name: 'Channel Fidzz',
caption: 'Tolong jadi admin channel saya ya!',
expiration: 86400, // dalam detik (24 jam)
jpegThumbnail: Buffer // opsional, bisa berupa buffer gambar
}
}
)Undangan Grup WhatsApp (Group Invite Message)
- Mengirim undangan ke grup tertentu menggunakan kode undangan.
await sock.sendMessage(
jid,
{
groupInvite: {
jid: '123xxx@g.us',
name: 'Grup Dev Fidzz',
caption: 'Ayo gabung ke grup WhatsApp kami!',
code: 'ABCD1234', // kode undangan grup
expiration: 86400,
jpegThumbnail: Buffer // opsional
}
}
)Pesan Bagikan Nomor Telepon (Share Phone Number)
- Mengirim permintaan eksplisit untuk membagikan nomor telepon pengguna.
await sock.sendMessage(
jid,
{
sharePhoneNumber: {}
}
)Pesan Permintaan Nomor Telepon (Request Phone Number)
- Meminta pengguna untuk membagikan nomor telepon mereka secara langsung.
await sock.sendMessage(
jid,
{
requestPhoneNumber: {}
}
)Pesan Balasan Tombol (Button Reply Message)
- Digunakan untuk merespons interaksi tombol yang diklik pengguna. Tipe pesan dibedakan berdasarkan jenis tombol yang digunakan.
Tombol Tipe List
await sock.sendMessage(
jid,
{
buttonReply: {
name: 'Hai',
description: 'Deskripsi pilihan',
rowId: 'pilihan_1'
},
type: 'list'
}
)Tombol Tipe Plain
await sock.sendMessage(
jid,
{
buttonReply: {
displayText: 'Halo',
id: 'plain_id'
},
type: 'plain'
}
)Tombol Tipe Template
await sock.sendMessage(
jid,
{
buttonReply: {
displayText: 'Pilih Saya',
id: 'template_id',
index: 1
},
type: 'template'
}
)Tombol Tipe Interactive (Native Flow)
await sock.sendMessage(
jid,
{
buttonReply: {
body: 'Mau pilih yang mana?',
nativeFlows: {
name: 'menu_options',
paramsJson: JSON.stringify({ id: 'menu_1', description: 'Deskripsi interaktif' }),
version: 1 // bisa juga 2 atau 3
}
},
type: 'interactive'
}
)Pesan dengan Tombol (Buttons Message)
- Pesan biasa yang disertai hingga 3 tombol untuk respon cepat.
await sock.sendMessage(
jid,
{
text: 'Ini adalah pesan tombol!',
caption: 'Gunakan jika memakai gambar/video',
footer: 'Salam dari FidzzHost!',
buttons: [
{
buttonId: 'btn1',
buttonText: { displayText: 'Tombol 1' }
},
{
buttonId: 'btn2',
buttonText: { displayText: 'Tombol 2' }
},
{
buttonId: 'btn3',
buttonText: { displayText: 'Tombol 3' }
}
]
}
)Pesan List Tombol (Buttons List Message)
- Hanya bisa digunakan di chat pribadi, bukan grup.
await sock.sendMessage(
jid,
{
text: 'Ini adalah daftar pilihan!',
footer: 'Dipersembahkan oleh FidzzHost',
title: 'Judul Daftar Pilihan',
buttonText: 'Klik untuk melihat opsi',
sections: [
{
title: 'Bagian 1',
rows: [
{ title: 'Opsi 1', rowId: 'opsi1' },
{ title: 'Opsi 2', rowId: 'opsi2', description: 'Deskripsi Opsi 2' }
]
},
{
title: 'Bagian 2',
rows: [
{ title: 'Opsi 3', rowId: 'opsi3' },
{ title: 'Opsi 4', rowId: 'opsi4', description: 'Deskripsi Opsi 4' }
]
}
]
}
)Pesan Daftar Produk dengan Tombol (Buttons Product List Message)
- Hanya dapat digunakan di chat pribadi, bukan grup.
- Menampilkan daftar produk dari katalog bisnis WhatsApp kamu.
await sock.sendMessage(
jid,
{
text: 'Ini adalah daftar produk!',
footer: 'Dikirim oleh FidzzHost',
title: 'Pilih Produk Unggulan',
buttonText: 'Lihat Daftar Produk',
productList: [
{
title: 'Kategori Produk Utama',
products: [
{ productId: '1234' },
{ productId: '5678' }
]
}
],
businessOwnerJid: '628xxx@s.whatsapp.net',
thumbnail: 'https://example.jpg' // atau buffer gambar
}
)Pesan Kartu dengan Tombol (Buttons Cards Message)
- Menampilkan beberapa kartu (card) interaktif dengan gambar atau video + tombol.
await sock.sendMessage(
jid,
{
text: 'Isi Utama Pesan',
title: 'Judul Utama',
subtile: 'Subjudul Opsional',
footer: 'Footer Pesan',
cards: [
{
image: { url: 'https://example.jpg' }, // bisa juga Buffer
title: 'Judul Kartu',
body: 'Isi Konten Kartu',
footer: 'Footer Kartu',
buttons: [
{
name: 'quick_reply',
buttonParamsJson: JSON.stringify({
display_text: 'Tombol Cepat',
id: 'ID_TOMBOL_1'
})
},
{
name: 'cta_url',
buttonParamsJson: JSON.stringify({
display_text: 'Kunjungi Website',
url: 'https://www.example.com'
})
}
]
},
{
video: { url: 'https://example.mp4' }, // bisa juga Buffer video
title: 'Judul Kartu Video',
body: 'Deskripsi Konten',
footer: 'Footer Kartu',
buttons: [
{
name: 'quick_reply',
buttonParamsJson: JSON.stringify({
display_text: 'Respon Cepat',
id: 'ID_TOMBOL_2'
})
},
{
name: 'cta_url',
buttonParamsJson: JSON.stringify({
display_text: 'Lihat Selengkapnya',
url: 'https://www.example.com'
})
}
]
}
]
}
)Pesan Tombol Template (Buttons Template Message)
- Menampilkan tombol dengan tipe URL, panggilan, atau tombol balasan cepat.
await sock.sendMessage(
jid,
{
text: 'Ini adalah pesan template tombol!',
footer: 'Dikirim oleh FidzzHost',
templateButtons: [
{
index: 1,
urlButton: {
displayText: 'Ikuti Channel',
url: 'https://whatsapp.com/channel/0029Vag9VSI2ZjCocqa2lB1y'
}
},
{
index: 2,
callButton: {
displayText: 'Hubungi Saya!',
phoneNumber: '628xxxx'
}
},
{
index: 3,
quickReplyButton: {
displayText: 'Balas Cepat',
id: 'id-button-reply'
}
}
]
}
)Pesan Tombol Interaktif (Interactive Buttons)
- Mendukung berbagai jenis tombol dan dapat digunakan dengan media.
await sock.sendMessage(
jid,
{
text: 'Ini pesan interaktif!',
title: 'Hai!',
subtitle: 'Subjudul di sini',
footer: 'Dikirim oleh FidzzHost',
interactiveButtons: [
{
name: 'quick_reply',
buttonParamsJson: JSON.stringify({
display_text: 'Klik Aku!',
id: 'id_kamu'
})
},
{
name: 'cta_url',
buttonParamsJson: JSON.stringify({
display_text: 'Kunjungi Channel',
url: 'https://whatsapp.com/channel/0029Vag9VSI2ZjCocqa2lB1y',
merchant_url: 'https://whatsapp.com/channel/0029Vag9VSI2ZjCocqa2lB1y'
})
},
{
name: 'cta_copy',
buttonParamsJson: JSON.stringify({
display_text: 'Salin Link',
copy_code: 'https://whatsapp.com/channel/0029Vag9VSI2ZjCocqa2lB1y'
})
},
{
name: 'cta_call',
buttonParamsJson: JSON.stringify({
display_text: 'Telepon Saya',
phone_number: '628xxxx'
})
},
{
name: 'single_select',
buttonParamsJson: JSON.stringify({
title: 'Pilih Opsi',
sections: [
{
title: 'Pilihan Utama',
highlight_label: 'Rekomendasi',
rows: [
{
header: 'Header 1',
title: 'Opsi 1',
description: 'Deskripsi 1',
id: 'id1'
},
{
header: 'Header 2',
title: 'Opsi 2',
description: 'Deskripsi 2',
id: 'id2'
}
]
}
]
})
}
]
}
)Versi dengan Media
Gambar
await sock.sendMessage(
jid,
{
image: { url: 'https://example.jpg' },
caption: 'Isi Pesan',
title: 'Judul',
subtitle: 'Subjudul',
footer: 'Footer',
interactiveButtons: [ /* tombol seperti di atas */ ],
hasMediaAttachment: false
}
)Video
await sock.sendMessage(
jid,
{
video: { url: 'https://example.mp4' },
caption: 'Isi Video',
title: 'Judul',
subtitle: 'Subjudul',
footer: 'Footer',
interactiveButtons: [ /* tombol seperti di atas */ ],
hasMediaAttachment: false
}
)Dokumen
await sock.sendMessage(
jid,
{
document: { url: 'https://example.jpg' },
mimetype: 'image/jpeg',
jpegThumbnail: await sock.resize('https://example.jpg', 320, 320),
caption: 'Isi Dokumen',
title: 'Judul',
subtitle: 'Subjudul',
footer: 'Footer',
interactiveButtons: [ /* tombol seperti di atas */ ],
hasMediaAttachment: false
}
)Lokasi
await sock.sendMessage(
jid,
{
location: {
degreesLatitude: -6.2,
degreesLongitude: 106.8,
name: 'FidzzHost'
},
caption: 'Ayo ke sini!',
title: 'Lokasi Tujuan',
subtitle: 'Subjudul Lokasi',
footer: 'Peta lokasi',
interactiveButtons: [ /* tombol seperti di atas */ ],
hasMediaAttachment: false
}
)Produk
await sock.sendMessage(
jid,
{
product: {
productImage: { url: 'https://example.jpg' },
productId: '836xxx',
title: 'Produk Pilihan',
description: 'Deskripsi produk terbaik',
currencyCode: 'IDR',
priceAmount1000: '283000',
retailerId: 'FidzzStore',
url: 'https://example.com',
productImageCount: 1
},
businessOwnerJid: '628xxx@s.whatsapp.net',
caption: 'Produk baru tersedia!',
title: 'Nama Produk',
subtitle: 'Subjudul Produk',
footer: 'Info Produk',
interactiveButtons: [ /* tombol seperti di atas */ ],
hasMediaAttachment: false
}
)Mention Status (Status Mentions Message)
- Digunakan untuk membuat status WhatsApp yang menyebut seseorang secara langsung.
await sock.sendStatusMentions(
jid,
{
image: {
url: 'https://example.com.jpg'
},
caption: 'Halo dari Fidzz!'
}
)Pesan Album (Send Album Message)
- Mengirim beberapa gambar atau video sebagai album (sekuens media). Bisa pakai
Bufferatau URL.
await sock.sendAlbumMessage(
jid,
[
{
image: { url: 'https://example.jpg' },
caption: 'Gambar 1'
},
{
image: Buffer,
caption: 'Gambar 2'
},
{
video: { url: 'https://example.mp4' },
caption: 'Video 1'
},
{
video: Buffer,
caption: 'Video 2'
}
],
{
quoted: message, // opsional, untuk membalas pesan
delay: 2000 // jeda antar media (ms)
}
)Pesan Toko (Shop Message)
- Digunakan untuk mengarahkan pengguna ke katalog atau produk dalam fitur bisnis WhatsApp.
Teks Saja
await sock.sendMessage(
jid,
{
text: 'Body pesan',
title: 'Judul Toko',
subtitle: 'Subjudul',
footer: 'Powered by FidzzHost',
shop: {
surface: 1,
id: 'https://example.com'
},
viewOnce: true
}
)Gambar
await sock.sendMessage(
jid,
{
image: { url: 'https://example.jpg' },
caption: 'Deskripsi produk',
title: 'Judul',
subtitle: 'Subjudul',
footer: 'Footer',
shop: {
surface: 1,
id: 'https://example.com'
},
hasMediaAttachment: false,
viewOnce: true
}
)Video
await sock.sendMessage(
jid,
{
video: { url: 'https://example.mp4' },
caption: 'Tonton videonya!',
title: 'Judul Video',
subtitle: 'Subjudul',
footer: 'Footer',
shop: {
surface: 1,
id: 'https://example.com'
},
hasMediaAttachment: false,
viewOnce: true
}
)Dokumen
await sock.sendMessage(
jid,
{
document: { url: 'https://example.jpg' },
mimetype: 'image/jpeg',
jpegThumbnail: await sock.resize('https://example.jpg', 320, 320),
caption: 'Lampiran dokumen',
title: 'Judul',
subtitle: 'Subjudul',
footer: 'Footer',
shop: {
surface: 1,
id: 'https://example.com'
},
hasMediaAttachment: false,
viewOnce: true
}
)Lokasi
await sock.sendMessage(
jid,
{
location: {
degreesLatitude: -6.2000,
degreesLongitude: 106.8166,
name: 'Lokasi Toko'
},
caption: 'Lihat lokasi kami!',
title: 'Judul Lokasi',
subtitle: 'Subjudul',
footer: 'Peta lokasi',
shop: {
surface: 1,
id: 'https://example.com'
},
hasMediaAttachment: false,
viewOnce: true
}
)Produk
await sock.sendMessage(
jid,
{
product: {
productImage: { url: 'https://example.jpg' },
productId: '836xxx',
title: 'Nama Produk',
description: 'Deskripsi produk menarik',
currencyCode: 'IDR',
priceAmount1000: '283000',
retailerId: 'FidzzStore',
url: 'https://example.com',
productImageCount: 1
},
businessOwnerJid: '628xxx@s.whatsapp.net',
caption: 'Lihat produk unggulan kami!',
title: 'Judul Produk',
subtitle: 'Subjudul Produk',
footer: 'Info produk',
shop: {
surface: 1,
id: 'https://example.com'
},
hasMediaAttachment: false,
viewOnce: true
}
)Pesan Koleksi (Collection Message)
- Fitur ini digunakan untuk menampilkan koleksi katalog dari bisnis tertentu di WhatsApp.
Teks Saja
await sock.sendMessage(
jid,
{
text: 'Isi pesan',
title: 'Judul Koleksi',
subtitle: 'Subjudul',
footer: 'Dari FidzzHost',
collection: {
bizJid: '628xxx@s.whatsapp.net',
id: 'https://example.com',
version: 1
},
viewOnce: true
}
)Gambar
await sock.sendMessage(
jid,
{
image: { url: 'https://example.jpg' },
caption: 'Koleksi Gambar',
title: 'Judul Koleksi',
subtitle: 'Subjudul',
footer: 'Katalog Fidzz',
collection: {
bizJid: '628xxx@s.whatsapp.net',
id: 'https://example.com',
version: 1
},
hasMediaAttachment: false,
viewOnce: true
}
)Video
await sock.sendMessage(
jid,
{
video: { url: 'https://example.mp4' },
caption: 'Koleksi Video',
title: 'Judul Video',
subtitle: 'Subjudul',
footer: 'Video Katalog',
collection: {
bizJid: '628xxx@s.whatsapp.net',
id: 'https://example.com',
version: 1
},
hasMediaAttachment: false,
viewOnce: true
}
)Dokumen
await sock.sendMessage(
jid,
{
document: { url: 'https://example.jpg' },
mimetype: 'image/jpeg',
jpegThumbnail: await sock.resize('https://example.jpg', 320, 320),
caption: 'Dokumen Katalog',
title: 'Judul Dokumen',
subtitle: 'Subjudul',
footer: 'Lampiran Koleksi',
collection: {
bizJid: '628xxx@s.whatsapp.net',
id: 'https://example.com',
version: 1
},
hasMediaAttachment: false,
viewOnce: true
}
)Lokasi
await sock.sendMessage(
jid,
{
location: {
degreesLatitude: -6.2,
degreesLongitude: 106.8,
name: 'Lokasi Bisnis'
},
caption: 'Lihat lokasi koleksi',
title: 'Judul Lokasi',
subtitle: 'Subjudul',
footer: 'Lokasi Katalog',
collection: {
bizJid: '628xxx@s.whatsapp.net',
id: 'https://example.com',
version: 1
},
hasMediaAttachment: false,
viewOnce: true
}
)Produk
await sock.sendMessage(
jid,
{
product: {
productImage: { url: 'https://example.jpg' },
productId: '836xxx',
title: 'Nama Produk',
description: 'Deskripsi produk',
currencyCode: 'IDR',
priceAmount1000: '283000',
retailerId: 'FidzzStore',
url: 'https://example.com',
productImageCount: 1
},
businessOwnerJid: '628xxx@s.whatsapp.net',
caption: 'Koleksi Produk',
title: 'Judul',
subtitle: 'Subjudul',
footer: 'Produk Katalog',
collection: {
bizJid: '628xxx@s.whatsapp.net',
id: 'https://example.com',
version: 1
},
hasMediaAttachment: false,
viewOnce: true
}
)Mengirim Pesan dengan Pratinjau Link (Link Preview)
- Secara default, WhatsApp Web tidak menampilkan pratinjau link.
- Namun, Baileys menyediakan fungsi pembangkit preview link otomatis.
- Untuk mengaktifkannya, install dulu dependensinya dengan:
yarn add link-preview-js - Contoh kirim pesan dengan pratinjau link:
await sock.sendMessage(
jid,
{
text: 'Hai! Ini dikirim dari https://github.com/whiskeysockets/baileys'
}
)Pesan Media (Media Messages)
Mengirim media (gambar, video, audio, stiker) jauh lebih efisien dengan Baileys.
!NOTE
Kamu bisa menggunakanBuffer,{ stream }, atau{ url }.
Lihat lebih lengkap di dokumentasi media!TIP
Gunakan stream atau url langsung agar lebih hemat memori.
Pesan GIF (video pendek)
WhatsApp tidak mendukung file
.gif, maka harus dikirim dalam bentuk.mp4dengan flaggifPlayback: true
await sock.sendMessage(
jid,
{
video: fs.readFileSync('Media/ma_gif.mp4'),
caption: 'Halo dari GIF!',
gifPlayback: true
}
)Pesan Video
await sock.sendMessage(
jid,
{
video: { url: './Media/ma_video.mp4' },
caption: 'Ini videonya'
}
)Pesan Video PTV (Picture to Video / video bulat WA)
await sock.sendMessage(
jid,
{
video: { url: './Media/ma_video.mp4' },
ptv: true
}
)Pesan Audio
Agar audio kompatibel di semua perangkat, sebaiknya gunakan
ffmpegdengan pengaturan berikut:
ffmpeg -i input.mp4 -avoid_negative_ts make_zero -ac 1 output.oggawait sock.sendMessage(
jid,
{
audio: { url: './Media/audio.ogg' },
mimetype: 'audio/ogg; codecs=opus'
}
)Pesan Gambar
await sock.sendMessage(
jid,
{
image: { url: './Media/ma_img.png' },
caption: 'Halo dari gambar!'
}
)Pesan View Once
Fitur View Once memungkinkan media hanya bisa dilihat satu kali.
await sock.sendMessage(
jid,
{
image: { url: './Media/ma_img.png' },
viewOnce: true,
caption: 'Media hanya bisa dilihat sekali'
}
)Memodifikasi Pesan
Menghapus Pesan (Untuk Semua Orang)
- Digunakan untuk menarik pesan yang sudah dikirim (delete for everyone).
const msg = await sock.sendMessage(jid, { text: 'Halo dunia' })
await sock.sendMessage(jid, { delete: msg.key })Catatan:
Untuk menghapus pesan hanya untuk diri sendiri, gunakanchatModify(lihat bagian Modifikasi Chat).
Mengedit Pesan
- Kamu dapat mengedit isi pesan yang telah dikirim sebelumnya, selama masih berada dalam konteks yang diizinkan oleh WhatsApp.
await sock.sendMessage(jid, {
text: 'Teks yang sudah diperbarui di sini',
edit: response.key
})Memanipulasi Pesan Media
Menambahkan Thumbnail pada Media
- Thumbnail (gambar pratinjau) untuk gambar dan stiker bisa dihasilkan secara otomatis jika kamu menambahkan salah satu dari dependency berikut:
yarn add jimp
# atau
yarn add sharp- Untuk video, kamu juga bisa menghasilkan thumbnail otomatis, tapi pastikan kamu sudah install
ffmpegdi sistem kamu.
Contoh penggunaan otomatis biasanya tidak perlu kamu atur manual — Baileys akan meng-generate thumbnail bila dependensi sudah tersedia.
Mengunduh Media dari Pesan (Downloading Media Messages)
Jika kamu ingin menyimpan media yang diterima dari pengguna:
import { createWriteStream } from 'fs'
import { downloadMediaMessage, getContentType } from '@fidzzhost/baileys'
sock.ev.on('messages.upsert', async ({ messages }) => {
let m = messages[0]
if (!m.message) return // jika tidak ada media atau isi pesan
let messageType = getContentType(m.message) // deteksi tipe pesan (image, video, audio, dll)
if (messageType === 'imageMessage') {
let stream = await downloadMediaMessage(
m,
'stream', // bisa juga 'buffer' kalau ingin langsung di-handle tanpa file
{},
{
logger,
reuploadRequest: sock.updateMediaMessage // agar bisa reupload jika file sudah tidak ada
}
)
let file = createWriteStream('./downloaded-image.jpeg')
stream.pipe(file)
}
})Re-upload Media ke WhatsApp
Jika media sudah dihapus dari server WhatsApp, kamu bisa minta perangkat pengirim untuk melakukan reupload:
await sock.updateMediaMessage(msg)Fitur ini penting saat media gagal diunduh karena sudah tidak tersedia di server WhatsApp.
Menolak Panggilan (Reject Call)
- Kamu bisa mendapatkan
callIddancallFromdari eventcall.
await sock.rejectCall(callId, callFrom)Mengirim Status ke Chat (Send States in Chat)
Menandai Pesan Dibaca (Reading Messages)
- Kamu harus menandai pesan satu per satu menggunakan key dari
WAMessage. - Tidak bisa menandai seluruh chat sebagai terbaca secara langsung seperti di WhatsApp Web.
const key = {
remoteJid: '628xxx@s.whatsapp.net',
fromMe: false,
id: 'ABCDEF123456'
}
// bisa juga array untuk banyak pesan sekaligus
await sock.readMessages([key])Kamu bisa mendapatkan
messageIDdari:let messageID = message.key.id
Memperbarui Status Kehadiran (Update Presence)
- Status
presencebisa berupa:available,unavailable,composing,recording,paused, dll.
Lihat daftar lengkapnya di sini
await sock.sendPresenceUpdate('available', jid) // online
await sock.sendPresenceUpdate('composing', jid) // mengetik
await sock.sendPresenceUpdate('unavailable', jid) // offlineCatatan:
Jika kamu menggunakan WhatsApp Desktop secara bersamaan, maka WA tidak akan mengirim notifikasi ke perangkat lain.
Kalau kamu ingin tetap terima notifikasi di HP, kamu bisa set status bot jadi offline:await sock.sendPresenceUpdate('unavailable')
Memodifikasi Chat (Modifying Chats)
WhatsApp menggunakan komunikasi terenkripsi untuk memperbarui status chat atau aplikasi. Beberapa fitur modifikasi sudah didukung oleh Baileys, dan bisa kamu kirim seperti di bawah ini.
PERINGATAN:
Jika kamu salah menggunakan modifikasi ini (misal kirim data invalid), WhatsApp bisa logout semua perangkat dan kamu harus scan ulang QR.
Mengarsipkan Chat (Archive)
let lastMsgInChat = await getLastMessageInChat(jid) // kamu buat fungsi ini sendiri
await sock.chatModify({ archive: true, lastMessages: [lastMsgInChat] }, jid)Membisukan / Mengaktifkan Notifikasi (Mute / Unmute)
| Durasi | Milidetik |
|---|---|
| Hapus | null |
| 8 Jam | 86400000 |
| 7 Hari | 604800000 |
await sock.chatModify({ mute: 8 * 60 * 60 * 1000 }, jid) // bisukan 8 jam
await sock.chatModify({ mute: null }, jid) // aktifkan kembali notifikasiTandai Sebagai Terbaca / Belum Dibaca
let lastMsgInChat = await getLastMessageInChat(jid)
await sock.chatModify({ markRead: false, lastMessages: [lastMsgInChat] }, jid)Hapus Pesan Hanya untuk Saya
await sock.chatModify(
{
clear: {
messages: [
{
id: 'ATWYHDNNWU81732J',
fromMe: true,
timestamp: '1654823909'
}
]
}
},
jid
)Hapus Chat Secara Keseluruhan
let lastMsgInChat = await getLastMessageInChat(jid)
await sock.chatModify({
delete: true,
lastMessages: [
{
key: lastMsgInChat.key,
messageTimestamp: lastMsgInChat.messageTimestamp
}
]
}, jid)Pin / Unpin Chat
await sock.chatModify({
pin: true // false untuk unpin
}, jid)Tandai / Hapus Bintang dari Pesan
await sock.chatModify({
star: {
messages: [
{
id: 'messageID',
fromMe: true
}
],
star: true // true: beri bintang, false: hapus bintang
}
}, jid)Pesan Menghilang Otomatis (Disappearing Messages)
| Durasi | Detik (Seconds) |
|---|---|
| Nonaktif | 0 |
| 24 Jam | 86400 |
| 7 Hari | 604800 |
| 90 Hari | 7776000 |
Aktifkan
await sock.sendMessage(jid, {
disappearingMessagesInChat: 604800 // 7 hari
})Kirim Pesan dengan Mode Menghilang
await sock.sendMessage(
jid,
{ text: 'halo' },
{ ephemeralExpiration: 604800 }
)Nonaktifkan
await sock.sendMessage(jid, {
disappearingMessagesInChat: false
})Menghapus Pesan Tertentu (Clear Messages)
await sock.clearMessage(jid, key, timestamps)Query Pengguna (User Queries)
Cek Apakah Nomor Terdaftar di WhatsApp
let [result] = await sock.onWhatsApp(jid)
if (result.exists) console.log(`${jid} terdaftar di WhatsApp sebagai ${result.jid}`)Ambil Riwayat Chat (termasuk grup)
Kamu perlu mengambil pesan paling lama dari chat tersebut
let msg = await getOldestMessageInChat(jid)
await sock.fetchMessageHistory(
50, // maksimal 50 per query
msg.key,
msg.messageTimestamp
)- Hasilnya akan dikirimkan melalui event
messaging.history-set
Ambil Status WhatsApp (Bio)
let status = await sock.fetchStatus(jid)
console.log('Status: ' + status)Ambil Foto Profil (Profil, Grup, Channel)
let ppUrl = await sock.profilePictureUrl(jid)
console.log('Foto profil: ' + ppUrl)Ambil Profil Bisnis (Business Profile)
Cocok untuk akun bisnis WhatsApp, seperti deskripsi & kategori bisnis
let profile = await sock.getBusinessProfile(jid)
console.log('Deskripsi bisnis: ' + profile.description + ', Kategori: ' + profile.category)Cek Kehadiran Seseorang (Presence: Online / Typing)
sock.ev.on('presence.update', console.log)
await sock.presenceSubscribe(jid)Ubah Profil
Ubah Status Profil (Bio)
await sock.updateProfileStatus('Halo Dunia!')Ubah Nama Profil
await sock.updateProfileName('FidzzHost')Ubah Foto Profil (termasuk grup)
Sama seperti pesan media, kamu bisa pakai:
{ url },Buffer, atau{ stream }
await sock.updateProfilePicture(jid, { url: './foto-baru.jpeg' })Hapus Foto Profil (termasuk grup)
await sock.removeProfilePicture(jid)Grup WhatsApp (Groups)
Untuk mengubah pengaturan grup, kamu harus menjadi admin grup tersebut.
Membuat Grup
let group = await sock.groupCreate('Grup Hebat Fidzz', ['1234@s.whatsapp.net', '4564@s.whatsapp.net'])
console.log('Grup berhasil dibuat dengan ID: ' + group.gid)
await sock.sendMessage(group.id, { text: 'Halo semuanya!' })Tambah / Hapus / Jadikan Admin / Turunkan Admin
await sock.groupParticipantsUpdate(
jid,
['abcd@s.whatsapp.net', 'efgh@s.whatsapp.net'],
'add' // bisa diganti: 'remove', 'promote', 'demote'
)Ubah Nama Grup
await sock.groupUpdateSubject(jid, 'Nama Baru Grup!')Ubah Deskripsi Grup
await sock.groupUpdateDescription(jid, 'Deskripsi baru untuk grup ini')Ubah Pengaturan Grup
// hanya admin yang bisa kirim pesan
await sock.groupSettingUpdate(jid, 'announcement')
// semua anggota bisa kirim pesan
await sock.groupSettingUpdate(jid, 'not_announcement')
// semua anggota bisa ubah info grup (foto, nama, dll.)
await sock.groupSettingUpdate(jid, 'unlocked')
// hanya admin yang bisa ubah info grup
await sock.groupSettingUpdate(jid, 'locked')Keluar dari Grup
await sock.groupLeave(jid)Dapatkan Kode Undangan Grup
let code = await sock.groupInviteCode(jid)
console.log('Kode undangan grup: ' + code)
// gabung pakai: https://chat.whatsapp.com/ + codeReset / Ganti Kode Undangan Grup
let newCode = await s