これは、WordPress の API を Yii のロールベースの認証マネージャーにラップする単純なクラスです。コントローラー内で、チェックしたい「ロール」(別名 WordPress 機能) を指定します。
<?php public function accessRules()
{
return array(
array('allow',
'actions'=>array('index','view'),
'roles'=>array('publish_posts')
//WordPress capability check.
// See @link http://codex.wordpress.org/Roles_and_Capabilities
),
}
?>
これは新しい User クラスであり、Yii 設定ファイルの components => user => class = 'wpUser' セクションに追加する必要があります。これは、Yii のデフォルトの CWebUser (config 配列で指定されていない - デフォルトでロードされる) を置き換えます。また、配列から "allowAutoLogin" => true を削除する必要があります。
<?php
class wpUser extends CApplicationComponent implements IWebUser, IApplicationComponent {
public function init ()
{
parent::init();
}
function checkAccess ($operation, $params = array()) {
return current_user_can($operation);
}
function getId() {
return get_current_user_id();
}
function getIsGuest () {
$is_user_logged_in = is_user_logged_in();
return ! $is_user_logged_in;
}
function getName () {
$name = wp_get_current_user()->user_login;
return $name;
}
public function loginRequired()
{
wp_login_form(array('redirect' => Yii::app()->getRequest()->getUrl()));
}
}
?>
Yiiのウィキで公開