2019-05-10 14:14:10 +00:00
|
|
|
Authorization
|
|
|
|
=============
|
|
|
|
|
2019-05-28 14:41:55 +00:00
|
|
|
Once a :doc:`project is set up <../intro/setup>`, you will still have to follow a few steps before you can actually use Pyrogram to make
|
2019-05-17 23:45:01 +00:00
|
|
|
API calls. This section provides all the information you need in order to authorize yourself as user or bot.
|
2019-05-10 14:14:10 +00:00
|
|
|
|
2020-04-01 18:08:46 +00:00
|
|
|
.. contents:: Contents
|
|
|
|
:backlinks: none
|
|
|
|
:local:
|
|
|
|
|
|
|
|
-----
|
|
|
|
|
2019-05-10 14:14:10 +00:00
|
|
|
User Authorization
|
|
|
|
------------------
|
|
|
|
|
|
|
|
In order to use the API, Telegram requires that users be authorized via their phone numbers.
|
2019-05-23 16:59:29 +00:00
|
|
|
Pyrogram automatically manages this process, all you need to do is create an instance of the
|
2019-05-28 14:41:55 +00:00
|
|
|
:class:`~pyrogram.Client` class by passing to it a ``session_name`` of your choice (e.g.: "my_account") and call
|
|
|
|
the :meth:`~pyrogram.Client.run` method:
|
2019-05-10 14:14:10 +00:00
|
|
|
|
|
|
|
.. code-block:: python
|
|
|
|
|
|
|
|
from pyrogram import Client
|
|
|
|
|
|
|
|
app = Client("my_account")
|
|
|
|
app.run()
|
|
|
|
|
|
|
|
This starts an interactive shell asking you to input your **phone number** (including your `Country Code`_) and the
|
|
|
|
**phone code** you will receive in your devices that are already authorized or via SMS:
|
|
|
|
|
|
|
|
.. code-block:: text
|
|
|
|
|
|
|
|
Enter phone number: +39**********
|
|
|
|
Is "+39**********" correct? (y/n): y
|
|
|
|
Enter phone code: 32768
|
|
|
|
Logged in successfully as Dan
|
|
|
|
|
|
|
|
After successfully authorizing yourself, a new file called ``my_account.session`` will be created allowing Pyrogram to
|
|
|
|
execute API calls with your identity. This file will be loaded again when you restart your app, and as long as you
|
|
|
|
keep the session alive, Pyrogram won't ask you again to enter your phone number.
|
|
|
|
|
|
|
|
.. important::
|
|
|
|
|
|
|
|
Your ``*.session`` files are personal and must be kept secret.
|
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
2019-06-06 16:25:23 +00:00
|
|
|
The code above does nothing except asking for credentials and keeping the client online, hit :guilabel:`CTRL+C` now
|
|
|
|
to stop your application and keep reading.
|
2019-05-10 14:14:10 +00:00
|
|
|
|
|
|
|
Bot Authorization
|
|
|
|
-----------------
|
|
|
|
|
|
|
|
Bots are a special kind of users that are authorized via their tokens (instead of phone numbers), which are created by
|
|
|
|
the `Bot Father`_. Bot tokens replace the users' phone numbers only — you still need to
|
2019-05-28 14:41:55 +00:00
|
|
|
:doc:`configure a Telegram API key <../intro/setup>` with Pyrogram, even when using bots.
|
2019-05-10 14:14:10 +00:00
|
|
|
|
|
|
|
The authorization process is automatically managed. All you need to do is choose a ``session_name`` (can be anything,
|
|
|
|
usually your bot username) and pass your bot token using the ``bot_token`` parameter. The session file will be named
|
2019-05-17 23:45:01 +00:00
|
|
|
after the session name, which will be ``my_bot.session`` for the example below.
|
2019-05-10 14:14:10 +00:00
|
|
|
|
|
|
|
.. code-block:: python
|
|
|
|
|
|
|
|
from pyrogram import Client
|
|
|
|
|
|
|
|
app = Client(
|
|
|
|
"my_bot",
|
|
|
|
bot_token="123456:ABC-DEF1234ghIkl-zyx57W2v1u123ew11"
|
|
|
|
)
|
2019-05-16 19:28:34 +00:00
|
|
|
|
2019-05-10 14:14:10 +00:00
|
|
|
app.run()
|
|
|
|
|
|
|
|
.. _Country Code: https://en.wikipedia.org/wiki/List_of_country_calling_codes
|
|
|
|
.. _Bot Father: https://t.me/botfather
|