UserServiceInterface.php 3.09 KB
Newer Older
王源's avatar
王源 committed
1 2 3 4 5 6 7 8 9 10 11 12 13
<?php
/**
 * Created by PhpStorm.
 * User: 王源
 * Date: 2020/1/9
 * Time: 15:07
 */

namespace Meibuyu\Micro\Service\Interfaces;

interface UserServiceInterface
{

14 15 16 17 18 19 20 21
    /**
     * 通过用户名称模糊获取用户
     * @param string $name
     * @param array $columns
     * @return array
     */
    public function getByName(string $name, array $columns = ['id', 'name']): array;

王源's avatar
王源 committed
22 23
    /**
     * 获取单个数据
王源's avatar
王源 committed
24 25
     * @param int $id
     * @param array $columns
王源's avatar
王源 committed
26
     * @param array $relations 可传入['teams', 'departments', 'position', 'assessment_plan'],分别是团队,部门,岗位和考核方案
王源's avatar
王源 committed
27 28
     * @return mixed
     */
王源's avatar
王源 committed
29 30 31 32 33
    public function get(int $id, array $columns = ['*'], array $relations = []);

    /**
     * 获取全部数据
     * @param array $columns
王源's avatar
王源 committed
34
     * @param array $relations 可传入['teams', 'departments', 'position', 'assessment_plan'],分别是团队,部门,岗位和考核方案
王源's avatar
王源 committed
35 36 37
     * @return array
     */
    public function all(array $columns = ['*'], array $relations = []): array;
王源's avatar
王源 committed
38

39 40 41 42
    /**
     * 通过id列表获取用户数组
     * @param array $idList
     * @param array $columns
王源's avatar
王源 committed
43
     * @param array $relations 可传入['teams', 'departments', 'position', 'assessment_plan'],分别是团队,部门,岗位和考核方案
44 45
     * @return mixed
     */
王源's avatar
王源 committed
46
    public function getByIdList(array $idList, array $columns = ['*'], array $relations = []);
47

48 49 50 51 52 53 54 55
    /**
     * 通过部门id列表获取用户数组(包括子部门用户)
     * @param array $deptIds
     * @param array $columns 用户字段,默认['id', 'name', 'department_id']
     * @return array
     */
    public function getListByDeptIds(array $deptIds, $columns = []);

56 57 58 59 60 61 62
    /**
     * 判断是否是超级管理员
     * @param int $userId
     * @return bool
     */
    public function isSuperAdmin(int $userId): bool;

王源's avatar
王源 committed
63
    /**
64
     * 鉴权
65 66 67
     * @param int $userId
     * @param string $perm
     * @return bool
王源's avatar
王源 committed
68
     */
69
    public function checkPerm(int $userId, string $perm): bool;
王源's avatar
王源 committed
70

71 72 73
    /**
     * 获取用户拥有某个应用的所有权限
     * @param int $userId
王源's avatar
王源 committed
74
     * @param mixed $appNames 应用名,多个传数组
75 76
     * @return array
     */
王源's avatar
王源 committed
77
    public function getPerms(int $userId, $appNames = null): array;
78

79 80 81 82 83 84 85 86 87 88 89 90
    /**
     * 获取带领导字符串数组的列表
     * [
     *     ['id' => -1, 'name' => '总经理'],
     *     ['id' => -2, 'name' => '直属领导'],
     *     ['id' => -3, 'name' => '部门领导'],
     *     [...]
     * ]
     * @return array
     */
    public function allWithLeader(): array;

91 92 93 94 95 96 97 98 99
    /**
     * 获取带有领导真实信息的用户列表
     * @param int $userId
     * @param array $idList 可包含[-1,-2,-3]
     * @param array $columns
     * @return array
     */
    public function getListWithLeader(int $userId, array $idList = [], array $columns = ['id', 'name']): array;

100 101 102 103 104 105 106 107 108 109
    /**
     * 更新用户考核方案
     * @param $userId
     * @param array $attributes
     * 'review_users' => '1,2,3' // 点评人
     * 'cc_person' => '1,2,3' // 抄送人
     * @return int
     */
    public function updateAssessmentPlan($userId, array $attributes);

王源's avatar
王源 committed
110
}