mirror of
https://github.com/pixelfed/pixelfed.git
synced 2025-01-25 22:10:47 +00:00
Update ActivityPub
This commit is contained in:
parent
8c88c88fc0
commit
e1f4968e8d
2 changed files with 46 additions and 28 deletions
|
@ -21,8 +21,6 @@ use App\Jobs\AvatarPipeline\CreateAvatar;
|
||||||
use App\Jobs\RemoteFollowPipeline\RemoteFollowImportRecent;
|
use App\Jobs\RemoteFollowPipeline\RemoteFollowImportRecent;
|
||||||
use App\Jobs\ImageOptimizePipeline\{ImageOptimize,ImageThumbnail};
|
use App\Jobs\ImageOptimizePipeline\{ImageOptimize,ImageThumbnail};
|
||||||
use App\Jobs\StatusPipeline\NewStatusPipeline;
|
use App\Jobs\StatusPipeline\NewStatusPipeline;
|
||||||
use App\Util\HttpSignatures\{GuzzleHttpSignatures, KeyStore, Context, Verifier};
|
|
||||||
use Symfony\Bridge\PsrHttpMessage\Factory\DiactorosFactory;
|
|
||||||
use App\Util\ActivityPub\HttpSignature;
|
use App\Util\ActivityPub\HttpSignature;
|
||||||
use Illuminate\Support\Str;
|
use Illuminate\Support\Str;
|
||||||
|
|
||||||
|
@ -193,6 +191,7 @@ class Helpers {
|
||||||
$res = Zttp::withHeaders(self::zttpUserAgent())->get($url);
|
$res = Zttp::withHeaders(self::zttpUserAgent())->get($url);
|
||||||
$res = json_decode($res->body(), true, 8);
|
$res = json_decode($res->body(), true, 8);
|
||||||
if(json_last_error() == JSON_ERROR_NONE) {
|
if(json_last_error() == JSON_ERROR_NONE) {
|
||||||
|
abort_if(!self::validateObject($res), 422);
|
||||||
return $res;
|
return $res;
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
|
@ -238,14 +237,26 @@ class Helpers {
|
||||||
}
|
}
|
||||||
|
|
||||||
$scope = 'private';
|
$scope = 'private';
|
||||||
|
|
||||||
$cw = isset($activity['sensitive']) ? (bool) $activity['sensitive'] : false;
|
$cw = isset($activity['sensitive']) ? (bool) $activity['sensitive'] : false;
|
||||||
|
|
||||||
if(isset($res['to']) == true && in_array('https://www.w3.org/ns/activitystreams#Public', $res['to'])) {
|
if(isset($res['to']) == true) {
|
||||||
|
if(is_array($res['to']) && in_array('https://www.w3.org/ns/activitystreams#Public', $res['to'])) {
|
||||||
$scope = 'public';
|
$scope = 'public';
|
||||||
}
|
}
|
||||||
|
if(is_string($res['to']) && 'https://www.w3.org/ns/activitystreams#Public' == $res['to']) {
|
||||||
|
$scope = 'public';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if(isset($res['cc']) == true && in_array('https://www.w3.org/ns/activitystreams#Public', $res['cc'])) {
|
if(isset($res['cc']) == true) {
|
||||||
$scope = 'unlisted';
|
$scope = 'unlisted';
|
||||||
|
if(is_array($res['cc']) && in_array('https://www.w3.org/ns/activitystreams#Public', $res['cc'])) {
|
||||||
|
$scope = 'unlisted';
|
||||||
|
}
|
||||||
|
if(is_string($res['cc']) && 'https://www.w3.org/ns/activitystreams#Public' == $res['cc']) {
|
||||||
|
$scope = 'unlisted';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(config('costar.enabled') == true) {
|
if(config('costar.enabled') == true) {
|
||||||
|
@ -309,7 +320,7 @@ class Helpers {
|
||||||
$status->scope = $scope;
|
$status->scope = $scope;
|
||||||
$status->visibility = $scope;
|
$status->visibility = $scope;
|
||||||
$status->save();
|
$status->save();
|
||||||
self::importNoteAttachment($res, $status);
|
// self::importNoteAttachment($res, $status);
|
||||||
return $status;
|
return $status;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -336,28 +347,28 @@ class Helpers {
|
||||||
if(in_array($type, $allowed) == false || $valid == false) {
|
if(in_array($type, $allowed) == false || $valid == false) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
$info = pathinfo($url);
|
// $info = pathinfo($url);
|
||||||
|
|
||||||
// pleroma attachment fix
|
// // pleroma attachment fix
|
||||||
$url = str_replace(' ', '%20', $url);
|
// $url = str_replace(' ', '%20', $url);
|
||||||
|
|
||||||
$img = file_get_contents($url, false, stream_context_create(['ssl' => ["verify_peer"=>true,"verify_peer_name"=>true]]));
|
// $img = file_get_contents($url, false, stream_context_create(['ssl' => ["verify_peer"=>true,"verify_peer_name"=>true]]));
|
||||||
$file = '/tmp/'.str_random(32);
|
// $file = '/tmp/'.str_random(32);
|
||||||
file_put_contents($file, $img);
|
// file_put_contents($file, $img);
|
||||||
$fdata = new File($file);
|
// $fdata = new File($file);
|
||||||
$path = Storage::putFile($storagePath, $fdata, 'public');
|
// $path = Storage::putFile($storagePath, $fdata, 'public');
|
||||||
$media = new Media();
|
// $media = new Media();
|
||||||
$media->status_id = $status->id;
|
// $media->status_id = $status->id;
|
||||||
$media->profile_id = $status->profile_id;
|
// $media->profile_id = $status->profile_id;
|
||||||
$media->user_id = null;
|
// $media->user_id = null;
|
||||||
$media->media_path = $path;
|
// $media->media_path = $path;
|
||||||
$media->size = $fdata->getSize();
|
// $media->size = $fdata->getSize();
|
||||||
$media->mime = $fdata->getMimeType();
|
// $media->mime = $fdata->getMimeType();
|
||||||
$media->save();
|
// $media->save();
|
||||||
|
|
||||||
ImageThumbnail::dispatch($media);
|
// ImageThumbnail::dispatch($media);
|
||||||
ImageOptimize::dispatch($media);
|
// ImageOptimize::dispatch($media);
|
||||||
unlink($file);
|
// unlink($file);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -380,15 +391,15 @@ class Helpers {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
$domain = parse_url($res['id'], PHP_URL_HOST);
|
$domain = parse_url($res['id'], PHP_URL_HOST);
|
||||||
$username = $res['preferredUsername'];
|
$username = Purify::clean($res['preferredUsername']);
|
||||||
$remoteUsername = "@{$username}@{$domain}";
|
$remoteUsername = "@{$username}@{$domain}";
|
||||||
|
|
||||||
$profile = Profile::whereRemoteUrl($res['id'])->first();
|
$profile = Profile::whereRemoteUrl($res['id'])->first();
|
||||||
if(!$profile) {
|
if(!$profile) {
|
||||||
$profile = new Profile;
|
$profile = new Profile;
|
||||||
$profile->domain = $domain;
|
$profile->domain = $domain;
|
||||||
$profile->username = $remoteUsername;
|
$profile->username = Purify::clean($remoteUsername);
|
||||||
$profile->name = strip_tags($res['name']);
|
$profile->name = Purify::clean($res['name']) ?? 'user';
|
||||||
$profile->bio = Purify::clean($res['summary']);
|
$profile->bio = Purify::clean($res['summary']);
|
||||||
$profile->sharedInbox = isset($res['endpoints']) && isset($res['endpoints']['sharedInbox']) ? $res['endpoints']['sharedInbox'] : null;
|
$profile->sharedInbox = isset($res['endpoints']) && isset($res['endpoints']['sharedInbox']) ? $res['endpoints']['sharedInbox'] : null;
|
||||||
$profile->inbox_url = $res['inbox'];
|
$profile->inbox_url = $res['inbox'];
|
||||||
|
@ -407,6 +418,11 @@ class Helpers {
|
||||||
|
|
||||||
public static function sendSignedObject($senderProfile, $url, $body)
|
public static function sendSignedObject($senderProfile, $url, $body)
|
||||||
{
|
{
|
||||||
|
$url = self::validateUrl($url);
|
||||||
|
if($url == false) {
|
||||||
|
abort(400, 'Invalid url');
|
||||||
|
}
|
||||||
|
|
||||||
$payload = json_encode($body);
|
$payload = json_encode($body);
|
||||||
$headers = HttpSignature::sign($senderProfile, $url, $body);
|
$headers = HttpSignature::sign($senderProfile, $url, $body);
|
||||||
|
|
||||||
|
|
|
@ -135,6 +135,8 @@ class Inbox
|
||||||
|
|
||||||
public function handleNoteCreate()
|
public function handleNoteCreate()
|
||||||
{
|
{
|
||||||
|
return;
|
||||||
|
|
||||||
$activity = $this->payload['object'];
|
$activity = $this->payload['object'];
|
||||||
$actor = $this->actorFirstOrCreate($this->payload['actor']);
|
$actor = $this->actorFirstOrCreate($this->payload['actor']);
|
||||||
if(!$actor || $actor->domain == null) {
|
if(!$actor || $actor->domain == null) {
|
||||||
|
|
Loading…
Reference in a new issue