UNPKG

telegram-mtproto

Version:
192 lines (131 loc) 5.88 kB
# telegram-mtproto [![npm version][npm-image]][npm-url] **Telegram Mobile Protocol** [(MTProto)](https://core.telegram.org/mtproto) library in **es6** ## About MTProto.. **MTProto** is the [Telegram Messenger](http://www.telegram.org) protocol _"designed for access to a server API from applications running on mobile devices"_. The Mobile Protocol is subdivided into three components ([from the official site](https://core.telegram.org/mtproto#general-description)): - High-level component (API query language): defines the method whereby API queries and responses are converted to binary messages. - Cryptographic (authorization) layer: defines the method by which messages are encrypted prior to being transmitted through the transport protocol. - Transport component: defines the method for the client and the server to transmit messages over some other existing network protocol (such as, http, https, tcp, udp). ## telegram-mtproto in short.. No more additional libs. The **telegram-mtproto** library implements the **Mobile Protocol** and provides all features for work with telegram protocol: - A high level api for server connection - Promise-based API - **HTTP connections** implemented in the transport layer - **Web worker** support for blazing fast crypto math works in background - A cipher implementation for **AES and RSA encryption** in the security layer - Both **plain-text and encrypted message** to communicate data with the server - **Diffie-Hellman key exchange** supported by the **prime factorization** function implemented in the security layer - **MTProto TL-Schema** compilation as **javascript classes and functions** - Custom **async storage** support for saving user data between sessions ## Installation ```bash $ npm install --save telegram-mtproto@beta ``` ## Usage ```javascript import MTProto from 'telegram-mtproto' const phone = { num : '+9996620001', code: '22222' } const api = { layer : 57, initConnection : 0x69796de9, api_id : 49631 } const server = { dev: true //We will connect to the test server. } //Any empty configurations fields can just not be specified const client = MTProto({ server, api }) async function connect(){ const { phone_code_hash } = await client('auth.sendCode', { phone_number : phone.num, current_number: false, api_id : 49631, api_hash : 'fb050b8f6771e15bfda5df2409931569' }) const { user } = await client('auth.signIn', { phone_number : phone.num, phone_code_hash: phone_code_hash, phone_code : phone.code }) console.log('signed as ', user) } connect() ``` Above we used two functions from the API. ```typescript type auth.sendCode = (phone_number: string, sms_type: int, api_id: int, api_hash: string, lang_code: string) => { phone_registered: boolean, phone_code_hash: string, send_call_timeout: int, is_password: boolean } type auth.signIn = (phone_number: string, phone_code_hash: string, phone_code: string) => { expires: int, user: User } ``` [More][send-code] about [them][sign-in], as well as about many other methods, you can read in the [official documentation][docs]. Additional examples can be obtained from [examples][examples] folder. ### Browser build Mtproto has standalone browser build `mtproto-browser.js`, which can be found in `node_modules/telegram-mtproto/dist` folder with a html page example. ## Storage `AsyncStorage` is an interface of the asynchronous plug-in for storing connection information, for example, user authorization is placed here. The module is made as pluggable for compatibility with any user data stores You can use your own storages like [localForage][localForage] for saving data. Module accepts the following interface ```typescript interface AsyncStorage { get(key: string): Promise<any>; set(key: string, value: any): Promise<void>; remove(...keys: string[]): Promise<void>; clear(): Promise<void>; } ``` ```javascript import { MTProto } from 'telegram-mtproto' import { api } from './config' import CustomStorage from './storage' const client = MTProto({ api, app: { storage: CustomStorage } }) ``` I draw your attention to the fact that typescript here is only for illustration purposes, and plain javascript is quite enough to make your own storage. By default, [MemoryStorage][memory-storage] is used, and all data is stored only in RAM. Also, library is shipped with [FileStorage][file-storage] for using with nodejs At the moment, the library uses the interface to store the following objects: ```typescript type StoredData = { dc: number, //ID of user's primary datacenter dcN_auth_key: string, dcN_server_salt: string //Datacenters auth keys, where N - dc id } ``` > When manually specifying a base datacenter, the library immediately starts using the updated value `AsyncStorage` interface references * [TypeScript][storage-ts] * [Flow][storage-flow] ## License The project is released under the [Mit License](./LICENSE) [examples]: https://github.com/zerobias/telegram-mtproto/tree/develop/examples [memory-storage]: https://github.com/zerobias/telegram-mtproto/blob/develop/src/plugins/memory-storage.js [file-storage]: https://github.com/zerobias/telegram-mtproto/blob/develop/src/plugins/file-storage/simple-file-storage.js [storage-ts]: https://github.com/zerobias/telegram-mtproto/blob/develop/index.d.ts#L56 [storage-flow]: https://github.com/zerobias/telegram-mtproto/blob/develop/src/plugins/index.h.js [localForage]: https://github.com/localForage/localForage [docs]: https://core.telegram.org/ [send-code]: https://core.telegram.org/method/auth.sendCode [sign-in]: https://core.telegram.org/method/auth.signIn [npm-url]: https://www.npmjs.org/package/telegram-mtproto [npm-image]: https://badge.fury.io/js/telegram-mtproto.svg