Skip to main content

No project description provided

Project description

AIOAuth Client – OAuth support for Asyncio/Trio libraries.

Tests Status PYPI Version

Requirements

  • python >= 3.8

Installation

AIOAuth Client should be installed using pip:

pip install aioauth-client

Usage

# OAuth1
from aioauth_client import TwitterClient

twitter = TwitterClient(
    consumer_key='J8MoJG4bQ9gcmGh8H7XhMg',
    consumer_secret='7WAscbSy65GmiVOvMU5EBYn5z80fhQkcFWSLMJJu4',
)

request_token, request_token_secret, _ = await twitter.get_request_token()

authorize_url = twitter.get_authorize_url(request_token)
print("Open",authorize_url,"in a browser")
# ...
# Reload client to authorize_url and get oauth_verifier
# ...
print("PIN code:")
oauth_verifier = input()
oauth_token, oauth_token_secret, _ = await twitter.get_access_token(oauth_verifier)

# Save the tokens for later use

# ...

twitter = TwitterClient(
    consumer_key='J8MoJG4bQ9gcmGh8H7XhMg',
    consumer_secret='7WAscbSy65GmiVOvMU5EBYn5z80fhQkcFWSLMJJu4',
    oauth_token=oauth_token,
    oauth_token_secret=oauth_token_secret,
)

# Or you can use this if you have initilized client already
# twitter.access_token = oauth_token
# twitter.access_token_secret = oauth_token_secret

timeline = await twitter.request('GET', 'statuses/home_timeline.json')
content = await timeline.read()
print(content)
# OAuth2
from aioauth_client import GithubClient

github = GithubClient(
    client_id='b6281b6fe88fa4c313e6',
    client_secret='21ff23d9f1cad775daee6a38d230e1ee05b04f7c',
)

authorize_url = github.get_authorize_url(scope="user:email")

# ...
# Reload client to authorize_url and get code
# ...

otoken, _ = await github.get_access_token(code)

# Save the token for later use

# ...

github = GithubClient(
    client_id='b6281b6fe88fa4c313e6',
    client_secret='21ff23d9f1cad775daee6a38d230e1ee05b04f7c',
    access_token=otoken,
)

# Or you can use this if you have initilized client already
# github.access_token = otoken

response = await github.request('GET', 'user')
user_info = await response.json()

Example

Run example with command:

make example

Open http://localhost:5000 in your browser.

Bug tracker

If you have any suggestions, bug reports or annoyances please report them to the issue tracker at https://github.com/klen/aioauth-client/issues

Contributing

Development of AIOAuth Client happens at: https://github.com/klen/aioauth-client

License

Licensed under a MIT license.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

aioauth-client-0.25.2.tar.gz (12.5 kB view details)

Uploaded Source

Built Distribution

aioauth_client-0.25.2-py3-none-any.whl (11.1 kB view details)

Uploaded Python 3

File details

Details for the file aioauth-client-0.25.2.tar.gz.

File metadata

  • Download URL: aioauth-client-0.25.2.tar.gz
  • Upload date:
  • Size: 12.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.55.0 CPython/3.8.6

File hashes

Hashes for aioauth-client-0.25.2.tar.gz
Algorithm Hash digest
SHA256 52e7a88dfcaf3a3931405bc3ff36be4bdfedb7928d5031bbfdf7d542d5e18964
MD5 4a28faf3b3ef3779d025b40870c8e023
BLAKE2b-256 d8de3f809bf35063701f8a8f6b24e3e8eeea4ecff149e63c6e380bf3e505e227

See more details on using hashes here.

File details

Details for the file aioauth_client-0.25.2-py3-none-any.whl.

File metadata

  • Download URL: aioauth_client-0.25.2-py3-none-any.whl
  • Upload date:
  • Size: 11.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.55.0 CPython/3.8.6

File hashes

Hashes for aioauth_client-0.25.2-py3-none-any.whl
Algorithm Hash digest
SHA256 c5bee69c0fdcf313fd4569b9a805b9583735a8a92d6c8277b04f7759ba42294a
MD5 d180eec88bda37b83490d9c391bd2d20
BLAKE2b-256 8b7df4775029059c4666ffa29b07fb3e61aef74d0b24efb5f407d5f63703d5aa

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page