Logo

dev-resources.site

for different kinds of informations.

Threads-API ist da

Published at
6/18/2024
Categories
graphapi
threads
automatisiert
Author
disane
Categories
3 categories in total
graphapi
open
threads
open
automatisiert
open
Author
6 person written this
disane
open
Threads-API ist da

Ich zeige dir wie du die API von Threads nutzt um Posts automatisiert zu generieren 🎉


Seit heute steht die API von Threads bereit und ich zeige dir, wie du sie verwenden kannst um Inhalte automatisiert dort bereitzustellen.

Voraussetzungen

Du musst auf jeden Fall einen Entwickler-Konto bei Meta haben. Das kannst du dir ganz einfach hier anlegen:

Preview image

Zusätzlich dazu, muss dein Account zwingend als Business-Account verifiziert sein. Das musst du im Vorfeld machen, da du sonst keinen Zugriff hast. Bei mir hat ausgereicht entsprechende Dokumente vorzulegen und wurde dann zwar nach 1-2 Tagen abgelehnt, aber ein Widerspruch hat dann später dazu geführt, dass ich verifiziert wurde und nun Business-Apps anlegen kann.

Business-App ist Pflicht ☝🏼

Die API richtet sich an geschäftliche Kunden, damit die Workflows geöffnet werden und so auch ein Crossposten von Inhalten ermöglicht wird. Darum musst du zwingend eine Business-App anlegen. Das kannst du recht einfach im App-Dashboard machen. Es muss auch eine neue App sein, da alte Apps Threads nicht integriert haben. In den Funktionen der neuen App wählst du "Access the Threads API" aus:

Du gibst dann einen App-Namen an und deine Mailadresse. Das musst du dann einmal mit deinem Meta-Kennwort bestätigen und ab geht es.

Berechtigungen setzen 🔏

Du musst dann deiner App entsprechende Berechtigungen setzen. Wenn du nur Posten willst, dann wird für dich vermutlich threads_basicund threads_content_publishausreichen:

Weitere Rechte kannst du aber später noch hinzufügen. Du kannst so auch zum Beispiel Replies prüfen, automatisch Bereinigen oder noch vieles anderes. Diese werden später als SCOPESnoch weiter benötigt.

OAuth konfigurieren 🤝

Damit du (oder eventuell auch andere Leute) deine App nutzen können, musst du URLs konfigurieren, die von OAuth genutzt werden. OAuth ist ein Autorisierungsprozess, der komplett passwortlos arbeitet und so die Benutzer am System der Ressource autorisiert.

Sofern du keine eigene Website hast, kannst du hier Postman nutzen. Postman vereinfacht die Nutzung von APIs ungemein und kann auch den kompletten OAuth-Flow für dich übernehmen. Bei der Redirect Callback URLskannst du, wenn du Postman schon hast, diese URL eintragen: https://oauth.pstmn.io/v1/callback. Alternativ jede andere URL, die die Autorisierungs-Codes von OAuth in Empfang nehmen kann.

Tester hinzufügen 🤵🏼

Möchtest du nur bestimmte Leute einladen, kannst du auch bestimmte Tester hinzufügen. Das brauchst du in dem Falle aber nicht, da wir über OAuth die Rechte direkt anfragen und Threads mit deiner neuen App verknüpfen.

Für richtige App ist das durchaus sinnvoll, dass man hier bestimmte Leute auswählt, die einen-Testzugang zu deiner App haben.

App-Einstellungen merken 💡

Damit du nun die API-Calls gegen die Threads-API machen kannst, brauchst du noch die CLIENT_IDund das CLIENT_SECRET. Vor allem auf das Secret musst du sehr gut aufpassen, da damit Zugriffe auf deine App möglich sind. Sei vorsichtig damit, wo du es eingibst und gebe es idealerweise an niemanden weiter. Beide Werte kannst du unter App settingsund dann Basic einsehen:

Wir autorisieren uns

Autorisierungscode abfragen ❓

Da wir nun soweit alle Voraussetzungen getroffen haben, können wir nun die ersten Anfragen an die Threads API erstellen. Damit wir überhaupt erst einmal Zugriff auf die Ressourcen haben, müssen wir einen Autorisierungscode beantragen. Das passiert über eine URL, die wir im Browser eingeben müssen oder dem Benutzer öffnen. Diese URL sieht wie folgt aus:

https://threads.net/oauth/authorize?
client_id=[CLIENT ID]&
redirect_uri=[REDIRECT URL]
&scope=[VERGEBENE SCOPES]
&response_type=code
Enter fullscreen mode Exit fullscreen mode

Hast du die Abfrage im Browser aufgerufen, erscheint eine Seite, die dich auf eine Verknüpfungsanfrage hinweist und dich dies nochmal prüfen und akzeptieren lässt:

Wenn du fortfährst, dann wird der Autorisierungscode an die REDIRECT URL (die du in OAuth der App konfiguriert hast) übergeben. Eine Rückgabe würde wie folgt aussehen:

{
  "code": "Dein Autorisierungscode"
}
Enter fullscreen mode Exit fullscreen mode

Mit diesem Code kannst du dann einen Access-Token beantragen.

Kurzlebigen Access-Token beantragen 🔑

Damit du nun Zugriff auf die Ressourcen hast, musst Autorisierungscode in einen Access-Token umwandeln lassen. Hier gibt es zwei Arten von Tokens:

  • Kurzlebigen Access Tokens
  • Langlebige Access Tokens

Beide haben ihre Vor- und Nachteile. Da du vermutlich einen längeren Zugriff haben möchtest als nur wenige Stunden, holen wir uns einen langlebigen Access Token. Dafür brauchen wir aber erst einen kurzlebigen, den wir dann zu einem langlebigen umwandeln.

Um einen kurzlebigen Access Token zu bekommen, musst du den Autorisierungscode an die API senden:

curl -X POST \
  https://graph.threads.net/oauth/access_token \
  -F client_id=[CLIENT ID] \
  -F client_secret=[CLIENT SECRET] \
  -F grant_type=authorization_code \
  -F redirect_uri=[REDIRECT URL] \
  -F code=[AUTH CODE]
Enter fullscreen mode Exit fullscreen mode

Wenn alles geklappt hat, solltest du eine solche Rückgabe erhalten:

{
  "access_token": "THQVJ...",
  "user_id": xyz
}
Enter fullscreen mode Exit fullscreen mode

Beides solltest du dir nun zusätzlich auch noch speichern. Den Access Token brauchst du bei jeder Anfrage an die API, ebenso die user_id.

Langlebigen Access Token erzeugen 🧬

Da wir nun aber die API mehr als nur ein paar Stunden nutzen möchten, musst du den kurzlebigen Access Token in einen langlebigen umwandeln. Das geht recht einfach mit dem nachfolgenden API-Call:

curl -i -X GET "https://graph.threads.net/access_token
  ?grant_type=th_exchange_token
  &client_secret=[CLIENT SECRET]
  &access_token=[SHORT_LIVED_ACCESS_TOKEN]"
Enter fullscreen mode Exit fullscreen mode

Wenn alles geklappt hat, solltest du folgende Rückgabe erhalten:

{
  "access_token": "<LONG_LIVED_USER_ACCESS_TOKEN>",
  "token_type": "bearer",
  "expires_in": 5183944  // number of seconds until token expires
}
Enter fullscreen mode Exit fullscreen mode

Den access_tokenkannst du dir dann anstelle des kurzlebigen merken und weiter verwenden.

Access Token erneuern ♻️

Beide Tokens laufen irgendwann einmal aus, der eine früher und der andere später. Darum gibt es auch die Möglichkeit Access Tokens zu erneuern, bevor sie abgelaufen sind.

Hierfür kannst du ganz einfach einen langlebigen Access Token nehmen und ihn an die API senden, dass sie dir einen neuen ausstellen soll:

curl -i -X GET "https://graph.threads.net/refresh_access_token
  ?grant_type=th_refresh_token
  &access_token=[LONG_LIVED_ACCESS_TOKEN]"
Enter fullscreen mode Exit fullscreen mode

Hat auch das geklappt, kannst du auf diese Rückgabe hoffen:

{
  "access_token": "<LONG_LIVED_USER_ACCESS_TOKEN>",
  "token_type": "bearer",
  "expires_in": 5183944 // number of seconds until token expires
}
Enter fullscreen mode Exit fullscreen mode

Und damit hättest du auch schon einen neuen gültigen Access Token erzeugt.

Posten von Inhalten 📷

Jetzt wird es langsam spannend. Du kannst dich nun authentifizieren und autorisieren. Fehlt eigentlich nur noch das Posten von Inhalten. Threads bietet eine Vielzahl an Inhalten an, die gepostet werden können. Welche möglich sind, kannst du in der API-Dokumentation nachlesen.

Preview image

Möchten wir nur einen einfachen Text oder ein Bild senden, können wir das recht elegant mit diesem API-Call machen. Hierfür brauchst du deine THREADS_USER_IDdie du oben beim Generieren eines Access Tokens bekommen und hoffentlich gespeichert hast:

curl -i -X POST \
"https://graph.threads.net/v1.0/<THREADS_USER_ID>/threads?media_type=IMAGE&image_url=https://www.example.com/images/bronz-fonz.jpg&text=#BronzFonz&access_token=<ACCESS_TOKEN>"
Enter fullscreen mode Exit fullscreen mode

In diesem Falle laden wir ein Bild von einer öffentlichen URL bei Threads hoch und fügen noch den Text #BronzFronzhinzu. Du musst aber nicht nur Bilder hochladen, sondern kannst auch nur Texte mit URLs oder ähnliche Sachen hochladen.

{
  "id": "1234567" // Threads Media Container ID
}
Enter fullscreen mode Exit fullscreen mode

Damit hast du aber nur einen Media-Container angelegt. Zu dem Zeitpunkt ist noch nichts hochgeladen worden! Das musst du separat mit einem eigenen API-Call machen. Hierfür brauchst du die idaus der vorherigen Rückgabe:

curl -i -X POST \ 
"https://graph.threads.net/v1.0/<THREADS_USER_ID>/threads_publish?creation_id=<MEDIA_CONTAINER_ID>&access_token=<ACCESS_TOKEN>"
Enter fullscreen mode Exit fullscreen mode

Hat das geklappt, solltest du eine solche Rückgabe bekommen:

{
  "id": "1234567" // Threads Media ID
}
Enter fullscreen mode Exit fullscreen mode

Und du solltest deinen neuen Post nun auf Threads sehen! Gratulation 🎉

Die API kann aber nicht nur Posten. Du kannst damit auch komplett andere Dinge tun und dir Daten aus Threads für Analysezwecke ziehen. Aber schau einfach mal in die API-Doku hinein, da findest du sicher noch sehr schöne Anwendungsfälle.

Fazit 📃

Du hast nun gelernt wie man die Threads API nutzt und kannst nun automatisiert Dinge dort hochladen. Wie einfach das geht, habe ich dir jetzt gezeigt. Es ist auf jeden Fall für Creator oder Geschäfte/Unternehmen sehr reizvoll, darauf Workflows auszurichten und z.B. Cross-Posts bei Threads zu realisieren.

Diesen Post wirst du vermutlich nun auch bei Threads gesehen haben, der wurde auch automatisch über die API hochgeladen 😉


If you like my posts, it would be nice if you follow my Blog for more tech stuff.

threads Article's
30 articles in total
Favicon
Launch Announcement: TwistFiber - Automate Your Threads Workflow 🚀
Favicon
Mastering ExecutorService Shutdown: Tracking ThreadPool Termination
Favicon
Threads Overhauls Its Search Feature to Improve User Experience and Engagement
Favicon
Concurrency in Python with Threading and Multiprocessing
Favicon
The Benefits of Having More Threads than Cores: Unlocking the Power of Multi-threading in Modern Computing
Favicon
What is Python GIL? How it works?
Favicon
🚀 Edge Detection with Threads and MiniMagick in Ruby 🌄
Favicon
Master OS Concepts 💡 | Understanding Threads, Processes & IPC 🔧
Favicon
Join Our Threads Community for Exclusive Bad Bunny Merch Discussions!
Favicon
Threads-API ist da
Favicon
Connect with NBA YoungBoy Merch on Threads!
Favicon
Estudo de caso: Thread pools e Out-of-memory
Favicon
Paralelismo e Concorrência 102: Java parallel streams na prática
Favicon
Concurrency and Parallelism in Ruby
Favicon
My take on Modeling Large Amounts of HLA Molecules with Ruby
Favicon
In Java what is ConcurrentModificationException? How to avoid it in multi-threading. #InterviewQuestion
Favicon
Threads API is here
Favicon
How Threads and Concurrency Work in Linux Systems
Favicon
Mastering Concurrency in Go: A Comprehensive Guide
Favicon
Is Threads still a thing?
Favicon
Async/Await: O que tem de novo no .NET 8?
Favicon
How Buying Threads Likes Can Skyrocket Your Follower Count
Favicon
Async/Await: Para que serve o CancellationToken?
Favicon
#6 Subgrid, Threads, Clouds Aren't Real, and Intl.Segmenter
Favicon
Threads Video Downloader - Snapthreads.io
Favicon
Demystifying Java Threads for Beginners
Favicon
Explorando o Multitarefa com Threads em Java
Favicon
Você já usou o System.Threading.Channels?
Favicon
Multithreading in Python: the obvious and the incredible
Favicon
Parallelism via Fiber Coroutines

Featured ones: