--- title: Methods description: What do you want to do? image: https://docs.madelineproto.xyz/favicons/android-chrome-256x256.png --- # What do you want to do? [Go back to API documentation index](..) [Go to the old code-version method index](api_README.md) * [Logout](https://docs.madelineproto.xyz/logout.html) * [Login](https://docs.madelineproto.xyz/docs/LOGIN.html) * [Change 2FA password](https://docs.madelineproto.xyz/update2fa.html) * [Get all chats, broadcast a message to all chats](https://docs.madelineproto.xyz/docs/DIALOGS.html) * [Get the full participant list of a channel/group/supergroup](https://docs.madelineproto.xyz/getPwrChat.html) * [Get full info about a user/chat/supergroup/channel](https://docs.madelineproto.xyz/getFullInfo.html) * [Get info about a user/chat/supergroup/channel](https://docs.madelineproto.xyz/getInfo.html) * [Get info about the currently logged-in user](https://docs.madelineproto.xyz/getSelf.html) * [Upload or download files up to 1.5 GB](https://docs.madelineproto.xyz/docs/FILES.html) * [Make a phone call and play a song](https://docs.madelineproto.xyz/docs/CALLS.html) * [Create a secret chat bot](https://docs.madelineproto.xyz/docs/SECRET_CHATS.html) * Add GIF to saved gifs list: messages.saveGif * Add/remove sticker from recent stickers list: messages.saveRecentSticker * Adds a user to a chat and sends a service message on it.: messages.addChatUser * Adds the user to the blacklist.: contacts.block * Allow or disallow any user to invite users to this channel/supergroup: channels.toggleInvites * Answer an inline query, for bots only: messages.setInlineBotResults * Answers a custom query; for bots only: bots.answerWebhookJSONQuery * Cancel the login verification code: auth.cancelCode * Chanages chat name and sends a service message on it.: messages.editChatTitle * Change privacy settings of current account: account.setPrivacy * Change the phone number of the current account: account.changePhone * Change the photo of a [channel/supergroup](https://core.telegram.org/api/channel): channels.editPhoto * Change the username of a supergroup/channel: channels.updateUsername * Changes chat photo and sends a service message on it: messages.editChatPhoto * Changes username for the current user.: account.updateUsername * Check if a username is free and can be assigned to a channel/supergroup: channels.checkUsername * Check if this phone number is registered on telegram: auth.checkPhone * Check the validity of a chat invite link and get basic info about it: messages.checkChatInvite * Clear recent stickers: messages.clearRecentStickers * Clear saved payment information: payments.clearSavedInfo * Confirm a phone number to cancel account deletion, for more info [click here »](https://core.telegram.org/api/account-deletion): account.confirmPhone * Confirms receipt of messages by a client, cancels PUSH-notification sending.: messages.receivedMessages * Create a [supergroup/channel](https://core.telegram.org/api/channel).: channels.createChannel * Creates a new chat.: messages.createChat * Delete a [channel/supergroup](https://core.telegram.org/api/channel): channels.deleteChannel * Delete a contact: contacts.deleteContact * Delete all messages sent by a certain user in a [supergroup](https://core.telegram.org/api/channel): channels.deleteUserHistory * Delete all temporary authorization keys **except for** the ones specified: auth.dropTempAuthKeys * Delete messages in a [channel/supergroup](https://core.telegram.org/api/channel): channels.deleteMessages * Delete the user's account from the telegram servers. Can be used, for example, to delete the account of a user that provided the login code, but forgot the [2FA password and no recovery method is configured](https://core.telegram.org/api/srp).: account.deleteAccount * Deletes a device by its token, stops sending PUSH-notifications to it.: account.unregisterDevice * Deletes a user from a chat and sends a service message on it.: messages.deleteChatUser * Deletes communication history.: messages.deleteHistory * Deletes messages by their identifiers.: messages.deleteMessages * Deletes profile photos.: photos.deletePhotos * Deletes several contacts from the list.: contacts.deleteContacts * Deletes the user from the blacklist.: contacts.unblock * Destroy current authorization key: destroy_auth_key * Destroy the current MTProto session: destroy_session * Do not send answer to provided request: rpc_drop_answer * Edit an inline bot message: messages.editInlineBotMessage * Edit message: messages.editMessage * Edit the about text of a channel/supergroup: channels.editAbout * Edit the name of a [channel/supergroup](https://core.telegram.org/api/channel): channels.editTitle * Edits notification settings from a given user/group, from all users/all groups.: account.updateNotifySettings * Enable all users are admins in normal groups (not supergroups): messages.toggleChatAdmins * Enable/disable message signatures in channels: channels.toggleSignatures * Export an invite link for a chat: messages.exportChatInvite * Export contact as card: contacts.exportCard * Export the invite link of a channel: channels.exportInvite * Find out if a media message's caption can be edited: messages.getMessageEditData * Forward message: messages.forwardMessage * Forwards messages by their IDs.: messages.forwardMessages * Get [channel/supergroup](https://core.telegram.org/api/channel) messages: channels.getMessages * Get [channels/supergroups/geogroups](https://core.telegram.org/api/channel) we're admin in. Usually called when the user exceeds the [limit](../constructors/config.md) for owned public [channels/supergroups/geogroups](https://core.telegram.org/api/channel), and the user is given the choice to remove one of his channels/supergroups/geogroups.: channels.getAdminedPublicChannels * Get [instant view](https://instantview.telegram.org) page: messages.getWebPage * Get a document by its SHA256 hash, mainly used for gifs: messages.getDocumentByHash * Get a payment form: payments.getPaymentForm * Get all archived stickers: messages.getArchivedStickers * Get all chats, channels and supergroups: messages.getAllChats * Get all installed stickers: messages.getAllStickers * Get and increase the view counter of a message sent or forwarded from a [channel](https://core.telegram.org/api/channel): messages.getMessagesViews * Get changelog of current app: help.getAppChangelog * Get chats in common with a user: messages.getCommonChats * Get days to live of account: account.getAccountTTL * Get dialog info of specified peers: messages.getPeerDialogs * Get featured stickers: messages.getFeaturedStickers * Get future salts: get_future_salts * Get highscores of a game sent using an inline bot: messages.getInlineGameHighScores * Get highscores of a game: messages.getGameHighScores * Get info about [channels/supergroups](https://core.telegram.org/api/channel): channels.getChannels * Get info about a [channel/supergroup](https://core.telegram.org/api/channel) participant: channels.getParticipant * Get info about a stickerset: messages.getStickerSet * Get installed mask stickers: messages.getMaskStickers * Get link and embed info of a message in a [channel/supergroup](https://core.telegram.org/api/channel): channels.exportMessageLink * Get logged-in sessions: account.getAuthorizations * Get most used peers: contacts.getTopPeers * Get payment receipt: payments.getPaymentReceipt * Get peer settings: messages.getPeerSettings * Get phone call configuration to be passed to libtgvoip's shared config: phone.getCallConfig * Get pinned dialogs: messages.getPinnedDialogs * Get preview of webpage: messages.getWebPagePreview * Get privacy settings of current account: account.getPrivacy * Get recent stickers: messages.getRecentStickers * Get saved GIFs: messages.getSavedGifs * Get saved payment information: payments.getSavedInfo * Get stickers attached to a photo or video: messages.getAttachedStickers * Get temporary payment password: account.getTmpPassword * Get terms of service: help.getTermsOfService * Get the participants of a channel: channels.getParticipants * Gets back found messages: messages.search * Gets back the conversation history with one interlocutor / within a chat: messages.getHistory * Gets current notification settings for a given user/group, from all users/all groups.: account.getNotifySettings * Hide report spam popup: messages.hideReportSpam * If you sent an invoice requesting a shipping address and the parameter is\_flexible was specified, the bot will receive an [updateBotShippingQuery](../constructors/updateBotShippingQuery.md) update. Use this method to reply to shipping queries.: messages.setBotShippingResults * Import a chat invite and join a private chat/supergroup/channel: messages.importChatInvite * Import card as contact: contacts.importCard * Imports contacts: saves a full list on the server, adds already registered contacts to the contact list, returns added contacts and their info.: contacts.importContacts * Informs the server about the number of pending bot updates if they haven't been processed for a long time; for bots only: help.setBotUpdatesStatus * Initialize connection: initConnection * Install a stickerset: messages.installStickerSet * Installs a previously uploaded photo as a profile photo.: photos.updateProfilePhoto * Invite friends to telegram!: auth.sendInvites * Invite users to a channel/supergroup: channels.inviteToChannel * Invoke a request without subscribing the used connection for [updates](https://core.telegram.org/api/updates) (this is enabled by default for [file queries](https://core.telegram.org/api/files)).: invokeWithoutUpdates * Invoke the specified query using the specified API [layer](https://core.telegram.org/api/invoking#layers): invokeWithLayer * Invokes a query after a successfull completion of previous queries: invokeAfterMsgs * Invokes a query after successfull completion of one of the previous queries.: invokeAfterMsg * Join a channel/supergroup: channels.joinChannel * Kick user from channel: channels.kickFromChannel * Leave a [channel/supergroup](https://core.telegram.org/api/channel): channels.leaveChannel * Log out an active [authorized session](https://core.telegram.org/api/auth) by its hash: account.resetAuthorization * Make a user admin in a [legacy group](https://core.telegram.org/api/channel).: messages.editChatAdmin * Mark [channel/supergroup](https://core.telegram.org/api/channel) history as read: channels.readHistory * Mark new featured stickers as read: messages.readFeaturedStickers * Marks message history as read.: messages.readHistory * Marks message history within a secret chat as read.: messages.readEncryptedHistory * Modify the admin rights of a user in a [supergroup/channel](https://core.telegram.org/api/channel).: channels.editAdmin * Notifies the sender about the recipient having listened a voice message or watched a video.: messages.readMessageContents * Obtain configuration for two-factor authorization with password: account.getPassword * Once the user has confirmed their payment and shipping details, the bot receives an [updateBotPrecheckoutQuery](../constructors/updateBotPrecheckoutQuery.md) update. Use this method to respond to such pre-checkout queries. **Note**: Telegram must receive an answer within 10 seconds after the pre-checkout query was sent.: messages.setBotPrecheckoutResults * Optional: notify the server that the user is currently busy in a call: this will automatically refuse all incoming phone calls until the current phone call is ended.: phone.receivedCall * Pin/unpin a dialog: messages.toggleDialogPin * Pings the server and causes disconection if the same method is not called within ping_disconnect_delay: ping_delay_disconnect * Pings the server: ping * Press an inline callback button and get a callback answer from the bot: messages.getBotCallbackAnswer * Query an inline bot: messages.getInlineBotResults * Rate a call: phone.setCallRating * Register device to receive [PUSH notifications](https://core.telegram.org/api/push-updates): account.registerDevice * Reorder installed stickersets: messages.reorderStickerSets * Reorder pinned dialogs: messages.reorderPinnedDialogs * Report a new incoming chat for spam, if the [peer settings](../constructors/peerSettings.md) of the chat allow us to do that: messages.reportSpam * Report a peer for violation of telegram's Terms of Service: account.reportPeer * Report a secret chat for spam: messages.reportEncryptedSpam * Reports some messages from a user in a supergroup as spam; requires administrator rights in the supergroup: channels.reportSpam * Request recovery code of a [2FA password](https://core.telegram.org/api/srp), only for accounts with a [recovery email configured](https://core.telegram.org/api/srp#email-verification).: auth.requestPasswordRecovery * Requests Diffie-hellman parameters for key exchange: req_DH_params * Requests PQ for factorization: req_pq * Resend the login code via another medium, the phone code type is determined by the return value of the previous auth.sendCode/auth.resendCode: see [login](https://core.telegram.org/api/auth) for more info.: auth.resendCode * Reset [rating](https://core.telegram.org/api/top-rating) of top peer: contacts.resetTopPeerRating * Reset the [2FA password](https://core.telegram.org/api/srp) using the recovery code sent using [auth.requestPasswordRecovery](../methods/auth.requestPasswordRecovery.md).: auth.recoverPassword * Resets all notification settings from users and groups.: account.resetNotifySettings * Returns a list of available wallpapers.: account.getWallPapers * Returns basic user info according to their identifiers.: users.getUsers * Returns chat basic info on their IDs.: messages.getChats * Returns content of an HTTP file or a part, by proxying the request through telegram.: upload.getWebFile * Returns current configuration, icluding data center configuration.: help.getConfig * Returns info on data centre nearest to the user.: help.getNearestDc * Returns information on update availability for the current application.: help.getAppUpdate * Returns text of a text message with an invitation.: help.getInviteText * Returns the current user dialog list.: messages.getDialogs * Returns the current user's contact list.: contacts.getContacts * Returns the list of blocked users.: contacts.getBlocked * Returns the list of contact statuses.: contacts.getStatuses * Returns the list of messages by their IDs.: messages.getMessages * Returns the list of user photos.: photos.getUserPhotos * Returns the support user for the 'ask a question' feature.: help.getSupport * Returns users found by username substring.: contacts.search * Save a message [draft](https://core.telegram.org/api/drafts) associated to a chat.: messages.saveDraft * Save developer info for telegram contest: contest.saveDeveloperInfo * Save get all message [drafts](https://core.telegram.org/api/drafts).: messages.getAllDrafts * Saves logs of application on the server.: help.saveAppLog * Search for GIFs: messages.searchGifs * Search for messages and peers globally: messages.searchGlobal * Send a media: messages.sendMedia * Send a result obtained using [messages.getInlineBotResults](../methods/messages.getInlineBotResults.md).: messages.sendInlineBotResult * Send compiled payment form: payments.sendPaymentForm * Send confirmation code to cancel account deletion, for more info [click here »](https://core.telegram.org/api/account-deletion): account.sendConfirmPhoneCode * Send phone call debug data to server: phone.saveCallDebug * Send typing event by the current user to a secret chat.: messages.setEncryptedTyping * Sends a current user typing event (see [SendMessageAction](../types/SendMessageAction.md) for all event types) to a conversation partner or group.: messages.setTyping * Sends a custom request; for bots only: bots.sendCustomRequest * Sends a message to a chat: messages.sendMessage * Sends a message with a file attachment to a secret chat: messages.sendEncryptedFile * Sends a service message to a secret chat.: messages.sendEncryptedService * Sends a text message to a secret chat.: messages.sendEncrypted * Set account self-destruction period: account.setAccountTTL * Set the callback answer to a user button press (bots only): messages.setBotCallbackAnswer * Set the pinned message of a channel/supergroup: channels.updatePinnedMessage * Sets client diffie-hellman parameters: set_client_DH_params * Start a conversation with a bot using a [deep linking parameter](https://core.telegram.org/bots#deep-linking): messages.startBot * Submit requested order information for validation: payments.validateRequestedInfo * Terminates all user's authorized sessions except for the current one. After calling this method it is necessary to reregister the current device using the method [account.registerDevice](../methods/account.registerDevice.md): auth.resetAuthorizations * Turn a [legacy group into a supergroup](https://core.telegram.org/api/channel): messages.migrateChat * Uninstall a stickerset: messages.uninstallStickerSet * Updates current user profile photo.: photos.uploadProfilePhoto * Updates online user status.: account.updateStatus * Updates user profile.: account.updateProfile * Use this method to set the score of the specified user in a game sent as a normal message (bots only).: messages.setGameScore * Use this method to set the score of the specified user in a game sent as an inline message (bots only).: messages.setInlineGameScore * Validates a username and checks availability.: account.checkUsername * Verify a new phone number to associate to the current account: account.sendChangePhoneCode * When client-side passcode lock feature is enabled, will not show message texts in incoming [PUSH notifications](https://core.telegram.org/api/push-updates).: account.updateDeviceLocked * You cannot use this method directly, instead modify the PFS and default_temp_auth_key_expires_in settings, see https://docs.madelineproto.xyz/docs/SETTINGS.html for more info: auth.bindTempAuthKey * You cannot use this method directly, instead use $MadelineProto->getDhConfig();: messages.getDhConfig * You cannot use this method directly, see https://docs.madelineproto.xyz for more info on handling secret chats: messages.acceptEncryption * You cannot use this method directly, see https://docs.madelineproto.xyz for more info on handling secret chats: messages.discardEncryption * You cannot use this method directly, see https://docs.madelineproto.xyz for more info on handling secret chats: messages.requestEncryption * You cannot use this method directly, see https://docs.madelineproto.xyz for more info on handling updates: updates.getChannelDifference * You cannot use this method directly, see https://docs.madelineproto.xyz for more info on handling updates: updates.getDifference * You cannot use this method directly, see https://docs.madelineproto.xyz for more info on handling updates: updates.getState * You cannot use this method directly, see https://docs.madelineproto.xyz#calls for more info on handling calls: phone.acceptCall * You cannot use this method directly, see https://docs.madelineproto.xyz#calls for more info on handling calls: phone.confirmCall * You cannot use this method directly, see https://docs.madelineproto.xyz#calls for more info on handling calls: phone.discardCall * You cannot use this method directly, see https://docs.madelineproto.xyz#calls for more info on handling calls: phone.requestCall * You cannot use this method directly, use $MadelineProto->exportAuthorization() instead, see https://docs.madelineproto.xyz/docs/LOGIN.html: auth.exportAuthorization * You cannot use this method directly, use $MadelineProto->importAuthorization($authorization) instead, see https://docs.madelineproto.xyz/docs/LOGIN.html: auth.importAuthorization * You cannot use this method directly, use the botLogin method instead (see https://docs.madelineproto.xyz for more info): auth.importBotAuthorization * You cannot use this method directly, use the completePhoneLogin method instead (see https://docs.madelineproto.xyz for more info): auth.signIn * You cannot use this method directly, use the completeSignup method instead (see https://docs.madelineproto.xyz for more info): auth.signUp * You cannot use this method directly, use the complete_2fa_login method instead (see https://docs.madelineproto.xyz for more info): auth.checkPassword * You cannot use this method directly, use the getPwrChat, getInfo, getFullInfo methods instead (see https://docs.madelineproto.xyz for more info): channels.getFullChannel * You cannot use this method directly, use the getPwrChat, getInfo, getFullInfo methods instead (see https://docs.madelineproto.xyz for more info): messages.getFullChat * You cannot use this method directly, use the getPwrChat, getInfo, getFullInfo methods instead (see https://docs.madelineproto.xyz for more info): users.getFullUser * You cannot use this method directly, use the logout method instead (see https://docs.madelineproto.xyz for more info): auth.logOut * You cannot use this method directly, use the phoneLogin method instead (see https://docs.madelineproto.xyz for more info): auth.sendCode * You cannot use this method directly, use the resolveUsername, getPwrChat, getInfo, getFullInfo methods instead (see https://docs.madelineproto.xyz for more info): contacts.resolveUsername * You cannot use this method directly, use the upload, downloadToStream, downloadToFile, downloadToDir methods instead; see https://docs.madelineproto.xyz for more info: upload.getFile * You cannot use this method directly, use the upload, downloadToStream, downloadToFile, downloadToDir methods instead; see https://docs.madelineproto.xyz for more info: upload.saveBigFilePart * You cannot use this method directly, use the upload, downloadToStream, downloadToFile, downloadToDir methods instead; see https://docs.madelineproto.xyz for more info: upload.saveFilePart * You cannot use this method directly: messages.receivedQueue * You cannot use this method directly; use $MadelineProto->update_2fa($params), instead (see https://docs.madelineproto.xyz for more info): account.getPasswordSettings * You cannot use this method directly; use $MadelineProto->update_2fa($params), instead (see https://docs.madelineproto.xyz for more info): account.updatePasswordSettings