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:
- Stream Laravel's
FeedManager
simplifies feed operations, offering pre-built feeds (user, news, notification). - Stream stores data as activities (actor, verb, object, time, plus custom data).
- The
FollowController
usesFeedManager
for following/unfollowing, updating feeds accordingly. - Activities are enriched before display, transforming raw data into a view-friendly format.
- Stream supports various feed types (news, notifications), allowing custom templates for different activities.
Activity Data Structure:
Stream represents data as activities with at least: actor, verb, object, and time. Custom fields are also allowed.
- object: Reference to the model instance.
- actor: Reference to the user creating the activity.
- verb: String representing the action (e.g., 'created').
Example: Defining the activityVerb
in the Post
model:
class Post extends Model { // ... other code ... /** * Stream: Activity verb for post creation. */ public function activityVerb() { return 'created'; } }
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:
// 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.'); } }
Displaying Feeds:
A FeedsController
is created to handle feed retrieval and display:
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 ... }
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:
class Post extends Model { // ... other code ... /** * Stream: Activity verb for post creation. */ public function activityVerb() { return 'created'; } }
Notification Feed:
The Follow
model is updated to include notification feed handling:
// 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.'); } }
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!

PHPsessionscanstorestrings,numbers,arrays,andobjects.1.Strings:textdatalikeusernames.2.Numbers:integersorfloatsforcounters.3.Arrays:listslikeshoppingcarts.4.Objects:complexstructuresthatareserialized.

TostartaPHPsession,usesession_start()atthescript'sbeginning.1)Placeitbeforeanyoutputtosetthesessioncookie.2)Usesessionsforuserdatalikeloginstatusorshoppingcarts.3)RegeneratesessionIDstopreventfixationattacks.4)Considerusingadatabaseforsessionstoragei

Session regeneration refers to generating a new session ID and invalidating the old ID when the user performs sensitive operations in case of session fixed attacks. The implementation steps include: 1. Detect sensitive operations, 2. Generate new session ID, 3. Destroy old session ID, 4. Update user-side session information.

PHP sessions have a significant impact on application performance. Optimization methods include: 1. Use a database to store session data to improve response speed; 2. Reduce the use of session data and only store necessary information; 3. Use a non-blocking session processor to improve concurrency capabilities; 4. Adjust the session expiration time to balance user experience and server burden; 5. Use persistent sessions to reduce the number of data read and write times.

PHPsessionsareserver-side,whilecookiesareclient-side.1)Sessionsstoredataontheserver,aremoresecure,andhandlelargerdata.2)Cookiesstoredataontheclient,arelesssecure,andlimitedinsize.Usesessionsforsensitivedataandcookiesfornon-sensitive,client-sidedata.

PHPidentifiesauser'ssessionusingsessioncookiesandsessionIDs.1)Whensession_start()iscalled,PHPgeneratesauniquesessionIDstoredinacookienamedPHPSESSIDontheuser'sbrowser.2)ThisIDallowsPHPtoretrievesessiondatafromtheserver.

The security of PHP sessions can be achieved through the following measures: 1. Use session_regenerate_id() to regenerate the session ID when the user logs in or is an important operation. 2. Encrypt the transmission session ID through the HTTPS protocol. 3. Use session_save_path() to specify the secure directory to store session data and set permissions correctly.

PHPsessionfilesarestoredinthedirectoryspecifiedbysession.save_path,typically/tmponUnix-likesystemsorC:\Windows\TemponWindows.Tocustomizethis:1)Usesession_save_path()tosetacustomdirectory,ensuringit'swritable;2)Verifythecustomdirectoryexistsandiswrita


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

WebStorm Mac version
Useful JavaScript development tools

SublimeText3 English version
Recommended: Win version, supports code prompts!

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

Atom editor mac version download
The most popular open source editor
