Компонент CakePHP Auth с использованием 2 таблиц
CakePHP версия 1.2.5
Я бы хотел, чтобы у одного пользователя было несколько адресов электронной почты.
Я бы хотел, чтобы у одного пользователя был один пароль.
Я хотел бы, чтобы пользователи входили в систему, используя любой из своих нескольких адресов электронной почты и один пароль.
Я создал таблицу пользователей с идентификатором и паролем.
Я создал таблицу user_email_addresses с полем id, полем user_id и полем email_address.
Вопрос:
Как я могу изменить компонент auth минимально, чтобы искать "имя пользователя» в этом случае, "адрес электронной почты", в таблице user_email_addresses и "пароль" в таблице пользователей?
Похоже, что изменение метода identifier в компоненте auth может сделать это. Но я думаю, что изменение компонента auth напрямую - плохая идея - есть идеи, как расширить и все же возможно изменить метод идентификации?http://cakebaker.42dh.com/2009/09/08/extending-cakephps-core-components/ или, возможно, назначить другой объект аутентификации?
Стартовая строка 774:
function identify($user = null, $conditions = null) {
if ($conditions === false) {
$conditions = null;
} elseif (is_array($conditions)) {
$conditions = array_merge((array)$this->userScope, $conditions);
} else {
$conditions = $this->userScope;
}
if (empty($user)) {
$user = $this->user();
if (empty($user)) {
return null;
}
} elseif (is_object($user) && is_a($user, 'Model')) {
if (!$user->exists()) {
return null;
}
$user = $user->read();
$user = $user[$this->userModel];
} elseif (is_array($user) && isset($user[$this->userModel])) {
$user = $user[$this->userModel];
}
if (is_array($user) && (isset($user[$this->fields['username']]) || isset($user[$this->userModel . '.' . $this->fields['username']]))) {
if (isset($user[$this->fields['username']]) && !empty($user[$this->fields['username']]) && !empty($user[$this->fields['password']])) {
if (trim($user[$this->fields['username']]) == '=' || trim($user[$this->fields['password']]) == '=') {
return false;
}
$find = array(
$this->userModel.'.'.$this->fields['username'] => $user[$this->fields['username']],
$this->userModel.'.'.$this->fields['password'] => $user[$this->fields['password']]
);
} elseif (isset($user[$this->userModel . '.' . $this->fields['username']]) && !empty($user[$this->userModel . '.' . $this->fields['username']])) {
if (trim($user[$this->userModel . '.' . $this->fields['username']]) == '=' || trim($user[$this->userModel . '.' . $this->fields['password']]) == '=') {
return false;
}
$find = array(
$this->userModel.'.'.$this->fields['username'] => $user[$this->userModel . '.' . $this->fields['username']],
$this->userModel.'.'.$this->fields['password'] => $user[$this->userModel . '.' . $this->fields['password']]
);
} else {
return false;
}
$model =& $this->getModel();
$data = $model->find(array_merge($find, $conditions), null, null, 0);
if (empty($data) || empty($data[$this->userModel])) {
return null;
}
} elseif (!empty($user) && is_string($user)) {
$model =& $this->getModel();
$data = $model->find(array_merge(array($model->escapeField() => $user), $conditions));
if (empty($data) || empty($data[$this->userModel])) {
return null;
}
}
if (!empty($data)) {
if (!empty($data[$this->userModel][$this->fields['password']])) {
unset($data[$this->userModel][$this->fields['password']]);
}
return $data[$this->userModel];
}
return null;
}