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 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
.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
andNullsLast
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 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: false
when the server callsunsubscribe
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 givencontext
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:
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
KeyError
s #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. Adduse ... 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
: 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
OperationStore
with new module-based execution traces (#4389)
1.24.0 (10 Feb 2023)
New Features
- Support the
redis-client
gem 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-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 ofredis:
for use with theconnection_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. Passuse ..., 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
andArel::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
withCASE
#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 (usecleanup_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 ofobject
as the CanCan subject #3350
Bug Fixes
- Subscriptions: Support
Redis::Namespace
without deprecation warnings forscript 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 theredis-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 benull: 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:
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_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)
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_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 beforeedges
ornodes
(#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
whenbefore
andmax_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; useGraphQL::Pro::PusherSubscriptions
instead which works the same, but better (see below). This new name avoids confusion with the later-addedAblySubscriptions
.
New Features
GraphQL::Pro::PusherSubscriptions
replacesGraphQL::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
GraphQL::Pro::Monitoring
is deprecated; see Tracing for a replacement: https://graphql-ruby.org/queries/tracing.htmlGraphQL::Pro::Repository
is 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
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(...)
andpundit_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
andscope_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
- 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 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 raisingMutationAuthorizationFailed
when an argument fails authorization, it will send aGraphQL::UnauthorizedError
to yourSchema.unauthorized_object
hook. (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::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'renil
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 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
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
andContent-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 toGraphQL::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:
andaccess:
filters. (It can be hidden with aview:
filter.)
1.5.7 (20 Sept 2017)
Bug Fix
- Properly return
nil
when 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
graphql
dependency 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::OperationStore
for persisted queries with Rails
1.4.8 (14 Jul 2017)
Bug Fix
- Update
authorization
to use type-levelresolve_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:
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
OrderedRelationConnection
supports ordering by joined fields
Bug Fix
- Update auth plugin for new Relay instrumenters
Pro::Encoder
supportsencoder(...)
as documented
1.4.2 (2 May 2017)
Bug Fix
- Fix compatibility of
RelationConnection
andRangeAdd
helper
1.4.1 (19 Apr 2017)
New Features
- Add
:datadog
monitoring
1.4.0 (19 Apr 2017)
New Features
ActiveRecord::Relation
s can be scoped by PunditScope
s, CanCanaccessible_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 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
RelationConnection
andRangeAdd
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 neitherfirst
norlast
are provided (usemax_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 toPundit.policy
, skipping apundit_policy_name
configuration.)
1.0.2
Bug Fixes
OrderedRelationConnection
exposes the underlying relation as#nodes
(likeRelationConnection
does), supporting custom connection fields.
1.0.1
New Features
- CanCan integration now supports a custom
Ability
class with theability_class:
option:
:cancan, ability_class: CustomAbility
1.0.0
GraphQL::Pro
released