// The following methods are available to edit the members of a feed
try await feed.updateFeedMembers(
request: .init(
members: [.init(
custom: ["joined": "2024-01-01"],
userId: "john"
)],
operation: .upsert
)
)
// Remove members
try await feed.updateFeedMembers(
request: .init(
members: [.init(userId: "john"), .init(userId: "jane")],
operation: .remove
)
)
// Set members (overwrites the list)
try await feed.updateFeedMembers(
request: .init(
members: [.init(userId: "john")],
operation: .set
)
)Members
Manage members
You can add and remove members to a feed. This is useful for building communities where a set of users can add content to the feed.
It's not possible to set/update member role on client-side. Use server-side SDKs for this. When adding members client-side all new members will have feed_member role:
_, err = feed.UpdateFeedMembers(context.Background(), &getstream.UpdateFeedMembersRequest{
Operation: "upsert",
Members: []getstream.FeedMemberRequest{
{
UserID: "john",
Role: getstream.PtrTo("feed_moderator"),
Custom: map[string]any{
"joined": "2024-01-01",
},
},
},
})
if err != nil {
log.Fatal(err)
}
// Remove members
_, err = feed.UpdateFeedMembers(context.Background(), &getstream.UpdateFeedMembersRequest{
Operation: "remove",
Members: []getstream.FeedMemberRequest{
{
UserID: "john",
},
{
UserID: "jane",
},
},
})
if err != nil {
log.Fatal(err)
}
// Set members (overwrites the list)
_, err = feed.UpdateFeedMembers(context.Background(), &getstream.UpdateFeedMembersRequest{
Operation: "set",
Members: []getstream.FeedMemberRequest{
{
UserID: "john",
Role: getstream.PtrTo("feed_moderator"),
},
},
})
if err != nil {
log.Fatal(err)
}Overview of the feed member model
Feed members vs followers
Followers and members might seem like similar concepts, but they serve two different purposes with some key differences.
Followers can only be feeds (for example the timeline feed of Alice follows the user feed of Bob). Followers' aim is to access the content of a feed they're interested in and interact with it.
Members can only be users (for example Alice adds Bob as a member to her feed about "Travel Hacks"). The aim of feed members is usually to help out with admin tasks (helpful if you want to build apps similar to Facebook pages) or to decide what activities a user has access to using membership levels (for example Bob becomes a premium member in Alice's community).
Member invites
You can invite members with the invite flag, where invited users can accept or reject the membership.
// Create feed
feed := client.Feeds().Feed("user", "alice")
// Update feed members with upsert operation
updateResponse, err := feed.UpdateFeedMembers(context.Background(), &getstream.UpdateFeedMembersRequest{
Operation: "upsert",
Members: []getstream.FeedMemberRequest{
{
UserID: "john",
Role: getstream.PtrTo("feed_moderator"),
Invite: getstream.PtrTo(true),
Custom: map[string]any{
"reason": "community builder",
},
},
},
})
if err != nil {
log.Fatal("Error updating feed members:", err)
}
log.Printf("Feed members updated: %+v", updateResponse)
// Accept feed member invite
acceptResponse, err := feed.AcceptFeedMemberInvite(context.Background(), &getstream.AcceptFeedMemberInviteRequest{
UserID: getstream.PtrTo("john"),
})
if err != nil {
log.Fatal("Error accepting feed member invite:", err)
}
log.Printf("Feed member invite accepted: %+v", acceptResponse)
// Reject feed member invite
rejectResponse, err := feed.RejectFeedMemberInvite(context.Background(), &getstream.RejectFeedMemberInviteRequest{
UserID: getstream.PtrTo("john"),
})
if err != nil {
log.Fatal("Error rejecting feed member invite:", err)
}
log.Printf("Feed member invite rejected: %+v", rejectResponse)Query Feed Members
You can query the members of a feed. This is useful for showing the list of members in a community.
val memberList = client.memberList(
MembersQuery(
fid = FeedId(group = "stock", id = "apple"),
filter = MembersFilterField.role.equal("moderator"),
)
)
memberList.get()
memberList.state.members.collect { members ->
// Handle members
}Feed Members Queryable Built-in Fields
| name | type | description | supported operations | example |
|---|---|---|---|---|
user_id | string or list of strings | The ID of the user who is a member of the feed | $in, $eq | { user_id: { $eq: 'user_123' } } |
role | string or list of strings | The role of the member | $in, $eq | { role: { $in: [ 'admin', 'moderator', 'member' ] } } |
status | string or list of strings | The membership status | $in, $eq | { status: { $in: [ 'member', 'pending', 'rejected' ] } } |
created_at | string, must be formatted as an RFC3339 timestamp | The time the membership was created | $eq, $gt, $gte, $lt, $lte | { created_at: { $gte: '2023-12-04T09:30:20.45Z' } } |
updated_at | string, must be formatted as an RFC3339 timestamp | The time the membership was last updated | $eq, $gt, $gte, $lt, $lte | { updated_at: { $gte: '2023-12-04T09:30:20.45Z' } } |