aws-graphql@connection没有按预期返回数组



我有一个graphql模型如下(一个用户可以有很多帖子1:m(

type User @model {
id: ID!
fullName: String!
emailAddress: String!
posts: [Post] @connection(name: "UserPostConnection")
}
type Post @model {
id: ID!
text: String!
user: User @connection(name: "UserPostConnection")
createdAt: String
updatedAt: String
}

我正试图返回特定用户的所有帖子,如下所示:

let queryInput = GetUserQuery(id: "879db4f2-1dad-47b9-b70d-8bca15bf2549")
appSyncClient?.fetch(query: queryInput, cachePolicy: .fetchIgnoringCacheData) { (result, error) in
print(result?.data?.getUser?.posts)
}
}        

然而,结果不是返回一个数组,而是返回一个可选的:

Optional(AWSStackSocial.GetUserQuery.Data.GetUser.Post(snapshot: ["__typename": Optional("ModelPostConnection"), "nextToken": nil]))

我已经确认a(用户存在,b(帖子也存在。

在AWS上:

query {
getUser(id: "879db4f2-1dad-47b9-b70d-8bca15bf2549") {
id 
posts {
items {
id
}
}
}
}

输出:

{
"data": {
"getUser": {
"id": "879db4f2-1dad-47b9-b70d-8bca15bf2549",
"posts": {
"items": [
{
"id": "04c4b571-6e92-4745-9a40-1a67a9d49d77"
},
{
"id": "0f44fe6e-4e15-4a8c-b591-555e8fa1f60e"
},
{
"id": "60c18c40-fea3-4ff3-8b21-df6857703dd2"
}
]
}
}
}
}
我找到了答案。放大GraphQL的默认深度级别为2,因此需要将其更改为3。这可以通过改变最大深度来实现:
amplify codegen configure

根据定义,模型中任何没有所需后缀(!(的东西都是可选的,无论它是否存在。你必须防止它是nil,因为它被定义为可以nil。如果你拥有这个模型,你可以根据需要更改它们(我不建议这样做!(。否则,在处理它们时,您将不得不简单地打开包装。

guard let user = result?.data?.getUser, let posts = user.posts else { throw NoPostsError }

相关内容

  • 没有找到相关文章

最新更新