Implementation of X/Twitter v1, v2, and GraphQL APIs
Project description
Twitter API
Installation
pip install Jam-Twitter-API
Usage
from Jam_Twitter_API.account_sync import TwitterAccountSync
from Jam_Twitter_API.errors import *
# Create a TwitterAccount object
# Set up a session using auth_token or cookies (it will auto create needed headers and cookies)
try:
account = TwitterAccountSync.run(
auth_token="0idfidfgdfgidfgijodfgjoidfgijo43",
proxy="http://user:pass@host:port",
setup_session=True,
)
account = TwitterAccountSync.run(
cookies={"auth_token": "0idfidfgdfgidfgijodfgjoidfgijo43", "ct0": "0idfidfgdfgidfgijodfgjoidfgijo43"},
proxy="http://user:pass@host:port",
setup_session=True,
)
except TwitterAccountSuspended as error:
# Raise when account is suspended
print(f"Account is suspended: {error}")
except TwitterError as error:
# Raise when Twitter error occurs
print(f"Twitter error occurred: {error.error_message} | {error.error_code}")
except IncorrectData as error:
# Raise when validation error occurs
print(f"Incorrect data provided: {IncorrectData}")
except RateLimitError as error:
# Raise when rate limit exceeded
print(f"Rate limit exceeded: {error}")
# A small part of the available methods:
user_tweets = account.user_last_tweets("elonmusk")
user_followers = account.user_followers("elonmusk")
user_following = account.user_followings("elonmusk")
user_info = account.get_user_info("elonmusk")
user_id = account.get_user_id("elonmusk")
follow = account.follow(1000)
unfollow = account.unfollow(1000)
bind_account_to_site_v1 = account.bind_account_v1("url")
bind_account_to_site_v2 = account.bind_account_v2({
"code_challenge": "test",
"code_challenge_method": "plain",
"client_id": "enpfUjhndkdrdHhld29adfg6eGM6MTpjaQ",
"redirect_uri": "https://www.test.io",
"response_type": "code",
"scope": "tweet.read users.read follows.read offline.access",
"state": "test",
})
tweet_replies = account.tweet_replies(1000000000)
tweet_retweets = account.tweet_retweeters(1000000000)
tweet_likes = account.tweet_likes(1000000000)
tweet = account.tweet("hello world")
untweet = account.untweet(1000000000)
quote = account.quote("hello world", 10000)
retweet = account.retweet(1000000000)
reply = account.reply("hello world", 1000000000)
like = account.like(1000000000)
unlike = account.unlike(1000000000)
update_image = account.update_profile_image("path/to/image.jpg")
update_banner = account.update_profile_banner("path/to/image.jpg")
update_profile_info = account.update_profile_info({"location": "San Francisco"})
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
jam_twitter_api-0.9.tar.gz
(40.0 kB
view details)
Built Distribution
File details
Details for the file jam_twitter_api-0.9.tar.gz
.
File metadata
- Download URL: jam_twitter_api-0.9.tar.gz
- Upload date:
- Size: 40.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.11.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9fc2a9d59bbaa730433741519211ff897dcf7bfa86ee574362ec396e4211d9a8 |
|
MD5 | 5564f72987bba8e7e865e10aa9f0c441 |
|
BLAKE2b-256 | a99a2080c15cd6f0391d770f452fa3e01ce1d611bb6934ba433774b169a8d43c |
File details
Details for the file Jam_Twitter_API-0.9-py3-none-any.whl
.
File metadata
- Download URL: Jam_Twitter_API-0.9-py3-none-any.whl
- Upload date:
- Size: 41.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.11.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7100845e410bb18e1d0ac122e97c6d12bbab911a7a18ffba4a77ea63d94b6531 |
|
MD5 | 987eaa6cee09432932a222ef51e8927e |
|
BLAKE2b-256 | 9e2dc3ed2bff086ce4b4b55331374cc60f57248a78314a65de0fb3ffb3798611 |