user = $user; } public function handle() { $user = $this->user; DB::transaction(function() use ($user) { AccountLog::chunk(200, function($logs) use ($user) { foreach($logs as $log) { if($log->user_id == $user->id) { $log->forceDelete(); } } }); }); DB::transaction(function() use ($user) { AccountInterstitial::whereUserId($user->id)->delete(); }); DB::transaction(function() use ($user) { if($user->profile) { $avatar = $user->profile->avatar; $avatar->forceDelete(); } $id = $user->profile_id; ImportData::whereProfileId($id) ->cursor() ->each(function($data) { $path = storage_path('app/'.$data->path); if(is_file($path)) { unlink($path); } $data->delete(); }); ImportJob::whereProfileId($id) ->cursor() ->each(function($data) { $path = storage_path('app/'.$data->media_json); if(is_file($path)) { unlink($path); } $data->delete(); }); MediaTag::whereProfileId($id)->delete(); Bookmark::whereProfileId($id)->forceDelete(); EmailVerification::whereUserId($user->id)->forceDelete(); 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 ($user) { $pid = $this->user->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 ($user) { $medias = Media::whereUserId($user->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 ($user) { Mention::whereProfileId($user->profile_id)->forceDelete(); Notification::whereProfileId($user->profile_id) ->orWhere('actor_id', $user->profile_id) ->forceDelete(); }); DB::transaction(function() use ($user) { $collections = Collection::whereProfileId($user->profile_id)->get(); foreach ($collections as $collection) { $collection->items()->delete(); $collection->delete(); } Contact::whereUserId($user->id)->delete(); HashtagFollow::whereUserId($user->id)->delete(); OauthClient::whereUserId($user->id)->delete(); ProfileSponsor::whereProfileId($user->profile_id)->delete(); }); DB::transaction(function() use ($user) { Status::whereProfileId($user->profile_id) ->cursor() ->each(function($status) { AccountInterstitial::where('item_type', 'App\Status') ->where('item_id', $status->id) ->delete(); $status->forceDelete(); }); Report::whereUserId($user->id)->forceDelete(); $this->deleteProfile($user); }); } protected function deleteProfile($user) { DB::transaction(function() use ($user) { Profile::whereUserId($user->id)->delete(); $this->deleteUserSettings($user); }); } protected function deleteUserSettings($user) { DB::transaction(function() use ($user) { UserDevice::whereUserId($user->id)->forceDelete(); UserFilter::whereUserId($user->id)->forceDelete(); UserSetting::whereUserId($user->id)->forceDelete(); $this->deleteUserColumns($user); }); } protected function deleteUserColumns($user) { DB::transaction(function() use ($user) { $user->status = 'deleted'; $user->name = 'deleted'; $user->email = $user->id; $user->password = ''; $user->remember_token = null; $user->is_admin = false; $user->{'2fa_enabled'} = false; $user->{'2fa_secret'} = null; $user->{'2fa_backup_codes'} = null; $user->{'2fa_setup_at'} = null; $user->save(); }); } }