2019-06-06 14:51:28 +10:00
|
|
|
<?php
|
|
|
|
|
/**
|
2020-09-06 19:38:10 +10:00
|
|
|
* Invoice Ninja (https://invoiceninja.com).
|
2019-06-06 14:51:28 +10:00
|
|
|
*
|
|
|
|
|
* @link https://github.com/invoiceninja/invoiceninja source repository
|
|
|
|
|
*
|
2022-04-27 13:20:41 +10:00
|
|
|
* @copyright Copyright (c) 2022. Invoice Ninja LLC (https://invoiceninja.com)
|
2019-06-06 14:51:28 +10:00
|
|
|
*
|
2021-06-16 16:58:16 +10:00
|
|
|
* @license https://www.elastic.co/licensing/elastic-license
|
2019-06-06 14:51:28 +10:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
namespace App\Repositories;
|
|
|
|
|
|
2020-03-09 20:38:15 +11:00
|
|
|
use App\DataMapper\CompanySettings;
|
2021-01-14 14:44:52 +11:00
|
|
|
use App\Events\User\UserWasArchived;
|
2020-03-24 20:15:30 +11:00
|
|
|
use App\Events\User\UserWasDeleted;
|
2021-01-14 14:44:52 +11:00
|
|
|
use App\Events\User\UserWasRestored;
|
2022-08-05 17:27:17 +10:00
|
|
|
use App\Jobs\Company\CreateCompanyToken;
|
2020-03-09 20:38:15 +11:00
|
|
|
use App\Models\CompanyUser;
|
|
|
|
|
use App\Models\User;
|
2020-07-08 22:02:16 +10:00
|
|
|
use App\Utils\Ninja;
|
2020-09-16 09:56:10 +10:00
|
|
|
use App\Utils\Traits\MakesHash;
|
2019-06-06 14:51:28 +10:00
|
|
|
use Illuminate\Http\Request;
|
2021-01-01 20:11:21 +11:00
|
|
|
use Illuminate\Support\Facades\Hash;
|
2019-06-06 14:51:28 +10:00
|
|
|
|
|
|
|
|
/**
|
2020-09-06 19:38:10 +10:00
|
|
|
* UserRepository.
|
2019-06-06 14:51:28 +10:00
|
|
|
*/
|
|
|
|
|
class UserRepository extends BaseRepository
|
|
|
|
|
{
|
2020-09-16 09:56:10 +10:00
|
|
|
use MakesHash;
|
|
|
|
|
|
2019-12-31 08:59:12 +11:00
|
|
|
/**
|
2020-09-06 19:38:10 +10:00
|
|
|
* Saves the user and its contacts.
|
2019-06-06 14:51:28 +10:00
|
|
|
*
|
2020-10-28 21:10:49 +11:00
|
|
|
* @param array $data The data
|
2020-11-04 00:27:41 +11:00
|
|
|
* @param \App\Models\User $user The user
|
2019-06-06 14:51:28 +10:00
|
|
|
*
|
2020-10-28 21:10:49 +11:00
|
|
|
* @param bool $unset_company_user
|
2020-11-04 00:27:41 +11:00
|
|
|
* @return \App\Models\User user Object
|
2019-06-06 14:51:28 +10:00
|
|
|
*/
|
2020-11-01 14:19:03 +11:00
|
|
|
public function save(array $data, User $user, $unset_company_user = false)
|
2019-12-31 08:59:12 +11:00
|
|
|
{
|
2020-04-07 22:43:44 +02:00
|
|
|
$details = $data;
|
|
|
|
|
|
2020-09-06 19:38:10 +10:00
|
|
|
/*
|
2020-04-07 22:43:44 +02:00
|
|
|
* Getting: SQLSTATE[42S22]: Column not found: 1054 Unknown column 'company_user'
|
|
|
|
|
* because of User::unguard().
|
|
|
|
|
* Solution. Unset company_user per request.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
if ($unset_company_user) {
|
|
|
|
|
unset($details['company_user']);
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-24 20:15:30 +11:00
|
|
|
$company = auth()->user()->company();
|
2020-09-06 19:38:10 +10:00
|
|
|
$account = $company->account;
|
2020-04-23 08:54:10 +10:00
|
|
|
|
|
|
|
|
/* If hosted and Enterprise we need to increment the num_users field on the accounts table*/
|
2022-08-05 17:27:17 +10:00
|
|
|
// 05-08-2022 This is an error, the num_users should _never_ increment
|
|
|
|
|
// if (! $user->id && $account->isEnterpriseClient()) {
|
|
|
|
|
// $account->num_users++;
|
|
|
|
|
// $account->save();
|
|
|
|
|
// }
|
2020-03-24 20:15:30 +11:00
|
|
|
|
2020-04-07 22:43:44 +02:00
|
|
|
$user->fill($details);
|
2020-09-16 09:56:10 +10:00
|
|
|
|
2021-01-01 20:11:21 +11:00
|
|
|
//allow users to change only their passwords - not others!
|
2021-01-04 13:38:00 +01:00
|
|
|
if (auth()->user()->id == $user->id && array_key_exists('password', $data) && isset($data['password'])) {
|
2021-01-01 20:11:21 +11:00
|
|
|
$user->password = Hash::make($data['password']);
|
|
|
|
|
}
|
|
|
|
|
|
2022-06-21 09:57:17 +00:00
|
|
|
if (! $user->confirmation_code) {
|
2021-11-06 11:46:12 +11:00
|
|
|
$user->confirmation_code = $this->createDbHash($company->db);
|
2020-11-25 15:19:52 +01:00
|
|
|
}
|
2020-09-16 09:56:10 +10:00
|
|
|
|
2020-04-23 08:54:10 +10:00
|
|
|
$user->account_id = $account->id;
|
2021-03-04 16:03:28 +11:00
|
|
|
|
2022-06-21 09:57:17 +00:00
|
|
|
if (strlen($user->password) >= 1) {
|
2021-03-04 16:03:28 +11:00
|
|
|
$user->has_password = true;
|
2022-06-21 09:57:17 +00:00
|
|
|
}
|
|
|
|
|
|
2019-06-06 14:51:28 +10:00
|
|
|
$user->save();
|
|
|
|
|
|
2019-12-31 08:59:12 +11:00
|
|
|
if (isset($data['company_user'])) {
|
2020-03-02 21:22:37 +11:00
|
|
|
$cu = CompanyUser::whereUserId($user->id)->whereCompanyId($company->id)->withTrashed()->first();
|
2019-11-21 19:38:57 +11:00
|
|
|
|
2019-12-04 12:06:14 +11:00
|
|
|
/*No company user exists - attach the user*/
|
2020-09-06 19:38:10 +10:00
|
|
|
if (! $cu) {
|
2020-04-23 08:54:10 +10:00
|
|
|
$data['company_user']['account_id'] = $account->id;
|
2020-03-09 20:38:15 +11:00
|
|
|
$data['company_user']['notifications'] = CompanySettings::notificationDefaults();
|
2019-11-23 08:10:53 +11:00
|
|
|
$user->companies()->attach($company->id, $data['company_user']);
|
2019-12-31 08:59:12 +11:00
|
|
|
} else {
|
2022-06-21 09:57:17 +00:00
|
|
|
if (auth()->user()->isAdmin()) {
|
2021-05-07 07:41:37 +10:00
|
|
|
$cu->fill($data['company_user']);
|
|
|
|
|
$cu->restore();
|
|
|
|
|
$cu->tokens()->restore();
|
|
|
|
|
$cu->save();
|
2022-08-05 17:27:17 +10:00
|
|
|
|
2022-08-05 17:42:54 +10:00
|
|
|
//05-08-2022
|
2022-08-05 17:27:17 +10:00
|
|
|
if($cu->tokens()->count() == 0){
|
|
|
|
|
(new CreateCompanyToken($cu->company, $cu->user, 'restored_user'))->handle();
|
|
|
|
|
}
|
|
|
|
|
|
2022-06-21 09:57:17 +00:00
|
|
|
} else {
|
2021-05-07 07:41:37 +10:00
|
|
|
$cu->notifications = $data['company_user']['notifications'];
|
|
|
|
|
$cu->settings = $data['company_user']['settings'];
|
|
|
|
|
$cu->save();
|
|
|
|
|
}
|
2019-12-04 12:06:14 +11:00
|
|
|
}
|
2020-03-09 20:38:15 +11:00
|
|
|
|
2020-03-21 16:37:30 +11:00
|
|
|
$user->with(['company_users' => function ($query) use ($company, $user) {
|
2020-03-09 20:38:15 +11:00
|
|
|
$query->whereCompanyId($company->id)
|
|
|
|
|
->whereUserId($user->id);
|
|
|
|
|
}])->first();
|
2019-11-21 19:38:57 +11:00
|
|
|
}
|
2020-03-25 10:20:42 +11:00
|
|
|
$user->restore();
|
2019-11-21 19:38:57 +11:00
|
|
|
|
2021-05-24 10:53:04 +10:00
|
|
|
return $user->fresh();
|
2019-12-31 08:59:12 +11:00
|
|
|
}
|
2020-03-02 21:22:37 +11:00
|
|
|
|
|
|
|
|
public function destroy(array $data, User $user)
|
|
|
|
|
{
|
2022-06-21 09:57:17 +00:00
|
|
|
if ($user->isOwner()) {
|
2021-03-07 17:27:44 +11:00
|
|
|
return $user;
|
2022-06-21 09:57:17 +00:00
|
|
|
}
|
2021-03-07 17:27:44 +11:00
|
|
|
|
2020-03-21 16:37:30 +11:00
|
|
|
if (array_key_exists('company_user', $data)) {
|
2020-03-02 21:22:37 +11:00
|
|
|
$this->forced_includes = 'company_users';
|
|
|
|
|
|
|
|
|
|
$company = auth()->user()->company();
|
|
|
|
|
|
|
|
|
|
$cu = CompanyUser::whereUserId($user->id)
|
|
|
|
|
->whereCompanyId($company->id)
|
|
|
|
|
->first();
|
|
|
|
|
|
2020-03-11 22:05:05 +11:00
|
|
|
$cu->tokens()->forceDelete();
|
|
|
|
|
$cu->forceDelete();
|
2020-03-02 21:22:37 +11:00
|
|
|
}
|
2020-03-11 22:05:05 +11:00
|
|
|
|
2021-05-07 07:12:07 +10:00
|
|
|
event(new UserWasDeleted($user, $company, Ninja::eventVars(auth()->user() ? auth()->user()->id : null)));
|
2020-03-24 20:15:30 +11:00
|
|
|
|
2020-09-28 12:56:11 +10:00
|
|
|
$user->delete();
|
|
|
|
|
|
2020-03-02 21:22:37 +11:00
|
|
|
return $user->fresh();
|
|
|
|
|
}
|
2020-03-11 22:05:05 +11:00
|
|
|
|
2020-03-24 20:15:30 +11:00
|
|
|
/*
|
|
|
|
|
* Soft deletes the user and the company user
|
|
|
|
|
*/
|
2020-03-18 20:40:15 +11:00
|
|
|
public function delete($user)
|
|
|
|
|
{
|
|
|
|
|
$company = auth()->user()->company();
|
|
|
|
|
|
|
|
|
|
$cu = CompanyUser::whereUserId($user->id)
|
|
|
|
|
->whereCompanyId($company->id)
|
|
|
|
|
->first();
|
|
|
|
|
|
2020-03-21 16:37:30 +11:00
|
|
|
if ($cu) {
|
2020-03-18 20:40:15 +11:00
|
|
|
$cu->tokens()->delete();
|
|
|
|
|
$cu->delete();
|
|
|
|
|
}
|
|
|
|
|
|
2021-05-07 07:12:07 +10:00
|
|
|
event(new UserWasDeleted($user, auth()->user(), $company, Ninja::eventVars(auth()->user() ? auth()->user()->id : null)));
|
2020-09-28 12:56:11 +10:00
|
|
|
|
2022-06-21 09:57:17 +00:00
|
|
|
$user->is_deleted = true;
|
|
|
|
|
$user->save();
|
|
|
|
|
$user->delete();
|
2020-03-24 20:15:30 +11:00
|
|
|
|
2020-03-18 20:40:15 +11:00
|
|
|
return $user->fresh();
|
|
|
|
|
}
|
2021-01-14 14:44:52 +11:00
|
|
|
|
|
|
|
|
public function archive($user)
|
|
|
|
|
{
|
|
|
|
|
if ($user->trashed()) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$user->delete();
|
|
|
|
|
|
2021-05-07 07:12:07 +10:00
|
|
|
event(new UserWasArchived($user, auth()->user(), auth()->user()->company, Ninja::eventVars(auth()->user() ? auth()->user()->id : null)));
|
2021-01-14 14:44:52 +11:00
|
|
|
}
|
|
|
|
|
|
2022-06-21 09:57:17 +00:00
|
|
|
/**
|
2021-01-14 14:44:52 +11:00
|
|
|
* @param $entity
|
|
|
|
|
*/
|
|
|
|
|
public function restore($user)
|
|
|
|
|
{
|
|
|
|
|
if (! $user->trashed()) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2022-01-11 19:08:08 +11:00
|
|
|
if (Ninja::isHosted()) {
|
|
|
|
|
$count = User::where('account_id', auth()->user()->account_id)->count();
|
2022-06-21 09:57:17 +00:00
|
|
|
if ($count >= auth()->user()->account->num_users) {
|
2022-01-11 19:08:08 +11:00
|
|
|
return;
|
2022-06-21 09:57:17 +00:00
|
|
|
}
|
2022-01-11 19:08:08 +11:00
|
|
|
}
|
|
|
|
|
|
2021-03-26 19:07:43 +11:00
|
|
|
$user->is_deleted = false;
|
|
|
|
|
$user->save();
|
2021-01-14 14:44:52 +11:00
|
|
|
$user->restore();
|
2021-03-26 19:07:43 +11:00
|
|
|
|
|
|
|
|
$cu = CompanyUser::withTrashed()
|
|
|
|
|
->where('user_id', $user->id)
|
|
|
|
|
->where('company_id', auth()->user()->company()->id)
|
|
|
|
|
->first();
|
|
|
|
|
|
|
|
|
|
$cu->restore();
|
2021-01-14 14:44:52 +11:00
|
|
|
|
2021-05-07 07:12:07 +10:00
|
|
|
event(new UserWasRestored($user, auth()->user(), auth()->user()->company, Ninja::eventVars(auth()->user() ? auth()->user()->id : null)));
|
2021-01-14 14:44:52 +11:00
|
|
|
}
|
2019-12-31 08:59:12 +11:00
|
|
|
}
|