AWS Amplify AppSync订阅:数据返回空

如何解决AWS Amplify AppSync订阅:数据返回空

我正在开发我的Amplify应用程序,并且我的订阅可以正常使用:

graphql:

type Item @model(subscriptions: null)
    @auth(rules: [
        {allow: owner},{allow: groups,groups: ["Admin"],operations: [create,update,read,delete] }
  ]) {
  id: ID!
  name: String
  files: String
}


type Subscription {
    itemUpdated(id: ID): Item @aws_subscribe(mutations: ["updateItem"])
}

js:

const handleSubscription = (data) => {
  if (data.value.data.itemUpdated) {
    setItemObj(data.value.data.itemUpdated);
  }
};
useEffect(() => {
  const subscription = API.graphql(
      graphqlOperation(subscriptions.itemUpdated,{
        id,}),).subscribe({
      next: handleSubscription,});
    return () => subscription.unsubscribe();
  },[]);

在handleSubscription方法中,当应用对商品进行突变调用时,返回数据(data.value.data.itemUpdated)将具有正确的数据。

现在,由于我不清楚的原因,当发生突变时,我仍然可以看到订阅事件触发,但是返回数据(data.value.data.itemUpdated)始终为空。

我已尝试按照This Question的建议从graphql模式的auth字段中删除{allow: owner}规则-没用(除了:我仍然很好奇为什么这首先会起作用,但我没有足够的代表对此发表评论。)

在撰写本文时,我的想法是我将尝试创建一个没有{allow: owner}规则的新商品,然后再试一次,如果可行,我将进行报告,但是我的问题将转向问为什么和然后问我如何确保物品仍是所有者专有的?最后,我几乎可以肯定的是,我也有{allow: owner}规则在起作用的情况,但是我可能会误会。

我也尝试过:

  • 已测试过更新不同的Item字段

  • 让扩增cli重建我的graphql js文件

  • 更改了代码,即

    • 删除了return () => subscription.unsubscribe();
    • 使输入更加具体API.graphql(graphqlOperation(subscriptions.itemUpdated,{input: { id: id },})(我相信这没关系,但我想尝试。)

我只是不确定这里发生了什么。一切似乎都这么简单,一定是我想念的愚蠢……我知道最终我会弄清楚的,但是我想在这里找人,以防万一。

版本:

  • "aws-amplify": "^3.0.24"
  • "@aws-amplify/ui-react": "^0.2.15"
  • "react": "^16.13.1"
  • amplify-cli: 4.29.0

请让我知道是否遗漏了任何重要信息。预先感谢您的帮助。

解决方法

好吧..就像我想的那样愚蠢。我很浪费时间!

library(shiny)
library(shinyWidgets)
# ui object

ui <- fluidPage(
  titlePanel(p("Spatial app",style = "color:#3474A7")),sidebarLayout(
    sidebarPanel(
      uiOutput("inputp1"),numericInput("num",label = ("value"),value = 1),#Add the output for new pickers
      uiOutput("pickers"),actionButton("button","Update")
    ),mainPanel(
      DTOutput("table")
    )
  )
)

# server()
server <- function(input,output,session) {
  DF1 <- reactiveValues(data=NULL)
  
  dt <- reactive({
    name<-c("John","Jack","Bill")
    value1<-c(2,4,6)
    dt<-data.frame(name,value1)
  })
  
  observe({
    DF1$data <- dt()
  })

  output$inputp1 <- renderUI({
    pickerInput(
      inputId = "p1",label = "Select Column headers",choices = colnames( dt()),multiple = TRUE,options = list(`actions-box` = TRUE)
    )
  })

  observeEvent(input$p1,{
    #Create the new pickers
    output$pickers<-renderUI({
      dt1 <- DF1$data
      div(lapply(input$p1,function(x){
        if (is.numeric(dt1[[x]])) {
          sliderInput(inputId=x,label=x,min=min(dt1[[x]]),max=max(dt1[[x]]),value=c(min(dt1[[x]]),max(dt1[[x]])))
        }else { # if (is.factor(dt1[[x]])) {
          selectInput(
            inputId = x,# The col name of selected column
            label = x,# The col label of selected column
            choices = dt1[,x],# all rows of selected column
            multiple = TRUE
          )
        }

      }))
    })
  })


  dt2 <- eventReactive(input$button,{
    req(input$num)
    dt <- DF1$data ## here you can provide the user input data read inside this observeEvent or recently modified data DF1$data
    dt$value1<-dt$value1*isolate(input$num)

    dt
  })
  observe({DF1$data <- dt2()})
  
  output_table <- reactive({
    req(input$p1,sapply(input$p1,function(x) input[[x]]))
    dt_part <- dt2()
    for (colname in input$p1) {
      if (is.factor(dt_part[[colname]]) && !is.null(input[[colname]])) {
        dt_part <- subset(dt_part,dt_part[[colname]] %in% input[[colname]])
      } else {
        if (!is.null(input[[colname]][[1]])) {
          dt_part <- subset(dt_part,(dt_part[[colname]] >= input[[colname]][[1]]) & dt_part[[colname]] <= input[[colname]][[2]])
        }
      }
    }
    dt_part
  })
  
  output$table<-renderDT({
    output_table()
  })

}

# shinyApp()
shinyApp(ui = ui,server = server)

它是API.graphql( graphqlOperation(subscriptions.itemUpdated,{ id: Id,}),).subscribe({ next: handleSubscription,}); 参数。我之前将id: Id,变量命名为Id,并且js允许将id短接到{name: name}-我必须更改了{ name }变量并直接转到{ {1}},这是订阅的错误语法。

真正的骨头动作,我感到很尴尬。即使在测试过程中,也可以从不良的命名中学到好教训。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-