PostGraphile Launches Version 4

Announced 2018-10-02 by Team Graphile

The original GraphQL API for PostgreSQL: now vastly more performant, customizable and extensible than ever before

After a year of development and testing, Benjie is pleased to announce the release of PostGraphile Version 4 ā ā€” the most customizable and extensible automatic GraphQL API for PostgreSQL yet. PostGraphileā ā€”previously known as PostGraphQLā ā€”has been re-written from the ground up with a strong focus on performance, best practices and flexibility. This has been enabled through the creation of Graphile Engine - a powerful datasource-agnostic GraphQL Engine that has extensibility and performance at its core ā ā€” upon which PostGraphile Version 4 is built.

Instead of requiring developers to learn a new set of tools and lock business logic into a new software stack, PostGraphile encourages them to build the important thingsā ā€”their data and business logicā€”using the database they're already using. Then with minimal configuration, they can use PostGraphile to make this available as a secure and lightning-fast GraphQL API.

PostGraphile Version 4 is highly performant

Benjie has rebuilt the core of PostGraphile entirely, with a strong focus on performance. Unlike other solutions, PostGraphile is able to look at the GraphQL query holistically and find the most efficient way of executing it. This has lead to a large increase in the request throughput, and a 94% decrease in latency. Peak memory usage has also reduced by 92% as compared to Version 3. The result is a much faster application, and happier end users ā ā€” especially those on mobile. PostGraphile Version 3 developers will be able to reap these massive performance improvements simply by updating ā ā€” no need to change their application code.

Read more about the stunning new performance of PostGraphile version 4

Version 4 is highly customizable

Version 4 has added three handy features to help developers streamline their GraphQL schema. First, unnecessary functionality from PostgreSQL extensions is automatically filtered out by default, so only the tables and functions the developer has added are exposed. Secondly, PostGraphile can now inspect database permissions, and automatically remove types and fields from the generated schema the end user has no way of accessing. Finally, Version 4 introduces the concept of "smart comments".

The new smart comments functionality enables the developer to customize their GraphQL schema as they see fit. By adding smart comments, the developer can easily perform operations such as renaming fields without modifying the underlying table structure. Besides renaming fields, current operations include renaming types, detailing when a field should be included or not (e.g. making a field read-only), and handling deprecation gracefully. Plugin authors are already using the smart comments functionality to add new features to their PostGraphile schemas, such as adding relations on views.

These features lead to smaller GraphQL schemas that are easier for developers to understand and manage without sacrificing desired functionality.

Read more about the new smart comments system

Version 4 is highly extensible

Before commencing work on PostGraphile Version 4, Benjie reviewed every issue in the PostGraphile bug tracker, and concluded that a rigid one-size-fits all GraphQL API was too restrictive for many users. The rigid nature of Version 3 resulted in a number of users having to compromise with workarounds such as schema stitching, or resort to maintaining a separate fork of the project to add their desired functionality. With this in mind Benjie, set out to find a solution to all these issues.

PostGraphile became a modular project, with its GraphQL generation powered by a new plugin-based project named Graphile Engine. Users can now use plugins to add functionality to their GraphQL schema without requiring modifications to the core ā ā€” and they can even share these features with the world. During the development stages of Graphile Engine, a community of plugin authors formed; with their help, the plugin system solidified into the capable production-ready system that Benjie is proud to be releasing today. This work has negated the need to maintain forks of PostGraphile, and has lead to a growing ecosystem of functionality putting PostGraphile at the forefront of PostgreSQL GraphQL APIs.

Read more about the new plug in system

PostGraphile is open source, supported by the community

PostGraphile thanks the community

This release of PostGraphile wouldnā€™t have been possible without the community. Benjie says, ā€œThe community's response to PostGraphile has been amazing! People have found so many ways to help support the project: from testing and reporting issues, to documentation fixes, and even large feature development. Their sponsorship now funds one day a week dedicated to PostGraphile development, and this support is growing every month which is already leading to more features and faster releases. This voluntary financial support from the community is very motivational, a great antidote to the burn-out that's common in open source maintainers, and it's exciting to be turning PostGraphile into a sustainable open source project that people can rely on for years to come. It's also wonderful to see the community being so supportive of each other ā ā€” sharing knowledge, debugging issues, testing and sharing plugins. There's so much more to come from PostGraphile ā ā€” bring on the future!ā€