graphql-pro

Breaking Changes

Deprecations

New Features

1.29.2 (4 Sept 2024)

  • Subscriptions: show broadcast subscriber count in dashboard (Pusher requires "subscription count" to be turned on and use ... show_broadcast_subscribers_count: true)

1.29.1 (29 Aug 2024)

  • OperationStore: Accept a context: in #add

1.29.0 (28 Aug 2024)

  • Subscriptions: use a single Pusher or Ably channel to deliver broadcast payloads to subscribers
  • Dashboard: fix crash when a topic had no active subscriptions

1.28.1 (22 Aug 2024)

  • Subscriptions: Track last_triggered_at; add more metadata to the dashboard.

1.28.0 (20 Aug 2024)

  • OperationStore: require the ActiveRecord backend inside an ActiveSupport.on_load(:active_record) { ... } block to improve Rails compatibility

1.27.7 (13 Aug 2024)

  • Subscriptions: Fix another Lua error in big cleanup operations

1.27.6 (13 Aug 2024)

  • Subscriptions: Fix Lua error when cleaning up huge numbers of inactive subscriptions

1.27.5 (9 May 2024)

  • OperationStore: remove needless call to .metadata #4947

1.27.4 (2 May 2024)

  • Pundit, CanCan, OperationStore: add Rails generators for getting started

1.27.3 (1 May 2024)

  • OperationStore: Fix .reindex for many stored operations #4940

1.27.2 (30 Apr 2024)

  • Dashboard: handle missing index references gracefully #4940

1.27.1 (18 Apr 2024)

  • OperationStore: Don't call query.query_string if there's already a parsed document #4922

1.27.0 (11 Apr 2024)

  • RelationConnection: support Arel's NullsFirst and NullsLast nodes #4910

1.26.5 (1 Mar 2024)

  • OperationStore::AddOperationBatch: remove rescue for StatementInvalid inside transaction

1.26.4 (27 Feb 2024)

  • RelationConnection: Don't quote table names that weren't quoted in original SQL, fixes #4508 (comment)

1.26.3 (19 Feb 2024)

  • OperationStore: fix sync endpoint for Rack 3+ #4829
  • Improve error message handling on Rails 7.1

1.26.2 (30 Jan 2024)

  • @defer / @stream: Write delimiters at the end of each patch so that clients respond to payloads more quickly. (Previously, delimiters were added at the start of each patch, so clients had to wait for the next patch before they knew the current one was complete.)

1.26.1 (23 Jan 2024)

  • Pundit integration: improve error message when a Scope class is missing

1.26.0 (19 Jan 2024)

Breaking Changes

  • Pundit integration: when the integration encounters an Array, it tries to find a configured policy class. If it can't, it raises an error.

Previously, the integration silently permitted all items in the array; this default has been changed. See #4726 for more discussion of this change.

If you encounter this error:

  • add scope: false to any fields that return arrays to get the previous behavior (no authorization applied to the array; each item authorized on its own)
  • Or, apply scoping by manually configuring a pundit_policy_class in the field's return type, then adding a class Scope ... inside that policy class. See the Pundit docs for the scope class API: https://github.com/varvet/pundit#scopes.

If you want to continue passing all arrays through without scoping (for example, if you know they've already been authorized another way, or if you're OK with them being authorized one-at-a-time later), you can implement this in your base Scope class, for example:

  class BasePolicy
    class Scope
      def initialize(user, items)
        @user = user
        @items = items
      end

      def resolve
        if items.is_a?(Array)
          items
        else
          raise "Implement #{self.class}#resolve to filter these items: #{items.inspect}"
        end
      end
    end

    # Pass this scope class along to subclasses:
    def self.inherited(child_class)
      child_class.const_set(:Scope, Class.new(BasePolicy::Scope))
      super
    end
  end

Alternatively, you could implement def self.scope_items(items, context) to skip arrays, for example:

  module SkipScopingOnArrays
    def scope_items(items, context)
      if items.is_a?(Array)
        items # return these as-is
      else
        super
      end
    end
  end

  # Then, in type definitions which should skip scoping on arrays:
  extend SkipScopingOnArrays

1.25.2 (29 Dec 2023)

New Features

  • Subscriptions: send more: false when the server calls unsubscribe

1.25.1 (21 Dec 2023)

Bug Fix

  • Ably subscriptions: update webhook handler for presence.message events

1.25.0 (7 Dec 2023)

Bug Fix

  • OperationStore: .dup the given context to avoid leaking state between queries when indexing
  • Subscriptions: use the schema or query logger to output debug messages

1.24.15 (17 Nov 2023)

Bug Fix

  • OperationStore: don't sort directives when normalizing, properly retain directives on Operation and Fragment definitions #4703

1.24.14 (16 Nov 2023)

Bug Fix

  • OperationStore: also pass context: for ActiveRecord backend batches

1.24.13 (13 Nov 2023)

New Features

  • OperationStore: accept context: for AddOperationBatch.call #4697

1.24.12 (13 Nov 2023)

New Features

  • OperationStore: accept context: to Validate.validate #4697

Bug Fix

  • OperationStore: don't rescue application-raised KeyErrors #4699

1.24.11 (8 Nov 2023)

Bug Fix

  • OperationStore: fix compatibility with 1.12.x #4696

1.24.10 (2 Nov 2023)

Bug Fix

  • Improve compatibility with GraphQL-Ruby 1.12.x

1.24.9 (4 Oct 2023)

Bug Fix

  • OperationStore: Preserve variable default values of false when normalizing queries

1.24.8 (29 Aug 2023)

Bug Fix

  • OperationStore: search for operation during Query#initialize to avoid races with other instrumentation. Add use ... trace: true to get the old behavior.

1.24.7 (16 June 2023)

Bug Fix

  • Stable relation connections: quote table names and column names in WHERE clauses #4508

1.24.6 (24 May 2023)

New Features

  • Defer: Add incremental: true for new proposed wire format, add example for working with GraphQL-Batch #4477

1.24.5 (24 May 2023)

Bug Fix

  • Stable relation connection: Quote table names and column names in selects and orders #4485

1.24.4 (18 April 2023)

Bug Fix

  • @defer: update context[:current_path] usage to fix path: on deferred errors

1.24.3 (14 April 2023)

Bug Fix

  • OperationStore: fix when used with Changesets (or other ways of defining arguments with the same name) #4440

1.24.2 (20 Mar 2023)

Bug Fix

  • Remove debug output, oops

1.24.1 (20 Mar 2023)

Bug Fix

  • Fix OperationStore with new module-based execution traces (#4389)

1.24.0 (10 Feb 2023)

New Features

  • Support the redis-client gem as redis:

1.23.9 (2 Feb 2023)

Bug Fix

  • Dashboard: Support Ruby 3.2.0

1.23.8 (27 Jan 2023)

New Features

  • OperationStore: Support Changeset-Version header for syncing with changesets #4304

1.23.7 (25 Jan 2023)

Bug Fix

  • Stable Relation Connections: Fix handling of Postgres JSON accesses

1.23.6

New Features

  • Subscriptions: accept connection_pool: instead of redis: for use with the connection_pool gem

Bug Fix

  • Stable connections: rescue ActiveRecord::StatementInvalid when loading nodes and return a client-facing error instead

1.23.5 (29 December 2022)

New Features

  • Ably subscriptions: Also listen for presence.leave webhooks to clean up subscriptions more quickly

1.23.4 (20 December 2022)

Bug Fix

  • Dashboard: nicely render subscriptions that are not found or cleaned up by read_subscription_failed_error

1.23.3 (19 December 2022)

New Features

  • Add GraphQL::Pro::Subscriptions#read_subscription_failed_error for handling errors that are raised when reloading queries from storage

1.23.2 (18 October 2022)

New Features

  • Add dashboard component for Enterprise mutation limiter

1.23.1 (25 August 2022)

Bug Fix

  • Redis: update redis usage to be forward-compatible with redis 5.x #4167

1.23.0 (2 August 2022)

New Features

  • Stable connections: support SQL queries that sort by IS NOT NULL #4153

1.22.3 (26 July 2022)

Bug Fix

  • Stable connections: handle edges {...} when an invalid cursor is given #4148

1.22.2 (20 April 2022)

Bug Fix

  • Use deprecated_accepts_definitions to stop warnings when loading this gem on 1.13.x

1.22.1 (22 March 2022)

Bug Fix

  • Pusher subscriptions: don't try to send empty trigger batches to Pusher

1.22.0 (19 March 2022)

New Features

  • Pusher subscriptions: it now sends updates in groups of 10 by default, pass use ..., batch_size: 1 to revert to the previous behavior.
  • OperationStore: when using ActiveRecord for storage, it now batches updates to last_used_at every 5 seconds. Pass use ..., update_last_used_at_every: 0 to update that column synchronously, instead, as before.

1.21.6 (16 March 2022)

Bug Fix

  • OperationStore: Fix no method error in Redis pipeline usage

1.21.5 (7 March 2022)

Bug Fix

  • Postgres stable connection: support more complex aliased selects #3976

1.21.4 (15 February 2022)

Bug Fix

  • Encoders: don't extend DeprecatedDefine if it's not present (graphql-ruby < 1.12)

1.21.3 (9 February 2022)

New Features

  • Future-proof for GraphQL-Ruby 2.0

1.21.2 (27 January 2022)

New Features

  • Dashboard, Routes: support lazy-loading the schema with Routes::Lazy #3868
  • OperationStore: Update deprecated usage of @redis.pipelined to address warning

1.21.1 (20 January 2022)

Bug Fix

  • Stream, Defer: Include hasNext: true|false in patches

1.21.0 (20 January 2022)

New Features

  • Stream: Add @stream directive for evaluating list items one-at-a-time

1.20.4 (4 December 2021)

Bug Fix

  • Stable connections: Fix using startCursor / endCursor without nodes #3752

1.20.3 (27 November 2021)

Bug Fix

  • Stable Connections: Properly handle cursors containing invalid JSON #3735

1.20.2 (15 November 2021)

New Features

  • Operation Store sync: ActiveRecord backend performance improvements: when syncing operations, only validate newly-added operations, reduce allocations when normalizing incoming query strings

1.20.1 (8 November 2021)

Bug Fix

  • Operation Store sync: fix when operations are re-synced with new aliases

1.20.0 (5 November 2021)

New Features

  • Operation Store: Use Rails insert_all for better performance when adding new operations

1.19.2 (26 October 2021)

New Features

  • Pundit and CanCan integrations: Add ResolverIntegration modules for plain resolvers #3392

Bug Fix

  • OperationStore Redis backend: pipeline updates to last_used_at values #3672

1.19.1 (15 October 2021)

Bug Fix

  • OperationStore: fix a stack overflow error on GraphQL 1.9 #3653

1.19.0 (13 October 2021)

New Features

  • Dashboard: add a component for GraphQL-Enterprise rate limiters # 1.18.3 (1 Sept 2021)

Breaking Changes

  • Stable cursors: raise an error on unrecognized orderings instead of ignoring them #3605

Bug Fix

  • Stable cursors: Handle Arel::Attributes::Attribute and Arel::SqlLiteral #3605

1.18.2 (16 August 2021)

Bug Fix

  • Stable connections: nicely handle incoming cursors with too many sort values #3581

1.18.1 (20 July 2021)

Bug Fix

  • Stable connections: improve handling of SELECT with CASE #3558
  • Defer: fix to support runtime wrapper objects in graphql-ruby 1.12.13

1.18.0 (31 May 2021)

New Features

  • Ably subscriptions: send quickAck: true for a faster response from Ably

Bug Fix

  • Defer: support dataloader inside deferred blocks

1.17.15 (29 Apr 2021)

New Features

  • Defer: support label: argument which is returned in the patch for that deferral #3454

1.17.14 (14 Apr 2021)

  • Dashboard: fix stack error when OperationStore isn't configured on a class-based schema

1.17.13 (14 Apr 2021)

  • Stable Connections: When using aliases and GROUP BY, replace the alias when building a HAVING condition.
  • Pundit integration: Add a use_owner_role(true) configuration option

1.17.12 (3 Apr 2021)

Bug Fix

  • Stable Connections: Re-select aliased fields that are referenced by ORDER BY. #3421

1.17.11 (12 Mar 2021)

Bug Fix

  • Pundit integration: properly halt when unauthorized_by_pundit returns errors-as-data after a mutation argument fails authorization #3384

1.17.10 (11 Mar 2021)

Bug Fix

  • Pundit, CanCan integrations: properly call configured auth hooks for arguments that are lists and input objects

1.17.9 (3 Mar 2021)

Bug Fix

  • Fix OperationStore assignment on GraphQL-Ruby 1.9

1.17.8 (23 Feb 2021)

New Features

  • Subscriptions: change the default cleanup_delay_s: to 5 seconds (use cleanup_delay_s: 0 to get the old behavior)

Bug Fix

  • Subscriptions: Handle unsubscribe race condition #3357

1.17.7 (19 Feb 2021)

New Features

  • CanCan integration: support can_can_subject: config for overriding the use of object as the CanCan subject #3350

Bug Fixes

  • Subscriptions: Support Redis::Namespace without deprecation warnings for script load #3347

1.17.6 (18 Feb 2021)

New Features

  • Stable connections: implement range_add_edge to leverage GraphQL-Ruby 1.12.5's improved RangeAdd #2184

Bug Fix

  • Defer: Update to work with Dataloader

1.17.5 (13 Feb 2021)

Bug Fix

  • Subscriptions: Use MULTI instead of Lua for some operations
  • Subscriptions: Use EVAL_SHA for duplicate scripts to reduce network overhead #3285
  • Subscriptions: Don't use redis.call, which is unsupported in the redis-namespace gem #3322

1.17.4 (4 Feb 2021)

Bug Fix

  • Stable Relation Connection: Don't emit OR ... IS NULL for columns that are known to be null: false (this improves index utilization)

1.17.3 (2 Feb 2021)

New Features

  • Pusher subscriptions: context[:compress_pusher_payload] = true will cause the payload to be gzipped before being sent to Pusher

1.17.2 (30 Jan 2021)

Bug Fix

  • Subscriptions: don't generate keys inside Lua scripts (for redis-namespace compatibility, and probably better support for Redis cluster) #3307

1.17.1 (25 Jan 2021)

New Features

  • OperationStore: add OperationStore::AddOperationBatch.call for adding data directly
  • Subscriptions: use Lua scripts for more efficient Redis access

1.17.0 (20 Jan 2021)

New Features

  • Updates for 1.12.0 compatibility

Bug Fix

  • OperationStore: improve performance by batching reads and writes during updates

1.16.2 (21 Dec 2020)

New Features

  • Subscriptions: Add stale_ttl_s: and cleanup_delay_s: to customize persistence in Redis #3252

1.16.1 (3 Dec 2020)

Bug Fix

  • Fix duplicate calls to Argument#authorized? in CanCan and Pundit integrations #3242

1.16.0 (10 Nov 2020)

New Features

  • Ably Subscriptions: cipher_base: sets up end-to-end encryption

1.15.7 (29 Sept 2020)

Bug Fix

  • Encoder: fix Ruby 2.7 warning #3161
  • Stable connections: Handle ARRAY[...] selections and cursors on Postgres #3166
  • Pundit: properly lookup policies for list inputs #3146

1.15.6 (17 Sept 2020)

Bug Fix

  • Stable Connections: Use method access to get .cursor_#{idx} values instead of .attributes[:cursor_#{idx}], fixes #3149

1.15.5

New Features

  • Stable Connections: use .to_sql to handle orderings that use complex Arel expressions (#3109)

1.15.4 (28 July 2020)

New Features

  • Pundit: add pundit_policy_class_for(object, context) and pundit_role_for(object, context) for custom runtime lookups

1.15.3 (17 July 2020)

Bug Fix

  • Subscriptions: don't send empty updates when subscriptions return :no_update

1.15.2 (16 July 2020)

New Features

  • OperationStore: improve handling of archived operations in index views

1.15.1 (16 July 2020)

(Oops, bad release!)

1.15.0 (15 July 2020)

  • OperationStore: Store & display last_used_at for operation store clients and operations. To upgrade, add the column to your ActiveRecord table:
  add_column :graphql_client_operations, :last_used_at, :datetime

(It works out-of-the-box with the Redis backend.)

You can opt out of this feature by adding use GraphQL::Pro::OperationStore, ... default_touch_last_used_at: false to your schema setup.

  • OperationStore: Add archive/unarchive workflow for operations. To upgrade, add the column to your table:
  add_column :graphql_client_operations, :is_archived, :boolean, index: true

(It works out-of-the-box with the Redis backend.)

  • OperationStore: Fix indexing of enum values

1.14.1 (29 June 2020)

  • CanCan: Accept can_can_attribute: configuration, which is passed as the third input to .can?(...)

1.14.0 (13 June 2020)

New Features

  • Add PubnubSubscriptions
  • Update subscription implementations to support broadcast: true when available

Bug Fix

  • More Ruby 2.7 warning fixes

1.13.6 (8 June 2020)

Bug Fix

  • Return the proper pageInfo values when it's requested before edges or nodes (#2972)

1.13.5 (11 May 2020)

Bug Fix

  • Fix some warnings on Ruby 2.7

1.13.4 (17 Apr 2020)

Bug Fix

  • StableRelationConnection: properly return hasNextPage: true when before and max_page_size are used.

1.13.3 (2 Apr 2020)

New Features

  • GraphQL::Pro::OperationStore::Migration can be used to copy persisted operations from one backend to another (eg, ActiveRecord to Redis). See the source file, lib/graphql/pro/operation_store/migration.rb for docs.

1.13.2 (28 Mar 2020)

Deprecations

  • GraphQL::Pro::Subscriptions is deprecated; use GraphQL::Pro::PusherSubscriptions instead which works the same, but better (see below). This new name avoids confusion with the later-added AblySubscriptions.

New Features

  • GraphQL::Pro::PusherSubscriptions replaces GraphQL::Pro::Subscriptions and adds orphaned record cleanup. (No more dangling records in Redis.)

1.13.1 (12 Mar 2020)

  • Use nonce: true when working with cursors in new stable connections

1.13.0 (10 Feb 2020)

New Features

  • OperationStore supports a redis: backend
  • OperationStore supports an arbitrary backend_class: for persistence operations

Bug Fix

  • Use a loop when clearing Redis subscription state to avoid large stack traces #2701
  • Handle empty subscription keys when publishing updates #2061

1.12.2 (22 Jan 2020)

Bug Fix

  • Improve backwards compat with OperationStore (Improve adding .tracer, use .graphql_name when indexing)

1.12.1 (20 Jan 2020)

Bug Fix

  • Fix OperationStore on class-based schemas with query instrumenters that use the query string

1.12.0 (20 Jan 2020)

Deprecations

New Features

  • New stable connection support based on GraphQL-Ruby 1.10's new pagination implementation. New classes provide better handling of NULL values in order-by columns and they can be applied on a field-by-field basis(GraphQL::Pro::SqliteStableRelationConnection, GraphQL::Pro::MySQLStableRelationConnection, GraphQL::Pro::PostgresStableRelationConnection).

Bug Fix

  • Add the Access query analyzer to class-based schemas

1.11.0 (10 Oct 2019)

New Features

  • Forwards-compatibility for graphql 1.10.0
  • Support 1.10.0.pre1's input object argument loads: authorization

1.10.8 (8 Oct 2019)

Bug Fix

  • Continue authorizing input object arguments
  • Use millisecond-aware string format for datetimes in cursors

1.10.7 (22 Jul 2019)

Bug Fix

  • Support multiple subscriptions in one document

1.10.6 (27 Jun 2019)

New Features

  • Support custom #can_can_ability methods on query context for CanCanIntegration
  • Support custom #pundit_user method on query context for PunditIntegration

Bug Fix

  • Fix off-by-one error when paginating backwards from the last item in a stable relation connection

1.10.5 (11 May 2019)

New Features

  • Include expected HMAC digest in OperationStore debug output

1.10.4 (26 Mar 2019)

Bug Fix

  • Include content-length and content-type headers in OperationStore JSON responses

1.10.3 (13 Mar 2019)

Bug Fix

  • Support stable connections ordered by Arel SQL literals

1.10.2 (11 Mar 2019)

Bug Fix

  • Support stable connections on realized views (which don't have primary keys)

1.10.1 (8 Mar 2019)

Bug Fix

  • Pundit integration: support pundit_policy_class String names when scoping connections

1.10.0 (5 Mar 2019)

New Features

  • Add GraphQL::Pro::Defer, implementing @defer for streaming responses

1.9.13 (4 Mar 2019)

Bug Fix

  • Pundit integration: correctly authorize fields when Query root is nil

1.9.12 (22 Feb 2019)

Bug Fix

  • Pundit integration: use overridden pundit_policy_class for scoping and mutation authorization

1.9.11 (20 Feb 2019)

Bug Fix

  • Pundit integration: Fields use the owner's configured pundit_policy_class if there is one
  • Pundit integration: avoid conflicts with #initialize for schema classes that don't need it

1.9.10 (19 Feb 2019)

Bug Fix

  • Support inheritance with pundit_policy_class(...)

1.9.9 (13 Feb 2019)

New Features

  • Support pundit_policy_class(...) and pundit_policy_class: to manually specify a class or class name.

1.9.8 (30 Jan 2019)

New Features

  • Inject context into policy lookup hooks instead of just the user

1.9.7 (30 Jan 2019)

New Features

  • Extract pundit_policy and scope_by_pundit_policy hooks for user override

1.9.6 (18 Jan 2019)

Bug Fix

  • Properly render subscription context in dashboard

1.9.5 (14 Jan 2019)

Bug Fix

1.9.4 (11 Jan 2019)

Bug Fix

  • Prepare for future compat with graphql-ruby 1.9

1.9.3 (3 Dec 2018)

Bug Fix

  • Include table name when adding a default order-by-id to ActiveRecord Relations
  • Raise if a required cursor attribute is missing
  • Improve rake routes output for operation store endpoint
  • Support already-parsed queries in subscription RedisStorage

1.9.2 (2 Nov 2018)

Bug Fix

  • Derp, remove the dummy app's .log files from the gem bundle
  • Fix ordering bug when a SQL function call doesn't have an explicit order

1.9.1 (1 Nov 2018)

Bug Fix

  • Fix Pusher reference in AblySubscriptions

1.9.0 (27 Oct 2018)

New Features

  • Add GraphQL::Pro::AblySubscriptions for GraphQL subscriptions over Ably.io transport

1.8.2 (22 Oct 2018)

Bug Fix

  • Support NULLS LAST in stable cursors

1.8.1 (16 Oct 2018)

Bug Fix

  • Improve operation store models to work when config.active_record.primary_key_prefix_type is set

1.8.0 (11 Oct 2018)

New Features

  • Support Rails 3.2 with OperationStore
  • Use .select to filter items in CanCanIntegration

Bug Fix

  • Properly send an ability and the configured can_can_action to .accessible_by
  • Use a string (not integer) for Content-Length header in the dashboard

1.7.13 (2 Oct 2018)

Breaking Change

  • PunditIntegration: instead of raising MutationAuthorizationFailed when an argument fails authorization, it will send a GraphQL::UnauthorizedError to your Schema.unauthorized_object hook. (This is what all other authorization failures do.) To retain the previous behavior, in your base mutation, add:
  def unauthorized_by_pundit(owner, value)
    # Raise a runtime error to halt query execution
    raise "#{value} failed #{owner}'s auth check"
  end

Otherwise, customize the handling of this behavior with Schema.unauthorized_object.

Bug Fix

  • Auth: mutation arguments which have authorization constraints but don't load an object from the database will have mutation instance passed to the auth check, not the input value.

1.7.12 (29 Aug 2018)

New Features

  • Add GraphQL::Pro::CanCanIntegration which leverages GraphQL-Ruby's built-in auth

1.7.11 (21 Aug 2018)

Bug Fix

  • PunditIntegration: Don't try to authorize loaded objects when they're nil

1.7.10 (10 Aug 2018)

New Features

  • Update PunditIntegration for arguments, unions, interfaces and mutations

1.7.9 (9 Aug 2018)

New Features

  • Add a new PunditIntegration which leverages the built-in authorization methods

1.7.8 (10 July 2018)

Bug Fix

  • Authorization: fix scoping lists of abstract type when there's no #scope method on the strategy

1.7.7 (10 May 2018)

Bug Fix

  • Fix ordering of authorization field instrumenter (put it at the end, not the beginning of the list)

1.7.6 (2 May 2018)

New Features

  • Authorization: Add view/access/authorize methods to GraphQL::Schema::Mutation

1.7.5 (19 Apr 2018)

New Features

  • Authorization: when a fallback: configuration is given, apply it to each field which doesn't have a configuration of its own or from its return type. Don't apply that configuration at schema level (it's applied to each otherwise uncovered field instead).

1.7.4 (16 Apr 2018)

New Features

  • Support Mongoid::Criteria in authorization scoping

1.7.3 (12 Apr 2018)

Bug Fix

  • Fix authorization code for when ActiveRecord is not defined

1.7.2 (10 Apr 2018)

Bug Fix

  • Use a more permissive regexp (/^\s*((?:[a-z._]+)\(.*\))\s*(asc|desc)?\s*$/im) to parse SQL functions

1.7.1 (4 Apr 2018)

Bug Fix

  • Fix route helpers to support class-based schemas

1.7.0 (25 Mar 2018)

New Features

  • Support 1.8-pre versions of GraphQL-Ruby

Bug Fix

  • Fix OperationStore when other query instrumenters need .query_string

1.6.5 (7 Feb 2018)

Bug Fix

  • Support LEAST(...) in stable cursors

1.6.4 (7 Feb 2018)

Bug Fix

  • Support CASE ... END in stable cursors

1.6.3 (26 Jan 2018)

Bug Fix

  • Support FIELD(...) in stable cursors

1.6.2 (13 Jan 2018)

Bug Fix

  • Improve detection of OperationStore for the dashboard
  • Serve Content-Type and Content-Length headers with dashboard pages
  • Better Dashboard#inspect for Rails routes output
  • Use a string to apply order-by-primary-key for better Rails 3 support

1.6.1 (22 Nov 2017)

New Features

  • Support composite_primary_keys gem

1.6.0 (13 Nov 2017)

Breaking Changes

  • GraphQL::Pro::UI renamed to GraphQL::Pro::Dashboard

Deprecations

  • Routing method .ui was renamed to .dashboard

New Features

  • Added GraphQL::Pro::Subscriptions
  • Added subscriptions component to Dashboard

1.5.9 (10 Oct 2017)

Bug Fix

  • Don't crash when scoping lists of abstract types with Pundit

1.5.8 (2 Oct 2017)

New Features

  • Use authorize(:pundit, namespace: ) to lookup policies in a namespace instead of the global namespace.

Bug Fix

  • Introspection data is allowed through fallback: authorize: and access: filters. (It can be hidden with a view: filter.)

1.5.7 (20 Sept 2017)

Bug Fix

  • Properly return nil when a list of authorized objects returns nil

1.5.6 (19 Sept 2017)

New Features

  • Add authorization(..., operation_store:) option for authorizing operation store requests

1.5.5 (18 Sept 2017)

New Features

  • Support ConnectionType.bidrectional_pagination? in stable RelationConnection

1.5.4 (18 Sept 2017)

Bug Fix

  • Fix load issue when Rails is not present

1.5.3 (4 Sept 2017)

Bug Fix

  • Fix OperationStore views on PostgresQL
  • Fix stable cursors when joined tables have the same column names

Note: This is implemented by adding extra fields to the SELECT clause with aliases like cursor_#{idx}, so you'll notice this in your SQL logs.

1.5.2 (4 Aug 2017)

Bug Fix

  • Bump graphql dependency to 1.6

1.5.1 (2 Aug 2017)

New Features

  • Routing extensions moved to using GraphQL::Pro::Routes

Deprecations

  • Deprecate using GraphQL::Pro, move extensions to GraphQL::Pro::Routes

1.5.0 (31 Jul 2017)

New Features

  • Add GraphQL::Pro::OperationStore for persisted queries with Rails

1.4.8 (14 Jul 2017)

Bug Fix

  • Update authorization to use type-level resolve_type hooks

1.4.7 (13 Jul 2017)

Bug Fix

  • Update authorization instrumentation for graphql >= 1.6.5

1.4.6 (6 Jul 2017)

Bug Fix

  • Fix typo in RelationConnection source

1.4.5 (6 Jul 2017)

Bug Fix

  • Correctly fall back to offset-based cursors with before: argument

1.4.4 (15 Jun 2017)

New Features

  • Add Schema#unauthorized_object(obj, ctx) hook for failed runtime checks

Bug Fix

  • Prevent usage of parent_role: with view: or access: (since parent role requires a runtime check)
  • Fix versioned, encrypted cursors with 16-byte legacy cursors

1.4.3 (13 Jun 2017)

New Features

  • OrderedRelationConnection supports ordering by joined fields

Bug Fix

  • Update auth plugin for new Relay instrumenters
  • Pro::Encoder supports encoder(...) as documented

1.4.2 (2 May 2017)

Bug Fix

  • Fix compatibility of RelationConnection and RangeAdd helper

1.4.1 (19 Apr 2017)

New Features

  • Add :datadog monitoring

1.4.0 (19 Apr 2017)

New Features

  • ActiveRecord::Relations can be scoped by Pundit Scopes, CanCan accessible_by, or custom strategy's #scope(gate, relation) methods
  • Default authorization configuration can be provided with authorization(..., fallback: { ... })
  • Authorization's :current_user key can be customized with authorization(..., current_user: ...)

1.3.0 (7 Mar 2017)

New Features

  • Serve static, persisted queries with GraphQL::Pro::Repository

1.2.3 (2 May 2017)

Bug Fix

  • Fix compatibility of RelationConnection and RangeAdd helper

1.2.2 (6 Mar 2017)

Bug Fix

  • Raise GraphQL::Pro::RelationConnection::InvalidRelationError when a grouped, unordered relation is returned from a field. (This relation can't be stably paginated.)

1.2.1 (3 Mar 2017)

New Features

  • Formally support ActiveRecord >= 4.1.0

Bug Fix

  • Support grouped relations in GraphQL::Pro::RelationConnection

1.2.0 (1 Mar 2017)

New Features

  • Authorize fields based on their parent object, for example:
  AccountType = GraphQL::ObjectType.define do
    name "Account"
    # This field is visible to all users:
    field :name, types.String
    # This is only visible when the current user is an `:owner`
    # of this account
    field :account_balance, types.Int, authorize: { parent_role: :owner }
  end

1.1.1 (22 Feb 2017)

Bug Fixes

  • Fix monitoring when Query#selected_operation is nil

1.1.0 (9 Feb 2017)

New Features

  • Add AppSignal monitoring platform
  • Add type- and field-level opting in and opting out of monitoring
  • Add monitor_scalars: false to skip monitoring on scalars

Bug Fixes

  • Fix OrderedRelationConnection when neither first nor last are provided (use max_page_size or don't limit)

1.0.4 (23 Jan 2017)

Bug Fixes

  • OrderedRelationConnection exposes more metadata methods: parent, field, arguments, max_page_size, first, after, last, before

1.0.3 (23 Jan 2017)

Bug Fixes

  • When an authorization check fails on a non-null field, propagate the null and add a response to the errors key (as if the field had returned null). It previously leaked the internal symbol __graphql_pro_access_not_allowed__.
  • Apply a custom Pundit policy even when the value isn't nil. (It previously fell back to Pundit.policy, skipping a pundit_policy_name configuration.)

1.0.2

Bug Fixes

  • OrderedRelationConnection exposes the underlying relation as #nodes (like RelationConnection does), supporting custom connection fields.

1.0.1

New Features

  • CanCan integration now supports a custom Ability class with the ability_class: option:
  authorize :cancan, ability_class: CustomAbility

1.0.0

  • GraphQL::Pro released