Skip to content

Init Data

In the list of launch parameters, initialization data is located in the tgWebAppData parameter. It is a set of data mostly related to a specific user who launched the Mini App.

A striking feature of init data is the fact that it can be used as an authentication or authorization factor. For this reason, do not forget about the security of the application and init data specifically.

TIP

This section provides detailed information about an essential aspect of Telegram Mini Apps, which relates to application security for developers. We recommend utilizing well-established and tested packages:

Retrieving

To extract init data, it is required to firstly get the launch parameters, then extract parameter with name tgWebAppData and pass it to the URLSearchParams constructor:

typescript
// Get launch parameters.
const params = new URLSearchParams(window.location.hash.slice(1));
const initDataRaw = params.get('tgWebAppData'); // user=...&query_id=...&...

const initData = new URLSearchParams(initDataRaw);
// ['user', '{"id":279058397,"first_name":"Vladislav", ... }']
// ['chat_instance', '8428209589180549439']
// ['chat_type', 'sender']
// ['auth_date', '1698272211']
// ['hash', 'ddc15fc7419ae9cb9a597b98efee42ea0']
// Get launch parameters.
const params = new URLSearchParams(window.location.hash.slice(1));
const initDataRaw = params.get('tgWebAppData'); // user=...&query_id=...&...

const initData = new URLSearchParams(initDataRaw);
// ['user', '{"id":279058397,"first_name":"Vladislav", ... }']
// ['chat_instance', '8428209589180549439']
// ['chat_type', 'sender']
// ['auth_date', '1698272211']
// ['hash', 'ddc15fc7419ae9cb9a597b98efee42ea0']

Authorization and Authentication

A special feature of initialization data is the ability to be used as a factor for authorization or authentication. The fact is that the data generated by the native Telegram application is signed with the secret key of the Telegram bot, after which the generated signature is placed next to the parameters themselves.

Thus, knowing the secret key of the Telegram bot, the developer has the opportunity to verify the signature of the parameters and make sure that they were indeed issued to the specified user.

Also, the signature verification operation is fast enough and does not require large server resources. More information about the data signature and verification algorithm can be found in this documentation.

Sending to Server

In order to authorize the user on the server, the developer needs to transmit the initialization data that was specified when launching the Mini App. To make life easier for yourself, the developer can transmit them at each request to the server, after which the signature verification is carried out on the server side.

Here comes the example with the usage of such package as axios:

typescript
import axios from 'axios';

const initData = new URLSearchParams(window.location.hash.slice(1))
  .get('tgWebAppData');

if (initData === null) {
  throw new Error('Ooof! Something is wrong. Init data is missing');
}

// Create axios instance.  
const http = axios.create({
  headers: {
    // Append authorization header. 
    Authorization: `tma ${initData}`,
  }
});
import axios from 'axios';

const initData = new URLSearchParams(window.location.hash.slice(1))
  .get('tgWebAppData');

if (initData === null) {
  throw new Error('Ooof! Something is wrong. Init data is missing');
}

// Create axios instance.  
const http = axios.create({
  headers: {
    // Append authorization header. 
    Authorization: `tma ${initData}`,
  }
});

In turn, the following actions must be performed on the server side:

  1. Get the value of the Authorization header;
  2. Check that the first part of it is equal to tma;
  3. Get initialization data and verify its signature.

If this algorithm is successful, the server part of the application can trust the transmitted initialization data.

TIP

In real-world applications, it is recommended to use additional mechanisms for verifying initialization data. For example, add their expiration date. This check can be implemented using the auth_date parameter, which is responsible for the date when the parameters were created. This solution will allow in case of theft of initialization data to prevent their constant use by an attacker.

Parameters List

This section provides a complete list of parameters used in initialization data.

ParameterTypeDescription
auth_datenumber The date the initialization data was created. Is a number representing a Unix timestamp.
can_send_afternumberOptional. The number of seconds after which a message can be sent via the method answerWebAppQuery.
chatChatOptional. An object containing information about the chat with the bot in which the Mini Apps was launched. It is returned only for Mini Apps opened through the attachments menu.
chat_typestringOptional. The type of chat from which the Mini Apps was opened. Values:
  • sender
  • private
  • group
  • supergroup
  • channel
Returned only for applications opened by direct link.
chat_instancestringOptional. A global identifier indicating the chat from which the Mini Apps was opened. Returned only for applications opened by direct link.
hashstringInitialization data signature.
query_idstringOptional. The unique session ID of the Mini App. Used in the process of sending a message via the method answerWebAppQuery.
receiverUserOptional. An object containing data about the chat partner of the current user in the chat where the bot was launched via the attachment menu. Returned only for private chats and only for Mini Apps launched via the attachment menu.
start_paramstringOptional. The value of the startattach or startapp query parameter specified in the link. It is returned only for Mini Apps opened through the attachment menu.
userUserOptional. An object containing information about the current user.

Other Types

Chat

Describes the chat information.

PropertyTypeDescription
idnumberUnique chat ID.
typestring Chat type. Values:
  • group
  • supergroup
  • channel
titlestringChat title.
photo_urlstringOptional. Chat photo link. The photo can have .jpeg and .svg formats. It is returned only for Mini Apps opened through the attachments menu.
usernamestringOptional. Chat user login.

User

Describes information about a user or bot.

PropertyTypeDescription
added_to_attachment_menubooleanOptional. True, if this user added the bot to the attachment menu.
allows_write_to_pmbooleanOptional. True, if this user allowed the bot to message them.
is_premiumbooleanOptional. Has the user purchased Telegram Premium.
first_namestringBot or user name.
idnumberBot or user ID.
is_botbooleanOptional. Is the user a bot.
last_namestringOptional. User's last name.
language_codestringOptional. IETF user's language.
photo_urlstringOptional. Link to the user's or bot's photo. Photos can have formats .jpeg and .svg. It is returned only for Mini Apps opened through the attachment menu.
usernamestringOptional. Login of the bot or user.

Released under the MIT License.