Built and signed on GitHub ActionsBuilt and signed on GitHub Actions
Built and signed on GitHub Actions
latest
gramiojs/typesCode-generated and Auto-published Telegram Bot API types
This package works with Cloudflare Workers, Node.js, Deno, Bun, Browsers




JSR Score
100%
Published
2 months ago (8.3.3)
Code-generated and Auto-published Telegram Bot API types
Versioning
8.1.x types are for 8.1 Telegram Bot API
Usage as an NPM package
import type { APIMethods, APIMethodReturn } from "@gramio/types"; type SendMessageReturn = Awaited<ReturnType<APIMethods["sendMessage"]>>; // ^? type SendMessageReturn = TelegramMessage type GetMeReturn = APIMethodReturn<"getMe">; // ^? type GetMeReturn = TelegramUser
Please see API Types References
Auto-update package
This library is updated automatically to the latest version of the Telegram Bot API in case of changes thanks to CI CD! If the github action failed, there are no changes in the Bot API
Imports (after @gramio/
)
index
- exports everything in the sectionmethods
- exportsAPIMethods
which describes the api functionsobjects
- exports objects with theTelegram
prefix (for example Update)params
- exports params that are used inmethods
withParams
postfix
Write you own type-safe Telegram Bot API wrapper
import type { APIMethods, APIMethodParams, TelegramAPIResponse, } from "@gramio/types"; const TBA_BASE_URL = "https://api.telegram.org/bot"; const TOKEN = ""; const api = new Proxy({} as APIMethods, { get: <T extends keyof APIMethods>(_target: APIMethods, method: T) => async (params: APIMethodParams<T>) => { const response = await fetch(`${TBA_BASE_URL}${TOKEN}/${method}`, { method: "POST", headers: { "Content-Type": "application/json", }, body: JSON.stringify(params), }); const data = (await response.json()) as TelegramAPIResponse; if (!data.ok) throw new Error(`Some error occurred in ${method}`); return data.result; }, }); api.sendMessage({ chat_id: 1, text: "message", });
Usage with @gramio/keyboards
import { Keyboard } from "@gramio/keyboards"; // the code from the example above api.sendMessage({ chat_id: 1, text: "message with keyboard", reply_markup: new Keyboard().text("button text"), });
With File uploading support
Generate types manually
Prerequire - rust
- Clone this repo and open it
git clone https://github.com/gramiojs/types.git
- Clone repo with Telegram Bot API schema generator
git clone https://github.com/ark0f/tg-bot-api.git
- Run the JSON schema generator in the
cloned
folder
cd tg-bot-api && cargo run --package gh-pages-generator --bin gh-pages-generator -- dev && cd ..
- Run types code-generation from the
root
of the project
bun generate
or, if you don't use bun
, use tsx
npx tsx src/index.ts
- Profit! Check out the types of Telegram Bot API in
out
folder!
Built and signed on
View transparency logGitHub Actions
Add Package
deno add jsr:@gramio/types
Import symbol
import * as types from "@gramio/types";
---- OR ----
Import directly with a jsr specifier
import * as types from "jsr:@gramio/types";
Add Package
npx jsr add @gramio/types
Import symbol
import * as types from "@gramio/types";
Add Package
yarn dlx jsr add @gramio/types
Import symbol
import * as types from "@gramio/types";
Add Package
pnpm dlx jsr add @gramio/types
Import symbol
import * as types from "@gramio/types";
Add Package
bunx jsr add @gramio/types
Import symbol
import * as types from "@gramio/types";