All Projects → Astrotomic → laravel-webmentions

Astrotomic / laravel-webmentions

Licence: MIT license
A simple client to retrieve webmentions for your pages.

Programming Languages

PHP
23972 projects - #3 most used programming language

Projects that are alternatives of or similar to laravel-webmentions

microlight
A fully IndieWeb-compatible PHP blogging engine
Stars: ✭ 35 (+75%)
Mutual labels:  webmention, webmentions
indieweb-post-kinds
adds support for responding to and interacting with other sites using the standards developed by the Indieweb Community
Stars: ✭ 39 (+95%)
Mutual labels:  webmention
webmentiond
A simple webmention receiver in Go
Stars: ✭ 41 (+105%)
Mutual labels:  webmention
webmention
Webmention Plugin for Craft CMS
Stars: ✭ 38 (+90%)
Mutual labels:  webmention
Pushl
Push notification adapter for feeds
Stars: ✭ 25 (+25%)
Mutual labels:  webmention
node-webmention-testpinger
A tool to ping your site with a variety of real world WebMentions
Stars: ✭ 28 (+40%)
Mutual labels:  webmention
sweetroll2
A powerful micro/blogging engine with IndieWeb features (abandoned)
Stars: ✭ 27 (+35%)
Mutual labels:  webmention
nicolas-hoizey.com
The personal website/blog from Nicolas Hoizey, built with https://pack11ty.dev/
Stars: ✭ 77 (+285%)
Mutual labels:  webmention
entries.pub
WIP IndieWeb blog engine
Stars: ✭ 13 (-35%)
Mutual labels:  webmention

Laravel Webmentions

Latest Version MIT License Offset Earth Larabelles

GitHub Workflow Status StyleCI Total Downloads

A simple client to retrieve webmentions for your pages.

Installation

You can install the package via composer:

composer require astrotomic/laravel-webmentions

Configuration

At firsts you will have to add your webmention.io API access token to the services.php config file.

return [
    // ...
    'webmention' => [
        'token' => env('WEBMENTION_TOKEN'),
    ],
    // ...
];

Usage

You can retrieve all webmentions for a given URL by calling the get() method on the packages client.

use Astrotomic\Webmentions\Facades\Webmentions;

$records = Webmentions::get('https://gummibeer.dev/blog/2020/human-readable-intervals');

If you omit the url as argument it will automatically use \Illuminate\Http\Request::url() as default. The return value will be an instance of \Astrotomic\Webmentions\Collections\WebmentionsCollection which provides you with predefined filter methods. You can also use the shorthand methods on the client to retrieve a collection of likes, mentions, replies or reposts.

use Astrotomic\Webmentions\Facades\Webmentions;

$likes = Webmentions::likes('https://gummibeer.dev/blog/2020/human-readable-intervals');
$mentions = Webmentions::mentions('https://gummibeer.dev/blog/2020/human-readable-intervals');
$replies = Webmentions::replies('https://gummibeer.dev/blog/2020/human-readable-intervals');
$reposts = Webmentions::reposts('https://gummibeer.dev/blog/2020/human-readable-intervals');

All items will be a corresponding instance of \Astrotomic\Webmentions\Models\Like, \Astrotomic\Webmentions\Models\Mention, \Astrotomic\Webmentions\Models\Reply or \Astrotomic\Webmentions\Models\Repost.

If you only need the count of items you can use the Webmentions::count() method.

use Astrotomic\Webmentions\Facades\Webmentions;

$counts = Webmentions::count('https://gummibeer.dev/blog/2020/human-readable-intervals');
[
  'count' => 52,
  'type' => [
    'like' => 23,
    'mention' => 8,
    'reply' => 16,
    'repost' => 5,
  ],
];

Caching

The client uses a poor man cache by default - so per runtime every domain is only requested once. If you want extended caching behavior you should wrap the calls in a Cache::remember() for example.

Blade Component

To receive webmentions for your page you have to add two <link/> tags to your head. This package provides a <x-webmention-links/> Blade component that makes it easier for you.

<x-webmention-links />
<!-- will use the domain of current request -->
<x-webmention-links domain="gummibeer.dev" />
<!-- will use the given domain -->

<!-- RESULT -->
<link rel="webmention" href="https://webmention.io/gummibeer.dev/webmention" />
<link rel="pingback" href="https://webmention.io/gummibeer.dev/xmlrpc" />

Testing

composer test

Changelog

Please see CHANGELOG for more information what has changed recently.

Contributing

Please see CONTRIBUTING for details. You could also be interested in CODE OF CONDUCT.

Security

If you discover any security related issues, please check SECURITY for steps to report it.

Credits

License

The MIT License (MIT). Please see License File for more information.

Treeware

You're free to use this package, but if it makes it to your production environment I would highly appreciate you buying the world a tree.

It’s now common knowledge that one of the best tools to tackle the climate crisis and keep our temperatures from rising above 1.5C is to plant trees. If you contribute to my forest you’ll be creating employment for local families and restoring wildlife habitats.

You can buy trees at offset.earth/treeware

Read more about Treeware at treeware.earth

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].