mirror of
https://github.com/IT4Change/gradido.git
synced 2025-12-13 07:45:54 +00:00
git-subtree-dir: community_server git-subtree-mainline: ff11f6efe35bba180260fe84077bcd94298895c1 git-subtree-split: b6544b9e69fb85d4da100934675323c3e8c8ef67
131 lines
3.8 KiB
PHP
131 lines
3.8 KiB
PHP
<?php
|
|
namespace App\Model\Table;
|
|
|
|
use Cake\ORM\Query;
|
|
use Cake\ORM\RulesChecker;
|
|
use Cake\ORM\Table;
|
|
use Cake\Validation\Validator;
|
|
|
|
/**
|
|
* Users Model
|
|
*
|
|
* @property \App\Model\Table\EmailOptInTable&\Cake\ORM\Association\HasMany $EmailOptIn
|
|
* @property \App\Model\Table\UserBackupsTable&\Cake\ORM\Association\HasMany $UserBackups
|
|
* @property \App\Model\Table\UserRolesTable&\Cake\ORM\Association\HasMany $UserRoles
|
|
*
|
|
* @method \App\Model\Entity\User get($primaryKey, $options = [])
|
|
* @method \App\Model\Entity\User newEntity($data = null, array $options = [])
|
|
* @method \App\Model\Entity\User[] newEntities(array $data, array $options = [])
|
|
* @method \App\Model\Entity\User|false save(\Cake\Datasource\EntityInterface $entity, $options = [])
|
|
* @method \App\Model\Entity\User saveOrFail(\Cake\Datasource\EntityInterface $entity, $options = [])
|
|
* @method \App\Model\Entity\User patchEntity(\Cake\Datasource\EntityInterface $entity, array $data, array $options = [])
|
|
* @method \App\Model\Entity\User[] patchEntities($entities, array $data, array $options = [])
|
|
* @method \App\Model\Entity\User findOrCreate($search, callable $callback = null, $options = [])
|
|
*
|
|
* @mixin \Cake\ORM\Behavior\TimestampBehavior
|
|
*/
|
|
class UsersTable extends Table
|
|
{
|
|
/**
|
|
* Initialize method
|
|
*
|
|
* @param array $config The configuration for the Table.
|
|
* @return void
|
|
*/
|
|
public function initialize(array $config)
|
|
{
|
|
parent::initialize($config);
|
|
|
|
$this->setTable('users');
|
|
$this->setDisplayField('id');
|
|
$this->setPrimaryKey('id');
|
|
|
|
$this->addBehavior('Timestamp');
|
|
|
|
$this->hasMany('EmailOptIn', [
|
|
'foreignKey' => 'user_id',
|
|
]);
|
|
$this->hasMany('UserBackups', [
|
|
'foreignKey' => 'user_id',
|
|
]);
|
|
$this->hasMany('UserRoles', [
|
|
'foreignKey' => 'user_id',
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* Default validation rules.
|
|
*
|
|
* @param \Cake\Validation\Validator $validator Validator instance.
|
|
* @return \Cake\Validation\Validator
|
|
*/
|
|
public function validationDefault(Validator $validator)
|
|
{
|
|
$validator
|
|
->integer('id')
|
|
->allowEmptyString('id', null, 'create');
|
|
|
|
$validator
|
|
->email('email')
|
|
->requirePresence('email', 'create')
|
|
->notEmptyString('email')
|
|
->add('email', 'unique', ['rule' => 'validateUnique', 'provider' => 'table']);
|
|
|
|
$validator
|
|
->scalar('first_name')
|
|
->maxLength('first_name', 150)
|
|
->requirePresence('first_name', 'create')
|
|
->notEmptyString('first_name');
|
|
|
|
$validator
|
|
->scalar('last_name')
|
|
->maxLength('last_name', 255)
|
|
->allowEmptyString('last_name');
|
|
|
|
$validator
|
|
->requirePresence('password', 'create')
|
|
->notEmptyString('password');
|
|
|
|
$validator
|
|
->allowEmptyString('pubkey');
|
|
|
|
$validator
|
|
->allowEmptyString('privkey');
|
|
|
|
$validator
|
|
->boolean('email_checked')
|
|
->notEmptyString('email_checked');
|
|
|
|
$validator
|
|
->scalar('language')
|
|
->maxLength('language', 4)
|
|
->notEmptyString('language');
|
|
|
|
return $validator;
|
|
}
|
|
|
|
/**
|
|
* Returns a rules checker object that will be used for validating
|
|
* application integrity.
|
|
*
|
|
* @param \Cake\ORM\RulesChecker $rules The rules object to be modified.
|
|
* @return \Cake\ORM\RulesChecker
|
|
*/
|
|
public function buildRules(RulesChecker $rules)
|
|
{
|
|
$rules->add($rules->isUnique(['email']));
|
|
|
|
return $rules;
|
|
}
|
|
|
|
/**
|
|
* Returns the database connection name to use by default.
|
|
*
|
|
* @return string
|
|
*/
|
|
public static function defaultConnectionName()
|
|
{
|
|
return 'loginServer';
|
|
}
|
|
}
|