Twitter has released the official API v2 endpoint for the bookmark feature. https://twittercommunity.com/t/build-with-bookmarks-on-the-twitter-api-v2/168804/
The following descriptions are or will soon be no longer useful; I suggest using the new official API.
I found out the endpoints for bookmark with Chrome Developer Tools: GET timeline/bookmark
, POST bookmark/entries/remove
, POST bookmark/entries/remove
.
The rate limits below are values returned by an official endpoint GET application/rate_limit_status
.
This document is still a work in progress because I got stuck in GET timeline/bookmark
. Please let me know if you find how to use it.
- It is necessary that
x-csrf-token
in a request header andct0
in a cookie are the same value. Twitter uses them to avoid CSRF attacks. I recommend that you extract the values from your browsers. - All of the endpoints requires OAuth2 Authorizations. Note that they refuse OAuth2 Bearer tokens obtained from
POST oauth2/token
. - You can easily reach the rate limit and get HTTP 429 Error (too many requests), so you should be careful about how many requests you send.
- I have heard that someone said that "GET timeline/bookmark" returned HTTP 403 Error even though OAuth authentication succeeded. Maybe the endpoint refuses mechanical accesses.
- In some cases, perhaps it is better to use the official TweetDeck Collection API instead of the undocumented and uncertain API.
- cf: https://github.com/geekodour/twitmarks/ / https://github.com/acorn/twitter-bookmarks-search (It seems the developers understand how to use the endpoints)
I succeeded in requesting
POST /1.1/bookmark/entries/add.json
andPOST /1.1/bookmark/entries/remove.json
with Postman.A successful HTTP request is like this:
(The tokens and
tweet_id
in the above are example values)x-csrf-token
andct0
have the same value.A request for
remove.json
also successfully works with the same header values.Note that we have to extract
x-csrf-token
,auth_token
,ct0
, and Bearer token inAuthorization
out of browsers each time when we write requests.I'm planning to develop a browser extension that makes the process easier.
A successful response body is like this:
Anyway, I finished my work for the add/remove endpoints, so I'll concentrate on
/2/timeline/bookmark.json
.