Home >Backend Development >PHP Tutorial >Building a Social Network with Laravel and Stream? Easy!
This article builds on a previous tutorial about adding the "follow" feature to a Laravel application using Stream. This part focuses on configuring models for activity tracking, exploring Stream's feed types, retrieving feeds, and rendering them in views.
Key Concepts:
FeedManager
simplifies feed operations, offering pre-built feeds (user, news, notification).FollowController
uses FeedManager
for following/unfollowing, updating feeds accordingly.Activity Data Structure:
Stream represents data as activities with at least: actor, verb, object, and time. Custom fields are also allowed.
Example: Defining the activityVerb
in the Post
model:
<code class="language-php">class Post extends Model { // ... other code ... /** * Stream: Activity verb for post creation. */ public function activityVerb() { return 'created'; } }</code>
Utilizing the FeedManager:
The FeedManager
simplifies feed interactions. It's accessed via the facade alias set in config/app.php
.
Pre-configured Feeds:
The FeedManager
provides pre-built feeds: User, News, and Notification. This example primarily uses News and Notification feeds. Further details on other feed types are available here.
Follow/Unfollow Functionality with FeedManager:
The FollowController
is updated to use FeedManager
for efficient follow/unfollow actions:
<code class="language-php">// app/Http/Controllers/FollowController.php public function follow(User $user) { if (!Auth::user()->isFollowing($user->id)) { Auth::user()->follows()->create(['target_id' => $user->id]); FeedManager::followUser(Auth::id(), $user->id); return back()->with('success', 'Now following ' . $user->name); } else { return back()->with('error', 'Already following this user.'); } } public function unfollow(User $user) { if (Auth::user()->isFollowing($user->id)) { $follow = Auth::user()->follows()->where('target_id', $user->id)->first(); FeedManager::unfollowUser(Auth::id(), $follow->target_id); $follow->delete(); return back()->with('success', 'Unfollowed ' . $user->name); } else { return back()->with('error', 'Not following this user.'); } }</code>
Displaying Feeds:
A FeedsController
is created to handle feed retrieval and display:
<code class="language-php">use GetStream\StreamLaravel\Enrich; class FeedsController extends Controller { // ... other code ... public function newsFeed(Request $request) { $feed = FeedManager::getNewsFeeds($request->user()->id)['timeline']; $activities = $feed->getActivities(0, 25)['results']; $activities = $this->enrich()->enrichActivities($activities); return view('feed.newsfeed', ['activities' => $activities]); } private function enrich() { return new Enrich; } // ... other methods ... }</code>
The enrich
method handles data transformation for view rendering. A route is defined to access this controller action.
Templating:
The newsfeed
view iterates through enriched activities, using a partial (stream-laravel::render_activity
) for rendering individual activities. Custom activity partials (e.g., created.blade.php
for post creation) are created within the activity
view folder.
Example created.blade.php
partial:
<code class="language-php">class Post extends Model { // ... other code ... /** * Stream: Activity verb for post creation. */ public function activityVerb() { return 'created'; } }</code>
Notification Feed:
The Follow
model is updated to include notification feed handling:
<code class="language-php">// app/Http/Controllers/FollowController.php public function follow(User $user) { if (!Auth::user()->isFollowing($user->id)) { Auth::user()->follows()->create(['target_id' => $user->id]); FeedManager::followUser(Auth::id(), $user->id); return back()->with('success', 'Now following ' . $user->name); } else { return back()->with('error', 'Already following this user.'); } } public function unfollow(User $user) { if (Auth::user()->isFollowing($user->id)) { $follow = Auth::user()->follows()->where('target_id', $user->id)->first(); FeedManager::unfollowUser(Auth::id(), $follow->target_id); $follow->delete(); return back()->with('success', 'Unfollowed ' . $user->name); } else { return back()->with('error', 'Not following this user.'); } }</code>
A similar controller action, route, and view (notifications.blade.php
) are created for the notification feed. A separate partial (notification_follow.blade.php
) is used for follow notifications.
Conclusion:
Stream simplifies the addition of robust feed functionality to Laravel applications. The tutorial demonstrates how to track various activities, manage different feed types, and render them efficiently in views. Further exploration of Stream's capabilities is encouraged.
FAQs (Slightly Reformatted):
The FAQs section is well-written and provides helpful information. No significant changes are needed, but minor formatting adjustments could improve readability. Consider using a numbered list or bolding key terms for better visual organization.
The above is the detailed content of Building a Social Network with Laravel and Stream? Easy!. For more information, please follow other related articles on the PHP Chinese website!