Search code examples
typescriptamazon-web-servicesgraphqlaws-amplifyaws-amplify-cli

Amplify API GraphQL Circular Resources Dependency


I'm working with existing amplify graphql api that is in production, the task I was given was to move the amplify to different aws account for development purposes. I've spent about 3 days to get things right but when I do update the schema for graphql I got an error on my cli stated

✖ An error occurred when pushing the resources to the cloud
🛑 An error occurred during the push operation: ["Index: 1 State: {\"deploy\":\"waitingForDeployment\"} Message: Resource is not in the state stackUpdateComplete"]

looking more in cloud formation event log, it said

Circular dependency between resources: [BuildingAdminBuilding, BuildingAdmin, ConnectionStack, CustomResourcesjson]

the mentioned resources are defined as

type BuildingAdminBuilding @model(subscriptions: null) @aws_cognito_user_pools @auth(rules: [
  {
    provider: apiKey, allow: public, operations: [read, create, update, delete]
  },
  {
    # TODO TEMP ONLY - FOR TESTING UNTIL PROPER GROUPS ARE SETUP
    provider: userPools, allow: private, operations: [read, create, update, delete]
  },
]) {
  id: ID!
  buildingAdmin: BuildingAdmin! @auth(rules: [
    {
      provider: apiKey, allow: public, operations: [read, create, update, delete]
    },
    {
      # TODO TEMP ONLY - FOR TESTING UNTIL PROPER GROUPS ARE SETUP
      provider: userPools, allow: private, operations: [read, create, update, delete]
    },
  ]) @connection(name: "BuildingAdminBuilding")
  # building: Building! @connection(name: "BuildingBuildingAdmin") @auth(rules: [
  #   {
  #     provider: apiKey, allow: public, operations: [read, create, update, delete]
  #   },
  #   {
  #     # TODO TEMP ONLY - FOR TESTING UNTIL PROPER GROUPS ARE SETUP
  #     provider: userPools, allow: private, operations: [read, create, update, delete]
  #   },
  # ])
}

type BuildingAdmin
@model(subscriptions: null)
@aws_cognito_user_pools @auth(rules: [
  {
    provider: apiKey, allow: public, operations: [read, create, update, delete]
  },
  {
    provider: userPools, allow: private, operations: [read, create, update, delete]
  }
]) {
  id: ID!
  user: User @connection(name: "BuildingAdminUser")
  buildings: [BuildingAdminBuilding] @auth(rules: [
    {
      provider: apiKey, allow: public, operations: [read, create, update, delete]
    },
    {
      # TODO TEMP ONLY - FOR TESTING UNTIL PROPER GROUPS ARE SETUP
      provider: userPools, allow: private, operations: [read, create, update, delete]
    },
  ])  @connection(name: "BuildingAdminBuilding")
}

I'm not sure why it triggers circular dependency, at first I thought it was the attributes type but other model works ok. do you guys have any ideas?


Solution

  • It might not be a solution, but for me, redoing all the query is the solution and tries to push table one by one in a specific order to amplify. The order was to push type A, then push pivot table AB with only property that have connection to A, then push B, then update pivot AB with property that have connection to B.