嗨,我是 Kohana 的新手,我正在尝试使用 twitter 登录模块,我可以访问 twitter 信息,但是在注册时我正在使用 Auth orm 注册(我已经使用 Model_Auth_User 扩展了我的用户模型,否则在登录时会出现问题) ,但是在注册时,由于 twitter 不提供电子邮件(这是我认为的问题)验证失败,我需要知道是否可以删除所需电子邮件字段的验证
我正在添加我的代码以供参考
if(!empty($_GET['oauth_verifier']) && Session::instance()->get('oauth_token') && Session::instance()->get('oauth_token_secret'))
{
$twitteroauth = new TwitterOAuth(Kohana::$config->load('apiKey.twitter.TWITTER_CONSUMER_KEY'),Kohana::$config->load('apiKey.twitter.TWITTER_CONSUMER_SECRET'),Session::instance()->get('oauth_token'),Session::instance()->get('oauth_token_secret'));
$access_token = $twitteroauth->getAccessToken($_GET['oauth_verifier']);
$user_info = $twitteroauth->get('account/verify_credentials');
if(isset($user_info->error))
{
show_error("Some error has occured.");
}
else
{
$model = ORM::factory('user');
$result = $model->where('twitter_id','=', $user_info->id)->find();
if(!$result->id)
{
$name = explode(' ',$user_info->name);
$model = ORM::factory('user');
$data['twitter_id'] = $user_info->id;
$data['first_name'] = $name[0];
$data['last_name'] = $name[1];
$data['username'] = $user_info->screen_name;
$data['password'] = Auth::instance()->hash_password($user_info->screen_name);
$model->values($data);
$result = $model->save();
$role = ORM::factory('role')->where('name', '=', 'login')->find();
$model->add('roles', $role);
}
if($result->id)
{
//creating new ORM instance to use the result id
$model = ORM::factory('user');
$user = $model->find($result->id);
Auth::instance()->login($user->username,Auth::instance()->hash_password($user->username));
//Session::instance()->set('id', $model->id);
HTTP::redirect('user/dashboard');
}
else
{
HTTP::redirect('/');
}
}
}
else
{
$twitteroauth = new TwitterOAuth(Kohana::$config->load('apiKey.twitter.TWITTER_CONSUMER_KEY'),Kohana::$config->load('apiKey.twitter.TWITTER_CONSUMER_SECRET'));
$request_token = $twitteroauth->getRequestToken(URL::site());
$url = $twitteroauth->getAuthorizeURL($request_token['oauth_token']);
Session::instance()->set('oauth_token',$request_token['oauth_token']);
Session::instance()->set('oauth_token_secret', $request_token['oauth_token_secret']);
HTTP::redirect($url);
}