kopia lustrzana https://github.com/pixelfed/pixelfed
				
				
				
			Update InternalApiController, update discoverPosts method to improve performance
							rodzic
							
								
									1ac60173af
								
							
						
					
					
						commit
						9862a85599
					
				| 
						 | 
				
			
			@ -35,6 +35,8 @@ use Illuminate\Support\Str;
 | 
			
		|||
use App\Services\MediaTagService;
 | 
			
		||||
use App\Services\ModLogService;
 | 
			
		||||
use App\Services\PublicTimelineService;
 | 
			
		||||
use App\Services\SnowflakeService;
 | 
			
		||||
use App\Services\StatusService;
 | 
			
		||||
 | 
			
		||||
class InternalApiController extends Controller
 | 
			
		||||
{
 | 
			
		||||
| 
						 | 
				
			
			@ -82,37 +84,27 @@ class InternalApiController extends Controller
 | 
			
		|||
        $following = array_merge($following, $filters);
 | 
			
		||||
 | 
			
		||||
        $sql = config('database.default') !== 'pgsql';
 | 
			
		||||
 | 
			
		||||
        $min_id = SnowflakeService::byDate(now()->subMonths(3));
 | 
			
		||||
        $posts = Status::select(
 | 
			
		||||
                'id', 
 | 
			
		||||
                'caption', 
 | 
			
		||||
                'is_nsfw',
 | 
			
		||||
                'profile_id',
 | 
			
		||||
                'type',
 | 
			
		||||
                'uri',
 | 
			
		||||
                'created_at'
 | 
			
		||||
              )
 | 
			
		||||
              ->whereNull('uri')
 | 
			
		||||
              ->whereIn('type', ['photo','photo:album', 'video'])
 | 
			
		||||
              ->whereIsNsfw(false)
 | 
			
		||||
              ->whereVisibility('public')
 | 
			
		||||
              ->whereNotIn('profile_id', $following)
 | 
			
		||||
              ->when($sql, function($q, $s) {
 | 
			
		||||
                return $q->where('created_at', '>', now()->subMonths(3));
 | 
			
		||||
              })
 | 
			
		||||
              ->with('media')
 | 
			
		||||
              ->where('id', '>', $min_id)
 | 
			
		||||
              ->inRandomOrder()
 | 
			
		||||
              ->latest()
 | 
			
		||||
              ->take(39)
 | 
			
		||||
              ->get();
 | 
			
		||||
              ->pluck('id');
 | 
			
		||||
 | 
			
		||||
        $res = [
 | 
			
		||||
            'posts' => $posts->map(function($post) {
 | 
			
		||||
                return [
 | 
			
		||||
                    'type' => $post->type,
 | 
			
		||||
                    'url' => $post->url(),
 | 
			
		||||
                    'thumb' => $post->thumb(),
 | 
			
		||||
                ];
 | 
			
		||||
                return StatusService::get($post);
 | 
			
		||||
            })
 | 
			
		||||
        ];
 | 
			
		||||
        return response()->json($res);
 | 
			
		||||
| 
						 | 
				
			
			@ -323,117 +315,7 @@ class InternalApiController extends Controller
 | 
			
		|||
 | 
			
		||||
    public function composePost(Request $request)
 | 
			
		||||
    {
 | 
			
		||||
        $this->validate($request, [
 | 
			
		||||
            'caption' => 'nullable|string|max:'.config('pixelfed.max_caption_length', 500),
 | 
			
		||||
            'media.*'   => 'required',
 | 
			
		||||
            'media.*.id' => 'required|integer|min:1',
 | 
			
		||||
            'media.*.filter_class' => 'nullable|alpha_dash|max:30',
 | 
			
		||||
            'media.*.license' => 'nullable|string|max:140',
 | 
			
		||||
            'media.*.alt' => 'nullable|string|max:140',
 | 
			
		||||
            'cw' => 'nullable|boolean',
 | 
			
		||||
            'visibility' => 'required|string|in:public,private,unlisted|min:2|max:10',
 | 
			
		||||
            'place' => 'nullable',
 | 
			
		||||
            'comments_disabled' => 'nullable',
 | 
			
		||||
            'tagged' => 'nullable'
 | 
			
		||||
        ]);
 | 
			
		||||
 | 
			
		||||
        if(config('costar.enabled') == true) {
 | 
			
		||||
            $blockedKeywords = config('costar.keyword.block');
 | 
			
		||||
            if($blockedKeywords !== null && $request->caption) {
 | 
			
		||||
                $keywords = config('costar.keyword.block');
 | 
			
		||||
                foreach($keywords as $kw) {
 | 
			
		||||
                    if(Str::contains($request->caption, $kw) == true) {
 | 
			
		||||
                        abort(400, 'Invalid object');
 | 
			
		||||
                    }
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        $user = Auth::user();
 | 
			
		||||
        $profile = $user->profile;
 | 
			
		||||
        $visibility = $request->input('visibility');
 | 
			
		||||
        $medias = $request->input('media');
 | 
			
		||||
        $attachments = [];
 | 
			
		||||
        $status = new Status;
 | 
			
		||||
        $mimes = [];
 | 
			
		||||
        $place = $request->input('place');
 | 
			
		||||
        $cw = $request->input('cw');
 | 
			
		||||
        $tagged = $request->input('tagged');
 | 
			
		||||
 | 
			
		||||
        foreach($medias as $k => $media) {
 | 
			
		||||
            if($k + 1 > config('pixelfed.max_album_length')) {
 | 
			
		||||
                continue;
 | 
			
		||||
            }
 | 
			
		||||
            $m = Media::findOrFail($media['id']);
 | 
			
		||||
            if($m->profile_id !== $profile->id || $m->status_id) {
 | 
			
		||||
                abort(403, 'Invalid media id');
 | 
			
		||||
            }
 | 
			
		||||
            $m->filter_class = in_array($media['filter_class'], Filter::classes()) ? $media['filter_class'] : null;
 | 
			
		||||
            $m->license = $media['license'];
 | 
			
		||||
            $m->caption = isset($media['alt']) ? strip_tags($media['alt']) : null;
 | 
			
		||||
            $m->order = isset($media['cursor']) && is_int($media['cursor']) ? (int) $media['cursor'] : $k;
 | 
			
		||||
            if($cw == true || $profile->cw == true) {
 | 
			
		||||
                $m->is_nsfw = $cw;
 | 
			
		||||
                $status->is_nsfw = $cw;
 | 
			
		||||
            }
 | 
			
		||||
            $m->save();
 | 
			
		||||
            $attachments[] = $m;
 | 
			
		||||
            array_push($mimes, $m->mime);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        $mediaType = StatusController::mimeTypeCheck($mimes);
 | 
			
		||||
 | 
			
		||||
        if(in_array($mediaType, ['photo', 'video', 'photo:album']) == false) {
 | 
			
		||||
            abort(400, __('exception.compose.invalid.album'));
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if($place && is_array($place)) {
 | 
			
		||||
            $status->place_id = $place['id'];
 | 
			
		||||
        }
 | 
			
		||||
        
 | 
			
		||||
        if($request->filled('comments_disabled')) {
 | 
			
		||||
            $status->comments_disabled = (bool) $request->input('comments_disabled');
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        $status->caption = strip_tags($request->caption);
 | 
			
		||||
        $status->scope = 'draft';
 | 
			
		||||
        $status->profile_id = $profile->id;
 | 
			
		||||
        $status->save();
 | 
			
		||||
 | 
			
		||||
        foreach($attachments as $media) {
 | 
			
		||||
            $media->status_id = $status->id;
 | 
			
		||||
            $media->save();
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        $visibility = $profile->unlisted == true && $visibility == 'public' ? 'unlisted' : $visibility;
 | 
			
		||||
        $cw = $profile->cw == true ? true : $cw;
 | 
			
		||||
        $status->is_nsfw = $cw;
 | 
			
		||||
        $status->visibility = $visibility;
 | 
			
		||||
        $status->scope = $visibility;
 | 
			
		||||
        $status->type = $mediaType;
 | 
			
		||||
        $status->save();
 | 
			
		||||
 | 
			
		||||
        foreach($tagged as $tg) {
 | 
			
		||||
            $mt = new MediaTag;
 | 
			
		||||
            $mt->status_id = $status->id;
 | 
			
		||||
            $mt->media_id = $status->media->first()->id;
 | 
			
		||||
            $mt->profile_id = $tg['id'];
 | 
			
		||||
            $mt->tagged_username = $tg['name'];
 | 
			
		||||
            $mt->is_public = true; // (bool) $tg['privacy'] ?? 1;
 | 
			
		||||
            $mt->metadata = json_encode([
 | 
			
		||||
                '_v' => 1,
 | 
			
		||||
            ]);
 | 
			
		||||
            $mt->save();
 | 
			
		||||
            MediaTagService::set($mt->status_id, $mt->profile_id);
 | 
			
		||||
            MediaTagService::sendNotification($mt);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        NewStatusPipeline::dispatch($status);
 | 
			
		||||
        Cache::forget('user:account:id:'.$profile->user_id);
 | 
			
		||||
        Cache::forget('_api:statuses:recent_9:'.$profile->id);
 | 
			
		||||
        Cache::forget('profile:status_count:'.$profile->id);
 | 
			
		||||
        Cache::forget($user->storageUsedKey());
 | 
			
		||||
        return $status->url();
 | 
			
		||||
        abort(400, 'Endpoint deprecated');
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public function bookmarks(Request $request)
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Ładowanie…
	
		Reference in New Issue