Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
程序yang
unidocs-zh
提交
6a81e213
U
unidocs-zh
项目概览
程序yang
/
unidocs-zh
与 Fork 源项目一致
Fork自
DCloud / unidocs-zh
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
unidocs-zh
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
6a81e213
编写于
12月 01, 2022
作者:
雪洛
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
docs: update jql-schema-ext
上级
cf369c52
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
66 addition
and
0 deletion
+66
-0
docs/uniCloud/jql-schema-ext.md
docs/uniCloud/jql-schema-ext.md
+66
-0
未找到文件。
docs/uniCloud/jql-schema-ext.md
浏览文件 @
6a81e213
...
...
@@ -79,6 +79,7 @@ ext.js里引入公共模块的机制:
|field |array
<
string
>
|- |read必备 |当前请求访问的字段列表(见下方说明) |
|addDataList|array
<
object
>
|- |create必备 |新增操作传入的数据列表(见下方说明) |
|updateData |object |- |update必备 |更新操作传入的数据(见下方说明) |
|clientInfo |object |- |必备 |客户端信息,详见:
[
clientInfo
](
cf-functions.md#get-client-infos
)
|
#### where
...
...
@@ -262,6 +263,71 @@ module.exports {
}
}
}
```
### 在触发器内使用jql语法@using-jql-in-schema
jql触发器内可以使用jql语法操作数据库。
我们现在增加一个阅读记录表,schema如下
为了不增加示例的复杂度,所有权限均设置为true,实际项目中切勿随意模仿。
```
js
// article.schema.ext.js
{
"
bsonType
"
:
"
object
"
,
"
required
"
:
[
"
title
"
,
"
content
"
],
"
permission
"
:
{
"
read
"
:
true
,
"
create
"
:
true
,
"
update
"
:
true
,
"
delete
"
:
true
},
"
properties
"
:
{
"
_id
"
:
{
"
bsonType
"
:
"
string
"
},
"
article_id
"
:
{
"
bsonType
"
:
"
string
"
,
"
foreignKey
"
:
"
article._id
"
},
"
reader_id
"
:
{
"
bsonType
"
:
"
string
"
,
"
foreignKey
"
:
"
uni-id-users._id
"
,
"
forceDefaultValue
"
:
{
"
$env
"
:
"
uid
"
}
}
}
}
```
使用jql语法可以自动验证客户端身份,仍以上述article表为例,在afterRead触发器内插入阅读记录。此时会将读者id插入到reader_id字段
```
js
module
.
exports
=
{
trigger
:
{
afterRead
:
async
function
({
where
,
field
,
clientInfo
}
=
{})
{
const
id
=
where
&&
where
.
_id
if
(
typeof
id
!==
'
string
'
||
!
field
.
includes
(
'
content
'
))
{
return
}
const
dbJQL
=
uniCloud
.
databaseForJQL
({
clientInfo
})
await
dbJQL
.
collection
(
'
article-view-log
'
)
.
add
({
article_id
:
id
,
reader_id
:
dbJQL
.
getCloudEnv
(
'
$cloudEnv_uid
'
)
})
}
}
```
### 注意事项
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录