CLI утилита для быстрого создания и настройки проектов на базе мультиплатформенного фреймворка umbot. Позволяет
генерировать готовую структуру для голосовых навыков (Алиса, Маруся, Сбер SmartApp) или чат-ботов (Telegram, VK, Viber, MAX) одной командой.
Также позволяет:
Установите фреймворк и создайте новый проект:
npx umbot create my-bot
cd my-bot
npm install
npm run build
npm start
После этого приложение будет доступно локально. Для тестирования используйте npm run dev (если настроено).
| Команда | Описание | Параметры |
|---|---|---|
create |
Создание нового проекта | <project-name> или <config-file.json> |
generateEnv |
Сгенерировать файл .env | - |
create| Флаг | Описание |
|---|---|
--minimal |
Создаёт минимальный рабочий проект (один файл, без контроллера и конфигов). Подходит для быстрого прототипа. Работает только с типом default. |
--prod |
Создаёт production-готовый проект с Dockerfile, .github/workflows/deploy.yml, .env. Удобно для развёртывания на сервере. |
💡 Важно: флаг
--minimalне применяется к типуquiz, так как викторина требует сложной логики и хранения состояния.
Для быстрого создания приложения, выполните следующую команду
npx umbot create my-bot-project
После выполнения команды, приложение успешно создастся, и останется только выполнить команду:
npm i
npm run build
npm start
Для быстрого создания приложения с дополнительными настройками, выполните следующую команду
Создайте файл config.json
{
"name": "quiz-bot",
"type": "quiz",
"mode": "dev",
"path": "./bots/quiz",
"config": {
"json": "./data",
"error_log": "./logs",
"isLocalStorage": true,
"tokens": {
"alisa": {
"token": "..."
},
"telegram": {
"token": "..."
}
}
},
"isEnv": true
}
Затем выполните:
npx umbot create config.json
Утилита создаст проект в папке ./bots/quiz со всеми указанными настройками.
npm i
npm run build
npm start
При создании проекта через JSON можно передать следующие параметры:
interface ProjectConfig {
// Название проекта (обязательное поле)
name: string;
// Тип проекта: "default" или "quiz"
type?: 'default' | 'quiz';
// Режим работы: "prod", "dev", "dev-online", "build"
mode?: 'prod' | 'dev' | 'dev-online' | 'build';
// Конфигурация приложения (IAppConfig из umbot)
// В CLI это объект, который будет слит с дефолтным конфигом шаблона.
config?: Record<string, unknown>;
// Параметры платформы/интенты (IAppParam из umbot)
// В CLI это объект, который будет слит с дефолтными params шаблона.
params?: Record<string, unknown>;
// Путь для создания проекта
path?: string;
// Имя хоста на котором будет запущено приложение. По умолчанию localhost
hostname?: string;
// Порт на котором будет запущено приложение. По умолчанию 3000
port?: number;
// Определяет нужно создавать .env файл или нет
isEnv?: boolean;
}
{
"name": "my-quiz-bot",
"type": "quiz",
"mode": "dev",
"path": "./bots/quiz",
"config": {
"json": "./data",
"error_log": "./logs",
"isLocalStorage": true,
"db": {
"host": "",
"user": "",
"pass": "",
"database": ""
},
"tokens": {
"alisa": {
"token": "token"
}
}
},
"isEnv": true
}
| Тип | Описание | Особенности |
|---|---|---|
default |
Базовый шаблон | Минимальная структура проекта |
quiz |
Шаблон викторины | Готовая структура для создания викторин |
| Режим | Описание |
|---|---|
prod |
Продакшн режим |
dev |
Режим разработки |
dev-online |
Режим разработки с webhook |
build |
Режим сборки |
Именование проектов:
Конфигурация:
Структура проекта: