org.telegram.telegrambots.meta.api.objects.User Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of telegrambots-meta Show documentation
Show all versions of telegrambots-meta Show documentation
Easy to use library to create Telegram Bots
package org.telegram.telegrambots.meta.api.objects;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonProperty;
import lombok.AllArgsConstructor;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.NonNull;
import lombok.RequiredArgsConstructor;
import lombok.Setter;
import lombok.ToString;
import lombok.experimental.SuperBuilder;
import lombok.extern.jackson.Jacksonized;
import org.telegram.telegrambots.meta.api.interfaces.BotApiObject;
/**
* This object represents a Telegram user or bot.
* @author Ruben Bermudez
* @version 6.1
*/
@EqualsAndHashCode(callSuper = false)
@Getter
@Setter
@ToString
@RequiredArgsConstructor
@AllArgsConstructor
@SuperBuilder
@Jacksonized
@JsonIgnoreProperties(ignoreUnknown = true)
public class User implements BotApiObject {
private static final String ID_FIELD = "id";
private static final String FIRST_NAME_FIELD = "first_name";
private static final String IS_BOT_FIELD = "is_bot";
private static final String LAST_NAME_FIELD = "last_name";
private static final String USERNAME_FIELD = "username";
private static final String LANGUAGE_CODE_FIELD = "language_code";
private static final String CAN_JOIN_GROUPS_FIELD = "can_join_groups";
private static final String CAN_READ_ALL_GROUP_MESSAGES_FIELD = "can_read_all_group_messages";
private static final String SUPPORT_INLINE_QUERIES_FIELD = "supports_inline_queries";
private static final String IS_PREMIUM_FIELD = "is_premium";
private static final String ADDED_TO_ATTACHMENT_MENU_FIELD = "added_to_attachment_menu";
private static final String CAN_CONNECT_TO_BUSINESS_FIELD = "can_connect_to_business";
/**
* Unique identifier for this user or bot.
*
* @apiNote This number may have more than 32 significant bits and some programming languages may have difficulty/silent defects in interpreting it.
* But it has at most 52 significant bits, so a 64-bit integer or double-precision float type are safe for storing this identifier.
*/
@JsonProperty(ID_FIELD)
@NonNull
private Long id;
/**
* User‘s or bot’s first name
*/
@JsonProperty(FIRST_NAME_FIELD)
@NonNull
private String firstName;
/**
* True, if this user is a bot
*/
@JsonProperty(IS_BOT_FIELD)
@NonNull
private Boolean isBot;
/**
* Optional.
* User‘s or bot’s last name
*/
@JsonProperty(LAST_NAME_FIELD)
private String lastName;
/**
* Optional.
* User‘s or bot’s username
*/
@JsonProperty(USERNAME_FIELD)
private String userName;
/**
* Optional.
* IETF language tag of the user's language
*/
@JsonProperty(LANGUAGE_CODE_FIELD)
private String languageCode;
/**
* Optional.
* True, if the bot can be invited to groups. Returned only in getMe.
*/
@JsonProperty(CAN_JOIN_GROUPS_FIELD)
private Boolean canJoinGroups;
/**
* Optional.
* True, if privacy mode is disabled for the bot. Returned only in getMe.
*/
@JsonProperty(CAN_READ_ALL_GROUP_MESSAGES_FIELD)
private Boolean canReadAllGroupMessages;
/**
* Optional.
* True, if the bot supports inline queries. Returned only in getMe.
*/
@JsonProperty(SUPPORT_INLINE_QUERIES_FIELD)
private Boolean supportInlineQueries;
/**
* Optional.
* True, if this user is a Telegram Premium user
*/
@JsonProperty(IS_PREMIUM_FIELD)
private Boolean isPremium;
/**
* Optional.
* True, if this user added the bot to the attachment menu
*/
@JsonProperty(ADDED_TO_ATTACHMENT_MENU_FIELD)
private Boolean addedToAttachmentMenu;
/**
* Optional.
* True, if the bot can be connected to a Telegram Business account to receive its messages.
* Returned only in getMe.
*/
@JsonProperty(CAN_CONNECT_TO_BUSINESS_FIELD)
private Boolean canConnectToBusiness;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy