telega_webapp

Telegram Mini Apps (Web Apps) support for the Telega Telegram Bot Library.

Package VersionHex Docs

A Mini App's frontend hands your backend a signed initData string. This package verifies that signature and decodes it into typed values, so you can trust who is calling. Pure Gleam, Erlang target.

Installation

gleam add telega_webapp

Usage

import telega_webapp
pub fn authenticate(token: String, init_data: String) {
// `init_data` is the raw `Telegram.WebApp.initData` query string your
// frontend forwarded (commonly in an `Authorization: tma <initData>` header).
case telega_webapp.validate_with_max_age(token, init_data, 86_400) {
Ok(data) -> {
let assert option.Some(user) = data.user
// `user` is now trusted: user.id, user.first_name, user.username, ...
Ok(user)
}
Error(reason) -> Error(reason)
}
}

Third-party apps

When your service receives Mini App data for a bot whose token you don't hold, verify the Ed25519signature instead, using the bot's numeric id:

telega_webapp.validate_third_party(bot_id, init_data, telega_webapp.Production)

Answering inline queries

import telega/inline_mode
import telega_webapp
let result =
inline_mode.new()
|> inline_mode.article(id: "1", title: "Done", text: "Saved!")
|> inline_mode.results
|> list.first
let assert Ok(result) = result
telega_webapp.answer_web_app_query(client, query_id, result)

Pair it with telega_wisp: forward Telegram.WebApp.initData from your frontend (e.g. in an Authorization: tma <initData> header), validate it in your wisp handler, and you have a full-stack Telegram app — telega + telega_wisp + telega_webapp.

License

Apache-2.0