Хостинг: Vercel Serverless Functions
У цьому посібнику ви дізнаєтесь, як розгорнути свого бота на Vercel за допомогою Vercel Serverless Functions; передбачається, що у вас вже є обліковий запис Vercel.
Структура проєкту
Єдиною передумовою для початку роботи з Vercel Serverless Functions є переміщення вашого коду до каталогу api
, як показано нижче. Ви також можете переглянути документацію Vercel для отримання додаткової інформації.
.
├── node_modules/
├── build/
├── api/
│ └── bot.ts
├── package.json
├── package-lock.json
└── tsconfig.json
Якщо ви використовуєте TypeScript, то вам, напевно, захочеться встановити @vercel
як залежність розробки (dev dependency
), але це необовʼязково для слідування цьому посібнику.
Налаштування Vercel
Наступним кроком є створення файлу vercel
на верхньому рівні вашого проєкту. Для прикладу наданої вище структури його вміст буде наступним:
{
"functions": {
"api/bot.ts": {
"memory": 1024,
"maxDuration": 10
}
}
}
2
3
4
5
6
7
8
Якщо ви хочете використовувати безкоштовний тарифний план Vercel, ваші конфігурації
memory
таmax
мають виглядати так, як показано вище, щоб не виходити за межі безкоштовних лімітів.Duration
Якщо ви хочете дізнатися більше про файл конфігурації vercel
, дивіться документацію Vercel.
Налаштування TypeScript
У файлі tsconfig
ми повинні вказати каталог виведення збірки як build
, а кореневий каталог як api
. Це важливо, оскільки ми будемо вказувати їх у параметрах розгортання Vercel.
{
"compilerOptions": {
"target": "ES2019",
"module": "commonjs",
"rootDir": "./api",
"moduleResolution": "node",
"resolveJsonModule": true,
"outDir": "./build",
"allowSyntheticDefaultImports": true,
"esModuleInterop": true,
"strict": true,
"skipLibCheck": true
}
}
2
3
4
5
6
7
8
9
10
11
12
13
14
Головний файл
Незалежно від того, чи використовуєте ви TypeScript або JavaScript, має бути вихідний файл, через який працює ваш бот. Він має виглядати приблизно так:
import { Bot, webhookCallback } from "grammy";
const token = process.env.BOT_TOKEN;
if (!token) throw new Error("BOT_TOKEN не вказаний");
const bot = new Bot(token);
export default webhookCallback(bot, "https");
2
3
4
5
6
7
8
Vercel Edge Functions надає обмежену підтримку grammY
Ви все ще можете використовувати пакет grammY та низку плагінів, але інші плагіни можуть бути несумісними через залежності лише від Node.js, які можуть не підтримуватися в Edge Runtime Vercel.
Наразі ми не маємо повного списку сумісних плагінів, тому вам доведеться перевірити це самостійно.
Використовуйте наведений нижче фрагмент коду, якщо ви хочете переключитися на Edge Functions:
import { Bot, webhookCallback } from "grammy";
const token = process.env.BOT_TOKEN;
if (!token) throw new Error("BOT_TOKEN is unset");
const bot = new Bot(token);
export const config = {
runtime: "edge",
};
export default webhookCallback(bot, "std/http");
2
3
4
5
6
7
8
9
10
11
12
У панелі керування Vercel
Припускаючи, що у вас вже є обліковий запис у Vercel, який підключений до GitHub, додайте новий проєкт та виберіть репозиторій свого бота. У розділі Build & Development Settings:
- Каталог виведення:
build
- Команда встановлення:
npm install
Не забудьте в налаштуваннях додати секрети, як-от токен вашого бота, як змінні середовища. Якщо ви це зробили, ви можете розгорнути свого бота!
Налаштування вебхуку
Наступним кроком є підключення вашого застосунку Vercel до Telegram. Змініть наведену нижче URL-адресу на свої дані авторизації та відвідайте її у своєму браузері:
https://api.telegram.org/bot<токен-бота>/setWebhook?url=<адреса>
<адреса>
потребує особливої уваги, оскільки потрібно використовувати домен вашого застосунку Vercel з маршрутом до коду бота: наприклад, https://
. Де bot
посилається на ваш файл bot
або bot
.
Після цього ви повинні побачити відповідь, схожу на цю:
{
"ok": true,
"result": true,
"description": "Webhook was set"
}
2
3
4
5
Вітаємо! Ваш бот тепер має бути запущений та працювати.