Organizing Code for OTP Abstractions
Let’s learn how we can integrate our layers into projects that make OTP callbacks.
We'll cover the following
A growing number of Elixir projects are allowing library integration by making OTP callbacks, or something like them, directly available to developers. In the following few lessons, we’ll suggest how you might integrate our layers into those frameworks. We’ll cover the following:
-
Phoenix Channels
-
Phoenix LiveView
-
Scenic
Once we know how these work, we’ll have a pretty good idea of how to integrate with other callback-style frameworks.
Let’s go over a few clues that will help us recognize where the primary integration points might be for each section. Once we find those integration points, we’ll know how to tie it into the rest of the layers in our project. In each case, the key will be to find where each library exposes callbacks from within an OTP GenServer
.
Understand callback-style libraries
If we want to use a simple mix project as a dependency, whether an OTP project or a simple library, we don’t care about the callback structure. Sometimes, though, we’ll want to replace the boundary layer in the chapter Isolating Process Machinery in a Boundary with one wired directly to the framework we’re using. The GenServer
behavior has at least two pieces of functionality any framework needs to wrap:
A way to start a process
The GenServer
calls these functions within process start machinery. The formal GenServer
behavior has both a start_link
function and an init
function.
A way to process a callback
GenServers invoke these callbacks in the machinery that receives messages. The GenServer
behavior has at least three interesting callbacks, including handle_call
, handle_cast
, and handle_info
.
For convenience, we also wrapped our callbacks in functions, but don’t let that distract you. Startup and callbacks are the pieces we want to look for. Once we identify those pieces, then incorporating an event-based library is easy.
Get hands-on with 1400+ tech skills courses.