123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198 |
- <?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 Storage;
- use Illuminate\Support\Str;
- use App\Services\AccountService;
- use App\Services\FollowerService;
- use App\Services\PublicTimelineService;
- use App\{
- AccountInterstitial,
- AccountLog,
- 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,
- StatusArchived,
- Status,
- Story,
- StoryView,
- User,
- UserDevice,
- UserFilter,
- UserSetting,
- };
- use App\Models\Conversation;
- use App\Models\Poll;
- use App\Models\PollVote;
- use App\Models\Portfolio;
- use App\Models\UserPronoun;
- use App\Jobs\StatusPipeline\StatusDelete;
- class DeleteAccountPipeline implements ShouldQueue
- {
- use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
- protected $user;
- public $timeout = 900;
- public $tries = 3;
- public $maxExceptions = 1;
- public $deleteWhenMissingModels = true;
- public function __construct(User $user)
- {
- $this->user = $user;
- }
- public function handle()
- {
- $user = $this->user;
- $profile = $user->profile;
- $id = $user->profile_id;
- Status::whereProfileId($id)->chunk(50, function($statuses) {
- foreach($statuses as $status) {
- StatusDelete::dispatch($status);
- }
- });
- AccountLog::whereItemType('App\User')->whereItemId($user->id)->forceDelete();
- AccountInterstitial::whereUserId($user->id)->delete();
- // Delete Avatar
- $profile->avatar->forceDelete();
- // Delete Poll Votes
- PollVote::whereProfileId($id)->delete();
- // Delete Polls
- Poll::whereProfileId($id)->delete();
- // Delete Portfolio
- Portfolio::whereProfileId($id)->delete();
- 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)->orWhere('to_id', $id)->delete();
- Conversation::whereFromId($id)->orWhere('to_id', $id)->delete();
- StatusArchived::whereProfileId($id)->delete();
- UserPronoun::whereProfileId($id)->delete();
- FollowRequest::whereFollowingId($id)
- ->orWhere('follower_id', $id)
- ->forceDelete();
- Follower::whereProfileId($id)
- ->orWhere('following_id', $id)
- ->each(function($follow) {
- FollowerService::remove($follow->profile_id, $follow->following_id);
- $follow->delete();
- });
- FollowerService::delCache($id);
- Like::whereProfileId($id)->forceDelete();
- Mention::whereProfileId($id)->forceDelete();
- StoryView::whereProfileId($id)->delete();
- $stories = Story::whereProfileId($id)->get();
- foreach($stories as $story) {
- $path = storage_path('app/'.$story->path);
- if(is_file($path)) {
- unlink($path);
- }
- $story->forceDelete();
- }
- UserDevice::whereUserId($user->id)->forceDelete();
- UserFilter::whereUserId($user->id)->forceDelete();
- UserSetting::whereUserId($user->id)->forceDelete();
- Mention::whereProfileId($id)->forceDelete();
- Notification::whereProfileId($id)
- ->orWhere('actor_id', $id)
- ->forceDelete();
- $collections = Collection::whereProfileId($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();
- DB::table('oauth_access_tokens')->whereUserId($user->id)->delete();
- DB::table('oauth_auth_codes')->whereUserId($user->id)->delete();
- ProfileSponsor::whereProfileId($id)->delete();
- Report::whereUserId($user->id)->forceDelete();
- PublicTimelineService::warmCache(true, 400);
- $this->deleteUserColumns($user);
- AccountService::del($user->profile_id);
- Profile::whereUserId($user->id)->delete();
- }
- 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();
- });
- }
- }
|