potibm/phluesky
最新稳定版本:v0.6.1
Composer 安装命令:
composer require potibm/phluesky
包简介
An small PHP library for posting messages to the bluesky social network using the AT Protocol.
README 文档
README
An small PHP library for Bluesky social using the AT Protocol.
Usage
Install
Installing using composer is suggested
composer require potibm/phluesky
You will need a PSR-7, PSR-17 and PSR-18 client or adapter from this list. For development symfony/http-client and nyholm/psr7 are used.
The HTTP service discovery will do the magic. In most cases no additional steps are required.
Setup and posting a simple message
$api = new \potibm\Bluesky\BlueskyApi('nick.bsky.social', 'abcd-efgh-ijkl-mnop'); $postService = new \potibm\Bluesky\BlueskyPostService($api); $post = \potibm\Bluesky\Feed\Post::create('✨ example mentioning @atproto.com to share the URL 👨❤️👨 https://en.wikipedia.org/wiki/CBOR.'); $response = $api->createRecord($post);
Adding mentions and links from post text
$post = \potibm\Bluesky\Feed\Post::create('✨ example mentioning @atproto.com to share the URL 👨❤️👨 https://en.wikipedia.org/wiki/CBOR.'); $post = $postService->addFacetsFromMentionsAndLinks($post);
Adding mentions and links and tags from post text
$post = \potibm\Bluesky\Feed\Post::create('✨ example mentioning @atproto.com to share the URL 👨❤️👨 https://en.wikipedia.org/wiki/CBOR. and #HashtagFun'); $post = $postService->addFacetsFromMentionsAndLinksAndTags($post);
Adding images
https://atproto.com/blog/create-post#images-embeds
$post = \potibm\Bluesky\Feed\Post::create('example post with image attached'); $post = $postService->addImage( $post, 'image.jpg', 'alt text' );
Adding website card embeds
https://atproto.com/blog/create-post#website-card-embeds
$post = \potibm\Bluesky\Feed\Post::create('post which embeds an external URL as a card'); $post = $postService->addWebsiteCard( $post, 'https://example.com', 'Example website', 'Example website description', 'optionalimage.jpg' );
Reply to a post
https://atproto.com/blog/create-post#replies
$post = \potibm\Bluesky\Feed\Post::create('example of a reply'); $post = $postService->addReply( $post, 'at://did:plc:u5cwb2mwiv2bfq53cjufe6yn/app.bsky.feed.post/3k43tv4rft22g' );
Quote a post
https://atproto.com/blog/create-post#quote-posts
$post = \potibm\Bluesky\Feed\Post::create('example of a quote-post'); $post = $postService->addQuote( $post, 'at://did:plc:u5cwb2mwiv2bfq53cjufe6yn/app.bsky.feed.post/3k44deefqdk2g' );
Handling errors
While performing requests using the API, exceptions may be thrown.
The exceptions are of the base type potibm\Bluesky\Exception\Exception.
The exception message will contain details from the API.
try { $response = $api->createRecord($post); } catch (\potibm\Bluesky\Exception\HttpRequestException $e) { echo 'Error performing request on HTTP level: ' . $e->getMessage(); } catch (\potibm\Bluesky\Exception\AuthenticationErrorException $e) { echo 'Unable to authorize: ' . $e->getMessage(); } catch (\potibm\Bluesky\Exception\HttpStatusCodeException $e) { echo 'Unable to perform request on API level: ' . $e->getMessage(); } catch (\potibm\Bluesky\Exception\InvalidPayloadException $e) { echo 'Received unserializable JSON payload: ' . $e->getMessage(); }
License
The MIT License (MIT). Please see License File for more information.
统计信息
- 总下载量: 17.13k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 37
- 点击次数: 1
- 依赖项目数: 2
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2023-10-18