Merge pull request #172 from bjsi/add-bookmarks-support

feat: add support for getting bookmarks
Этот коммит содержится в:
vladkens 2024-06-29 16:23:23 +03:00 коммит произвёл GitHub
родитель 09d035c0ba 6b67421f7a
Коммит 7e82ff70d2
Не найден ключ, соответствующий данной подписи
Идентификатор ключа GPG: B5690EEEBB952194
2 изменённых файлов: 42 добавлений и 0 удалений

17
test_bookmarks.py Обычный файл
Просмотреть файл

@ -0,0 +1,17 @@
import asyncio
import twscrape
from twscrape.utils import gather
async def main():
api = twscrape.API()
# add accounts here or before from cli (see README.md for examples)
await api.pool.add_account("BookmarkTe60140", "", '', '')
await api.pool.login_all()
bms = await gather(api.bookmarks())
for bm in bms:
print(bm.rawContent)
print('-----')
if __name__ == "__main__":
asyncio.run(main())

Просмотреть файл

@ -23,6 +23,7 @@ OP_Likes = "RaAkBb4XXis-atDL3rV-xw/Likes"
OP_BlueVerifiedFollowers = "AXsZSOWx3FCvneEIzxDj6A/BlueVerifiedFollowers" OP_BlueVerifiedFollowers = "AXsZSOWx3FCvneEIzxDj6A/BlueVerifiedFollowers"
OP_UserCreatorSubscriptions = "NHT8e7FjnCS3TP0QfP_OUQ/UserCreatorSubscriptions" OP_UserCreatorSubscriptions = "NHT8e7FjnCS3TP0QfP_OUQ/UserCreatorSubscriptions"
OP_UserMedia = "aQQLnkexAl5z9ec_UgbEIA/UserMedia" OP_UserMedia = "aQQLnkexAl5z9ec_UgbEIA/UserMedia"
OP_UserBookmarks = "yzqS_xq0glDD7YZJ2YDaiA/Bookmarks"
GQL_URL = "https://twitter.com/i/api/graphql" GQL_URL = "https://twitter.com/i/api/graphql"
@ -385,6 +386,30 @@ class API:
yield x yield x
# user_media # user_media
async def bookmarks_raw(self, limit=-1, kv=None):
op = OP_UserBookmarks
kv = {
"count": 20,
"includePromotedContent": False,
"withClientEventToken": False,
"withBirdwatchNotes": False,
"withVoice": True,
"withV2Timeline": True,
**(kv or {}),
}
ft = {
'graphql_timeline_v2_bookmark_timeline': True,
}
async with aclosing(self._gql_items(op, kv, ft, limit=limit)) as gen:
async for x in gen:
yield x
async def bookmarks(self, limit=-1, kv=None):
async with aclosing(self.bookmarks_raw(limit=limit, kv=kv)) as gen:
async for rep in gen:
for x in parse_tweets(rep.json(), limit):
yield x
async def user_media_raw(self, uid: int, limit=-1, kv=None): async def user_media_raw(self, uid: int, limit=-1, kv=None):
op = OP_UserMedia op = OP_UserMedia