mirror of
https://github.com/pixelfed/pixelfed.git
synced 2024-11-22 14:31:26 +00:00
Add /api/v1/statuses/{id}/card endpoint
This commit is contained in:
parent
db3b873a50
commit
9225120835
3 changed files with 56 additions and 12 deletions
|
@ -927,7 +927,7 @@ class ApiV1Controller extends Controller
|
||||||
* POST /api/v1/media
|
* POST /api/v1/media
|
||||||
*
|
*
|
||||||
*
|
*
|
||||||
* @return App\Transformer\Api\MediaTransformer
|
* @return MediaTransformer
|
||||||
*/
|
*/
|
||||||
public function mediaUpload(Request $request)
|
public function mediaUpload(Request $request)
|
||||||
{
|
{
|
||||||
|
@ -1011,7 +1011,7 @@ class ApiV1Controller extends Controller
|
||||||
*
|
*
|
||||||
* @param integer $id
|
* @param integer $id
|
||||||
*
|
*
|
||||||
* @return App\Transformer\Api\MediaTransformer
|
* @return MediaTransformer
|
||||||
*/
|
*/
|
||||||
public function mediaUpdate(Request $request, $id)
|
public function mediaUpdate(Request $request, $id)
|
||||||
{
|
{
|
||||||
|
@ -1041,7 +1041,7 @@ class ApiV1Controller extends Controller
|
||||||
* GET /api/v1/mutes
|
* GET /api/v1/mutes
|
||||||
*
|
*
|
||||||
*
|
*
|
||||||
* @return App\Transformer\Api\AccountTransformer
|
* @return AccountTransformer
|
||||||
*/
|
*/
|
||||||
public function accountMutes(Request $request)
|
public function accountMutes(Request $request)
|
||||||
{
|
{
|
||||||
|
@ -1072,7 +1072,7 @@ class ApiV1Controller extends Controller
|
||||||
*
|
*
|
||||||
* @param integer $id
|
* @param integer $id
|
||||||
*
|
*
|
||||||
* @return App\Transformer\Api\RelationshipTransformer
|
* @return RelationshipTransformer
|
||||||
*/
|
*/
|
||||||
public function accountMuteById(Request $request, $id)
|
public function accountMuteById(Request $request, $id)
|
||||||
{
|
{
|
||||||
|
@ -1104,7 +1104,7 @@ class ApiV1Controller extends Controller
|
||||||
*
|
*
|
||||||
* @param integer $id
|
* @param integer $id
|
||||||
*
|
*
|
||||||
* @return App\Transformer\Api\RelationshipTransformer
|
* @return RelationshipTransformer
|
||||||
*/
|
*/
|
||||||
public function accountUnmuteById(Request $request, $id)
|
public function accountUnmuteById(Request $request, $id)
|
||||||
{
|
{
|
||||||
|
@ -1137,7 +1137,7 @@ class ApiV1Controller extends Controller
|
||||||
* GET /api/v1/notifications
|
* GET /api/v1/notifications
|
||||||
*
|
*
|
||||||
*
|
*
|
||||||
* @return App\Transformer\Api\NotificationTransformer
|
* @return NotificationTransformer
|
||||||
*/
|
*/
|
||||||
public function accountNotifications(Request $request)
|
public function accountNotifications(Request $request)
|
||||||
{
|
{
|
||||||
|
@ -1177,7 +1177,7 @@ class ApiV1Controller extends Controller
|
||||||
* GET /api/v1/timelines/home
|
* GET /api/v1/timelines/home
|
||||||
*
|
*
|
||||||
*
|
*
|
||||||
* @return App\Transformer\Api\StatusTransformer
|
* @return StatusTransformer
|
||||||
*/
|
*/
|
||||||
public function timelineHome(Request $request)
|
public function timelineHome(Request $request)
|
||||||
{
|
{
|
||||||
|
@ -1279,7 +1279,7 @@ class ApiV1Controller extends Controller
|
||||||
* GET /api/v1/timelines/public
|
* GET /api/v1/timelines/public
|
||||||
*
|
*
|
||||||
*
|
*
|
||||||
* @return App\Transformer\Api\StatusTransformer
|
* @return StatusTransformer
|
||||||
*/
|
*/
|
||||||
public function timelinePublic(Request $request)
|
public function timelinePublic(Request $request)
|
||||||
{
|
{
|
||||||
|
@ -1354,8 +1354,17 @@ class ApiV1Controller extends Controller
|
||||||
return response()->json($res);
|
return response()->json($res);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* GET /api/v1/statuses/{id}
|
||||||
|
*
|
||||||
|
* @param integer $id
|
||||||
|
*
|
||||||
|
* @return StatusTransformer
|
||||||
|
*/
|
||||||
public function statusById(Request $request, $id)
|
public function statusById(Request $request, $id)
|
||||||
{
|
{
|
||||||
|
abort_if(!$request->user(), 403);
|
||||||
|
|
||||||
$status = Status::whereVisibility('public')->findOrFail($id);
|
$status = Status::whereVisibility('public')->findOrFail($id);
|
||||||
$resource = new Fractal\Resource\Item($status, new StatusTransformer());
|
$resource = new Fractal\Resource\Item($status, new StatusTransformer());
|
||||||
$res = $this->fractal->createData($resource)->toArray();
|
$res = $this->fractal->createData($resource)->toArray();
|
||||||
|
@ -1363,9 +1372,42 @@ class ApiV1Controller extends Controller
|
||||||
return response()->json($res);
|
return response()->json($res);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function context(Request $request)
|
/**
|
||||||
|
* GET /api/v1/statuses/{id}/context
|
||||||
|
*
|
||||||
|
* @param integer $id
|
||||||
|
*
|
||||||
|
* @return StatusTransformer
|
||||||
|
*/
|
||||||
|
public function statusContext(Request $request, $id)
|
||||||
{
|
{
|
||||||
// todo
|
abort_if(!$request->user(), 403);
|
||||||
|
|
||||||
|
$status = Status::whereVisibility('public')->findOrFail($id);
|
||||||
|
|
||||||
|
// Return empty response since we don't handle threading like this
|
||||||
|
$res = [
|
||||||
|
'ancestors' => [],
|
||||||
|
'descendants' => []
|
||||||
|
];
|
||||||
|
|
||||||
|
return response()->json($res);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* GET /api/v1/statuses/{id}/card
|
||||||
|
*
|
||||||
|
* @param integer $id
|
||||||
|
*
|
||||||
|
* @return StatusTransformer
|
||||||
|
*/
|
||||||
|
public function statusCard(Request $request, $id)
|
||||||
|
{
|
||||||
|
abort_if(!$request->user(), 403);
|
||||||
|
|
||||||
|
$status = Status::whereVisibility('public')->findOrFail($id);
|
||||||
|
|
||||||
|
// Return empty response since we don't handle threading like this
|
||||||
$res = [
|
$res = [
|
||||||
'ancestors' => [],
|
'ancestors' => [],
|
||||||
'descendants' => []
|
'descendants' => []
|
||||||
|
|
|
@ -9,7 +9,5 @@ Route::group(['prefix' => 'api'], function() {
|
||||||
Route::group(['prefix' => 'v1'], function() {
|
Route::group(['prefix' => 'v1'], function() {
|
||||||
Route::post('apps', 'Api\ApiV1Controller@apps');
|
Route::post('apps', 'Api\ApiV1Controller@apps');
|
||||||
Route::get('instance', 'Api\ApiV1Controller@instance');
|
Route::get('instance', 'Api\ApiV1Controller@instance');
|
||||||
Route::get('statuses/{id}', 'Api\ApiV1Controller@statusById');
|
|
||||||
Route::get('statuses/{id}/context', 'Api\ApiV1Controller@context');
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -116,6 +116,10 @@ Route::domain(config('pixelfed.domain.app'))->middleware(['validemail', 'twofact
|
||||||
Route::post('accounts/{id}/unmute', 'Api\ApiV1Controller@accountUnmuteById')->middleware('auth:api');
|
Route::post('accounts/{id}/unmute', 'Api\ApiV1Controller@accountUnmuteById')->middleware('auth:api');
|
||||||
Route::get('notifications', 'Api\ApiV1Controller@accountNotifications')->middleware('auth:api');
|
Route::get('notifications', 'Api\ApiV1Controller@accountNotifications')->middleware('auth:api');
|
||||||
|
|
||||||
|
Route::get('statuses/{id}', 'Api\ApiV1Controller@statusById')->middleware('auth:api');
|
||||||
|
Route::get('statuses/{id}/context', 'Api\ApiV1Controller@statusContext')->middleware('auth:api');
|
||||||
|
Route::get('statuses/{id}/card', 'Api\ApiV1Controller@statusCard')->middleware('auth:api');
|
||||||
|
|
||||||
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');
|
||||||
|
|
Loading…
Reference in a new issue