1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-14 07:02:34 +01:00
invoiceninja/app/Http/ValidationRules/UniqueUserRule.php
David Bomba 957ac9f5d8
Fix for password protected authorization (#3198)
* Remove unnecessary save() on invoice

* Update copyright

* Working on Credit Repository

* Implement credits as a paymentable entity

* Add credit_id to transformer

* fix rules for update payment

* Fix random deleted_at keys in transformers

* Fix for password_protect check
2020-01-07 11:13:47 +11:00

68 lines
1.4 KiB
PHP

<?php
/**
* Invoice Ninja (https://invoiceninja.com)
*
* @link https://github.com/invoiceninja/invoiceninja source repository
*
* @copyright Copyright (c) 2020. Invoice Ninja LLC (https://invoiceninja.com)
*
* @license https://opensource.org/licenses/AAL
*/
namespace App\Http\ValidationRules;
use App\Libraries\MultiDB;
use App\Models\User;
use Illuminate\Contracts\Validation\Rule;
/**
* Class UniqueUserRule
* @package App\Http\ValidationRules
*/
class UniqueUserRule implements Rule
{
public $user;
public $new_email;
public function __construct($user, $new_email)
{
$this->user= $user;
$this->new_email = $new_email;
}
/**
* @param string $attribute
* @param mixed $value
* @return bool
*/
public function passes($attribute, $value)
{
/* If the input has not changed, return early! */
if ($this->user->email == $this->new_email) {
return true;
} else {
return ! $this->checkIfEmailExists($value);
} //if it exists, return false!
}
/**
* @return string
*/
public function message()
{
return ctrans('texts.email_already_register');
}
/**
* @param $email
* @return bool
*/
private function checkIfEmailExists($email) : bool
{
return MultiDB::checkUserEmailExists($email);
}
}