.. _intro: Introduction ============ Quart-Discord is an extension for Quart - Python web framework which makes easy implementation of Discord OAuth2 API. After creating a discord client object, one can easily request authorization and hence any of the resources provided by the discord OAuth2 API under the available scope permissions. Requirements ------------ - **Quart** This is a Quart extension. - **requests_oauthlib** It also requires requests_oauthlib to make OAuth2 sessions with discord. - **cachetools** Quart Discord supports caching discord objects to boost the performance when page loads. - **discord.py** Makes use of discord.py for re-using many Discord models. Installing ---------- You can install Quart-Discord directly from PyPI using PIP and following command in shell or command prompt: :: python3 -m pip install -U Quart-Discord You can also install the latest development version (**maybe unstable/broken**) by using following command: :: python3 -m pip install -U git+https://github.com/jnawk/Quart-Discord.git@dev Basic Usage ----------- Here is a simple example to get users authorization token using OAuth2 and use it in exchange for fetching user's details and display them on web page. .. code-block:: python3 from quart import Quart, redirect, url_for from quart_discord import DiscordOAuth2Session, requires_authorization, Unauthorized app = Quart(__name__) app.secret_key = b"random bytes representing quart secret key" app.config["DISCORD_CLIENT_ID"] = 490732332240863233 # Discord client ID. app.config["DISCORD_CLIENT_SECRET"] = "" # Discord client secret. app.config["DISCORD_REDIRECT_URI"] = "" # URL to your callback endpoint. app.config["DISCORD_BOT_TOKEN"] = "" # Required to access BOT resources. discord = DiscordOAuth2Session(app) @app.route("/login/") def login(): return discord.create_session() @app.route("/callback/") def callback(): discord.callback() return redirect(url_for(".me")) @app.errorhandler(Unauthorized) def redirect_unauthorized(e): return redirect(url_for("login")) @app.route("/me/") @requires_authorization def me(): user = discord.fetch_user() return f""" {user.name} """ if __name__ == "__main__": app.run()