A New Architecture For Rails
About the Book
Note: This book discusses Trailblazer 1.x. We provide free guides for TRB2 on the website, but the general idea of this book still applies.
Trailblazer is a thin layer on top of Rails and brings a high-level application architecture, decent encapsulation and a new code structure. Here are the main features.
- Logicless models solely focusing on persistence.
- Skinny controllers working as endpoints, only.
- Domain objects for your business logic, known as operations.
- Form objects for deserialisation and validation.
- View models to introduce a widget architecture.
- Representers that parse and render documents for APIs.
- Twin objects for decorating models.
This book takes you for an adventure trip from Rails' code jungle to Trailblazer beach. We're building a complete Rails application using all of Trailblazer's goodies while exploiting the Rails Way where it helps us.
What we build here is not just a simple 5-minutes blog, but a full-blown commenting application with complex forms, composed views, signed-in users and admin, authentication rules, polymorphic views and operatoins, a document-based JSON API, and more. We have a strong focus on testing, object design and structuring the code using Trailblazer's concept-oriented framework.
2. The Trailblazer Architectural Style
Chapter 2 is a complete overview about all the concepts of Trailblazer, starting from domain objects, integrated form to view models, policies and twins.
3. Operations and Forms
The third chapter gives you everything you need to encapsulate your business logic into operations and building rock-solid domain components using the integrated form. We also learn how to render forms from operations, and how to test both for a good sleep.
We then discuss the principles of Cells view models, how to encapsulate your view into components and the way helpers work in this layer. Learning how to test your rendering and integrating those with smoke tests round up this fine chapter.
5. Nested Forms
Forms can and do represent deeply nested object structures. In this chapter we learn how to nest forms to create more than one model in an operation.
6. Composed Views and AJAX Pagination
Usability, or "UI is king!" is one of Trailblazer's maxims. We walk through advanced Cells features, learn how to embedd forms into existing pages, break Rails' "RESTfulness" and discuss AJAX-backed pagination with Cells.
7. Mastering Forms
Forms are an integral part of Trailblazer. They orchestrate deserialization of input, population and validation. The seventh chapter really dives into Reform, dynamic population, skipping nested items, form inheritance and removing items from collections. We also discuss Non-CRUD behavior and how operation and form work together to expose more than just plain CRUD semantics.
Callbacks in Trailblazer no longer sit in one huge model file but get restructured in operations. Sending email notifications, adding and inheriting callbacks, and the structure of operations are the main content of this chapter. A discussion about view caching and expiring those via callbacks will prepare you to write advanced operations.
A section about file uploads will make sure this chapter covers all major parts of post-processing business logic.
Operations are the perfect place for authentication logic. We will implement sign in, sign up, mail notifications, and many more authentication-related functions in this chapter. Strong tests will make sure only authenticated users get access to certain parts of the application.
You will learn how the Tyrant gem helps implementing authentication workflows without all the pain you've had with Devise.
10. Policies and Authorization
Policies are a technique to restrict users to specific operations and UI elements. But, there's more to it. Using policies and builders, we can use polymorphism to map operations to different contexts, like anonymous users or admins. We'll refine our forms and UI for specific user types in this chapter and learn everything about policies to protect your functions from unauthorized use.
11. Hypermedia APIs: Rendering
Operations in Trailblazer integrate with representers from the Representable/Roar gem. This helps quickly setting up document APIs. This chapter discusses how representers can be inferred, specified and explicitly created to render things, comments, and their associations following the HAL media format.
12. Hypermedia APIs: Deserialization
The hardest part of API code is the deserialization: parsing documents into object graphs. Trailblazer leverages representers to parse incoming documents directly to your operation's contract, and this chapter explains all you got to know to understand every step of it.
This is punk! Trailblazer breaks with the established MVC dogma. This book has a bigger scope than Ruby and Rails, it's about architecture and good design. Nick made the book easy to read with some condiments of humor and lifestyle.
The Trailblazer book smacks you in the face with a very well reasoned argument for a new architecture for Rails, Nick escorts the reader to a complete understanding of both the motivation behind Trailblazer and the effective use of it.
Yuri Freire Lima
Trailblazer helps organize my code, the book showed me how. It's very easy and intuitive, it should be shipped as an essential part of Rails.
Trailblazer has saved me from the ninth level of development hell. The book is one of the most well-written technical books I've ever had the pleasure (yes, PLEASURE) of reading. Buy it if you value your time and sanity.
CTO of Workshare
Trailblazer does as much for Rails as Ruby did. An amazing book and a fundamentally new way of thinking about RoR. This book is humorous, comforting and packed with insight and pragmatism. A must read for anyone committed to Rails and OO programming.
Haven't been this excited about Rails since 2007, Trailblazer - makes Rails development fun again. Especially on big projects. It's one of the better implementations of the ServiceObject / ViewModel / Policy layers I've seen.
Trailblazer has brought the fun back to Rails for me. Nick’s years of insight in software architecture have been distilled into this helpful primer, explaining his thought process for organizing real, complex apps. Highly recommended!
I searched for a long time to bring my Rails apps to the next level. TRB goes further than classic MVC and helpers - it's exactly how I imagined my structure. The book helped me a lot to understand how Trailblazer works and what the author's thinking. A must read and learn!
- How To Read This Book
- The Missing Architecture
- Learnings About Reality
The Trailblazer Architectural Style
- Why Trailblazer?
- A Non Intrusive Framework
- Trailblazer In A Nutshell
- Logicless Models
- Concepts and File Structure
- High-Level Domain
- High-Level Architecture
- Inheritance Over Configuration
- Authorization And Policy
- API: Parsing and Rendering
- Using Hypermedia
- Rendering Views
- A Note On Complexity
Operations And Forms
- The Example app
- The Create Operation
- Reform: Form Objects
- Operation’s Form Integration
- Model Semantics
- Rendering Forms
- Testing Validations
- Testing Controllers: Integration Tests
- Update Operation
- Reform and strong_parameters
- Rails Views and Encapsulation
- View Models
- Modelling the UI with Cells
- Anatomy of a Cell
- Rendering Collections
- Integration Tests
- Cell Tests
- Nesting Cells
- Rails and MVC
- Final Test Setup
- Adding Comments
- The Comment Concept
- Nested Contracts
- Pre-populating Forms
- Form Processing
- Populating Forms for Validation
- Saving Nested Objects
- Flash messages and Redirecting
- Readers for Operations
- Static Form Population
- Form Presentation Helpers
- Pre-selecting Values
- Operation and Form Tests
- Multiple Operations for Composed Pages
- Form Submission: Widgets vs. “RESTful”
- Writing a Cells Feature
- Application-wide Features
- Simple Decorator Helpers
- Rails’ View Architecture
- Kaminari Pagination and Cells
- AJAX Pagination with Cells
- On Controller Structuring
- Cells Tests
- Smoke Tests
- Things and Authors
- Adding Authors
- Dynamic Prepopulation
- Validation Population
- Skipping Blanks
- Form Debugging Techniques
- Adding Authorships
- Non-CRUD Behavior
- Complex Validations
- Testing Create
- Presentation Tests
- Updating Things
- Hacking the View
- Helpers in Forms
- Form Inheritance
- Virtual Properties
- Persisting the Deletion
- Testing Update
- Extracting Forms to Separate Files
- Domain Callbacks
- The Persisted Module
- Explicit Callbacks
- Imperative Callbacks
- Callbacks in Operations
- Testing Callbacks
- View Caching
- Cache Keys
- Expiring Keys
- Debugging View Caching
- Caching Composed Views
- The CacheVersion Pattern
- File Uploads
- File Validations
- Callback Groups
- Rendering Images
- Testing Uploads
- Populating by ID
- Sign Up
- SignUp Form
- Testing SignUp
- Sign In
- Modelless Forms
- Application-wide Tyrant
- A Warm Greeting
- Signing Out
- Testing Logins
- Putting Users to Sleep
- Waking Up Sleeping Users
- Integration Tests for Wake Up
Authorization And Polymorphism
- Operation Inheritance
- Polymorphic Builders
- Refining Operations with Modules
- Polymorphic Testing
- Polymorphic Views
- Integration Test: Create
- Composable Operations
- Update Tests
Hypermedia APIs: Rendering
- File Structure
- Rendering Comments
- HAL Hypermedia Links
- GET Controller
- Inferring Representer
- Composing Representer
- Rendering Nested Documents
- Scopes and Sorting
- Index Operation
- Lonely Collections
Hypermedia APIs: Deserialization
- Deserialization in Trailblazer
- Parsing Comment
- Deserialization and Contract
- Deserialization in Reform
- Deserializing HAL
- Polymorphic Update
- Basic Auth
- Discussion: Polymorphic Operations and APIs
- This Book
- Why Not a New Framework?
The Leanpub 45-day 100% Happiness Guarantee
Within 45 days of purchase you can get a 100% refund on any Leanpub purchase, in two clicks.
See full terms
Free Updates. DRM Free.
If you buy a Leanpub book, you get free updates for as long as the author updates the book! Many authors use Leanpub to publish their books in-progress, while they are writing them. All readers get free updates, regardless of when they bought the book or how much they paid (including free).
Most Leanpub books are available in PDF (for computers), EPUB (for phones and tablets) and MOBI (for Kindle). The formats that a book includes are shown at the top right corner of this page.
Finally, Leanpub books don't have any DRM copy-protection nonsense, so you can easily read them on any supported device.
El Manual del ManagerKeyvan Akbary, Félix López, and Álvaro Salazar
¿Has deseado alguna vez el haber tenido una buena introducción al rol del Engineering Manager? En este libro aprenderás lo necesario para ejercer el rol de una manera efectiva: Expectativas y Responsabilidades del Rol, 1-1s, Ayudar a Crecer, Objetivos, Planes de Carrera, Cultura, Feedback, Contratación, Cultura de Producto y mucho más.
Ansible for KubernetesJeff Geerling
Ansible is a powerful infrastructure automation tool. Kubernetes is a powerful application deployment platform. Learn how to use these tools to automate massively-scalable, highly-available infrastructure.
Functional Design and ArchitectureAlexander Granin
Software Design in Functional Programming, Design Patterns and Practices, Methodologies and Application Architectures. How to build real software in Haskell with less efforts and low risks. The first complete source of knowledge.
CCIE Service Provider Version 4 Written and Lab Exam Comprehensive GuideNicholas Russo
The service provider landscape has changed rapidly over the past several years. Networking vendors are continuing to propose new standards, techniques, and procedures for overcoming new challenges while concurrently reducing costs and delivering new services. Cisco has recently updated the CCIE Service Provider track to reflect these changes; this book represents the author's personal journey in achieving that certification.
CCIE SP v4.1 - WorkbookŁukasz Bromirski, Piotr Jablonski, and Nicholas Russo
Are you striving to prepare to and pass CCIE SP lab exam? Take the opportunity and get this workbook! With the attached initial cfg files you will prepare yourself for the CCIE SP exam as well as learn SP technologies applicable to all kinds of today modern networks! This workbook covers blueprint topics and provides challenging examples.
Ansible for DevOpsJeff Geerling
Ansible is a simple, but powerful, server and configuration management tool. Learn to use Ansible effectively, whether you manage one server—or thousands.
Code Faster in DelphiAlister Christie
This book will make you a faster Delphi developer, it doesn't matter if you are just starting out, or have been using Delphi since version 1, you will find all sorts of tips, tricks and hacks to boost your productivity.
R Programming for Data ScienceRoger D. Peng
This book brings the fundamentals of R programming to you, using the same material developed as part of the industry-leading Johns Hopkins Data Science Specialization. The skills taught in this book will lay the foundation for you to begin your journey learning data science. Printed copies of this book are available through Lulu.
Practical FP in Scala: A hands-on approachGabriel Volpe
A practical book aimed for those familiar with functional programming in Scala who are yet not confident about architecting an application from scratch.
Together, we will develop a purely functional application using the best libraries in the Cats ecosystem, while learning about design patterns and best practices.
Cloud StrategyGregor Hohpe
“Strategy is the difference between making a wish and making it come true.” A successful migration to the cloud shouldn’t be driven by wishes, but guided by a sound strategy, frameworks, and decision models. This book tells you how—without becoming superficial nor getting lost in technology and product details.
11 BooksThe Quality Software Bundle is for managers, would-be managers, and any of us who find themselves being managed and confused. This comprehensive bundle covers the entire span of software development approaches, from hacking through waterfall, cascade, prototyping, Iterative enhancement, reusable code, off-the-shelf, to Agile teams. The bundle...
11 BooksIn this bundle, you will find 10 different agile books. They are about different aspects of being agile. - finding a job - doing coding dojo's - Retrospectives - Personal kanban - a non-typical coaching book and even a book that gives you an insight in the lives of some agile people.
WTFlop 6M + HU - Beta Bundle
Fifty Quick Ideas
3 BooksGet all three books for the price of two! Fifty Quick Ideas books are full of practical, real-world techniques that you can use to improve teamwork, build better products and build them in a better way.
Growing Agile: Coach's Guide Series
4 BooksThis bundle provides a collection of training and workshop plans for a variety of agile topics. The series is aimed at agile coaches, trainers and ScrumMasters who often find themselves needing to help teams understand agile concepts. Each book in the series provides the plans, slides, handouts and activity instructions to run a number of...
Marionette.js A to Z
Complete Scala Bundle
3 BooksScala is a general-purpose programming language and it's getting extremely popular these days. Some say that learning Scala could be a challenging task. My experience, however, suggests that this is actually a myth that has very little to do with reality. With the right approach, learning Scala can be easy, fun and rewarding.The first book from...
Build A Better Backbone App
3 BooksThe best way to learn new development skills is through experience, but that takes time you don't have.Get the best of both worlds with this bundle: you'll learn how to produce modern web applications by learning from experienced developers like Derick Bailey and David Sulc. BackboneJS is one of the favorite tools on the web today, but it...
People Skills—Soft but Difficult
7 BooksPerhaps you've been told that "lack of people skills" has been holding you back. No wonder: you may have had hundreds of hours of technical training, but little or no "people skills" guidance.You've heard it said that people skills are "soft," whereas technical skills are "hard." For you, though, technical skills are "easy," but people skills...