Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Degreet/nestgram
Framework for working with Telegram Bot API on TypeScript like Nest.js
https://github.com/Degreet/nestgram
bot nest nestgram nestjs telegram telegram-bot telegram-bot-api typescript
Last synced: 2 months ago
JSON representation
Framework for working with Telegram Bot API on TypeScript like Nest.js
- Host: GitHub
- URL: https://github.com/Degreet/nestgram
- Owner: Degreet
- Created: 2022-05-31T18:54:27.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2024-06-10T20:04:44.000Z (7 months ago)
- Last Synced: 2024-11-01T08:36:25.581Z (2 months ago)
- Topics: bot, nest, nestgram, nestjs, telegram, telegram-bot, telegram-bot-api, typescript
- Language: TypeScript
- Homepage: https://degreetpro.gitbook.io/nestgram/
- Size: 244 KB
- Stars: 26
- Watchers: 1
- Forks: 5
- Open Issues: 3
-
Metadata Files:
- Readme: readme.md
Awesome Lists containing this project
- awesome-telegram - Nestgram
- awesome-telegram - Nestgram
README
# What is Nestgram?
Nestgram - Framework for working with Telegram Bot API on TypeScript like Nest.js
> βΉοΈ Nestgram in development. Current version is **1.8.7**
> If you found a bug, you can ask the [author](https://t.me/degreet) or ask the [form](https://do67hlsz91r.typeform.com/to/sI6NXBKV)> β οΈ Nestgram can't use Nest.js modules. But you can create own modules for Nestgram :)
# Links
- [Official website](https://degreetpro.gitbook.io/nestgram/)
- [GitHub](https://github.com/Degreet/nestgram)
- [Author](https://t.me/degreet)
- Our telegram channels:
- πΊπ¦ [Channel](https://t.me/nestgram_ts)
- πΊπΈ [Channel](https://t.me/nestgram_en)# Guide
You can read the [guide on the official Nestgram website](https://degreetpro.gitbook.io/nestgram/getting-started/guide), on [Medium website](https://medium.com/p/ff251fb825fd) or here
## Install Nestgram
You need to install nestgram at first. You can do this using yarn or npm
```nginx
yarn add nestgram
// or
npm i nestgram
```## Create main file
Our next step is creating the main file, so let's create the `main.ts` file
```typescript
import { NestGram } from 'nestgram';
import { AppModule } from './app/app.module';async function bootstrap(): Promise {
const bot = new NestGram('TOKEN', AppModule);
await bot.start();
}bootstrap();
```At first, we imported nestgram and our `AppModule`, later we will create it. In the next step, we created a bootstrap function, in which we set up and run the project. The `NestGram` class takes arguments:
| Argument | Name | Required |
|:---------|:------------------------------------------------------------------------------------------------------------------------------------------|:-------------|
| 1 | Bot token. You can get it [here](https://t.me/BotFather) | **Required** |
| 2 | [App module](#create-app.module.ts) | **Required** |
| 3 | Config [IPollingConfig](https://core.telegram.org/bots/api#getupdates) or [IWebhookConfig](https://core.telegram.org/bots/api#setwebhook) | Optional |
| 4 | [Run config](https://degreetpro.gitbook.io/nestgram/config/webhooks-and-run-config#run-config) | Optional |## Create app.module.ts
Let's create the `app.module.ts` file. In it, we will describe all available controllers and services
```typescript
import { Module } from 'nestgram';
import { AppController } from './app.controller';
import { AppService } from './app.service';@Module({
controllers: [AppController],
services: [AppService],
})
export class AppModule {}
```At first, we imported Module class from nestgram, `AppController` and `AppService` also, that we will create later. Then we described our controllers and services in `@Module` decorator
## Create app.controller.ts
Let's create the `app.controller.ts` file. In it, we will describe updates, that we want to handle
```typescript
import { OnCommand, Controller } from 'nestgram';
import { AppService } from './app.service';@Controller()
export class AppController {
constructor(private readonly appService?: AppService) {}@OnCommand('start')
start(): string {
return 'Hello, world!';
}
}
```We have created a controller where we describe an update when the user writes `/start`, and we handle it by sending a message `Hello, world!`
## Create app.service.ts
Let's create the `app.service.ts` file. In it, we will describe methods with working with db, that we will call in controller
```typescript
import { Service } from 'nestgram';@Service()
export class AppService {}
```We can describe methods in `AppService` class, and call it in controller by `this.appService`
## Run project
To run the project, open a terminal in the project directory and type:
```nginx
npm run dev
```Or build and run production:
```nginx
npm run build && npm run prod
```# Whatβs next?
Now you know about the syntax and structure of the Nestgram project, but if you want to write your own pro bot, you can check out the [Nestgram documentation](https://degreetpro.gitbook.io/nestgram/)
# Found a bug?
You can ask the [author](https://t.me/degreet) or ask the [form](https://do67hlsz91r.typeform.com/to/sI6NXBKV?typeform-source=admin.typeform.com)