gitlab-org--gitlab-foss/spec/graphql
Luke Duncalfe ccb4edbca1 Improve GraphQL Authorization DSL
Previously GraphQL field authorization happened like this:

    class ProjectType
      field :my_field, MyFieldType do
        authorize :permission
      end
    end

This change allowed us to authorize like this instead:

    class ProjectType
      field :my_field, MyFieldType, authorize: :permission
    end

A new initializer registers the `authorize` metadata keyword on GraphQL
Schema Objects and Fields, and we can collect this data within the
context of Instrumentation like this:

    field.metadata[:authorize]

The previous functionality of authorize is still being used for
mutations, as the #authorize method here is called at during the code
that executes during the mutation, rather than when a field resolves.

https://gitlab.com/gitlab-org/gitlab-ce/issues/57828
2019-02-26 10:22:12 +13:00
..
features Improve GraphQL Authorization DSL 2019-02-26 10:22:12 +13:00
mutations Add mutation toggling WIP state of merge requests 2018-07-25 18:37:12 +02:00
resolvers Add GraphQL filters for issuables (state, labels, time fields) 2019-02-21 09:40:49 +01:00
types Add GraphQL filters for issuables (state, labels, time fields) 2019-02-21 09:40:49 +01:00
gitlab_schema_spec.rb Add mutation toggling WIP state of merge requests 2018-07-25 18:37:12 +02:00