主题
用户
用户说明
用户的定义
HENGSHI 系统内的用户及 SSO 认证后自动创建用户,主要信息由登录名、邮箱、姓名、手机号码、用户属性等组成。 如果在系统中通过api创建了用户,再使用 SSO 认证是可以自动关联用户的。如: 通过api创建了用户loginName=demoTest,当通过 SSO 认证时的loginName也是demoTest,那么不会再自动创建用户, 而是将以demoTest的身份进行登录。关联的优先级是loginName,email,mobile。
用户结构说明
字段 | 类型 | 是否必须 | 描述 |
---|---|---|---|
id | LONG | 否 | id |
loginName | STRING | loginName,email不能同时为空 | 登录名,企业内不能重复。 |
STRING | loginName,email不能同时为空 | 邮箱,企业内不能重复。 | |
password | STRING | 重置密码时使用,填写当前登录用户的密码 | 公钥加密密码,用base64格式进行编码。重置密码时验证当前用户身份的验证字段。 |
newPassword | STRING | 不使用密码登录时可以不设置 | 公钥加密密码,用base64格式进行编码。填写需保存的用户密码。 |
uuid | STRING | 公钥对应的uuid | 解密使用。 |
mobile | STRING | 否 | 手机,企业内不能重复。 |
name | STRING | 否 | 显示名称(昵称) |
userType | STRING | 否 | 默认为internal,可选值:internal,ldap,cas,oauth2,saml2,dingtalk,wechat-work,ctr,yunzhijia,jwt-param,lark |
description | STRING | 否 | 用户备注 |
avatar | STRING | 否 | 用户头像 |
roles | JSON 数组 | 否 | 角色 |
roles[].id | LONG | 否 | 角色id |
organizations | JSON 数组 | 否 | 用户组 |
organizations[].id | LONG | 否 | 用户组id |
orgs | JSON 数组 | 否 | 用户组织架构 |
orgs[].id | LONG | 否 | 用户组织架构id |
platformConfig | JSON | 否 | 用户通过sso方式登陆同步的全局属性 |
config | JSON | 否 | 用户属性,其内容为自定义的用户属性,如:{"school":"a","grade":3} |
resetPassword | BOOLEAN | 否 | 用户登录以后是否需要重置密码。管理员重置用户密码时,不支持 API 更新该字段 |
config字段说明:
用户可以在页面创建用户属性并赋值。
用户可以通过api调用传递用户属性,需要以用户结构说明中的config,如:
{ "loginName":"demoUser001", "config":{ "text":"a", "number":1, "array":[ "test1" ] } }
oauth,jwt认证方式登录时会将除登录名,用户名,邮箱,手机,角色以外的json字段自动封装成用户属性,如下json,会将school、grade封装成用户属性,保存到用户的config字段。
json{ "loginName":"loginName",//登录名映射 "email":"email",//邮箱映射 "mobile":"mobile",//手机映射 "name":"name",//用户名映射 "school":"a",//用户属性 "grade":3 //用户属性 }
钉钉,企业微信,云之家,飞书认证方式登录时会将除登录名,用户名,邮箱,手机,角色以外的json自动封装成用户属性。具体的用户信息由 钉钉 , 企业微信 , 云之家 , 飞书 接口返回,请参考官方文档。
角色结构说明
字段 | 类型 | 是否必须 | 描述 |
---|---|---|---|
id | LONG | 是 | id |
name | STRING | 是 | 角色名称 |
description | STRING | 是 | 角色描述 |
角色是系统内置数据,不可更新, 系统内角色有:
name | 角色 |
---|---|
system admin | 系统管理 |
data admin | 数据管理 |
data analyst | 数据分析 |
data viewer | 数据查看 |
api admin | API 管理员 |
用户组结构说明
字段 | 类型 | 是否必须 | 描述 |
---|---|---|---|
id | LONG | 否 | id |
name | STRING | 是 | 名称 |
STRING | 否 | 邮箱 | |
description | STRING | 否 | 用户组备注 |
users | JSON 数组 | 否 | 用户 |
users[].id | LONG | 否 | 角色id |
接口说明
获取角色列表
获取角色列表。
请求URL
http
GET /api/users/roles HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
URL 参数
无
request body 参数
无
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
data | OBJECT | 见角色结构说明 |
接口示例1: 获取角色列表
http
GET /api/users/roles HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code":0,
"msg":"success",
"data":[
{
"id":1,
"name":"system admin",
"description":"system admin"
},
{
"id":2,
"name":"data admin",
"description":"data admin"
},
{
"id":3,
"name":"data analyst",
"description":"data analyst"
},
{
"id":4,
"name":"data viewer",
"description":"data viewer"
},
{
"id":5,
"name":"api admin",
"description":"api admin"
}
]
}
创建用户
创建用户。
请求URL
http
POST /api/users HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
URL 参数
无
request body 参数
说明
用户属性需要放在config
字段中传递
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
data.id | LONG | 用户的 id |
用户默认头像
接口示例1: 创建用户(完整信息)
包含基本完整的用户信息,创建成功以后,用户可以根据登录名和密码登录。使用场景多为预先创建,配置用户,使用用户名/密码方式登录使用系统。
http
POST /api/users HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
// Request Body:
{
"loginName":"demoUser001",
"name":"demoUser001",
"email":"anonymous@hengshi.com",
"newPassword":"duk5ZIVdikKtU9txy0aMZlLPJ8hntpINLx2hBWiJw8sYfSxSQ/pkSBRv85s/ROQb45J4R8MsCrN7VQkhONMoGQ==",
"description":"desc",
"uuid":"488b4801-1f50-4694-b0e1-7bd8fea4869f",
"roles":[
{
"id":3
},
{
"id":4
},
{
"id":2
}
],
"config":{
"text":"a",
"number":1,
"array":["test1"]
},
"organizations":[
{
"id":25
}
],
"orgs":[
{
"id":25
}
],
"avatar":"..."
}
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code":0,
"msg":"success",
"data":{
"id":800
}
}
接口示例2: 创建用户(必要信息)
只包含必要的用户信息,使用场景多为预先创建,根据需要配置用户角色(roles),用户属性(config)等,之后使用其他的认证方式( 如单点登录,jwt等)登录使用系统。
http
POST /api/users HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
// Request Body:
{
"loginName": "13333333333",
"roles": [
{
"id": 1
}
]
}
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code":0,
"msg":"success",
"data":{
"id":800
}
}
管理员修改用户
管理员修改用户。
请求URL
http
PUT /api/users/{userId} HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
URL 参数
字段 | 类型 | 是否必须 | 说明 |
---|---|---|---|
userId | LONG | 是 | 修改用户的 id |
request body 参数
说明
用户属性需要放在config
字段中传递
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
修改用户属性说明
若在更新用户时通过config修改用户属性,则需要传被修改用户的全量属性,该修改为直接覆盖,没有传的属性都会被置空
重制密码说明
4.1版本以后该接口不再支持修改密码功能,可调用管理员重置用户密码 4.3版本以后该接口不再支持启用/禁用用户,可调用管理员启用/停用用户
接口示例1: 修改用户
http
PUT /api/users/{userId} HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
// Request Body:
{
"enable":true,
"description":"desc",
"roles":[
{
"id":2
},
{
"id":3
},
{
"id":4
}
],
"config":{
"text":"a",
"number":1,
"array":["test1"]
},
"organizations":[
{
"id":25
}
],
"orgs":[
{
"id":25
}
]
}
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code":0,
"msg":"success"
}
修改用户属性
请求URL
http
PUT /api/users/{userId}/attrs HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
URL 参数
字段 | 类型 | 是否必须 | 说明 |
---|---|---|---|
userId | LONG | 是 | 修改用户的 id |
request body 参数
字段 | 类型 | 是否必须 | 说明 |
---|---|---|---|
attr | LIST<JSONOBJECT> | 是 | 修改属性的列表 |
attr.name | STRING | 是 | 属性的名称 |
attr.value | OBJECT | 是 | 属性的值 |
attr.customized | BOOLEAN | 是 | 是否自定义值 |
说明
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
修改用户属性说明
重复传递属性,后声明的会覆盖先声明的
接口示例1: 修改用户属性
http
PUT /api/users/{userId}/attrs HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
// Request Body:
[{
"customized": true,
"name":"attr1",
"value": "attr1-value"
}]
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code":0,
"msg":"success"
}
管理员重置用户密码
管理员重置用户密码。
请求URL
http
PUT /api/users/{userId}/reset-password HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
URL 参数
字段 | 类型 | 是否必须 | 说明 |
---|---|---|---|
userId | LONG | 是 | 修改用户的 id |
request body 参数
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
接口示例1: 管理员重置密码
http
PUT /api/users/{userId}/reset-password HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
// Request Body:
{
"password": "UEDK5yrm3xswER2JgWvMELLR3aETo76qKBOg5PW/4pDsP9270a+mYE5kkWXFfHYUqiZtPsC4Apumis3BG3oUlw==",
"newPassword": "asxasdfweswER2JgWvMELLR3aETo76qKBOg5PW/4pDsP9270a+mYE5kkWXFfHYUqiZtff234141aaaaa====",
"uuid": "68a5d0c6-5a33-45d6-833a-9b70c961a77a"
}
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code":0,
"msg":"success"
}
管理员启用/停用用户
管理员启用/停用用户。
请求URL
http
PUT /api/users/batch-enable HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
URL 参数
request body 参数
字段 | 类型 | 是否必须 | 说明 |
---|---|---|---|
enable | BOOLEAN | 是 | 启用:true,停用:false |
users | JSON数组 | 是 | 用户数组 |
users[].id | LONG | 是 | 用户id |
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
接口示例1: 管理员启用、停用用户
http
PUT /api/users/batch-enable HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
// Request Body:
{
"users":[
{
"id":26
}
],
"enable":false
}
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code":0,
"msg":"success"
}
用户自行修改帐号信息
用户自行修改帐号信息
请求URL
http
PUT /api/users/account/{userId} HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
URL 参数
字段 | 类型 | 是否必须 | 说明 |
---|---|---|---|
userId | LONG | 是 | 修改用户的 id |
request body 参数
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
用户可修改的信息
通过该接口用户可修改用户的名称
,头像
,密码
,使用语言
修改密码说明
若调用该接口修改用户密码,与管理员修改接口不同的时,该密码就直接作为用户登陆密码使用,无需再次被强制要求修改
不可同时更改多项信息
名称
,头像
,密码
,使用语言
一次调用只能修改其中一项,若四个参数都传,则按照密码
>头像
>名称
>使用语言
的顺序修改其中一项
接口示例1: 修改用户名称
http
PUT /api/users/account/{userId} HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
// Request Body:
{
"name": "test1"
}
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code": 0,
"msg": "success"
}
接口示例2: 修改密码
http
PUT /api/users/account/{userId} HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
// Request Body:
{
"uuid": "7a292f10-9db4-4d7a-b8cb-f29fdfb86e58",
"password": "QziD1WxdWSJjAdsx0YrRnOxItgPVoZNNAQVsz0X4/rzNehqtPxtcaWU7UQD2N4dIvDkfhxv/0EUjLL3BssoRtw==",
"newPassword": "P5vmmFYGYRsasXx0/v3LauKN041OipE19xAPP+AKGDrNwkITzDlw5q0GFoy5jwH7tld8a3GJbvAZg9fqz1Pb+w=="
}
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code": 0,
"msg": "success"
}
接口示例3: 修改头像
http
PUT /api/users/account/{userId} HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
// Request Body:
{
"avatar": ""
}
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code": 0,
"msg": "success"
}
接口示例4: 修改使用语言
http
PUT /api/users/account/{userId} HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
// Request Body:
{
"options": {
"language": "en-US"
}
}
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code": 0,
"msg": "success"
}
用户是否持有可用资源
说明
用户是否持有可用资源
请求URL
http
GET /api/users/{userId}/available-resources HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
URL Path 参数
字段 | 类型 | 是否必须 | 说明 |
---|---|---|---|
userId | LONG | 是 | 修改用户的 id |
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
data | BOOLEAN | 用户是否持有可用资源 |
接口示例1: 用户是否持有可用资源
http
GET /api/users/{userId}/available-resources HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code": 0,
"data": true,
"msg": "success"
}
删除用户
说明
- 若用户拥有任意未删除或转移给其他用户的资源(应用、链接、数据集成、数据科学),则不可删除用户
请求URL
http
DELETE /api/users/{userId} HTTP/1.1
请求参数
URL 参数
字段 | 类型 | 是否必须 | 说明 |
---|---|---|---|
userId | LONG | 是 | 修改用户的 id |
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
data | OBJECT | 见用户结构说明。 |
接口示例1: 删除用户
http
DELETE /api/users/{userId} HTTP/1.1
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code": 0,
"msg": "success"
}
通过id查询用户
请求URL
http
GET /api/users/details/{userId} HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
URL Path 参数
字段 | 类型 | 是否必须 | 说明 |
---|---|---|---|
id | Long | 是 | 用户的 id |
request body 参数
无
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
data | OBJECT | 见用户结构说明。 |
接口示例:
http
GET /api/users/details/{userId} HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code": 0,
"msg": "success",
"data": {
"id": 2,
"name": "helloa",
"email": "helloa@163.com",
"description": "",
"avatar": "",
"enable": true,
"createdAt": "2019-11-15 15:18:36",
"lastLoginAt": "2020-09-16 11:49:38",
"userType": "internal",
"isDelete": false,
"loginName": "hello"
}
}
通过loginName查询用户
请求URL
http
POST /api/users/get-by-loginname HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
URL 参数
无
request body 参数
字段 | 类型 | 是否必须 | 说明 |
---|---|---|---|
loginName | STRING | 是 | 用户的 loginName |
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
data | OBJECT | 见用户结构说明。 |
接口示例:
http
POST /api/users/get-by-loginname HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
// Request Body:
{
"loginName": "helloa"
}
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code": 0,
"msg": "success",
"data": {
"id": 2,
"name": "helloa",
"email": "helloa@163.com",
"description": "",
"avatar": "",
"enable": true,
"createdAt": "2019-11-15 15:18:36",
"lastLoginAt": "2020-09-16 11:49:38",
"userType": "internal",
"isDelete": false,
"loginName": "hello"
}
}
通过email查询用户
请求URL
http
POST /api/users/get-by-email HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
URL 参数
无
request body 参数
字段 | 类型 | 是否必须 | 说明 |
---|---|---|---|
STRING | 是 | 用户的 email |
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
data | OBJECT | 见用户结构说明。 |
接口示例:
http
POST /api/users/get-by-email HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
// Request Body:
{
"email": "helloa@163.com"
}
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code": 0,
"msg": "success",
"data": {
"id": 2,
"name": "helloa",
"email": "helloa@163.com",
"description": "",
"avatar": "",
"enable": true,
"createdAt": "2019-11-15 15:18:36",
"lastLoginAt": "2020-09-16 11:49:38",
"userType": "internal",
"isDelete": false,
"loginName": "hello"
}
}
通过mobile查询用户
请求URL
http
POST /api/users/get-by-mobile HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
URL 参数
无
request body 参数
字段 | 类型 | 是否必须 | 说明 |
---|---|---|---|
mobile | STRING | 是 | 用户的 email |
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
data | OBJECT | 见用户结构说明。 |
接口示例:
http
POST /api/users/get-by-mobile HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
// Request Body:
{
"mobile": "13012344321"
}
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code": 0,
"msg": "success",
"data": {
"id": 2,
"name": "helloa",
"email": "helloa@163.com",
"description": "",
"avatar": "",
"mobile": "13012344321",
"enable": true,
"createdAt": "2019-11-15 15:18:36",
"lastLoginAt": "2020-09-16 11:49:38",
"userType": "internal",
"isDelete": false,
"loginName": "hello"
}
}
通过用户id获取用户组和组织机构
请求URL
http
GET /api/users/orgs-organizations?userId={userId} HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
URL 参数
无
request Query 参数
字段 | 类型 | 是否必须 | 说明 |
---|---|---|---|
userId | LONG | 是 | 用户的 id |
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
data | OBJECT | 包含用户组和树形组织架构 |
data.organizations | JSONOBJECT ARRAY | 见用户组结构说明 |
data.orgTree | JSONOBJECT | 见组织结构说明 |
data.orgTree.children | JSONOBJECT | 下级组织,见组织结构说明 |
接口示例:通过用户id获取用户组和组织机构
http
GET /api/users/orgs-organizations?userId={userId} HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code":0,
"msg":"success",
"data":{
"organizations":[
{
"id":6431,
"name":"API用户组",
"description":"API用户组",
"category":"NORMAL"
}
],
"orgTree":[
{
"id":1,
"name":"衡石QA测试",
"description":"",
"createdBy":11630,
"createdAt":"2023-07-12 15:23:48",
"updatedBy":11630,
"updatedAt":"2023-07-12 15:23:48",
"source":"dingtalk",
"code":"1",
"orderNo":1,
"children":[
{
"id":25,
"name":"测试部",
"description":"",
"createdBy":11630,
"createdAt":"2023-07-12 15:23:48",
"updatedBy":11630,
"updatedAt":"2023-07-12 15:23:48",
"parentId":1,
"source":"dingtalk",
"code":"490184122",
"parentCode":"1",
"orderNo":3,
"delete":false
}
],
"delete":false
}
]
}
}
通过 loginName 或者 email 查询用户(不推荐使用),4.5之后的版本将不再支持
请参考 通过loginName查询用户 通过email查询用户 通过mobile查询用户
请求URL
http
GET /api/users/by-unique-key/{loginName or email} HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
URL 参数
字段 | 类型 | 是否必须 | 说明 |
---|---|---|---|
loginName or email | STRING | 是 | 用户的 loginName 或者 email |
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
data | OBJECT | 见用户结构说明。 |
接口示例: 通过 loginName 或者 email 查询用户(不推荐使用)
http
GET /api/users/by-unique-key/{loginName or email} HTTP/1.1
Accept: application/json
// Response:
{
"version": "version@9a5e106#6730f0d",
"code": 0,
"msg": "success",
"data": {
"id": 2,
"name": "helloa",
"email": "helloa@163.com",
"description": "",
"avatar": "",
"enable": true,
"createdAt": "2019-11-15 15:18:36",
"lastLoginAt": "2020-09-16 11:49:38",
"userType": "internal",
"isDelete": false,
"loginName": "hello"
}
}
获取用户列表
请求URL
http
GET /api/users HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
Query 参数
字段 | 类型 | 是否必须 | 说明 |
---|---|---|---|
returnAvatar | BOOLEAN | 否 | 是否返回用户头像,默认为true |
returnAttr | BOOLEAN | 否 | 是否返回用户头像,默认为false |
q | STRING | 否 | 用户显示名或登录名(like查询) |
organizations | LONG | 否 | 用户组id |
roles | LONG | 否 | 用户角色id |
offset | INT | 否 | 分页偏移量 |
limit | INT | 否 | 分页大小 |
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
data | OBJECT | 见用户结构说明。 |
接口示例1: 获取用户列表
http
GET /api/users?offset=0&limit=100&q=test&roles=1&roles=2 HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code": 0,
"msg": "success",
"data": [
{
"id": 2,
"name": "test2",
"email": "anonymous@hengshi.com",
"description": "",
"avatar": "",
"enable": true,
"userType": "internal",
"loginName": "test2",
"config": {
"sys.email": {
"source": "SYSTEM_DEFINED",
"value": "anonymous@hengshi.com",
"type": "string"
},
"sys.login_name": {
"source": "SYSTEM_DEFINED",
"value": "test2",
"type": "string"
},
"sys.mobile": {
"source": "SYSTEM_DEFINED",
"type": "string"
},
"sys.id": {
"source": "SYSTEM_DEFINED",
"value": 2,
"type": "number"
},
"sys.loginName": {
"source": "SYSTEM_DEFINED",
"value": "test2",
"type": "string"
},
"m_names": {
"source": "USER_DEFINED",
"value": [
"盗梦空间",
"搏击俱乐部"
],
"type": "any"
},
"sys.name": {
"source": "SYSTEM_DEFINED",
"value": "test2",
"type": "string"
},
"n_name": {
"source": "USER_DEFINED",
"value": "饮食男女",
"type": "any",
"defaultValue": "搏击俱乐部"
}
},
"options": {},
"roles": [
{
"id": 1,
"name": "system admin",
"description": "system admin"
},
{
"id": 2,
"name": "data admin",
"description": "data admin"
},
{
"id": 3,
"name": "data analyst",
"description": "data analyst"
},
{
"id": 4,
"name": "data viewer",
"description": "data viewer"
}
],
"organizations": []
},
{
"id": 9,
"name": "test4",
"email": "anonymous@hengshi.com",
"description": "",
"avatar": "",
"enable": true,
"userType": "internal",
"loginName": "test4",
"config": {
"sys.email": {
"source": "SYSTEM_DEFINED",
"value": "anonymous@hengshi.com",
"type": "string"
},
"sys.login_name": {
"source": "SYSTEM_DEFINED",
"value": "test4",
"type": "string"
},
"sys.mobile": {
"source": "SYSTEM_DEFINED",
"type": "string"
},
"sys.id": {
"source": "SYSTEM_DEFINED",
"value": 9,
"type": "number"
},
"sys.loginName": {
"source": "SYSTEM_DEFINED",
"value": "test4",
"type": "string"
},
"sys.name": {
"source": "SYSTEM_DEFINED",
"value": "test4",
"type": "string"
}
},
"options": {},
"roles": [
{
"id": 1,
"name": "system admin",
"description": "system admin"
},
{
"id": 2,
"name": "data admin",
"description": "data admin"
},
{
"id": 3,
"name": "data analyst",
"description": "data analyst"
},
{
"id": 4,
"name": "data viewer",
"description": "data viewer"
}
],
"organizations": []
}
]
}
获取用户简单信息列表
请求URL
http
GET /api/users/simplify HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
无
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
data | OBJECT | 见用户结构说明。 |
接口示例1: 获取用户简单信息列表
http
GET /api/users/simplify HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code": 0,
"msg": "success",
"data": [
{
"id": 2,
"name": "test2",
"loginName": "test2",
"email":"anonymous@hengshi.com"
}
]
}
获得可被授权的用户列表
请求URL
http
GET /api/users/grantors HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
URL Query 参数
字段 | 类型 | 是否必须 | 说明 |
---|---|---|---|
act | STRING | 是 | 授权类型,可选值:collaborate(协作),publish(发布) |
resource | STRING | 是 | 资源类型,可选值:app(应用),connection(链接) |
说明
- 资源类型为
connection
时,授权类型不可为publish
- 当条件为
app
&collaborate
时,返回的时系统中拥有数据分析
角色的用户 - 当条件为
app
&publish
时,返回的时系统中拥有数据查看
角色的用户 - 当条件为
connection
&collaborate
时,返回的时系统中拥有数据分析
或数据管理
角色的用户
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
data | OBJECT | 见用户结构说明。 |
接口示例1: 获得可被授权的用户列表
http
GET /api/users/grantors?act=collaborate&resource=app HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code": 0,
"msg": "success",
"data": [
{
"id": 41,
"name": "test",
"email": "anonymous@hengshi.com",
"description": "",
"enable": true,
"loginName": "test",
"config": {},
"options": {}
},
{
"id": 2,
"name": "test2",
"email": "anonymous@hengshi.com",
"description": "",
"enable": true,
"loginName": "test2",
"config": {
"m_names": "[\"盗梦空间\",\"搏击俱乐部\"]",
"n_name": "饮食男女"
},
"options": {}
},
{
"id": 9,
"name": "test4",
"email": "anonymous@hengshi.com",
"description": "",
"enable": true,
"loginName": "test4",
"config": {},
"options": {}
}
]
}
新增用户组
新增用户组。
请求URL
http
POST /api/organizations HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
URL 参数
无
request body 参数
返回对象的格式说明
接口示例1: 新增用户组
http
POST /api/organizations HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
// Request Body:
{
"name":"zjj_group",
"email":"anonymous@hengshi.com",
"description":"desc",
"users":[
{
"id":800
}
]
}
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code":0,
"msg":"success",
"data":{
"id":36,
"name":"zjj_group",
"email":"anonymous@hengshi.com",
"description":"desc",
"createdBy":1,
"createdAt":"2019-12-18 20:44:47",
"updatedBy":1,
"updatedAt":"2019-12-18 20:44:47",
"users":[
{
"id":800,
"userAttributes":{
"sys.id":800
}
}
]
}
}
获取所有用户组
请求URL
http
GET /api/organizations/simplify HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
无
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
data | OBJECT | 参数的共同结构见用户组结构说明。 |
接口示例1: 获取用户组列表
http
GET /api/organizations/simplify HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "5.4-SNAPSHOT@@git.commit.id.abbrev@#a98c540",
"code": 0,
"msg": "success",
"data": [
{
"id": 0,
"name": "ALL_USERS"
},
{
"id": 2,
"name": "g1"
},
{
"id": 4,
"name": "oy"
}
],
"chartDataStartTimeMillis": 0
}
获取用户组列表
请求URL
http
GET /api/organizations HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
URL 参数
字段 | 类型 | 是否必须 | 说明 |
---|---|---|---|
orderBy | STRING | 否 | 排序字段 |
orderType | STRING | 否 | 排序方式:ASC 、DESC |
q | STRING | 否 | 用户组名称模糊查询参数 |
offset | LONG | 否 | 偏移量 |
limit | LONG | 否 | 分页限制条数 |
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
data | OBJECT | 参数的共同结构见用户组结构说明。 |
接口示例1: 获取用户组列表
http
GET /api/organizations?offset=1&limit=3 HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code": 0,
"msg": "success",
"data": [
{
"id": 1,
"name": "ALL_USERS",
"description": "System organization for all users",
"category": "ALL_USERS",
"userCount": 0,
"users": []
},
{
"id": 3,
"name": "o4",
"description": "",
"category": "NORMAL",
"userCount": 0,
"users": []
},
{
"id": 4,
"name": "o42",
"description": "",
"category": "NORMAL",
"userCount": 0,
"users": []
}
]
}
根据ID获取用户组
请求URL
http
GET /api/organizations/{organizationId} HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
无
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
data | OBJECT | 参数的共同结构见用户组结构说明。 |
接口示例1: 根据ID获取用户组
http
GET /api/organizations/2 HTTP/1.1
Accept: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code": 0,
"msg": "success",
"data": {
"id": 2,
"name": "o1",
"description": "",
"category": "NORMAL",
"userCount": 2,
"users": [
{
"id": 2,
"name": "test2",
"email": "anonymous@hengshi.com",
"description": ""
},
{
"id": 9,
"name": "test4",
"email": "anonymous@hengshi.com",
"description": ""
}
]
}
}
修改用户组
修改用户组。
请求URL
http
PUT /api/organizations/{organizationId} HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
请求参数
URL 参数
字段 | 类型 | 是否必须 | 说明 |
---|---|---|---|
organizationId | LONG | 是 | 修改用户组的 id |
request body 参数
返回对象的格式说明
接口示例1: 修改用户组
http
PUT /api/organizations/${organizationId} HTTP/1.1
Content-Type: application/json
Cookie: csrf=183f1c4...; sid=26ee552d...; _USER_SESSION_ID=f2a01083...
// Request Body:
{
"name":"zjj_group",
"email":"anonymous@hengshi.com",
"description":"desc",
"users":[
{
"id":800
}
]
}
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code":0,
"msg":"success",
"data":{
"id":36,
"name":"zjj_group",
"email":"anonymous@hengshi.com",
"description":"desc",
"updatedBy":1,
"updatedAt":"2019-12-18 20:46:51",
"users":[
{
"id":800,
"userAttributes":{
"$user.config.id":800,
"$user.id":800
}
}
]
}
}
删除用户组
删除用户组。
请求URL
http
DELETE /api/organizations/{organizationId} HTTP/1.1
请求参数
URL 参数
字段 | 类型 | 是否必须 | 说明 |
---|---|---|---|
organizationId | LONG | 是 | 修改用户组的 id |
request body 参数
无
返回对象的格式说明
字段 | 类型 | 说明 |
---|---|---|
version | STRING | 当前系统版本哈希值 |
接口示例1: 删除用户组
http
DELETE /api/organizations/${organizationId} HTTP/1.1
http
HTTP/1.1 200 Ok
Content-Type: application/json
{
"version": "version@9a5e106#6730f0d",
"code":0,
"msg":"success"
}