Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions packages/stream_feeds/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
## Upcoming
- Added missing state updates for the websocket events.
- Add appeal-related methods to moderation client: `appeal`, `getAppeal`, and `queryAppeals`.
- Add `activityCount` field to `FeedData` model to track the number of activities in a feed.
- Add `ownFollowings` field to `FeedData` model to track feeds that the current user is following from this feed.

## 0.5.0
- [BREAKING] Unified `ThreadedCommentData` into `CommentData` to handle both flat and threaded comments.
Expand Down
33 changes: 33 additions & 0 deletions packages/stream_feeds/lib/src/client/moderation_client.dart
Original file line number Diff line number Diff line change
Expand Up @@ -100,6 +100,39 @@ class ModerationClient {
return _moderationRepository.flag(flagRequest);
}

/// Submits an appeal for a moderation decision.
///
/// Allows users to appeal moderation actions using the data in [appealRequest].
///
/// Returns a [Result] containing an [api.AppealResponse] or an error.
Future<Result<api.AppealResponse>> appeal({
required api.AppealRequest appealRequest,
}) {
return _moderationRepository.appeal(appealRequest);
}

/// Gets an appeal by ID.
///
/// Retrieves the appeal identified by [id].
///
/// Returns a [Result] containing a [api.GetAppealResponse] or an error.
Future<Result<api.GetAppealResponse>> getAppeal({
required String id,
}) {
return _moderationRepository.getAppeal(id);
}

/// Queries appeals.
///
/// Retrieves appeals using the specified [queryAppealsRequest] filters and pagination.
///
/// Returns a [Result] containing a [api.QueryAppealsResponse] or an error.
Future<Result<api.QueryAppealsResponse>> queryAppeals({
api.QueryAppealsRequest? queryAppealsRequest,
}) {
return _moderationRepository.queryAppeals(queryAppealsRequest);
}

/// Submits a moderation action.
///
/// Executes a moderation decision using the data in [submitActionRequest].
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,11 @@ abstract interface class DefaultApi {
@Body() required AddCommentsBatchRequest addCommentsBatchRequest,
});

@POST('/api/v2/moderation/appeal')
Future<Result<AppealResponse>> appeal({
@Body() required AppealRequest appealRequest,
});

@POST('/api/v2/moderation/ban')
Future<Result<BanResponse>> ban({
@Body() required BanRequest banRequest,
Expand Down Expand Up @@ -245,6 +250,11 @@ abstract interface class DefaultApi {
@GET('/api/v2/app')
Future<Result<GetApplicationResponse>> getApp();

@GET('/api/v2/moderation/appeal/{id}')
Future<Result<GetAppealResponse>> getAppeal({
@Path('id') required String id,
});

@GET('/api/v2/users/block')
Future<Result<GetBlockedUsersResponse>> getBlockedUsers();

Expand Down Expand Up @@ -300,6 +310,16 @@ abstract interface class DefaultApi {
@Body() GetOrCreateFeedRequest? getOrCreateFeedRequest,
});

@POST('/api/v2/feeds/follows/batch/upsert')
Future<Result<FollowBatchResponse>> getOrCreateFollows({
@Body() required FollowBatchRequest followBatchRequest,
});

@POST('/api/v2/feeds/unfollow/batch/upsert')
Future<Result<UnfollowBatchResponse>> getOrCreateUnfollows({
@Body() required UnfollowBatchRequest unfollowBatchRequest,
});

@GET('/api/v2/polls/{poll_id}')
Future<Result<PollResponse>> getPoll({
@Path('poll_id') required String pollId,
Expand Down Expand Up @@ -342,9 +362,9 @@ abstract interface class DefaultApi {
@Body() required MuteRequest muteRequest,
});

@POST('/api/v2/feeds/feeds/own_capabilities/batch')
Future<Result<OwnCapabilitiesBatchResponse>> ownCapabilitiesBatch({
@Body() required OwnCapabilitiesBatchRequest ownCapabilitiesBatchRequest,
@POST('/api/v2/feeds/feeds/own/batch')
Future<Result<OwnBatchResponse>> ownBatch({
@Body() required OwnBatchRequest ownBatchRequest,
});

@POST(
Expand All @@ -366,6 +386,11 @@ abstract interface class DefaultApi {
@Body() QueryActivityReactionsRequest? queryActivityReactionsRequest,
});

@POST('/api/v2/moderation/appeals')
Future<Result<QueryAppealsResponse>> queryAppeals({
@Body() QueryAppealsRequest? queryAppealsRequest,
});

@POST('/api/v2/feeds/bookmark_folders/query')
Future<Result<QueryBookmarkFoldersResponse>> queryBookmarkFolders({
@Body() QueryBookmarkFoldersRequest? queryBookmarkFoldersRequest,
Expand Down
208 changes: 195 additions & 13 deletions packages/stream_feeds/lib/src/generated/api/api/default_api.g.dart

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading