Peningkatan I: Codebase Skala Besar
Ketika bot-mu terus berkembang dan semakin kompleks, kamu akan mengalami kesulitan dalam mengatur struktur codebase untuk aplikasimu. Umumnya, kamu bisa membagi codebase menjadi beberapa file.
Solusi yang Tersedia
grammY masih cukup muda dan belum menyediakan integrasi resmi DI container. Ikuti @grammyjs
_news untuk mendapatkan notifikasi ketika integrasi sudah tersedia.
Perlu dicatat bahwa tidak ada satu solusi yang cocok untuk semua orang, sehingga kamu dapat dengan bebas mengatur struktur kode sesukamu. Berikut strategi yang sudah terbukti sesuai dalam penyusunan struktur kode.
- Kelompokkan hal-hal yang saling berkaitan di dalam file yang sama (atau di direktori yang sama, tergantung dari seberapa besar kode kamu).
- Buat sebuah instance bot terpusat yang menggabungkan semua middleware dengan cara memasangnya ke dalam bot.
- (Opsional) Filter update secara terpusat terlebih dahulu, lalu sebar update dengan cara yang sesuai. Untuk melakukannya, silahkan cek
bot
(API Reference) atau bisa juga menggunakan plugin router..route
Contoh siap pakai yang mengimplementasikan strategi-strategi di atas bisa ditemukan di Repositori Contoh Bot.
Contoh Struktur
Untuk bot sederhana yang menangani TODO list, kamu bisa menggunakan struktur berikut.
src/
├── bot.ts
└── todo/
├── item.ts
└── list.ts
item
hanya diperuntukkan untuk mendefinisikan hal-hal yang berhubungan dengan item-item TODO, kemudian bagian kode tersebut akan digunakan di list
.
Di list
, kamu bisa melakukan hal seperti berikut:
export const lists = new Composer();
// Tambahkan beberapa handler di sini
// yang fungsinya mengatur middleware kamu seperti biasanya.
lists.on("message", async (ctx) => {/* ... */});
2
3
4
5
Catatan: Jika menggunakan TypeScript, kamu perlu menambahkan custom context type-nya juga ketika membuat sebuah composer. Contohnya,
new Composer<My
.Context>()
Sebagai tambahan, kamu bisa menambahkan sebuah error boundary untuk mengatasi semua error yang terjadi di dalam module-mu.
Sekarang, kamu bisa memasang module-nya di bot
seperti ini:
import { lists } from "./todo/list";
const bot = new Bot("");
bot.use(lists);
// ... kamu bisa menambahkan beberapa module seperti `todo` di sini
bot.start();
2
3
4
5
6
7
8
Cara lainnya, kamu bisa menggunakan plugin router atau bot
untuk menggabungkan module-module yang berbeda dengan menentukan middleware mana yang akan digunakan di awal.
Yang perlu diingat adalah tidak ada satu cara mutlak untuk mengatur struktur bot kamu, karena masing-masing bot memiliki kasus yang berbeda. Seperti biasa, pilih cara yang menurutmu paling sesuai dan cocok untuk bot kamu, karena kamulah sebagai pencipta yang paham mengenai seluk-beluk dari bot kamu. 😉
Type Definition untuk Middleware yang Telah Di-extract
Struktur di atas dapat bekerja dengan baik menggunakan sebuah composer. Tetapi, di situasi tertentu kamu mungkin ingin meng-extract sebuah handler ke dalam sebuah function, alih-alih membuat sebuah composer baru lalu menambahkan logika ke dalamnya. Untuk melakukannya, kamu perlu menambahkan type definition middleware yang sesuai ke handler terkait karena mereka tidak bisa lagi mengambilnya dari composer.
grammY meng-export type definition untuk semua type middleware yang telah dikerucutkan, misalnya sebuah middleware yang bisa kamu tambahkan ke command handler. Selain itu, ia juga meng-export type definition beberapa context object yang telah dikerucutkan yang digunakan di middleware tersebut. Kedua type tersebut parameternya ditulis ulang dengan custom context object kamu. Oleh karena itu, command handler akan memiliki type Command
serta Command
di context objectnya. Mereka bisa digunakan dengan cara seperti ini:
import {
type CallbackQueryMiddleware,
type CommandContext,
type NextFunction,
} from "grammy";
function commandMiddleware(ctx: CommandContext<MyContext>, next: NextFunction) {
// menangani command handling
}
const callbackQueryMiddleware: CallbackQueryMiddleware<MyContext> = (ctx) => {
// menangani callback query
};
bot.command(["start", "help"], commandMiddleware);
bot.callbackQuery("query-data", callbackQueryMiddleware);
2
3
4
5
6
7
8
9
10
11
12
13
14
15
import {
type CallbackQueryMiddleware,
type CommandContext,
type NextFunction,
} from "https://deno.land/x/grammy@v1.30.0/mod.ts";
function commandMiddleware(ctx: CommandContext<MyContext>, next: NextFunction) {
// menangani command handling
}
const callbackQueryMiddleware: CallbackQueryMiddleware<MyContext> = (ctx) => {
// menangani callback query
};
bot.command(["start", "help"], commandMiddleware);
bot.callbackQuery("query-data", callbackQueryMiddleware);
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Kunjungi referensi API type aliases untuk melihat gambaran umum semua type aliases yang telah di-export oleh grammY.