Book Image

Build Your Own Web Framework in Elixir

By : Aditya Iyengar
Book Image

Build Your Own Web Framework in Elixir

By: Aditya Iyengar

Overview of this book

Elixir's functional nature and metaprogramming capabilities make it an ideal language for building web frameworks, with Phoenix being the most ubiquitous framework in the Elixir ecosystem and a popular choice for companies seeking scalable web-based products. With an ever-increasing demand for Elixir engineers, developers can accelerate their careers by learning Elixir and the Phoenix web framework. With Build Your Own Web Framework in Elixir, you’ll start by exploring the fundamental concepts of web development using Elixir. You'll learn how to build a robust web server and create a router to direct incoming requests to the correct controller. Then, you'll learn to dispatch requests to controllers to respond with clean, semantic HTML, and explore the power of Domain-Specific Languages (DSL) and metaprogramming in Elixir. You'll develop a deep understanding of Elixir's unique syntax and semantics, allowing you to optimize your code for performance and maintainability. Finally, you'll discover how to effectively test each component of your application for accuracy and performance. By the end of this book, you'll have a thorough understanding of how Elixir components are implemented within Phoenix, and how to leverage its powerful features to build robust web applications.
Table of Contents (15 chapters)
1
Part 1: Web Server Fundamentals
4
Part 2: Router, Controller, and View
10
Part 3: DSL Design

Understanding the Plug.Builder module

To add a similar plug pipeline to our controller, we will need to keep track of all the plug/3 calls in the controller and apply those plugs in the correct order whenever the controller receives a request. This sounds like a lot of work to do from scratch, but fortunately, the Plug package provides a module that could help – the Plug.Builder module.

The Plug.Builder module can be used to define a pipeline of plugs that are executed one after the other. It defines a plug/2 macro, which is the main interface to build a pipeline by adding a plug to the list of already registered plugs. The plugs in the pipeline are executed in the order of their definition, and the connection returned by the final plug is then passed along to the main plug call.

Here’s an example of this:

defmodule ExamplePlugPipeline do
  use Plug.Builder
  plug :plug1
  plug :plug2
  def plug1(conn, _opts) do
 ...