user; if(!$user) { return; } $this->userProfile($user); $this->userSettings($user); $this->userState($user); $this->userDevice($user); $this->userProfileId($user); } protected function userProfile($user) { if (empty($user->profile)) { DB::transaction(function() use($user) { $profile = new Profile(); $profile->user_id = $user->id; $profile->username = $user->username; $profile->name = $user->name; $pkiConfig = [ 'digest_alg' => 'sha512', 'private_key_bits' => 2048, 'private_key_type' => OPENSSL_KEYTYPE_RSA, ]; $pki = openssl_pkey_new($pkiConfig); openssl_pkey_export($pki, $pki_private); $pki_public = openssl_pkey_get_details($pki); $pki_public = $pki_public['key']; $profile->private_key = $pki_private; $profile->public_key = $pki_public; $profile->save(); CreateAvatar::dispatch($profile); }); } } protected function userSettings($user) { if (empty($user->settings)) { DB::transaction(function() use($user) { UserSetting::firstOrCreate([ 'user_id' => $user->id ]); }); } } protected function userState($user) { if($user->status != null) { $profile = $user->profile; if(!$profile) { return; } switch ($user->status) { case 'disabled': $profile->status = null; $user->status = null; $profile->save(); $user->save(); break; case 'delete': $profile->status = null; $profile->delete_after = null; $user->status = null; $user->delete_after = null; $profile->save(); $user->save(); break; default: # code... break; } } } protected function userDevice($user) { $device = DB::transaction(function() use($user) { return UserDevice::firstOrCreate([ 'user_id' => $user->id, 'ip' => request()->ip(), 'user_agent' => request()->userAgent(), ]); }); } protected function userProfileId($user) { if($user->profile_id == null) { DB::transaction(function() use($user) { $profile = $user->profile; $user->profile_id = $profile->id; $user->save(); }); } } }