Telegram Web, preconfigured for usage in I2P. http://web.telegram.i2p/
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
R4SAS b237792585
Add fix for gulp 4
5 years ago
.tx Added support for tx console util 9 years ago
app Merge upstream changes with switching to gulp 4 and dropping yarn 5 years ago
scripts Style bugfixes 10 years ago
test Added tests to improve Controller test coverage to over 10% (#1428) 7 years ago
.dockerignore Adds a Dockerfile 10 years ago
.gitignore Add karma, Jasmine, deps and karma.conf.js. Fixes #1291 (#1293) 8 years ago Added changelog for 0.6.0 7 years ago CONTRIBUTING: English fixes for PR rebase section 9 years ago
Dockerfile Update Dockerfile to work with gulp 9 years ago
LICENSE Initial commit 11 years ago
Makefile Bugfixes 8 years ago Merge upstream changes before upgrading to gulp 4 (it has issues) 5 years ago
gulpfile.js Add fix for gulp 4 5 years ago
karma.conf.js Added structure to test directory, Fully tested filters.js (#1393) 7 years ago
nginx-server.conf.example make websync reqests to i2p server 5 years ago
package.json Add fix for gulp 4 5 years ago Performance improvements 10 years ago
webogram.sublime-project Improved drafts sync 8 years ago


That fork of Webogram contain changes to work with I2P network.

js-standard-style Stories in Ready

Webogram — Telegram Web App

Telegram offers great apps for mobile communication. It is based on the MTProto protocol and has an Open API. I personally like Telegram for its speed and cloud-support (that makes a web app possible, unlike in the case of WA and others).

MTProto data can be carried over HTTP (SSL is also supported), so this project is my take at creating one.

That said, I'm using this app myself and I'd like to share its sources, so anyone can contribute to the development. Any help is welcome!


Here are some screenshots of the interface:

Sample screenshot 1 Mobile screenshot 2 Mobile screenshot 3

Unsupported at the moment

  • Secret chats
  • Black list
  • ...

Maintained locations

Description URL Type
Online Web-version (hosted on Telegram servers) hosted
Online Web-version (hosted on GitHub pages) hosted
Chrome Web Store clhhggbfdinjmjhajaheehoeibfljjno packed
Firefox & FirefoxOS Marketplace packed

Hosted version: the app is downloaded via HTTPS as a usual website. Will be available offline due to application cache.

Packed version: the app is downloaded at once in a package via HTTPS. The package is updated less frequently than the Web-version.

All of the apps above are submitted and maintained by @zhukov, so feel free to use them and report bugs here. Please do not report bugs which are only reproducible in different locations.

Technical details

The app is based on the AngularJS JavaScript framework, and written in pure JavaScript. jQuery is used for DOM manipulations, and Bootstrap as the CSS-framework.

Running locally

The project repository is based on angularjs-seed and includes gulp tasks, so it's easy to launch the app locally on your desktop. Install node.js.

Install dependencies with:

npm install

Optionaly, run the following commands in the project directory to install gulp globally:

sudo npm install -g gulp

This will install all the needed dependencies.

Running web-server

Just run npm start (gulp watch) to start the web server and the livereload task. Open http://localhost:8000/app/index.html in your browser.

Running as Chrome Packaged App

To run this application in Google Chrome as a packaged app, open this URL (in Chrome): chrome://extensions/, then tick "Developer mode" and press "Load unpacked extension...". Select the downloaded app folder and Webogram should appear in the list.

Run npm start (gulp watch) to watch for file changes and automatically rebuild the app.

Running as Firefox OS App

To run this application in Firefox as a packaged app, open "Menu" -> "Developer" -> "WebIDE" (or hit Shift + F8). Choose "Open packaged app" from the Project menu and select the app folder.

Run npm start (gulp watch) to watch for file changes and automatically rebuild the app.

Running in production

Run npm run clean (gulp clean), then npm run build (gulp publish) to build the minimized production version of the app. Copy dist folder contents to your web server. Don't forget to set X-Frame-Options SAMEORIGIN header (docs).

Third party libraries

Besides the frameworks mentioned above, other libraries are used for protocol and UI needs. Here is the short list:

Many thanks to all these libraries' authors and contributors. A detailed list with descriptions and licenses is available here.


The source code is licensed under GPL v3. License is available here.