mirror of
https://github.com/freescout-helpdesk/freescout.git
synced 2024-11-24 19:33:07 +01:00
64 lines
1.4 KiB
PHP
64 lines
1.4 KiB
PHP
<?php
|
|
|
|
namespace App;
|
|
|
|
use Illuminate\Database\Eloquent\Model;
|
|
|
|
class Email extends Model
|
|
{
|
|
/**
|
|
* Email types.
|
|
*/
|
|
const TYPE_WORK = 1;
|
|
const TYPE_HOME = 2;
|
|
const TYPE_OTHER = 3;
|
|
|
|
public static $types = [
|
|
self::TYPE_WORK => 'work',
|
|
self::TYPE_HOME => 'home',
|
|
self::TYPE_OTHER => 'other',
|
|
];
|
|
|
|
public $timestamps = false;
|
|
|
|
/**
|
|
* Attributes which are not fillable using fill() method.
|
|
*/
|
|
protected $guarded = ['id', 'customer_id'];
|
|
|
|
/**
|
|
* Get email's customer.
|
|
*/
|
|
public function customer()
|
|
{
|
|
return $this->belongsTo('App\Customer');
|
|
}
|
|
|
|
/**
|
|
* Sanitize email address.
|
|
*
|
|
* @param string $email
|
|
*
|
|
* @return string
|
|
*/
|
|
public static function sanitizeEmail($email)
|
|
{
|
|
// FILTER_VALIDATE_EMAIL does not work with long emails for example
|
|
// Email validation is not recommended:
|
|
// http://stackoverflow.com/questions/201323/using-a-regular-expression-to-validate-an-email-address/201378#201378
|
|
// So we just check for @
|
|
if (!preg_match('/@/', $email)) {
|
|
return false;
|
|
}
|
|
$email = filter_var($email, FILTER_SANITIZE_EMAIL);
|
|
$email = mb_strtolower($email, 'UTF-8');
|
|
|
|
return $email;
|
|
}
|
|
|
|
public function getNameFromEmail()
|
|
{
|
|
return explode('@', $this->email)[0];
|
|
}
|
|
}
|