Skip to content

Commit

Permalink
fix(GraphQL): Apply auth rules on type having @dgraph directive (#5702)…
Browse files Browse the repository at this point in the history
… (#5863)

Auth rules were not applied on type having @dgraph directive because they were stored in authRules map corresponding to Graphql type name and was fetched with Dgraph type name when rewriting the query.

(cherry picked from commit 8562311)
  • Loading branch information
Arijit Das authored Jul 9, 2020
1 parent fc72c53 commit 5ee54db
Show file tree
Hide file tree
Showing 4 changed files with 129 additions and 1 deletion.
86 changes: 86 additions & 0 deletions graphql/e2e/auth/auth_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,11 @@ type Project struct {
Columns []*Column `json:"columns,omitempty"`
}

type Student struct {
Id string `json:"id,omitempty"`
Email string `json:"email,omitempty"`
}

type TestCase struct {
user string
role string
Expand Down Expand Up @@ -147,6 +152,87 @@ func getJWT(t *testing.T, user, role string) http.Header {
return h
}

func (s Student) deleteByEmail(t *testing.T) {
getParams := &common.GraphQLParams{
Query: `
mutation delStudent ($filter : StudentFilter!){
deleteStudent (filter: $filter) {
numUids
}
}
`,
Variables: map[string]interface{}{"filter": map[string]interface{}{
"email": map[string]interface{}{"eq": s.Email},
}},
}
gqlResponse := getParams.ExecuteAsPost(t, graphqlURL)
require.Nil(t, gqlResponse.Errors)
}

func (s Student) add(t *testing.T) {
mutation := &common.GraphQLParams{
Query: `
mutation addStudent($student : AddStudentInput!) {
addStudent(input: [$student]) {
numUids
}
}`,
Variables: map[string]interface{}{"student": s},
}
result := `{"addStudent":{"numUids": 1}}`
gqlResponse := mutation.ExecuteAsPost(t, graphqlURL)
common.RequireNoGQLErrors(t, gqlResponse)
require.JSONEq(t, result, string(gqlResponse.Data))
}

func TestAuthWithDgraphDirective(t *testing.T) {
students := []Student{
{
Email: "[email protected]",
},
{
Email: "[email protected]",
},
}
for _, student := range students {
student.add(t)
}

testCases := []TestCase{{
user: students[0].Email,
role: "ADMIN",
result: `{"queryStudent":[{"email":"` + students[0].Email + `"}]}`,
}, {
user: students[0].Email,
role: "USER",
result: `{"queryStudent" : []}`,
}}

queryStudent := `
query {
queryStudent {
email
}
}`

for _, tcase := range testCases {
t.Run(tcase.role+"_"+tcase.user, func(t *testing.T) {
queryParams := &common.GraphQLParams{
Query: queryStudent,
Headers: getJWT(t, tcase.user, tcase.role),
}
gqlResponse := queryParams.ExecuteAsPost(t, graphqlURL)
common.RequireNoGQLErrors(t, gqlResponse)
require.JSONEq(t, tcase.result, string(gqlResponse.Data))
})
}

// Clean up
for _, student := range students {
student.deleteByEmail(t)
}
}

func TestAuthRulesWithMissingJWT(t *testing.T) {
testCases := []TestCase{
{name: "Query non auth field without JWT Token",
Expand Down
11 changes: 11 additions & 0 deletions graphql/e2e/auth/schema.graphql
Original file line number Diff line number Diff line change
Expand Up @@ -511,3 +511,14 @@ type Review @auth() {
comment: String!
}

type Student @dgraph(type: "is7sowSm")
@auth(query: { and : [ {rule: """
query($USER: String!) {
queryStudent(filter: {email: { eq: $USER}}) {
__typename
}
}
"""},{ rule: "{$ROLE: { eq: \"ADMIN\" }}"}]}) {
id: ID!
email: String! @dgraph(pred: "IOw80vnV") @search(by: [hash])
}
31 changes: 31 additions & 0 deletions graphql/resolve/auth_query_test.yaml
Original file line number Diff line number Diff line change
@@ -1,3 +1,34 @@
- name: "Auth query with @dgraph pred."
gqlquery: |
query {
queryStudent {
email
}
}
role: "ADMIN"
dgquery: |-
query {
queryStudent(func: uid(Student1)) @filter(uid(Student2)) {
email : IOw80vnV
dgraph.uid : uid
}
Student1 as var(func: type(is7sowSm))
Student2 as var(func: uid(Student1)) @filter(eq(IOw80vnV, "user1")) @cascade
}
- name: "Auth query with @dgraph pred (Test RBAC)."
gqlquery: |
query {
queryStudent {
email
}
}
role: "USER"
dgquery: |-
query {
queryStudent()
}
- name: "Auth with deep get query."
gqlquery: |
query {
Expand Down
2 changes: 1 addition & 1 deletion graphql/schema/wrappers.go
Original file line number Diff line number Diff line change
Expand Up @@ -1284,7 +1284,7 @@ func (m *mutation) IsAuthQuery() bool {
}

func (t *astType) AuthRules() *TypeAuth {
return t.inSchema.authRules[t.Name()]
return t.inSchema.authRules[t.DgraphName()]
}

func (t *astType) Field(name string) FieldDefinition {
Expand Down

0 comments on commit 5ee54db

Please sign in to comment.