Skip to main content

No project description provided

Project description

AIOHTTP OAuth Client – OAuth support for Aiohttp/Asyncio.

Build Status http://img.shields.io/pypi/v/aioauth-client.svg?style=flat-square http://img.shields.io/pypi/dm/aioauth-client.svg?style=flat-square

Requirements

  • python >= 3.5

Installation

AIOHTTP OAuth 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, _ = yield from 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, _ = yield from 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 = yield from twitter.request('GET', 'statuses/home_timeline.json')
content = yield from 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, _ = yield from 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 = yield from github.request('GET', 'user')
user_info = yield from response.json()

Example

Run example with command:

make run

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 AIOHTTP OAuth 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.24.1.tar.gz (12.6 kB view details)

Uploaded Source

Built Distribution

aioauth_client-0.24.1-py3-none-any.whl (11.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: aioauth-client-0.24.1.tar.gz
  • Upload date:
  • Size: 12.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.25.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.53.0 CPython/3.9.0

File hashes

Hashes for aioauth-client-0.24.1.tar.gz
Algorithm Hash digest
SHA256 0ee1a00e0e1c19d115a608f14b6697fd64064a6ccecae3f24d3195658c726dcc
MD5 1b33d317ea46b8d455cf5b76a9997dd3
BLAKE2b-256 7790cfddef371eccd979ceecac7827771cb9423d7f7395ef53790a5b1826ff26

See more details on using hashes here.

File details

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

File metadata

  • Download URL: aioauth_client-0.24.1-py3-none-any.whl
  • Upload date:
  • Size: 11.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.25.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.53.0 CPython/3.9.0

File hashes

Hashes for aioauth_client-0.24.1-py3-none-any.whl
Algorithm Hash digest
SHA256 17d300a5dfb126708cb800da25458262409c35358f86558f8baf3128da073752
MD5 3762b56d13d10b9420771604729fb93b
BLAKE2b-256 363357ce77df0eba7ed49e5607499ccc7dde91a0600f5ee2cbd571fad33136c5

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