Skip to content

Overview

@gramio/files is built-in GramIO package. You can also use it outside of this framework because it is framework-agnostic.

Usage

ts
import { 
Bot
,
MediaInput
,
MediaUpload
,
InlineKeyboard
} from "gramio";
const
bot
= new
Bot
(
process
.
env
.
BOT_BOT_TOKEN
as string)
.
on
("message", async (
ctx
) => {
ctx
.
sendMediaGroup
([
MediaInput
.
document
(
MediaUpload
.
url
(
"https://raw.githubusercontent.com/gramiojs/types/main/README.md" ) ),
MediaInput
.
document
(
MediaUpload
.
path
("./package.json")),
]); }) .
onStart
(
console
.
log
);
bot
.
start
();

Sending files

There are three ways to send files (photos, stickers, audio, media, etc.):

  1. If the file is already stored somewhere on the Telegram servers, you don't need to reupload it: each file object has a file_id field, simply pass this file_id as a parameter instead of uploading. There are no limits for files sent this way.
  2. Provide Telegram with an HTTP URL for the file to be sent. Telegram will download and send the file. 5 MB max size for photos and 20 MB max for other types of content.
  3. Post the file using multipart/form-data in the usual way that files are uploaded via the browser. 10 MB max size for photos, 50 MB for other files.

Sending by file_id

  • It is not possible to change the file type when resending by file_id. I.e. a video can't be sent as a photo, a photo can't be sent as a document, etc.
  • It is not possible to resend thumbnails.
  • Resending a photo by file_id will send all of its sizes.
  • file_id is unique for each individual bot and can't be transferred from one bot to another.
  • file_id uniquely identifies a file, but a file can have different valid file_ids even for the same bot.

To send a file by file_id with GramIO, you can put it as is.

ts
ctx
.
sendPhoto
(
fileId
);

Sending by URL

  • When sending by URL the target file must have the correct MIME type (e.g., audio/mpeg for sendAudio, etc.).
  • In sendDocument, sending by URL will currently only work for GIF, PDF and ZIP files.
  • To use sendVoice, the file must have the type audio/ogg and be no more than 1MB in size. 1-20MB voice notes will be sent as files.

To send a file by URL with GramIO, you can put it as is.

ts
ctx
.
sendPhoto
("https://.../cute-cat.png");

File uploading

To upload and send file you can use Media Upload Class-helper and GramIO will do all the work for you.

ts
ctx
.
sendPhoto
(
MediaUpload
.
path
("../cute-cat.png"));

Use File

In fact, GramIO can accept Web API's File and Blob.

So you can upload files even like this:

ts
import { Elysia } from "elysia";
import { bot } from "./bot";

new Elysia().post(
    "/",
    ({ body: { file } }) => {
        bot.api.sendPhoto({
            chat_id: 1,
            photo: file,
        });
    },
    {
        body: t.Object({
            file: t.File({
                type: "image",
                maxSize: "2m",
            }), // Elysia validates and accepts only the File type
        }),
    }
);

Or, for example, with Bun native File reader

ts
bot.api.sendDocument({
    chat_id: 1,
    document: Bun.file("README.md"),
});