Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/skybluesofa/laravel-followers
Gives Eloquent models the ability to manage followers.
https://github.com/skybluesofa/laravel-followers
followers friend-requests friendship friendships laravel-package
Last synced: 3 months ago
JSON representation
Gives Eloquent models the ability to manage followers.
- Host: GitHub
- URL: https://github.com/skybluesofa/laravel-followers
- Owner: skybluesofa
- License: mit
- Created: 2016-09-06T20:35:10.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2020-03-08T14:48:26.000Z (almost 5 years ago)
- Last Synced: 2024-11-07T14:41:33.239Z (4 months ago)
- Topics: followers, friend-requests, friendship, friendships, laravel-package
- Language: PHP
- Homepage:
- Size: 43 KB
- Stars: 60
- Watchers: 3
- Forks: 10
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# Laravel 5 Followers
[data:image/s3,"s3://crabby-images/41c37/41c371e93168177b3fdc1cca3cabb084233ba212" alt="Build Status"](https://travis-ci.org/skybluesofa/laravel-followers) [data:image/s3,"s3://crabby-images/32f5b/32f5b092ad6779b993c49be397ff9d6b7a3d7401" alt="Code Climate"](https://codeclimate.com/github/skybluesofa/laravel-followers) [data:image/s3,"s3://crabby-images/613be/613be68cb290bae9573e32a6d8275ded093104ab" alt="Test Coverage"](https://codeclimate.com/github/skybluesofa/laravel-followers/coverage) [data:image/s3,"s3://crabby-images/75340/75340f12f9e7ee1614a674148f6ad50cb43027df" alt="Total Downloads"](https://packagist.org/packages/skybluesofa/laravel-followers) [data:image/s3,"s3://crabby-images/914e5/914e502f5fff8dd5cac8d82f4cc4b10bfa285213" alt="Version"](https://packagist.org/packages/skybluesofa/laravel-followers) [data:image/s3,"s3://crabby-images/0152e/0152e19f839703436b276c7effec1281fbd95a43" alt="Software License"](LICENSE)Gives Eloquent models the ability to manage their followers.
## Models can:
- Send Follow Requests
- Accept Follow Requests
- Deny Follow Requests
- Block Another Model## Installation
First, install the package through Composer.
```php
composer require skybluesofa/laravel-followers
```Then include the service provider inside `config/app.php`.
```php
'providers' => [
...
Skybluesofa\Followers\ServiceProvider::class,
...
];
```
Publish config and migrations```
php artisan vendor:publish --provider="Skybluesofa\Followers\ServiceProvider"
```
Configure the published config in
```
config\followers.php
```
Finally, migrate the database
```
php artisan migrate
```## Setup a Model
```php
use Skybluesofa\Followers\Traits\Followable;
class User extends Model
{
use Followable;
...
}
```## How to use
[Check the Test file to see the package in action](https://github.com/skybluesofa/laravel-followers/blob/master/tests/FollowersTest.php)### Methods
#### Send a Follow Request
Will trigger a `Skybluesofa\LaravelFollowers\Events\FollowRequest` event.
```php
$user->follow($recipient);
```#### Accept a Follow Request
Will trigger a `Skybluesofa\LaravelFollowers\Events\FollowRequestAccepted` event.
```php
$recipient->acceptFollowRequestFrom($user);
```#### Deny a Follow Request
Will trigger a `Skybluesofa\LaravelFollowers\Events\FollowRequestDenied` event.
```php
$recipient->denyFollowRequestFrom($user);
```#### Remove Follow
Will trigger a `Skybluesofa\LaravelFollowers\Events\Unfollow` event.
```php
$user->unfollow($recipient);
```#### Block a User
Will trigger a `Skybluesofa\LaravelFollowers\Events\FollowingBlocked` event.
```php
$user->blockBeingFollowedBy($recipient);
```#### Unblock a User
Will trigger a `Skybluesofa\LaravelFollowers\Events\FollowingUnblocked` event.
```php
$user->unblockBeingFollowedBy($recipient);
```#### Check if User is Following another User
```php
$user->isFollowing($recipient);
```#### Check if User is being Followed by another User
```php
$recipient->isFollowedBy($user);
```#### Check if User has a pending Follow request from another User
```php
$recipient->hasFollowRequestFrom($user);
```#### Check if User sent a pending Follow request to another User
```php
$user->hasSentFollowRequestTo($recipient);
```#### Check if User has blocked another User
```php
$recipient->hasBlockedBeingFollowedBy($user);
```#### Check if User is blocked by another User
```php
$user->isBlockedFromFollowing($recipient);
```#### Get a single friendship
```php
$user->getFriendship($recipient);
```#### Get a list of all Friendships
```php
$user->getAllFriendships();
```#### Get a list of pending Friendships
```php
$user->getPendingFriendships();
```#### Get a list of accepted Friendships
```php
$user->getAcceptedFriendships();
```#### Get a list of denied Friendships
```php
$user->getDeniedFriendships();
```#### Get a list of blocked Friendships
```php
$user->getBlockedFriendships();
```#### Get a list of pending Friend Requests
```php
$user->getFriendRequests();
```#### Get the number of Friends
```php
$user->getFriendsCount();
```## Friends
To get a collection of friend models (ex. User) use the following methods:
#### Get Friends
```php
$user->getFriends();
```#### Get Friends Paginated
```php
$user->getFriends($perPage = 20);
```### Events
These events are triggered during the lifecycle of following/unfollowing/accept/deny followers:
```php
Skybluesofa\LaravelFollowers\Events\FollowingBlocked(Model $recipient, Model $sender);
Skybluesofa\LaravelFollowers\Events\FollowingUnblocked(Model $recipient, Model $sender);
Skybluesofa\LaravelFollowers\Events\FollowRequest(Model $recipient, Model $sender);
Skybluesofa\LaravelFollowers\Events\FollowRequestAccepted(Model $recipient, Model $sender);
Skybluesofa\LaravelFollowers\Events\FollowRequestDenied(Model $recipient, Model $sender);
Skybluesofa\LaravelFollowers\Events\Unfollow(Model $recipient, Model $sender);
```To listen for and react to these events, follow the [instructions available in the Laravel Documentation](https://laravel.com/docs/7.x/events#defining-listeners).
## Thank you
The basis of this code was garnered from [https://github.com/hootlex/laravel-friendships](https://github.com/hootlex/laravel-friendships). Although it was a jumping off point, much of the code has been rewritten to allow for Following as opposed to Mutual Friendship.## Contributing
See the [CONTRIBUTING](CONTRIBUTING.md) guide.