Skip to content

Commit

Permalink
Add /api/v1/accounts/{id}/unmute endpoint
Browse files Browse the repository at this point in the history
  • Loading branch information
dansup committed Sep 26, 2019
1 parent 3e98dce commit 41c96dd
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 4 deletions.
40 changes: 37 additions & 3 deletions app/Http/Controllers/Api/ApiV1Controller.php
Original file line number Diff line number Diff line change
Expand Up @@ -1030,24 +1030,24 @@ public function accountMutes(Request $request)
*
* @param integer $id
*
* @return App\Transformer\Api\AccountTransformer
* @return App\Transformer\Api\RelationshipTransformer
*/
public function accountMuteById(Request $request, $id)
{
abort_if(!$request->user(), 403);

$user = $request->user();
$pid = $user->profile_id;

$account = Profile::findOrFail($id);

$filter = UserFilter::firstOrCreate([
'user_id' => $user->profile_id,
'user_id' => $pid,
'filterable_id' => $account->id,
'filterable_type' => 'App\Profile',
'filter_type' => 'mute',
]);

$pid = $user->profile_id;
Cache::forget("user:filter:list:$pid");
Cache::forget("feature:discover:posts:$pid");
Cache::forget("api:local:exp:rec:$pid");
Expand All @@ -1057,6 +1057,40 @@ public function accountMuteById(Request $request, $id)
return response()->json($res);
}

/**
* POST /api/v1/accounts/{id}/unmute
*
* @param integer $id
*
* @return App\Transformer\Api\RelationshipTransformer
*/
public function accountUnmuteById(Request $request, $id)
{
abort_if(!$request->user(), 403);

$user = $request->user();
$pid = $user->profile_id;

$account = Profile::findOrFail($id);

$filter = UserFilter::whereUserId($pid)
->whereFilterableId($account->id)
->whereFilterableType('App\Profile')
->whereFilterType('mute')
->first();

if($filter) {
$filter->delete();
Cache::forget("user:filter:list:$pid");
Cache::forget("feature:discover:posts:$pid");
Cache::forget("api:local:exp:rec:$pid");
}

$resource = new Fractal\Resource\Item($account, new RelationshipTransformer());
$res = $this->fractal->createData($resource)->toArray();
return response()->json($res);
}

public function statusById(Request $request, $id)
{
$status = Status::whereVisibility('public')->findOrFail($id);
Expand Down
3 changes: 2 additions & 1 deletion routes/web.php
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,6 @@
Route::post('accounts/{id}/pin', 'Api\ApiV1Controller@accountEndorsements')->middleware('auth:api');
Route::post('accounts/{id}/unpin', 'Api\ApiV1Controller@accountEndorsements')->middleware('auth:api');
// Route::get('accounts/{id}', 'PublicApiController@account');
Route::get('accounts/{id}', 'Api\ApiV1Controller@accountById');
Route::post('avatar/update', 'ApiController@avatarUpdate')->middleware('auth:api');
Route::get('domain_blocks', 'Api\ApiV1Controller@accountDomainBlocks')->middleware('auth:api');
Route::post('domain_blocks', 'Api\ApiV1Controller@accountDomainBlocks')->middleware('auth:api');
Expand All @@ -114,6 +113,7 @@
Route::put('media/{id}', 'Api\ApiV1Controller@mediaUpdate')->middleware('auth:api');
Route::get('mutes', 'Api\ApiV1Controller@accountMutes')->middleware('auth:api');
Route::post('accounts/{id}/mute', 'Api\ApiV1Controller@accountMuteById')->middleware('auth:api');
Route::post('accounts/{id}/unmute', 'Api\ApiV1Controller@accountUnmuteById')->middleware('auth:api');

// Route::get('likes', 'ApiController@hydrateLikes');
// Route::post('media', 'ApiController@uploadMedia')->middleware('auth:api');
Expand All @@ -122,6 +122,7 @@
// Route::get('timelines/public', 'PublicApiController@publicTimelineApi');
// Route::get('timelines/home', 'PublicApiController@homeTimelineApi')->middleware('auth:api');
// Route::post('status', 'Api\ApiV1Controller@createStatus')->middleware('auth:api');
Route::get('accounts/{id}', 'Api\ApiV1Controller@accountById');
});
Route::group(['prefix' => 'v2'], function() {
Route::get('config', 'ApiController@siteConfiguration');
Expand Down

0 comments on commit 41c96dd

Please sign in to comment.