我想我有你的问题的答案,但我也有一个关于 AWS Amplifycodegen
查询、突变等的类似问题。如果你查看在~/graphql
文件夹内生成的代码,你会发现一个与此类似的声明文件:
export const listOrganizations = `query ListOrganizations(
$filter: ModelOrganizationFilterInput
$limit: Int
$nextToken: String
) {
listOrganizations(filter: $filter, limit: $limit, nextToken: $nextToken) {
items {
id
name
address
}
nextToken
}
}
`;
您可以在此处看到ListOrganizations
查询的第一个参数(在您的情况下为ListTodos
查询)的第一个参数为filter: $filter
。到目前为止,我已经发现您可以通过执行以下操作来修改此查询...
API.graphql(graphqlOperation(queries.listTodos, {
filter: {
status: {
eq: "completed"
}
}
})));
这应该过滤掉所有 Todo,除了它们status
等于 的那些completed
。那我遇到的问题是,我想启用不同级别的访问控制与的Cognito用户池组,使得任何人都Admin
可以查看@model
还有@owner
。我能够使用@auth
转换器使这一切正常工作,但现在我的问题是在某些屏幕上,我只想显示属于该owner
实体的某些实体,并且因为我也是Admin
,所以 API 默认为我提供所有内容. 我想使用这个@filter
或ModelOrganizationFilterInput
只给我我是所有者的数据。我发现这样做的唯一方法是添加owner
字段到我的架构,但是 API 总是提供所有者字段,我想过滤掉该字段。
我可以在这里找到关于aws-amplify
API
和graphqlOperation
方法的唯一文档:https : //aws-amplify.github.io/docs/js/api但示例并不多,它们也没有展示 API 的工作原理在客户端上。我被困住了。