-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmulti_v2.graphql
86 lines (80 loc) · 1.68 KB
/
multi_v2.graphql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
# This "input" configures a global authorization rule to enable public access to
# all models in this schema. Learn more about authorization rules here: https://docs.amplify.aws/cli/graphql/authorization-rules
# input AMPLIFY { globalAuthRule: AuthRule = { allow: public } } # FOR TESTING ONLY!
type Movie
@model
@auth(
rules: [
{
allow: private
provider: iam
operations: [create, read, update, delete]
}
]
) {
year: Int! @primaryKey(sortKeyFields: ["title"])
title: String!
}
type User
@model
@auth(
rules: [
{
allow: private
provider: iam
operations: [create, read, update, delete]
}
]
) {
id: ID!
name: String!
email: String!
organizationID: ID @index(name: "orgID")
organization: Org @belongsTo(fields: ["organizationID"])
managerID: ID @index(name: "manID")
manager: [User] @hasMany(fields: ["managerID"])
}
type Org
@model
@auth(
rules: [
{
allow: private
provider: iam
operations: [create, read, update, delete]
}
]
) {
id: ID!
name: String!
user: [User] @hasMany(indexName: "orgID", fields: ["id"])
movie: [Movie] @hasMany(fields: ["id"])
}
# type Role
# @model
# @auth(
# rules: [
# {
# allow: private
# provider: iam
# operations: [create, read, update, delete]
# }
# ]
# ) {
# name: String! @primaryKey
# }
# type UserRoleOrg
# @model
# @auth(
# rules: [
# {
# allow: private
# provider: iam
# operations: [create, read, update, delete]
# }
# ]
# ) {
# user: User! @hasOne
# role: Role! @hasOne
# org: Org! @hasOne
# }