mirror of
https://github.com/pixelfed/pixelfed.git
synced 2024-12-25 17:26:43 +00:00
Add /api/v1/accounts/{id}/block endpoint
This commit is contained in:
parent
ac9f1bc04e
commit
c6b1ed97f9
2 changed files with 41 additions and 0 deletions
|
@ -535,6 +535,46 @@ class ApiV1Controller extends Controller
|
||||||
return response()->json($res);
|
return response()->json($res);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* POST /api/v1/accounts/{id}/block
|
||||||
|
*
|
||||||
|
* @param integer $id
|
||||||
|
*
|
||||||
|
* @return \App\Transformer\Api\RelationshipTransformer
|
||||||
|
*/
|
||||||
|
public function accountBlockById(Request $request, $id)
|
||||||
|
{
|
||||||
|
abort_if(!$request->user(), 403);
|
||||||
|
|
||||||
|
$user = $request->user();
|
||||||
|
$pid = $user->profile_id ?? $user->profile->id;
|
||||||
|
|
||||||
|
if($id == $pid) {
|
||||||
|
abort(400, 'You cannot block yourself');
|
||||||
|
}
|
||||||
|
|
||||||
|
$profile = Profile::findOrFail($id);
|
||||||
|
|
||||||
|
Follower::whereProfileId($profile->id)->whereFollowingId($pid)->delete();
|
||||||
|
Follower::whereProfileId($pid)->whereFollowingId($profile->id)->delete();
|
||||||
|
Notification::whereProfileId($pid)->whereActorId($profile->id)->delete();
|
||||||
|
|
||||||
|
$filter = UserFilter::firstOrCreate([
|
||||||
|
'user_id' => $pid,
|
||||||
|
'filterable_id' => $profile->id,
|
||||||
|
'filterable_type' => 'App\Profile',
|
||||||
|
'filter_type' => 'block',
|
||||||
|
]);
|
||||||
|
|
||||||
|
Cache::forget("user:filter:list:$pid");
|
||||||
|
Cache::forget("api:local:exp:rec:$pid");
|
||||||
|
|
||||||
|
$resource = new Fractal\Resource\Item($profile, new RelationshipTransformer());
|
||||||
|
$res = $this->fractal->createData($resource)->toArray();
|
||||||
|
|
||||||
|
return response()->json($res);
|
||||||
|
}
|
||||||
|
|
||||||
public function statusById(Request $request, $id)
|
public function statusById(Request $request, $id)
|
||||||
{
|
{
|
||||||
$status = Status::whereVisibility('public')->findOrFail($id);
|
$status = Status::whereVisibility('public')->findOrFail($id);
|
||||||
|
|
|
@ -87,6 +87,7 @@ Route::domain(config('pixelfed.domain.app'))->middleware(['validemail', 'twofact
|
||||||
Route::post('accounts/{id}/follow', 'Api\ApiV1Controller@accountFollowById')->middleware('auth:api');
|
Route::post('accounts/{id}/follow', 'Api\ApiV1Controller@accountFollowById')->middleware('auth:api');
|
||||||
Route::post('accounts/{id}/unfollow', 'Api\ApiV1Controller@accountUnfollowById')->middleware('auth:api');
|
Route::post('accounts/{id}/unfollow', 'Api\ApiV1Controller@accountUnfollowById')->middleware('auth:api');
|
||||||
Route::get('blocks', 'Api\ApiV1Controller@accountBlocks')->middleware('auth:api');
|
Route::get('blocks', 'Api\ApiV1Controller@accountBlocks')->middleware('auth:api');
|
||||||
|
Route::post('accounts/{id}/block', 'Api\ApiV1Controller@accountBlockById')->middleware('auth:api');
|
||||||
// Route::get('accounts/{id}', 'PublicApiController@account');
|
// Route::get('accounts/{id}', 'PublicApiController@account');
|
||||||
Route::get('accounts/{id}', 'Api\ApiV1Controller@accountById');
|
Route::get('accounts/{id}', 'Api\ApiV1Controller@accountById');
|
||||||
Route::post('avatar/update', 'ApiController@avatarUpdate')->middleware('auth:api');
|
Route::post('avatar/update', 'ApiController@avatarUpdate')->middleware('auth:api');
|
||||||
|
|
Loading…
Reference in a new issue