diff --git a/app/Http/Controllers/StatusController.php b/app/Http/Controllers/StatusController.php
index 651d632d5..57a7e41c1 100644
--- a/app/Http/Controllers/StatusController.php
+++ b/app/Http/Controllers/StatusController.php
@@ -3,33 +3,40 @@
namespace App\Http\Controllers;
use Auth, Cache;
-use App\Jobs\StatusPipeline\{NewStatusPipeline, StatusDelete};
-use App\Jobs\ImageOptimizePipeline\ImageOptimize;
+use League\Fractal;
use Illuminate\Http\Request;
-use App\{Media, Profile, Status, User};
use Vinkla\Hashids\Facades\Hashids;
+use App\{Media, Profile, Status, User};
+use App\Jobs\ImageOptimizePipeline\ImageOptimize;
+use App\Transformer\ActivityPub\StatusTransformer;
+use App\Jobs\StatusPipeline\{NewStatusPipeline, StatusDelete};
class StatusController extends Controller
{
public function show(Request $request, $username, int $id)
{
$user = Profile::whereUsername($username)->firstOrFail();
+
$status = Status::whereProfileId($user->id)
->withCount(['likes', 'comments', 'media'])
->findOrFail($id);
+
if(!$status->media_path && $status->in_reply_to_id) {
return redirect($status->url());
}
+
+ if($request->wantsJson() && config('pixelfed.activitypub_enabled')) {
+ return $this->showActivityPub($request, $status);
+ }
+
$replies = Status::whereInReplyToId($status->id)->simplePaginate(30);
+
return view('status.show', compact('user', 'status', 'replies'));
}
public function compose()
{
- if(Auth::check() == false)
- {
- abort(403);
- }
+ $this->authCheck();
return view('status.compose');
}
@@ -156,4 +163,20 @@ class StatusController extends Controller
return $response;
}
+
+ public function showActivityPub(Request $request, $status)
+ {
+ $fractal = new Fractal\Manager();
+ $resource = new Fractal\Resource\Item($status, new StatusTransformer);
+ $res = $fractal->createData($resource)->toArray();
+ return response(json_encode($res['data']))->header('Content-Type', 'application/activity+json');
+ }
+
+ protected function authCheck()
+ {
+ if(Auth::check() == false)
+ {
+ abort(403);
+ }
+ }
}
diff --git a/resources/views/status/show.blade.php b/resources/views/status/show.blade.php
index 7f711f240..cf9b9db55 100644
--- a/resources/views/status/show.blade.php
+++ b/resources/views/status/show.blade.php
@@ -169,4 +169,4 @@
@push('meta')
-@endpush
+ @endpush