npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@bcoders.gr/telegram-client

v1.0.0

Published

Advanced Node.js Telegram client with EventEmitter support, message parsing, and real-time event handling

Downloads

7

Readme

@bcoders.gr/telegram-client

Advanced Node.js Telegram client with EventEmitter support, message parsing, and real-time event handling.

Features

  • 🚀 EventEmitter-based: Listen for new messages with event listeners
  • 📱 Message Parsing: Automatic extraction of URLs, cashtags, and metadata
  • 🔗 Reply & Forward Detection: Identifies related messages and relationships
  • 📂 Folder Support: Organizes chats by Telegram folders
  • 🧹 Clean Output: Removes empty fields and emoticons from chat titles
  • Real-time: Instant message processing and event emission

Installation

npm install @bcoders.gr/telegram-client

Quick Start

const MyTelegramClient = require('@bcoders.gr/telegram-client');

const apiId = 'your_api_id';
const apiHash = 'your_api_hash';
const session = 'your_session_string';

const client = new MyTelegramClient(apiId, apiHash, session);

// Listen for new messages
client.on('msg', (message) => {
    console.log('New message:', message);
});

// Connect to Telegram
async function start() {
    try {
        await client.connect();
        console.log('Connected successfully!');
    } catch (error) {
        console.error('Failed to connect:', error);
    }
}

start();

Message Structure

The client emits cleaned message objects with the following structure:

{
    id: 12345,
    timestamp: 1749401385,
    text: "Message content",
    urls: ["https://example.com"],
    cashtags: ["$BTC", "$ETH"],
    isForwarded: true,
    forwardedFrom: "Channel Name",
    relatedId: 12344,  // ID of replied-to or related message
    chatId: 1234567890,
    chatTitle: "Chat Name",
    chatFolder: "Crypto"
}

API Reference

Constructor

new MyTelegramClient(apiId, apiHash, session)
  • apiId: Your Telegram API ID
  • apiHash: Your Telegram API hash
  • session: Your session string

Methods

connect()

Connects to Telegram and starts listening for messages.

disconnect()

Disconnects from Telegram.

sendMessage(chatId, message)

Sends a message to a chat.

getMessages(chatId, limit = 10)

Retrieves messages from a chat.

getDialogs()

Gets all dialogs (chats) and organizes them by folders.

Events

msg

Emitted when a new message is received.

client.on('msg', (message) => {
    // Handle the message
});

Features in Detail

URL Extraction

Automatically extracts all URLs from messages, including:

  • HTTP/HTTPS links
  • Domain names
  • Shortened URLs

Cashtag Detection

Finds cryptocurrency symbols like $BTC, $ETH, $DOGE in messages.

Reply Detection

Identifies when a message is a reply to another message and includes the original message ID.

Forward Detection

Detects forwarded messages and extracts information about the original source.

Folder Organization

Organizes chats by Telegram folders for better categorization.

Clean Titles

Removes emoticons and extra whitespace from chat titles for cleaner output.

Getting Telegram Credentials

  1. Go to my.telegram.org
  2. Log in with your phone number
  3. Create a new application to get apiId and apiHash
  4. For the session string, you can use the telegram package's session generation

License

ISC

Contributing

Issues and pull requests are welcome on GitHub.

Author

pagovitsa