FAQ

Berikut ini adalah kumpulan pertanyaan yang sering diajukan mengenai beberapa error yang sering terjadi dan hal-hal seputar Deno.

Jika FAQ ini tidak menjawab pertanyaanmu, sebaiknya kamu juga membaca FAQ Botopen in new window yang ditulis oleh tim Telegram.

Kenapa Saya Mengalami Error Ini?

400 Bad Request: Cannot parse entities

Error ini terjadi karena kamu sedang mengirim sebuah pesan menggunakan format tertentu, misal kamu menggunakan parse_mode ketika mengirim pesan. Tetapi, format tersebut ada yang keliru, sehingga Telegram tidak bisa menguraikannya. Sebaiknya kamu membaca kembali dokumentasi Telegram di bagian pemformatanopen in new window. Byte offsite yang ditampilan di pesan error akan memberi tahu kamu dimana letak kesalahannya.

Menggunakan Entities Alih-Alih Formatting

Kamu bisa menyusun entities dengan mengirim pesan terkait menggunakan opsi entities. Teks pesanmu kemudian akan berisi string biasa, sehingga tidak perlu lagi menyaring karakter teks yang aneh. Meski kita jadi perlu menambahkan beberapa baris kode lagi, cara ini jauh lebih handal dan merupakan solusi yang cukup aman untuk permasalahan ini.

401 Unauthorized

Token bot kamu salah. Mungkin kamu berpikir ini hanyalah masalah sepele. Oh, boy! Kamu salah besar. Segera hubungi @BotFatheropen in new window untuk melihat token bot kamu.

403 Forbidden: bot was blocked by the user

Kamu mungkin menemui error ini ketika mengirim sebuah pesan ke seorang user.

Ketika seorang user memblokir bot kamu, kamu tidak bisa mengirim pesan ataupun berinteraksi dengan mereka (kecuali jika bot dan user tersebut berada di grup yang sama). Telegram sengaja melakukannya untuk melindungi para user. Kamu tidak bisa melakukan apa-apa dengan pemblokiran tersebut.

Setidaknya, kamu bisa melakukan tindakan-tindakan berikut:

  • Merespon error tersebut, misalnya dengan menghapus data user dari database.
  • Mengabaikan error-nya.
  • Menyimak update my_chat_member melalui bot.on("my_chat_member") untuk mendapatkan notifikasi ketika user memblokir bot kamu dengan cara membandingkan field status new chat member yang lama dengan yang baru.

404 Not found

Jika kamu menemui error ini ketika mengaktifkan bot, berarti ada yang salah dengan token bot kamu. Chat dengan @BotFatheropen in new window untuk melihat tokennya.

Jika bot sebelumnya berjalan dengan baik-baik saja, kemudian secara tiba-tiba mendapatkan error 404, berarti ada yang salah dengan coding-an bot kamu. Kamu bisa bertanya kepada kami di grupopen in new window (atau chat grup Rusiaopen in new window).

409 Conflict: terminated by other getUpdates request

Kamu secara tidak sengaja menjalankan bot sebanyak dua kali saat menggunakan long polling. Kamu hanya diizinkan menjalankan satu instance bot.

Jika kamu merasa sudah menjalankan bot sebanyak sekali saja, kamu perlu mengganti token bot-nya. Ketika token diganti, instance yang lain akan terhenti dengan sendirinya. Chat dengan @BotFatheropen in new window untuk mengganti token bot.

429: Too Many Requests: retry after X

Selamat! Kamu telah mendapatkan salah satu error yang paling sulit untuk diperbaiki.

Ada dua kemungkinan yang terjadi:

Pertama: Bot kamu tidak memiliki banyak user. Jika kasusnya seperti itu, berarti kamu sedang melakukan spam dengan cara mengirim request ke server Telegram secara berlebihan. Solusinya, jangan lakukan itu. Kamu harus mencari cara untuk mengurangi jumlah pemanggilan API tersebut seminimal mungkin.

Kedua: Bot kamu sangat populer dan memiliki banyak sekali user (ratusan ribu). Kamu sudah berupaya untuk melakukan pemanggilan API seminimal mungkin, tetapi tetap saja kamu menemui error ini (error flood wait).

Ada beberapa cara yang bisa kamu lakukan:

  1. Baca materi ini supaya paham dengan situasi yang dialami.
  2. Gunakan plugin transformer-throttler.
  3. Gunakan plugin auto-retry.
  4. Minta bantuan kami di grupopen in new window. Kami memiliki beberapa orang yang berpengalaman di sana.
  5. Meminta Telegram untuk meningkatkan batasan tersebut. Cara ini kemungkinan besar tidak akan berhasil jika kamu tidak melakukan langkah 1–3 terlebih dahulu.

Cannot find type definition file for ‘node-fetch’

Error ini dihasilkan karena beberapa type declaration tidak ditemukan.

Cara yang direkomendasikan untuk memperbaikinya adalah dengan mengubah skipLibCheck menjadi true di opsi compile TypeScript kamu.

Jka kamu merasa perlu untuk tetap menggunakan opsi ini di mode false, kamu bisa menginstal type definition yang hilang dengan cara menjalankan npm i -D @types/node-fetch@2.

Pertanyaan Seputar Deno

Kenapa kami mendukung Deno?

Berikut beberapa alasan kenapa kami lebih menyukai Deno dibandingkan dengan Node.js:

  • Pembuatannya lebih simpel dan cepat.
  • Peralatan yang disediakan lebih baik.
  • Secara bawaan mampu menjalankan TypeScript.
  • Tidak perlu mengurus package.json dan node_modules.
  • Ia memiliki sebuah library standar yang sudah di-review.

Deno diciptakan oleh Ryan Dahl—orang yang sama yang menciptakan Node.js. Dia mengutarakan 10 penyesalannya mengenai Node.js di video iniopen in new window.

grammY sendiri lebih memprioritaskan Deno, dari situ ia disusun ulang agar dapat mendukung Node.js sama baiknya.