Merge pull request #3994 from pixelfed/staging

Update AP helpers
This commit is contained in:
daniel 2022-12-23 22:23:42 -07:00 committed by GitHub
commit 7a75271569
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -440,8 +440,8 @@ class Helpers {
); );
return $status; return $status;
} else { } else {
$status = self::storeStatus($url, $profile, $res); $status = self::storeStatus($url, $profile, $res);
} }
return $status; return $status;
} }
@ -458,62 +458,60 @@ class Helpers {
$reply_to = self::getReplyTo($activity); $reply_to = self::getReplyTo($activity);
return DB::transaction(function() use($url, $profile, $activity, $reply_to, $id) { $ts = self::pluckval($activity['published']);
$ts = self::pluckval($activity['published']); $scope = self::getScope($activity, $url);
$scope = self::getScope($activity, $url); $cw = self::getSensitive($activity, $url);
$cw = self::getSensitive($activity, $url); $pid = is_object($profile) ? $profile->id : (is_array($profile) ? $profile['id'] : null);
$pid = is_object($profile) ? $profile->id : (is_array($profile) ? $profile['id'] : null); $commentsDisabled = isset($activity['commentsEnabled']) ? !boolval($activity['commentsEnabled']) : false;
$commentsDisabled = isset($activity['commentsEnabled']) ? !boolval($activity['commentsEnabled']) : false;
if(!$pid) { if(!$pid) {
return; return;
} }
$status = Status::updateOrCreate( $status = Status::updateOrCreate(
[ [
'uri' => $url 'uri' => $url
], [ ], [
'profile_id' => $pid, 'profile_id' => $pid,
'url' => $url, 'url' => $url,
'object_url' => $id, 'object_url' => $id,
'caption' => strip_tags($activity['content']), 'caption' => strip_tags($activity['content']),
'rendered' => Purify::clean($activity['content']), 'rendered' => Purify::clean($activity['content']),
'created_at' => Carbon::parse($ts)->tz('UTC'), 'created_at' => Carbon::parse($ts)->tz('UTC'),
'in_reply_to_id' => $reply_to, 'in_reply_to_id' => $reply_to,
'local' => false, 'local' => false,
'is_nsfw' => $cw, 'is_nsfw' => $cw,
'scope' => $scope, 'scope' => $scope,
'visibility' => $scope, 'visibility' => $scope,
'cw_summary' => ($cw == true && isset($activity['summary']) ? 'cw_summary' => ($cw == true && isset($activity['summary']) ?
Purify::clean(strip_tags($activity['summary'])) : null), Purify::clean(strip_tags($activity['summary'])) : null),
'comments_disabled' => $commentsDisabled 'comments_disabled' => $commentsDisabled
] ]
); );
if($reply_to == null) { if($reply_to == null) {
self::importNoteAttachment($activity, $status); self::importNoteAttachment($activity, $status);
} else { } else {
StatusReplyPipeline::dispatch($status); StatusReplyPipeline::dispatch($status);
} }
if(isset($activity['tag']) && is_array($activity['tag']) && !empty($activity['tag'])) { if(isset($activity['tag']) && is_array($activity['tag']) && !empty($activity['tag'])) {
StatusTagsPipeline::dispatch($activity, $status); StatusTagsPipeline::dispatch($activity, $status);
} }
if( config('instance.timeline.network.cached') && if( config('instance.timeline.network.cached') &&
$status->in_reply_to_id === null && $status->in_reply_to_id === null &&
$status->reblog_of_id === null && $status->reblog_of_id === null &&
in_array($status->type, ['photo', 'photo:album', 'video', 'video:album', 'photo:video:album']) && in_array($status->type, ['photo', 'photo:album', 'video', 'video:album', 'photo:video:album']) &&
$status->created_at->gt(now()->subHours(config('instance.timeline.network.max_hours_old'))) && $status->created_at->gt(now()->subHours(config('instance.timeline.network.max_hours_old'))) &&
(config('instance.hide_nsfw_on_public_feeds') == true ? $status->is_nsfw == false : true) (config('instance.hide_nsfw_on_public_feeds') == true ? $status->is_nsfw == false : true)
) { ) {
NetworkTimelineService::add($status->id); NetworkTimelineService::add($status->id);
} }
IncrementPostCount::dispatch($pid)->onQueue('low'); IncrementPostCount::dispatch($pid)->onQueue('low');
return $status; return $status;
});
} }
public static function getSensitive($activity, $url) public static function getSensitive($activity, $url)
@ -733,50 +731,45 @@ class Helpers {
$webfinger = "@{$username}@{$domain}"; $webfinger = "@{$username}@{$domain}";
if(!self::validateUrl($res['inbox'])) { if(!self::validateUrl($res['inbox'])) {
return; return;
} }
if(!self::validateUrl($res['id'])) { if(!self::validateUrl($res['id'])) {
return; return;
} }
$profile = DB::transaction(function() use($domain, $webfinger, $res) { $instance = Instance::updateOrCreate([
$instance = Instance::updateOrCreate([ 'domain' => $domain
'domain' => $domain ]);
]); if($instance->wasRecentlyCreated == true) {
if($instance->wasRecentlyCreated == true) { \App\Jobs\InstancePipeline\FetchNodeinfoPipeline::dispatch($instance)->onQueue('low');
\App\Jobs\InstancePipeline\FetchNodeinfoPipeline::dispatch($instance)->onQueue('low'); }
}
$profile = Profile::updateOrCreate( $profile = Profile::updateOrCreate(
[ [
'domain' => strtolower($domain), 'domain' => strtolower($domain),
'username' => Purify::clean($webfinger), 'username' => Purify::clean($webfinger),
], ],
[ [
'webfinger' => Purify::clean($webfinger), 'webfinger' => Purify::clean($webfinger),
'key_id' => $res['publicKey']['id'], 'key_id' => $res['publicKey']['id'],
'remote_url' => $res['id'], 'remote_url' => $res['id'],
'name' => isset($res['name']) ? Purify::clean($res['name']) : 'user', 'name' => isset($res['name']) ? Purify::clean($res['name']) : 'user',
'bio' => isset($res['summary']) ? Purify::clean($res['summary']) : null, 'bio' => isset($res['summary']) ? Purify::clean($res['summary']) : null,
'sharedInbox' => isset($res['endpoints']) && isset($res['endpoints']['sharedInbox']) ? $res['endpoints']['sharedInbox'] : null, 'sharedInbox' => isset($res['endpoints']) && isset($res['endpoints']['sharedInbox']) ? $res['endpoints']['sharedInbox'] : null,
'inbox_url' => $res['inbox'], 'inbox_url' => $res['inbox'],
'outbox_url' => isset($res['outbox']) ? $res['outbox'] : null, 'outbox_url' => isset($res['outbox']) ? $res['outbox'] : null,
'public_key' => $res['publicKey']['publicKeyPem'], 'public_key' => $res['publicKey']['publicKeyPem'],
] ]
); );
if( $profile->last_fetched_at == null ||
$profile->last_fetched_at->lt(now()->subHours(24))
) {
RemoteAvatarFetch::dispatch($profile);
}
$profile->last_fetched_at = now();
$profile->save();
return $profile;
});
if( $profile->last_fetched_at == null ||
$profile->last_fetched_at->lt(now()->subHours(24))
) {
RemoteAvatarFetch::dispatch($profile);
}
$profile->last_fetched_at = now();
$profile->save();
return $profile; return $profile;
} }
public static function profileFetch($url) public static function profileFetch($url)