_a['table'] = 'idf_emailaddresses'; $this->_a['model'] = __CLASS__; $this->_a['cols'] = array( // It is mandatory to have an "id" column. 'id' => array( 'type' => 'Pluf_DB_Field_Sequence', //It is automatically added. 'blank' => true, ), 'user' => array( 'type' => 'Pluf_DB_Field_Foreignkey', 'model' => 'Pluf_User', 'blank' => false, 'verbose' => __('user'), ), 'address' => array( 'type' => 'Pluf_DB_Field_Email', 'blank' => false, 'verbose' => __('email'), 'unique' => true, ), ); // WARNING: Not using getSqlTable on the Pluf_User object to // avoid recursion. $t_users = $this->_con->pfx.'users'; $this->_a['views'] = array( 'join_user' => array( 'join' => 'LEFT JOIN '.$t_users .' ON '.$t_users.'.id='.$this->_con->qn('user'), 'select' => $this->getSelect().', ' .$t_users.'.login AS login', 'props' => array('login' => 'login'), ) ); } function get_email_addresses_for_user($user) { $addr = $user->get_idf_emailaddress_list(); $addr[] = (object)array("address" => $user->email, "id" => -1, "user" => $user); return $addr; } function get_user_for_email_address($email) { $sql = new Pluf_SQL('email=%s', array($email)); $users = Pluf::factory('Pluf_User')->getList(array('filter'=>$sql->gen())); if ($users->count() > 0) { return $users[0]; } $sql = new Pluf_SQL('address=%s', array($email)); $matches = Pluf::factory('IDF_EmailAddress')->getList(array('filter'=>$sql->gen())); if ($matches->count() > 0) { return new Pluf_User($matches[0]->user); } return null; } }