Indicates info about a certain user.
Unless specified otherwise, when updating the local peer database, all fields from the newly received constructor take priority over the old constructor cached locally (including by removing fields that aren't set in the new constructor).
See here » for an implementation of the logic to use when updating the local user peer database.
Constructor schema is available as of layer 44. Switch »| Name | Type | Description | 
|---|---|---|
| flags | # | Flags, see TL conditional fields | 
| self | flags.10?true | Whether this user indicates the currently logged in user | 
| contact | flags.11?true | Whether this user is a contact When updating the local peer database, do not apply changes to this field if the minflag is set. | 
| mutual_contact | flags.12?true | Whether this user is a mutual contact. When updating the local peer database, do not apply changes to this field if the minflag is set. | 
| deleted | flags.13?true | Whether the account of this user was deleted. Changes to this flag should invalidate the local userFull cache for this user ID, see here » for more info. | 
| bot | flags.14?true | Is this user a bot? Changes to this flag should invalidate the local userFull cache for this user ID, see here » for more info. | 
| bot_chat_history | flags.15?true | Can the bot see all messages in groups? | 
| bot_nochats | flags.16?true | Can the bot be added to groups? | 
| verified | flags.17?true | Whether this user is verified | 
| restricted | flags.18?true | Access to this user must be restricted for the reason specified in restriction_reason | 
| min | flags.20?true | See min | 
| bot_inline_geo | flags.21?true | Whether the bot can request our geolocation in inline mode | 
| support | flags.23?true | Whether this is an official support user | 
| scam | flags.24?true | This may be a scam user | 
| apply_min_photo | flags.25?true | If set and minis set, the value ofphotocan be used to update the local database, see the documentation of that flag for more info. | 
| fake | flags.26?true | If set, this user was reported by many users as a fake or scam user: be careful when interacting with them. | 
| bot_attach_menu | flags.27?true | Whether this bot offers an attachment menu web app | 
| premium | flags.28?true | Whether this user is a Telegram Premium user Changes to this flag should invalidate the local userFull cache for this user ID, see here » for more info. Changes to this flag if the selfflag is set should also trigger the following calls, to refresh the respective caches:- The help.getConfig cache - The messages.getTopReactions cache if the botflag is not set | 
| attach_menu_enabled | flags.29?true | Whether we installed the attachment menu web app offered by this bot. When updating the local peer database, do not apply changes to this field if the minflag is set. | 
| flags2 | # | Flags, see TL conditional fields | 
| bot_can_edit | flags2.1?true | Whether we can edit the profile picture, name, about text and description of this bot because we own it. When updating the local peer database, do not apply changes to this field if the minflag is set.Changes to this flag (if minis not set) should invalidate the local userFull cache for this user ID. | 
| close_friend | flags2.2?true | Whether we marked this user as a close friend, see here » for more info. When updating the local peer database, do not apply changes to this field if the minflag is set. | 
| stories_hidden | flags2.3?true | Whether we have hidden » all active stories of this user. When updating the local peer database, do not apply changes to this field if the minflag is set. | 
| stories_unavailable | flags2.4?true | No stories from this user are visible. | 
| contact_require_premium | flags2.10?true | See here for more info on this flag ». | 
| bot_business | flags2.11?true | Whether this bot can be connected to a user as specified here ». | 
| bot_has_main_app | flags2.13?true | If set, this bot has configured a Main Mini App ». | 
| id | long | ID of the user, see here » for more info and the available ID range. | 
| access_hash | flags.0?long | Access hash of the user, see here » for more info. If this flag is set, when updating the local peer database, generate a virtual flag called min_access_hash, which is:- Set to trueifminis set AND-- The phoneflag is not set OR-- The phoneflag is set and the associated phone number string is non-empty- Set to falseotherwise.Then, apply both access_hashandmin_access_hashto the local database if:- min_access_hashis false OR- min_access_hashis true AND-- There is no locally cached object for this user OR -- There is no access_hashin the local cache OR-- The cached object's min_access_hashis also trueIf the final merged object stored to the database has the min_access_hashfield set to true, the relatedaccess_hashis only suitable to use ininputPeerPhotoFileLocation», to directly download the profile pictures of users, everywhere else ainputPeer*FromMessageconstructor will have to be generated as specified here ».Bots can also use min access hashes in some conditions, by passing 0instead of the min access hash. | 
| first_name | flags.1?string | First name. When updating the local peer database, apply changes to this field only if: - The minflag is not set OR- The minflag is set AND-- The minflag of the locally cached user entry is set. | 
| last_name | flags.2?string | Last name. When updating the local peer database, apply changes to this field only if: - The minflag is not set OR- The minflag is set AND-- The minflag of the locally cached user entry is set. | 
| username | flags.3?string | Main active username. When updating the local peer database, apply changes to this field only if: - The minflag is not set OR- The minflag is set AND-- The minflag of the locally cached user entry is set.Changes to this flag should invalidate the local userFull cache for this user ID if the above conditions are respected and the bot_can_editflag is also set. | 
| phone | flags.4?string | Phone number. When updating the local peer database, apply changes to this field only if: - The minflag is not set OR- The minflag is set AND-- The minflag of the locally cached user entry is set. | 
| photo | flags.5?UserProfilePhoto | Profile picture of user. When updating the local peer database, apply changes to this field only if: - The minflag is not set OR- The minflag is set AND-- The apply_min_photoflag is set OR-- The minflag of the locally cached user entry is set. | 
| status | flags.6?UserStatus | Online status of user. When updating the local peer database, apply changes to this field only if: - The minflag is not set OR- The minflag is set AND-- The minflag of the locally cached user entry is set OR-- The locally cached user entry is equal to userStatusEmpty. | 
| bot_info_version | flags.14?int | Version of the bot_info field in userFull, incremented every time it changes. Changes to this flag should invalidate the local userFull cache for this user ID, see here » for more info. | 
| restriction_reason | flags.18?Vector<RestrictionReason> | Contains the reason why access to this user must be restricted. | 
| bot_inline_placeholder | flags.19?string | Inline placeholder for this inline bot | 
| lang_code | flags.22?string | Language code of the user | 
| emoji_status | flags.30?EmojiStatus | Emoji status | 
| usernames | flags2.0?Vector<Username> | Additional usernames. When updating the local peer database, apply changes to this field only if: - The minflag is not set OR- The minflag is set AND-- The minflag of the locally cached user entry is set.Changes to this flag (if the above conditions are respected) should invalidate the local userFull cache for this user ID. | 
| stories_max_id | flags2.5?int | ID of the maximum read story. When updating the local peer database, do not apply changes to this field if the minflag of the incoming constructor is set. | 
| color | flags2.8?PeerColor | The user's accent color. | 
| profile_color | flags2.9?PeerColor | The user's profile color. | 
| bot_active_users | flags2.12?int | Monthly Active Users (MAU) of this bot (may be absent for small bots). | 
| bot_verification_icon | flags2.14?long | Describes a bot verification icon ». | 
| send_paid_messages_stars | flags2.15?long | If set, the user has enabled paid messages », we might need to pay the specified amount of Stars to send them messages, depending on the configured exceptions: check userFull. send_paid_messages_starsor users.getRequirementsToContact to see if the currently logged in user actually has to pay or not, see here » for the full flow. | 
Many constructors in the API need to be stored in a local database upon reception and should only ever be updated reactively (passively) when received via updates or by other means (as specified in the documentation), to avoid overloading the server by continuously requesting changes for the same unchanged information.
Extended user info
When updating the local peer database », all fields from the newly received constructor take priority over the old constructor cached locally (including by removing fields that aren't set in the new constructor).
In some situations user and channel constructors have reduced set of fields present (although id is always there) and min flag set.
Bots can install attachment menu and side menu entries, offering conveniently accessible, versatile web apps.
Returns current configuration, including data center configuration.
Got popular message reactions
Telegram allows users to specify granular privacy settings, choosing which users can or can't interact with them in certain ways.
Telegram users and channels can easily post and view stories through the API.
Business users can connect Telegram bots that will process and answer messages on their behalf. This allows businesses to seamlessly integrate any existing tools and workflows, or add AI assistants that manage their chats.
Bots can offer users interactive HTML5 web apps to completely replace any website.
Location of profile photo of channel/group/supergroup/user
How to transfer large data batches correctly.
User status has not been set yet.
Telegram allows users to set an emoticon or a custom emoji as status, to show next to their name in chats and profiles.
Telegram users and channels can change the accent color and background pattern of their profile page and their messages!
To further improve transparency on Telegram, official third-party services are able to assign extra verification icons to user accounts and chats — in order to prevent scams and reduce misinformation.
Telegram Stars can be used to pay for sending messages to users, supergroups and channels that have configured paid messages, requiring a payment for every message sent to them.
Telegram Stars are virtual items that allow users to purchase digital goods and services from bots and mini apps inside the Telegram ecosystem, send gifts to content creators on the Telegram platform, and more.
Check whether we can write to the specified users, used to implement bulk checks for Premium-only messages » and paid messages ».
For each input user, returns a RequirementToContact constructor (at the same offset in the vector) containing requirements to contact them.