Craft GraphQL APIs in Elixir with Absinthe
Flexible, Robust Services for Queries, Mutations, and Subscriptions
by: Bruce Williams and Ben Wilson
Published | 2018-03-27 |
---|---|
Internal code | wwgraphql |
Print status | In Print |
Pages | 302 |
User level | Intermediate |
Keywords | API, model, databases, microservices, back ends, graphql, elixir, OTP, scale, robust, real-time |
Related titles | - Programming Elixir |
ISBN | 9781680502558 |
Other ISBN |
Channel epub: 9781680505931 Channel PDF: 9781680505948 Kindle: 9781680505917 Safari: 9781680505924 Kindle: 9781680505917 |
BISACs | COM062000 COMPUTERS / Data Modeling & DesignCOM061000 COMPUTERS / Client-Server ComputingCOM061000 COMPUTERS / Client-Server Computing |
Highlight
Your domain is rich and interconnected, and your API should be too. Upgrade your web API to GraphQL, leveraging its flexible queries to empower your users, and its declarative structure to simplify your code. Absinthe is the GraphQL toolkit for Elixir, a functional programming language designed to enable massive concurrency atop robust application architectures. Written by the creators of Absinthe, this book will help you take full advantage of these two groundbreaking technologies. Build your own flexible, high-performance APIs using step-by-step guidance and expert advice you won’t find anywhere else.
Description
GraphQL is a new way of structuring and building web services, and the result is transformational. Find out how to offer a more tailored, cohesive experience to your users, easily aggregate data from different data sources, and improve your back end’s maintainability with Absinthe’s declarative approach to defining how your API works.
Build a GraphQL-based API from scratch using Absinthe, starting from core principles. Learn the type system and how to expand your schema to suit your application’s needs. Discover a growing ecosystem of tools and utilities to understand, debug, and document your API. Take it to production, but do it safely with solid best practices in mind. Find out how complexity analysis and persisted queries can let you support your users flexibly, but responsibly too. Along the way, discover how Elixir makes all the difference for a high performance, fault-tolerant API. Use asynchronous and batching execution, or write your own custom add-ons to extend Absinthe. Go live with subscriptions, delivering data over websockets on top of Elixir (and Erlang/OTP’s) famous solid performance and real-time capabilities.
Transform your applications with the powerful combination of Elixir and GraphQL, using Absinthe.
Contents and Extracts
- <b>Introduction</b>
- Build a GraphQL API
- Meet GraphQL
- On the Client
- On the Server
- Absinthe and the Tech Stack
- Moving On
- Building a Schema
- Preparing the Application
- Our Schema Module
- Making a Query <b>excerpt</b>
- Running Our Query with GraphiQL
- Testing Our Query
- Moving On
- Taking User Input <b>excerpt</b>
- Defining Field Arguments
- Providing Field Argument Values
- Using Enumeration Types
- Modeling Input Objects
- Marking Arguments as Non-Null
- Creating Your Own Scalar Types
- Moving On
- Adding Flexibility
- Organizing a Schema
- Understanding Abstract Types
- Using Named Fragments
- Moving On
- Making a Change with Mutations
- Defining a Root Mutation Type
- Building the Resolver
- Handling Mutation Errors
- Moving On
- Going Live with Subscriptions
- Setting Up Subscriptions
- Event Modeling
- Submitting Subscriptions <b>excerpt</b>
- Testing Subscriptions
- Subscription Triggers
- Moving On
- Meet GraphQL
- Publish Your API
- Resolution Middleware
- Our First Module
- Applying Middleware
- Setting Defaults
- Moving On
- Securing with Authentication and Authorization
- Logging In
- Using the Execution Context
- Securing Fields
- Structuring for Authorization
- Moving On
- Tuning Resolution
- Understanding the Problem
- Using Built-in Plugins
- Discovering Dataloader
- Moving On
- Resolution Middleware
- Use Your API
- Driving Phoenix Actions with GraphQL
- Building an Action
- Handling Input
- Complex Queries
- Moving On
- Integrating with the Frontend
- Starting Simple
- Choosing a Framework
- Using Apollo Client
- Using Relay
- Wrapping Up
- Driving Phoenix Actions with GraphQL