test
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

68 lines
1.7 KiB

<?php
namespace We7\Table\Uni;
class AccountUsers extends \We7Table {
protected $tableName = 'uni_account_users';
protected $primaryKey = 'id';
protected $field = array(
'uniacid',
'uid',
'role',
'rank',
'createtime',
);
protected $default = array(
'uniacid' => '',
'uid' => '',
'role' => '',
'rank' => '0',
'createtime' => '',
);
public function searchWithUserRole($role) {
return $this->query->where('role', $role);
}
public function getUsableAccountsByUid($uid) {
return $this->query->where('uid', $uid)->where('role !=', ACCOUNT_MANAGE_NAME_CLERK)->getall('uniacid');
}
public function getOwnedAccountsByUid($uid) {
return $this->query->where('uid', $uid)->where('role', ACCOUNT_MANAGE_NAME_OWNER)->getall('uniacid');
}
public function searchWithRole($role) {
return $this->query->where('u.role', $role);
}
public function getCommonUserOwnAccountUniacids($uid) {
return $this->query
->from('uni_account_users', 'u')
->select('u.uniacid, a.type')
->innerjoin('account', 'a')
->on(array('u.uniacid' => 'a.uniacid'))
->where('u.uid', $uid)
->getall('uniacid');
}
public function getAllUserRole($uid) {
return $this->query->where('uid', $uid)->getall('role');
}
public function getUserRoleByUniacid($uid, $uniacid) {
$info = $this->query->where(array('uid' => $uid, 'uniacid' => $uniacid))->get();
return $info['role'];
}
public function getUidByUniacidAndRole($uniacid, $role) {
$data = $this->where('uniacid', $uniacid)->where('role', $role)->get();
return empty($data['uid']) ? 0 : $data['uid'];
}
public function searchWithUsers() {
return $this->query->from($this->tableName, 'a')
->leftjoin('users', 'b')
->on('a.uid', 'b.uid');
}
}