mirror of
https://github.com/pixelfed/pixelfed.git
synced 2024-11-09 16:24:51 +00:00
Add /api/v1/statuses endpoint
This commit is contained in:
parent
f85a780907
commit
3aa729a362
2 changed files with 89 additions and 5 deletions
|
@ -31,8 +31,10 @@ use App\Transformer\Api\{
|
||||||
use App\Http\Controllers\FollowerController;
|
use App\Http\Controllers\FollowerController;
|
||||||
use League\Fractal\Serializer\ArraySerializer;
|
use League\Fractal\Serializer\ArraySerializer;
|
||||||
use League\Fractal\Pagination\IlluminatePaginatorAdapter;
|
use League\Fractal\Pagination\IlluminatePaginatorAdapter;
|
||||||
|
use App\Http\Controllers\StatusController;
|
||||||
use App\Jobs\LikePipeline\LikePipeline;
|
use App\Jobs\LikePipeline\LikePipeline;
|
||||||
|
use App\Util\Media\Filter;
|
||||||
|
use App\Jobs\StatusPipeline\NewStatusPipeline;
|
||||||
use App\Jobs\StatusPipeline\StatusDelete;
|
use App\Jobs\StatusPipeline\StatusDelete;
|
||||||
use App\Jobs\FollowPipeline\FollowPipeline;
|
use App\Jobs\FollowPipeline\FollowPipeline;
|
||||||
use App\Jobs\ImageOptimizePipeline\ImageOptimize;
|
use App\Jobs\ImageOptimizePipeline\ImageOptimize;
|
||||||
|
@ -1461,21 +1463,103 @@ class ApiV1Controller extends Controller
|
||||||
return response()->json($res);
|
return response()->json($res);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* POST /api/v1/statuses
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return StatusTransformer
|
||||||
|
*/
|
||||||
public function createStatus(Request $request)
|
public function createStatus(Request $request)
|
||||||
{
|
{
|
||||||
abort_if(!$request->user(), 403);
|
abort_if(!$request->user(), 403);
|
||||||
|
|
||||||
$this->validate($request, [
|
$this->validate($request, [
|
||||||
'status' => 'string',
|
'status' => 'nullable|string',
|
||||||
'media_ids' => 'array',
|
'in_reply_to_id' => 'nullable|integer',
|
||||||
|
'media_ids' => 'array|max:' . config('pixelfed.max_album_length'),
|
||||||
'media_ids.*' => 'integer|min:1',
|
'media_ids.*' => 'integer|min:1',
|
||||||
'sensitive' => 'nullable|boolean',
|
'sensitive' => 'nullable|boolean',
|
||||||
'visibility' => 'string|in:private,unlisted,public',
|
'visibility' => 'string|in:private,unlisted,public',
|
||||||
'in_reply_to_id' => 'integer'
|
|
||||||
]);
|
]);
|
||||||
|
|
||||||
|
if(config('costar.enabled') == true) {
|
||||||
|
$blockedKeywords = config('costar.keyword.block');
|
||||||
|
if($blockedKeywords !== null && $request->status) {
|
||||||
|
$keywords = config('costar.keyword.block');
|
||||||
|
foreach($keywords as $kw) {
|
||||||
|
if(Str::contains($request->status, $kw) == true) {
|
||||||
|
abort(400, 'Invalid object. Contains banned keyword.');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if(!$request->filled('media_ids') && !$request->filled('in_reply_to_id')) {
|
if(!$request->filled('media_ids') && !$request->filled('in_reply_to_id')) {
|
||||||
abort(403, 'Empty statuses are not allowed');
|
abort(403, 'Empty statuses are not allowed');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$ids = $request->input('media_ids');
|
||||||
|
$in_reply_to_id = $request->input('in_reply_to_id');
|
||||||
|
$user = $request->user();
|
||||||
|
|
||||||
|
if($in_reply_to_id) {
|
||||||
|
$parent = Status::findOrFail($in_reply_to_id);
|
||||||
|
|
||||||
|
$status = new Status;
|
||||||
|
$status->caption = strip_tags($request->input('status'));
|
||||||
|
$status->scope = $request->input('visibility');
|
||||||
|
$status->visibility = $request->input('visibility');
|
||||||
|
$status->profile_id = $user->profile_id;
|
||||||
|
$status->is_nsfw = $user->profile->cw == true ? true : $request->input('sensitive');
|
||||||
|
$status->in_reply_to_id = $parent->id;
|
||||||
|
$status->in_reply_to_profile_id = $parent->profile_id;
|
||||||
|
$status->save();
|
||||||
|
} else if($ids) {
|
||||||
|
$status = new Status;
|
||||||
|
$status->caption = strip_tags($request->input('status'));
|
||||||
|
$status->profile_id = $user->profile_id;
|
||||||
|
$status->scope = 'draft';
|
||||||
|
$status->is_nsfw = $user->profile->cw == true ? true : $request->input('sensitive');
|
||||||
|
$status->save();
|
||||||
|
|
||||||
|
$mimes = [];
|
||||||
|
|
||||||
|
foreach($ids as $k => $v) {
|
||||||
|
if($k + 1 > config('pixelfed.max_album_length')) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
$m = Media::findOrFail($v);
|
||||||
|
if($m->profile_id !== $user->profile_id || $m->status_id) {
|
||||||
|
abort(403, 'Invalid media id');
|
||||||
|
}
|
||||||
|
$m->status_id = $status->id;
|
||||||
|
$m->save();
|
||||||
|
array_push($mimes, $m->mime);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(empty($mimes)) {
|
||||||
|
$status->delete();
|
||||||
|
abort(500, 'Invalid media ids');
|
||||||
|
}
|
||||||
|
|
||||||
|
$status->scope = $request->input('visibility');
|
||||||
|
$status->visibility = $request->input('visibility');
|
||||||
|
$status->type = StatusController::mimeTypeCheck($mimes);
|
||||||
|
$status->save();
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!$status) {
|
||||||
|
$oops = 'An error occured. RefId: '.time().'-'.$user->profile_id.':'.Str::random(5).':'.Str::random(10);
|
||||||
|
abort(500, $oops);
|
||||||
|
}
|
||||||
|
|
||||||
|
NewStatusPipeline::dispatch($status);
|
||||||
|
Cache::forget('user:account:id:'.$user->id);
|
||||||
|
Cache::forget('profile:status_count:'.$user->profile_id);
|
||||||
|
Cache::forget($user->storageUsedKey());
|
||||||
|
|
||||||
|
$resource = new Fractal\Resource\Item($status, new StatusTransformer());
|
||||||
|
$res = $this->fractal->createData($resource)->toArray();
|
||||||
|
return response()->json($res);
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -125,13 +125,13 @@ Route::domain(config('pixelfed.domain.app'))->middleware(['validemail', 'twofact
|
||||||
Route::get('timelines/home', 'Api\ApiV1Controller@timelineHome')->middleware('auth:api');
|
Route::get('timelines/home', 'Api\ApiV1Controller@timelineHome')->middleware('auth:api');
|
||||||
Route::get('conversations', 'Api\ApiV1Controller@conversations')->middleware('auth:api');
|
Route::get('conversations', 'Api\ApiV1Controller@conversations')->middleware('auth:api');
|
||||||
Route::get('timelines/public', 'Api\ApiV1Controller@timelinePublic');
|
Route::get('timelines/public', 'Api\ApiV1Controller@timelinePublic');
|
||||||
|
Route::post('status', 'Api\ApiV1Controller@createStatus')->middleware('auth:api');
|
||||||
|
|
||||||
// Route::get('likes', 'ApiController@hydrateLikes');
|
// Route::get('likes', 'ApiController@hydrateLikes');
|
||||||
// Route::post('media', 'ApiController@uploadMedia')->middleware('auth:api');
|
// Route::post('media', 'ApiController@uploadMedia')->middleware('auth:api');
|
||||||
// Route::delete('media', 'ApiController@deleteMedia')->middleware('auth:api');
|
// Route::delete('media', 'ApiController@deleteMedia')->middleware('auth:api');
|
||||||
// Route::get('notifications', 'ApiController@notifications')->middleware('auth:api');
|
// Route::get('notifications', 'ApiController@notifications')->middleware('auth:api');
|
||||||
// Route::get('timelines/public', 'PublicApiController@publicTimelineApi');
|
// Route::get('timelines/public', 'PublicApiController@publicTimelineApi');
|
||||||
// Route::post('status', 'Api\ApiV1Controller@createStatus')->middleware('auth:api');
|
|
||||||
Route::get('accounts/{id}', 'Api\ApiV1Controller@accountById')->middleware('auth:api');
|
Route::get('accounts/{id}', 'Api\ApiV1Controller@accountById')->middleware('auth:api');
|
||||||
});
|
});
|
||||||
Route::group(['prefix' => 'v2'], function() {
|
Route::group(['prefix' => 'v2'], function() {
|
||||||
|
|
Loading…
Reference in a new issue