Hasura - v2.18.0


Changelog

Highlights

Dynamically route GraphQL requests to different database connections of a Postgres source (Cloud / Enterprise edition only)

The configuration object of Postgres source metadata accepts the following new fields.
1. connection_set - A set of database connections to which the GraphQL queries can be routed to.
2. connection_template - A Kriti template in which the routing logic is defined using various request parameters like session variables, client headers etc.

Find a sample Postgres source metadata here. A new query type, pg_test_connection_template is introduced in metadata API to test connection template of a Postgres source. Learn more about the API here.

Runtime behavior: Connection template, if configured, is resolved for all non-admin GraphQL requests and the SQL generated is executed on the resolved connection.

Please refer to the RFC at #9310 to learn more about the feature and current limitations. Below is an example of metadata configuration of connection set and connection template:

image

Export Traces in the OpenTelemetry format (Beta) (Enterprise edition only)

Traces are generated by instrumenting application code. Hasura has instrumented all API queries, mutations and subscriptions with the OpenTelemetry format. These traces can be exported directly from your Hasura instances to your observability tool that supports OpenTelemetry traces. This can be configured in the Settings section of the Hasura Console. For more information please refer to the docs.

OpenTelemetry Configuration

Bug fixes and improvements

Server

  • Log the statistics of event trigger and scheduled trigger events fetched under event-trigger-process and scheduled-trigger-process log types respectively, for every 10 minutes.
  • Fix a tracing issue where errors sometimes prevented enclosing spans from being reported (Cloud / Enterprise edition only)
  • Adjusting the *_suggest_relationships Metadata API to provide contextual constraint_name keys.
  • Fix next_retry_at for MSSQL event triggers and update the timezone of created_at and locked columns to UTC.
    Note: The default value of created at is altered for tables event_log and event_invocation_logs. After source migration, earlier events might be delayed or deliver earlier depending on the timezone of the SQL server.
  • Changes the list_source_kinds metadata API to return per-agent availability information rather than fail the API call.
  • Few new fields added to the livequery-poller-log log:
  • a kind field, which indicates if its a streaming subscription or a live-query subscription.
  • a new field db_execution_time to replace pg_execution_time, and intent to deprecate pg_execution_time in the future. With this change pg_execution_time will only be present only for vanilla PG backends (i.e. not in Cockroach, Citus etc.)
  • a new field subscription_options to replace live_query_options, and intent to deprecate live_query_options in the future. With this change live_query_options will only be present for live-query subscriptions.
  • Fix handling of special language characters in MS SQL Server event trigger payload (fixes: #9293, #8747)

Console

  • Fix editing columns with bigint arrays, when the column was not touched
  • Add console support for string query parameters in actions, event and cron triggers request transforms
  • Load filter and sort conditions from URL and preserve them while switching between tables.

CLI

  • Add EE support in CLI console (Enterprise edition only)
  • Fix broken CLI console when server console is disabled and local console assets are being used (fix #9378)
  • Support migrations for Cockroach DB in CLI Console
  • Add a new flag --console-hge-endpoint to hasura console command that allows the CLI console to be correctly configured when running the CLI inside of a container. (fix #2824)
  • Make the version update notifications when running Hasura CLI commands non-blocking (fix #9367)

Data Connectors

  • Added connection parameters to Snowflake connect strings to indicate that connections were initiated by Hasura. (Cloud / Enterprise edition only)
  • Bugfix for failure of the super-connector to properly order results based on a single column aggregate. (Cloud / Enterprise edition only)
  • Adding a new Data Connectors /datasets API for creating new databases from templates. For more information, see dc-agents/README.md.
  • Remove builtin scalar types from Data Connector backend. This means that HGE no longer assumes that all Data Connector agents support a minimal set of scalar types (number, string, and bool) or any particular aggregate functions. All scalar types, must now be explicitly specified in the agent capabilities, along with any aggregate functions they support.

Details

date
Feb. 7, 2023, 1:38 p.m.
name
v2.18.0
type
Minor
👇
Register or login to:
  • 🔍View and search all Hasura releases.
  • 🛠️Create and share lists to track your tools.
  • 🚨Setup notifications for major, security, feature or patch updates.
  • 🚀Much more coming soon!
Continue with GitHub
Continue with Google
or