Book Image

Accelerating Server-Side Development with Fastify

By : Manuel Spigolon, Maksim Sinik, Matteo Collina
5 (1)
Book Image

Accelerating Server-Side Development with Fastify

5 (1)
By: Manuel Spigolon, Maksim Sinik, Matteo Collina

Overview of this book

This book is a complete guide to server-side app development in Fastify, written by the core contributors of this highly performant plugin-based web framework. Throughout the book, you’ll discover how it fosters code reuse, thereby improving your time to market. Starting with an introduction to Fastify’s fundamental concepts, this guide will lead you through the development of a real-world project while providing in-depth explanations of advanced topics to prepare you to build highly maintainable and scalable backend applications. The book offers comprehensive guidance on how to design, develop, and deploy RESTful applications, including detailed instructions for building reusable components that can be leveraged across multiple projects. The book presents guidelines for creating efficient, reliable, and easy-to-maintain real-world applications. It also offers practical advice on best practices, design patterns, and how to avoid common pitfalls encountered by developers while building backend applications. By following these guidelines and recommendations, you’ll be able to confidently design, implement, deploy, and maintain an application written in Fastify, and develop plugins and APIs to contribute to the Fastify and open source communities.
Table of Contents (21 chapters)
1
Part 1:Fastify Basics
7
Part 2:Build a Real-World Project
14
Part 3:Advanced Topics

How to make live a GQL schema?

In the Writing the GQL Schema section, we wrote the application’s GQL schema. Now, we need to initialize a new npm project. For the sake of simplicity and in order to focus on the GQL logic only, we can build it by running the following code:

mkdir family-gql
cd family-gql/
npm init --yes
npm install fastify@4 mercurius@11

We are ready to create our first file, gql-schema.js. Here, we can just copy-paste the GQL schema we wrote in the previous section:

module.exports = `
# the GQL Schema string
`

Before proceeding further, it is worth mentioning that there are two different ways to define a GQL schema with Node.js:

  • Schema-first: The GQL schema is a string written following the GQL specification
  • Code-first: The GQL schema is generated by an external tool, such as the graphql npm module

In this chapter, we will follow the schema-first implementation as it is the most generic and allows you to get a clear overview of...