From ba67dd4f6797d86e5f8c9f0b562c53258d7deba7 Mon Sep 17 00:00:00 2001 From: Tim Schmelter Date: Tue, 7 Jan 2025 12:02:45 -0800 Subject: [PATCH] [amplify-data] feat: add gen1 manyToMany auth discussion (#8172) * feat: add gen1 manyToMany auth discussion * Fix directive format Co-authored-by: Rene Brandel <4989523+renebrandel@users.noreply.github.com> --------- Co-authored-by: Rene Brandel <4989523+renebrandel@users.noreply.github.com> --- .../customize-authorization-rules/index.mdx | 52 +++++++++++++++++++ .../graphqlapi/data-modeling/index.mdx | 6 +++ 2 files changed, 58 insertions(+) diff --git a/src/pages/gen1/[platform]/build-a-backend/graphqlapi/customize-authorization-rules/index.mdx b/src/pages/gen1/[platform]/build-a-backend/graphqlapi/customize-authorization-rules/index.mdx index 5baab1fa45b..cce6a690e1f 100644 --- a/src/pages/gen1/[platform]/build-a-backend/graphqlapi/customize-authorization-rules/index.mdx +++ b/src/pages/gen1/[platform]/build-a-backend/graphqlapi/customize-authorization-rules/index.mdx @@ -860,6 +860,58 @@ Refer to the [sample code](/gen1/[platform]/build-a-backend/graphqlapi/connect-f +### Authorizing `@manyToMany` relationships + +Under the hood, the [`@manyToMany` directive](/gen1/[platform]/build-a-backend/graphqlapi/data-modeling/#many-to-many-relationship) will create a "join table" named after the `relationName` to facilitate the many-to-many relationship. The authorization rules that Amplify applies to the "join table" it creates are a union of the authorization rules of the individual models in the many-to-many relationship. + +For example, consider a schema in which the owner of a `Post` (protected by an `owner` rule) can apply `Tag`s that are created by a system admin (protected by a `groups` rule). Behind the scenes, Amplify creates a `PostTags` table with both `owner` and `groups` auth: + +```graphql +type Post + @model + @auth( + rules: [ + { allow: owner } + ] + ) { + id: ID! + title: String! + content: String + tags: [Tag] @manyToMany(relationName: "PostTags") +} + +type Tag + @model + @auth( + rules: [ + { allow: groups, groups: ["admins"] } + ] + ) { + id: ID! + label: String! + posts: [Post] @manyToMany(relationName: "PostTags") +} + +### CREATED BEHIND THE SCENES +type PostTags + @model + @auth( + rules: [ + { allow: owner } + { allow: groups, groups: ["admins"] } + ] + ) { + id: ID! + postId: ID! + tagId: ID! + post: Post! + tag: Tag! + owner: String +} +``` + +For more control over the join table's authorization rules, you can create the join table explicitly, linking it to each model with a `@hasMany`/`@belongsTo` relationship, and set appropriate auth rules for your application. + ### How it works Definition of the `@auth` directive: diff --git a/src/pages/gen1/[platform]/build-a-backend/graphqlapi/data-modeling/index.mdx b/src/pages/gen1/[platform]/build-a-backend/graphqlapi/data-modeling/index.mdx index 50778e981c1..005742eae9d 100644 --- a/src/pages/gen1/[platform]/build-a-backend/graphqlapi/data-modeling/index.mdx +++ b/src/pages/gen1/[platform]/build-a-backend/graphqlapi/data-modeling/index.mdx @@ -793,6 +793,12 @@ const posts = listPostsResult.data.listPosts; const postTags = posts[0].tags; // access tags from post ``` + + +**Important**: The authorization rules that Amplify applies to the "join table" it creates are a union of the authorization rules of the individual models in the many-to-many relationship. See [this discussion](/gen1/[platform]/build-a-backend/graphqlapi/customize-authorization-rules/#authorizing-manytomany-relationships) for more context. + + + ## Assign default values for fields You can use the `@default` directive to specify a default value for optional [scalar type fields](https://docs.aws.amazon.com/appsync/latest/devguide/scalars.html) such as `Int`, `String`, and more.