This is part of the Semicolon&Sons Code Diary - consisting of lessons learned on the job. You're in the architecture category.
Last Updated: 2025-01-18
Imagine you have the following structure:
controller -> model -> paypal (e.g. hits api through a method here)
This is a bad design because an ActiveRecord
model should only be responsible
for talking to the DB. It should not be responsible for API stuff wtih PayPal.
A better design would be:
controller -> orchestrator/service -> [paypal_api, model]
In what ways is this better?