NOTE: This post is mainly about how I developed the php2Bluesky library. If you are looking for information on using the library in your own code please see here: https://github.com/williamsdb/php2Bluesky/
With all the uncertainty surrounding the future of X (née Twitter), I decided to take a look at Bluesky which somewhat ironically has its roots in Twitter where it was started as an internal project. Bluesky is still in beta and is invite-only. I worry about its long-term given that ultimately it too has to make money, something that Twitter has singularly failed to do. None of this, of course, affects the topic today which is posting to Bluesky via the API.
Basic Concepts
The first thing to say is that I am using the following library to actually post to BlueSky. What I am going to be looking at is how to format the parameters that you need to send to be able to:
- posting text only
- posting images
- handling links
- add in a web card
It is clear that Bluesky is much less polished than X which reflects the age of it but it does mean that you have to put in a lot more work doing things that work out the box on X.
Getting Started
Unlike X, the authentication for the Bluesky authentication is pretty simple. Head to Settings and then under “Advanced” select App passwords.
From the next page click the Add App Password button and give you app a name. The name is arbitary and really only seems to be for your reference.
When you click Create App Password the key you need to access the api will displayed. It will look something like ab1c-defg-hij2-k3l4. Make a note of this as once you click Done you won’t be able to view it again.
Connecting to BlueSky
As well as your App Password generated above you will also need your Bluesky handle to access. This looks something like: spokenlikeageek.bsky.social. Now you can create a connection to Bluesky.
function bluesky_connect($handle, $password)
{
$connection = new BlueskyApi($handle, $password);
return $connection;
}
Making your First Post
Now that we have an active connection to Bluesky API we can build the parameters to send a post. The following is the basic array of parameters that we will be using and will build upon in the subsequent posts. You can take this as is and simply replace the ‘Hello World!’ text with what you would like to post.
// build the arguments
$args = [
'collection' => 'app.bsky.feed.post',
'repo' => $connection->getAccountDid(),
'record' => [
'text' => 'Hello World!',
'langs' => ['en'],
'createdAt' => date('c'),
'$type' => 'app.bsky.feed.post',
],
];
Once you have this set-up you can post this to Bluesky by making the following call. Remember to check the response to make sure that it has been accepted but if it has then you will see the post in your Bluesky account.
// send to bluesky
return $connection->request('POST', 'com.atproto.repo.createRecord', $args);
Once you have the account access setup and the library loaded sending the post to Bluesky is relatively straight forward. Using what we have here we can build on this to add more functionality. In the next post we look at how to upload images to Bluesky posts via the API.
Thanks for doing this.. your connection code gave out an error, not sure why… and I forget the error. I just used the code from the github read me and it worked fine.. wondering if this tutorial needs an update?
Hi, thanks for the comment. This page is describing the code in the library rather than what you need to do in your code. I give a worked example in the next posts, I should perhaps make that clearer. To make a connection you simply need to:
$connection = bluesky_connect($handle, $password);
Best thing to do is to take a look at the example here: https://github.com/williamsdb/php2Bluesky/blob/main/src/index.php
The next post links to next post don’t seem to work.
Oops! I’ll take a look. Thanks for pointing it out.
They should all be fixed now. Thanks again!