mirror of
https://github.com/pixelfed/pixelfed.git
synced 2025-01-24 13:30:47 +00:00
Merge pull request #1666 from pixelfed/staging
Update StatusController, append .json to status urls for AP object
This commit is contained in:
commit
4a728741c6
3 changed files with 20 additions and 11 deletions
|
@ -22,7 +22,6 @@ class StatusController extends Controller
|
||||||
{
|
{
|
||||||
public function show(Request $request, $username, int $id)
|
public function show(Request $request, $username, int $id)
|
||||||
{
|
{
|
||||||
// $id = strlen($id) < 17 ? array_first(\Hashids::decode($id)) : $id;
|
|
||||||
$user = Profile::whereNull('domain')->whereUsername($username)->firstOrFail();
|
$user = Profile::whereNull('domain')->whereUsername($username)->firstOrFail();
|
||||||
|
|
||||||
if($user->status != null) {
|
if($user->status != null) {
|
||||||
|
@ -60,9 +59,24 @@ class StatusController extends Controller
|
||||||
return view($template, compact('user', 'status'));
|
return view($template, compact('user', 'status'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function showId(int $id)
|
||||||
|
{
|
||||||
|
abort(404);
|
||||||
|
$status = Status::whereNull('reblog_of_id')
|
||||||
|
->whereIn('scope', ['public', 'unlisted'])
|
||||||
|
->findOrFail($id);
|
||||||
|
return redirect($status->url());
|
||||||
|
}
|
||||||
|
|
||||||
public function showEmbed(Request $request, $username, int $id)
|
public function showEmbed(Request $request, $username, int $id)
|
||||||
{
|
{
|
||||||
return;
|
abort(404);
|
||||||
|
$profile = Profile::whereNull('status')->whereUsername($username)->first();
|
||||||
|
$status = Status::whereScope('private')->find($id);
|
||||||
|
if(!$profile || !$status) {
|
||||||
|
return view('status.embed-removed');
|
||||||
|
}
|
||||||
|
return view('status.embed', compact('status'));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function showObject(Request $request, $username, int $id)
|
public function showObject(Request $request, $username, int $id)
|
||||||
|
@ -77,13 +91,7 @@ class StatusController extends Controller
|
||||||
->whereNotIn('visibility',['draft','direct'])
|
->whereNotIn('visibility',['draft','direct'])
|
||||||
->findOrFail($id);
|
->findOrFail($id);
|
||||||
|
|
||||||
if($status->uri) {
|
abort_if($status->uri, 404);
|
||||||
$url = $status->uri;
|
|
||||||
if(ends_with($url, '/activity')) {
|
|
||||||
$url = str_replace('/activity', '', $url);
|
|
||||||
}
|
|
||||||
return redirect($url);
|
|
||||||
}
|
|
||||||
|
|
||||||
if($status->visibility == 'private' || $user->is_private) {
|
if($status->visibility == 'private' || $user->is_private) {
|
||||||
if(!Auth::check()) {
|
if(!Auth::check()) {
|
||||||
|
@ -190,7 +198,7 @@ class StatusController extends Controller
|
||||||
$resource = new Fractal\Resource\Item($status, new Note());
|
$resource = new Fractal\Resource\Item($status, new Note());
|
||||||
$res = $fractal->createData($resource)->toArray();
|
$res = $fractal->createData($resource)->toArray();
|
||||||
|
|
||||||
return response(json_encode($res['data']))->header('Content-Type', 'application/activity+json');
|
return response()->json($res['data'], 200, ['Content-Type' => 'application/activity+json'], JSON_PRETTY_PRINT);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function edit(Request $request, $username, $id)
|
public function edit(Request $request, $username, $id)
|
||||||
|
|
|
@ -109,7 +109,7 @@ return [
|
||||||
|
|
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
'lottery' => [2, 100],
|
'lottery' => [2, 1000],
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
|
|
@ -339,6 +339,7 @@ Route::domain(config('pixelfed.domain.app'))->middleware(['validemail', 'twofact
|
||||||
Route::get('p/{username}/{id}/c', 'CommentController@showAll');
|
Route::get('p/{username}/{id}/c', 'CommentController@showAll');
|
||||||
Route::get('p/{username}/{id}/edit', 'StatusController@edit');
|
Route::get('p/{username}/{id}/edit', 'StatusController@edit');
|
||||||
Route::post('p/{username}/{id}/edit', 'StatusController@editStore');
|
Route::post('p/{username}/{id}/edit', 'StatusController@editStore');
|
||||||
|
Route::get('p/{username}/{id}.json', 'StatusController@showObject');
|
||||||
Route::get('p/{username}/{id}', 'StatusController@show');
|
Route::get('p/{username}/{id}', 'StatusController@show');
|
||||||
Route::get('{username}/followers', 'ProfileController@followers')->middleware('auth');
|
Route::get('{username}/followers', 'ProfileController@followers')->middleware('auth');
|
||||||
Route::get('{username}/following', 'ProfileController@following')->middleware('auth');
|
Route::get('{username}/following', 'ProfileController@following')->middleware('auth');
|
||||||
|
|
Loading…
Reference in a new issue