Download the PHP package innocenzi/bluesky-notification-channel without Composer
On this page you can find all versions of the php package innocenzi/bluesky-notification-channel. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Table of contents
Download innocenzi/bluesky-notification-channel
More information about innocenzi/bluesky-notification-channel
Files in innocenzi/bluesky-notification-channel
Download innocenzi/bluesky-notification-channel
More information about innocenzi/bluesky-notification-channel
Files in innocenzi/bluesky-notification-channel
Vendor innocenzi
Package bluesky-notification-channel
Short Description Bluesky notification channel for the Laravel framework
License MIT
Homepage https://github.com/innocenzi/bluesky-notification-channel
Package bluesky-notification-channel
Short Description Bluesky notification channel for the Laravel framework
License MIT
Homepage https://github.com/innocenzi/bluesky-notification-channel
Please rate this library. Is it a good library?
Informations about the package bluesky-notification-channel
Bluesky notification channel
Notification channel implementation to create Bluesky posts using Laravel.
## Configuring credentials To interact with its API, Bluesky recommends creating an [application-specific password](https://atproto.com/specs/xrpc#app-passwords) instead of using your account's main password. You may generate one in your [account settings](https://bsky.app/settings/app-passwords). Once created, fill your `.env` accordingly: Add these values to `config/services.php`: ## Publishing posts To create a post, you will need to instruct the [notification](https://laravel.com/docs/master/notifications#generating-notifications) of your choice to use the `BlueskyChannel` channel and to implement the corresponding `toBluesky` method. This method may return a `BlueskyPost` instance or a simple `string`. You may then dispatch the notification: ## Sessions Bluesky doesn't provide a way to authenticate requests using classic API tokens. Instead, they only offer a JWT-based authentication system, including an access and a refresh token. Since these tokens expire, they cannot be stored in the environment. They are generated dynamically by creating and refreshing sessions and they need to be kept for as long as possible. This notification channel implementation uses a session manager and an identity repository based on Laravel's cache. This may be overriden by swapping `NotificationChannels\Bluesky\IdentityRepository\IdentityRepository` in the container. Additionnally, the key used by the cache-based identity repository may be configured by setting the `services.bluesky.identity_cache_key` option. ## Embeds For Bluesky, embeds are a client-side responsibility, which means we have to generate website embeds ourselves. This notification channel implementation uses Bluesky's own private API, `cardyb.bsky.app`, to fetch a website's metadata, including an URL to its thumbnail. However, that thumbnail stills has to be uploaded to Bluesky as a blob, so a reference to that blob can be added to the post's embed. You may disable automatic embed generation by calling `withoutAutomaticEmbeds` on a `BlueskyPost` instance, or replace the implementation altogether by swapping `NotificationChannels\Bluesky\Embeds\EmbedResolver` in the container.composer require innocenzi/bluesky-notification-channel
All versions of bluesky-notification-channel with dependencies
PHP Build Version
Package Version
Requires
php Version
^8.1
spatie/laravel-package-tools Version ^1.16.5
illuminate/contracts Version ^11.0
spatie/laravel-package-tools Version ^1.16.5
illuminate/contracts Version ^11.0
The package innocenzi/bluesky-notification-channel contains the following files
Loading the files please wait ....