graphql-pro
Breaking Changes
Deprecations
New Features
1.29.6 (5 May 2025)
@stream: AddFutureStreamfor lazy enumerators
1.29.5 (31 Mar 2025)
- OperationStore: Improve Redis cleanup when deleting a single client
- Stable connections: Fix NULL handling on Rails 7.2 + Postgresql
1.29.4 (18 Nov 2024)
- OperationStore: Add forward compatibility for removing old validation code #5164
1.29.3 (15 Nov 2024)
- OperationStore: Improve
syncperformance withGraphQL::Schema::Visibility
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
ActiveRecordbackend inside anActiveSupport.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
.reindexfor 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_stringif there's already a parsed document #4922
1.27.0 (11 Apr 2024)
- RelationConnection: support Arel's
NullsFirstandNullsLastnodes #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
syncendpoint 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
Scopeclass 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: falseto 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_classin the field's return type, then adding aclass 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: falsewhen the server callsunsubscribe
1.25.1 (21 Dec 2023)
Bug Fix
- Ably subscriptions: update webhook handler for
presence.messageevents
1.25.0 (7 Dec 2023)
Bug Fix
- OperationStore:
.dupthe givencontextto 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:forAddOperationBatch.call#4697
1.24.12 (13 Nov 2023)
New Features
- OperationStore: accept
context:toValidate.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
falsewhen normalizing queries
1.24.8 (29 Aug 2023)
Bug Fix
- OperationStore: search for operation during
Query#initializeto avoid races with other instrumentation. Adduse ... trace: trueto get the old behavior.
1.24.7 (16 June 2023)
Bug Fix
- Stable relation connections: quote table names and column names in
WHEREclauses #4508
1.24.6 (24 May 2023)
New Features
- Defer: Add
incremental: truefor 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: updatecontext[:current_path]usage to fixpath: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
OperationStorewith new module-based execution traces (#4389)
1.24.0 (10 Feb 2023)
New Features
- Support the
redis-clientgem asredis:
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-Versionheader 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 ofredis:for use with theconnection_poolgem
Bug Fix
- Stable connections: rescue
ActiveRecord::StatementInvalidwhen loading nodes and return a client-facing error instead
1.23.5 (29 December 2022)
New Features
- Ably subscriptions: Also listen for
presence.leavewebhooks 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_errorfor 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_definitionsto 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: 1to revert to the previous behavior. - OperationStore: when using ActiveRecord for storage, it now batches updates to
last_used_atevery 5 seconds. Passuse ..., update_last_used_at_every: 0to 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
DeprecatedDefineif 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.pipelinedto address warning
1.21.1 (20 January 2022)
Bug Fix
- Stream, Defer: Include
hasNext: true|falsein patches
1.21.0 (20 January 2022)
New Features
- Stream: Add
@streamdirective 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_allfor better performance when adding new operations
1.19.2 (26 October 2021)
New Features
- Pundit and CanCan integrations: Add
ResolverIntegrationmodules 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::AttributeandArel::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
SELECTwithCASE#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: truefor 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_punditreturns 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 (usecleanup_delay_s: 0to 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 ofobjectas the CanCan subject #3350
Bug Fixes
- Subscriptions: Support
Redis::Namespacewithout deprecation warnings forscript load#3347
1.17.6 (18 Feb 2021)
New Features
- Stable connections: implement
range_add_edgeto 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
MULTIinstead of Lua for some operations - Subscriptions: Use
EVAL_SHAfor duplicate scripts to reduce network overhead #3285 - Subscriptions: Don't use
redis.call, which is unsupported in theredis-namespacegem #3322
1.17.4 (4 Feb 2021)
Bug Fix
- Stable Relation Connection: Don't emit
OR ... IS NULLfor columns that are known to benull: false(this improves index utilization)
1.17.3 (2 Feb 2021)
New Features
- Pusher subscriptions:
context[:compress_pusher_payload] = truewill 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.callfor 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:andcleanup_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_sqlto handle orderings that use complex Arel expressions (#3109)
1.15.4 (28 July 2020)
New Features
- Pundit: add
pundit_policy_class_for(object, context)andpundit_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_atfor 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: truewhen available
Bug Fix
- More Ruby 2.7 warning fixes
1.13.6 (8 June 2020)
Bug Fix
- Return the proper
pageInfovalues when it's requested beforeedgesornodes(#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: truewhenbeforeandmax_page_sizeare used.
1.13.3 (2 Apr 2020)
New Features
GraphQL::Pro::OperationStore::Migrationcan 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.rbfor docs.
1.13.2 (28 Mar 2020)
Deprecations
GraphQL::Pro::Subscriptionsis deprecated; useGraphQL::Pro::PusherSubscriptionsinstead which works the same, but better (see below). This new name avoids confusion with the later-addedAblySubscriptions.
New Features
GraphQL::Pro::PusherSubscriptionsreplacesGraphQL::Pro::Subscriptionsand adds orphaned record cleanup. (No more dangling records in Redis.)
1.13.1 (12 Mar 2020)
- Use
nonce: truewhen 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_namewhen 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
GraphQL::Pro::Monitoringis deprecated; see Tracing for a replacement: https://graphql-ruby.org/queries/tracing.htmlGraphQL::Pro::Repositoryis deprecated; see OperationStore for a replacement: https://graphql-ruby.org/operation_store/overview.html
New Features
- New stable connection support based on GraphQL-Ruby 1.10's new pagination implementation. New classes provide better handling of
NULLvalues 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_abilitymethods on query context for CanCanIntegration - Support custom
#pundit_usermethod 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_classString names when scoping connections
1.10.0 (5 Mar 2019)
New Features
- Add
GraphQL::Pro::Defer, implementing@deferfor 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_classfor scoping and mutation authorization
1.9.11 (20 Feb 2019)
Bug Fix
- Pundit integration: Fields use the owner's configured
pundit_policy_classif there is one - Pundit integration: avoid conflicts with
#initializefor 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(...)andpundit_policy_class:to manually specify a class or class name.
1.9.8 (30 Jan 2019)
New Features
- Inject
contextinto policy lookup hooks instead of just the user
1.9.7 (30 Jan 2019)
New Features
- Extract
pundit_policyandscope_by_pundit_policyhooks 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
- Don't pass arrays to Pundit scopes (fixes https://github.com/rmosolgo/graphql-ruby/issues/2008)
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 routesoutput 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
.logfiles 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::AblySubscriptionsfor GraphQL subscriptions over Ably.io transport
1.8.2 (22 Oct 2018)
Bug Fix
- Support
NULLS LASTin stable cursors
1.8.1 (16 Oct 2018)
Bug Fix
- Improve operation store models to work when
config.active_record.primary_key_prefix_typeis set
1.8.0 (11 Oct 2018)
New Features
- Support Rails 3.2 with OperationStore
- Use
.selectto filter items in CanCanIntegration
Bug Fix
- Properly send an ability and the configured
can_can_actionto.accessible_by - Use a string (not integer) for
Content-Lengthheader in the dashboard
1.7.13 (2 Oct 2018)
Breaking Change
PunditIntegration: instead of raisingMutationAuthorizationFailedwhen an argument fails authorization, it will send aGraphQL::UnauthorizedErrorto yourSchema.unauthorized_objecthook. (This is what all other authorization failures do.) To retain the previous behavior, in your base mutation, add:
def (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::CanCanIntegrationwhich 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'renil
1.7.10 (10 Aug 2018)
New Features
- Update
PunditIntegrationfor arguments, unions, interfaces and mutations
1.7.9 (9 Aug 2018)
New Features
- Add a new
PunditIntegrationwhich 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
#scopemethod 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/authorizemethods toGraphQL::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
ActiveRecordis 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-preversions 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 ... ENDin 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
OperationStorefor the dashboard - Serve
Content-TypeandContent-Lengthheaders with dashboard pages - Better
Dashboard#inspectfor 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_keysgem
1.6.0 (13 Nov 2017)
Breaking Changes
GraphQL::Pro::UIrenamed toGraphQL::Pro::Dashboard
Deprecations
- Routing method
.uiwas 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:andaccess:filters. (It can be hidden with aview:filter.)
1.5.7 (20 Sept 2017)
Bug Fix
- Properly return
nilwhen a list of authorized objects returnsnil
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
graphqldependency to1.6
1.5.1 (2 Aug 2017)
New Features
- Routing extensions moved to
using GraphQL::Pro::Routes
Deprecations
- Deprecate
using GraphQL::Pro, move extensions toGraphQL::Pro::Routes
1.5.0 (31 Jul 2017)
New Features
- Add
GraphQL::Pro::OperationStorefor persisted queries with Rails
1.4.8 (14 Jul 2017)
Bug Fix
- Update
authorizationto use type-levelresolve_typehooks
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:withview:oraccess:(since parent role requires a runtime check) - Fix versioned, encrypted cursors with 16-byte legacy cursors
1.4.3 (13 Jun 2017)
New Features
OrderedRelationConnectionsupports ordering by joined fields
Bug Fix
- Update auth plugin for new Relay instrumenters
Pro::Encodersupportsencoder(...)as documented
1.4.2 (2 May 2017)
Bug Fix
- Fix compatibility of
RelationConnectionandRangeAddhelper
1.4.1 (19 Apr 2017)
New Features
- Add
:datadogmonitoring
1.4.0 (19 Apr 2017)
New Features
ActiveRecord::Relations can be scoped by PunditScopes, CanCanaccessible_by, or custom strategy's#scope(gate, relation)methods- Default authorization configuration can be provided with
authorization(..., fallback: { ... }) - Authorization's
:current_userkey can be customized withauthorization(..., 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
RelationConnectionandRangeAddhelper
1.2.2 (6 Mar 2017)
Bug Fix
- Raise
GraphQL::Pro::RelationConnection::InvalidRelationErrorwhen 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_operationis 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: falseto skip monitoring on scalars
Bug Fixes
- Fix
OrderedRelationConnectionwhen neitherfirstnorlastare provided (usemax_page_sizeor don't limit)
1.0.4 (23 Jan 2017)
Bug Fixes
OrderedRelationConnectionexposes 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 toPundit.policy, skipping apundit_policy_nameconfiguration.)
1.0.2
Bug Fixes
OrderedRelationConnectionexposes the underlying relation as#nodes(likeRelationConnectiondoes), supporting custom connection fields.
1.0.1
New Features
- CanCan integration now supports a custom
Abilityclass with theability_class:option:
:cancan, ability_class: CustomAbility
1.0.0
GraphQL::Proreleased