# Quart-Discord [![PyPI](https://img.shields.io/pypi/v/Quart-Discord?style=for-the-badge)](https://pypi.org/project/Quart-Discord/) [![Read the Docs](https://img.shields.io/readthedocs/quart-discord?style=for-the-badge)](https://quart-discord.readthedocs.io/en/latest/) Discord OAuth2 extension for Quart. ### Installation To install current latest release you can use following command: ```sh python3 -m pip install Quart-Discord ``` ### Basic Example ```python 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/") async def login(): return await discord.create_session() @app.route("/callback/") async def callback(): await discord.callback() return redirect(url_for(".me")) @app.errorhandler(Unauthorized) async def redirect_unauthorized(e): return redirect(url_for("login")) @app.route("/me/") @requires_authorization async def me(): user = await discord.fetch_user() return f""" {user.name} """ if __name__ == "__main__": app.run() ``` For an example to the working application, check [`test_app.py`](tests/test_app.py) ### Requirements * Quart * Async-OAuthlib * cachetools * discord.py ### Documentation Head over to [documentation] for full API reference. [documentation]: https://quart-discord.readthedocs.io/en/latest/