mirror of https://github.com/pixelfed/pixelfed
				
				
				
			
			You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			141 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			PHP
		
	
			
		
		
	
	
			141 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			PHP
		
	
<?php
 | 
						|
 | 
						|
namespace App\Jobs\DeletePipeline;
 | 
						|
 | 
						|
use Illuminate\Bus\Queueable;
 | 
						|
use Illuminate\Queue\SerializesModels;
 | 
						|
use Illuminate\Queue\InteractsWithQueue;
 | 
						|
use Illuminate\Contracts\Queue\ShouldQueue;
 | 
						|
use Illuminate\Foundation\Bus\Dispatchable;
 | 
						|
use DB;
 | 
						|
use Illuminate\Support\Str;
 | 
						|
use App\{
 | 
						|
	AccountInterstitial,
 | 
						|
	AccountLog,
 | 
						|
	Activity,
 | 
						|
	Avatar,
 | 
						|
	Bookmark,
 | 
						|
	Collection,
 | 
						|
	CollectionItem,
 | 
						|
	Contact,
 | 
						|
	DirectMessage,
 | 
						|
	EmailVerification,
 | 
						|
	Follower,
 | 
						|
	FollowRequest,
 | 
						|
	Hashtag,
 | 
						|
	HashtagFollow,
 | 
						|
	ImportData,
 | 
						|
	ImportJob,
 | 
						|
	Like,
 | 
						|
	Media,
 | 
						|
	MediaTag,
 | 
						|
	Mention,
 | 
						|
	Notification,
 | 
						|
	OauthClient,
 | 
						|
	Profile,
 | 
						|
	ProfileSponsor,
 | 
						|
	Report,
 | 
						|
	ReportComment,
 | 
						|
	ReportLog,
 | 
						|
	StatusHashtag,
 | 
						|
	Status,
 | 
						|
	Story,
 | 
						|
	StoryView,
 | 
						|
	User,
 | 
						|
	UserDevice,
 | 
						|
	UserFilter,
 | 
						|
	UserSetting,
 | 
						|
};
 | 
						|
 | 
						|
class DeleteRemoteProfilePipeline implements ShouldQueue
 | 
						|
{
 | 
						|
	use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
 | 
						|
 | 
						|
	protected $profile;
 | 
						|
 | 
						|
	public function __construct(Profile $profile)
 | 
						|
	{
 | 
						|
		$this->profile = $profile;
 | 
						|
	}
 | 
						|
 | 
						|
	public function handle()
 | 
						|
	{
 | 
						|
		$profile = $this->profile;
 | 
						|
 | 
						|
		if($profile->domain == null || $profile->private_key) {
 | 
						|
			return;
 | 
						|
		}
 | 
						|
 | 
						|
		DB::transaction(function() use ($profile) {
 | 
						|
			$profile->avatar->forceDelete();
 | 
						|
 | 
						|
			$id = $profile->id;
 | 
						|
 | 
						|
			MediaTag::whereProfileId($id)->delete();
 | 
						|
			StatusHashtag::whereProfileId($id)->delete();
 | 
						|
			DirectMessage::whereFromId($id)->delete();
 | 
						|
			FollowRequest::whereFollowingId($id)
 | 
						|
				->orWhere('follower_id', $id)
 | 
						|
				->forceDelete();
 | 
						|
			Follower::whereProfileId($id)
 | 
						|
				->orWhere('following_id', $id)
 | 
						|
				->forceDelete();
 | 
						|
			Like::whereProfileId($id)->forceDelete();
 | 
						|
		});
 | 
						|
 | 
						|
		DB::transaction(function() use ($profile) {
 | 
						|
			$pid = $profile->id;
 | 
						|
			StoryView::whereProfileId($pid)->delete();
 | 
						|
			$stories = Story::whereProfileId($pid)->get();
 | 
						|
			foreach($stories as $story) {
 | 
						|
				$path = storage_path('app/'.$story->path);
 | 
						|
				if(is_file($path)) {
 | 
						|
					unlink($path);
 | 
						|
				}
 | 
						|
				$story->forceDelete();
 | 
						|
			}
 | 
						|
		});
 | 
						|
 | 
						|
		DB::transaction(function() use ($profile) {
 | 
						|
			$medias = Media::whereProfileId($profile->id)->get();
 | 
						|
			foreach($medias as $media) {
 | 
						|
				$path = storage_path('app/'.$media->media_path);
 | 
						|
				$thumb = storage_path('app/'.$media->thumbnail_path);
 | 
						|
				if(is_file($path)) {
 | 
						|
					unlink($path);
 | 
						|
				}
 | 
						|
				if(is_file($thumb)) {
 | 
						|
					unlink($thumb);
 | 
						|
				}
 | 
						|
				$media->forceDelete();
 | 
						|
			}
 | 
						|
		});
 | 
						|
 | 
						|
		DB::transaction(function() use ($profile) {
 | 
						|
			Mention::whereProfileId($profile->id)->forceDelete();
 | 
						|
			Notification::whereProfileId($profile->id)
 | 
						|
				->orWhere('actor_id', $profile->id)
 | 
						|
				->forceDelete();
 | 
						|
		});
 | 
						|
 | 
						|
		DB::transaction(function() use ($profile) {
 | 
						|
			Status::whereProfileId($profile->id)
 | 
						|
				->cursor()
 | 
						|
				->each(function($status) {
 | 
						|
					AccountInterstitial::where('item_type', 'App\Status')
 | 
						|
						->where('item_id', $status->id)
 | 
						|
						->delete();
 | 
						|
					$status->forceDelete();
 | 
						|
				});
 | 
						|
			Report::whereProfileId($profile->id)->forceDelete();
 | 
						|
			$this->deleteProfile($profile);
 | 
						|
		});
 | 
						|
	}
 | 
						|
 | 
						|
	protected function deleteProfile($profile) {
 | 
						|
		DB::transaction(function() use ($profile) {
 | 
						|
			Profile::findOrFail($profile->id)->delete();
 | 
						|
		});
 | 
						|
	}
 | 
						|
}
 |