Как я могу иметь одно поле для обновления / изменения другого? - PullRequest
0 голосов
/ 22 октября 2018

Я хотел бы, чтобы поля были разрешены другим полем.

У меня есть список, сгенерированный в соответствии с некоторыми аргументами, и я хотел бы обновить общее поле

Мой подход, вероятно, неверен.

Очевидно, что я пытаюсь избежать повторного выполнения того же запроса к базе данных и пропускания фильтра до уровня в строке запроса.

Итак, предположим следующий тип рубина для моего запроса:

Types::PostListType = GraphQL::ObjectType.define do
    name 'PostList'

    field :total, !types.Int, default_value: 0 # <-- this is what I'd like to update in :posts resolution
    field :page, !types.Int, default_value: 0 # <-- this is what I'd like to update in :posts resolution
    field :per_page, !types.Int, default_value: 0 # <-- this is what I'd like to update in :posts resolution

    field :posts, types[Types::PostType] do
        argument :page, types.Int, default_value: 1
        argument :per_page, types.Int, default_value: 10 # <-- also need a limit here (hence why I need a field to tell what's been used in the end)
        argument :filter, types.String, default_value: ''
        resolve ->(user, *_args) {
            posts = function_to_filter(args[:filter])
            # how do I update total with posts.count here?
            posts.paginate(page: args[:page], per_page: args[:per_page])
            # how do I update per_page and page?
        }
    end

end

Мой запрос выглядит примерно так:

query ProspectList {
  posts(filter:"example", page: 2) {
    total
    page
    per_page
    posts {
      id
      ...
    }
  }
}

1 Ответ

0 голосов
/ 29 октября 2018

То, что вы хотите - это возвращать сообщения с итогом, страницей, на_страницу без повторного выполнения запроса к базе данных.

Я бы хотел изменить определение запроса, потому что посты, итоги, страницы, на_страницу должны объединяться по типу.

вот так: Типы :: PostListType

Types::PostListType = GraphQL::ObjectType.define do
  name 'PostList'

  field :total, !types.Int
  field :page, !types.Int
  field :per_page, !types.Int
  field :posts, types[Types::PostType]
end

Затем вернуть объект в разрешении, который содержит сообщений, всего, страницы, на_страницу

Types::QueryType = GraphQL::ObjectType.define do
  name "Query"

  field :postlist, Types::PostListType do
    argument :page, types.Int, default_value: 1
    argument :per_page, types.Int, default_value: 1
    argument :filter, types.String
    resolve ->(_obj, args, _ctx) {
      result = Post.paginate(page: args[:page], per_page: args[:per_page])
      Posts = Struct.new(:posts, :page, :per_page, :total)
      Posts.new(
        result,
        args[:page],
        args[:per_page],
        result.total_entries
      )
    }
  end
end

Также возможно определить объект и вернуть. Wrapper :: PostList

module Wrapper
  class PostList
    attr_accessor :posts, :total, :page, :per_page
    def initialize(posts, page, per_page)
      @posts = posts
      @total = posts.total_entries
      @page = page
      @per_page = per_page
    end
  end
end

...
  field :postlist, Types::PostListType do
    argument :page, types.Int, default_value: 1
    argument :per_page, types.Int, default_value: 1
    argument :filter, types.String
    resolve ->(_obj, args, _ctx) {
      Wrapper::PostList.new(Post.paginate(page: args[:page], per_page: args[:per_page]), args[:page], args[:per_page])
    }
...
...