Curated library of atomic AI agent skills for Hanami, dry-rb, and ROM Ruby development. Covers actions, slices, repositories, relations, changesets, providers, DI, operations, TDD, CLI, views, routing, and validation. Shared Ruby process skills have moved to ruby-core-skills. Uses Markdown + Front-matter architecture.
92
94%
Does it follow best practices?
Impact
92%
1.33xAverage score across 35 eval scenarios
Passed
No known issues
This document compares traditional Rails ActiveRecord exception/save patterns against Hanami's monadic Result patterns.
| Rails (ActiveRecord) | Hanami 2.x (dry-monads Result Pattern) |
|---|---|
User.create!(attrs) (raises on failure) | create_user.call(attrs) → Success(user) or Failure(error) |
ActiveRecord::RecordInvalid exceptions | Failure({ code: :validation_failed, errors: ... }) (as values) |
rescue_from ActiveRecord::RecordNotFound | Pattern match Failure in Action and halt 404 |
if user.save; ...; else; ...; end | case result; in Success(v); ...; in Failure(e); ...; end |
| Service objects (custom class with raise) | dry-monads service objects returning Success/Failure |
before_action for sequential steps | Do notation (yield) for sequencing multiple operations |
# Rails Controller
def create
@user = User.create!(user_params)
deliver_welcome_email(@user)
render json: @user, status: :created
rescue ActiveRecord::RecordInvalid => e
render json: { errors: e.record.errors }, status: :unprocessable_entity
end# Hanami Action
def handle(request, response)
result = create_user.call(request.params[:user])
case result
in Success(user)
response.status = 201
response.body = UserSerializer.new(user).to_json
in Failure(error_payload)
response.status = 422
response.body = { error: error_payload }.to_json
end
enddocs
evals
scenario-1
scenario-2
scenario-3
scenario-4
scenario-5
scenario-6
scenario-7
scenario-8
scenario-9
scenario-10
scenario-11
scenario-12
scenario-13
scenario-14
scenario-15
scenario-16
scenario-17
scenario-18
scenario-19
scenario-20
scenario-21
scenario-22
scenario-23
scenario-24
scenario-25
scenario-26
scenario-27
scenario-28
scenario-29
scenario-30
scenario-31
scenario-32
scenario-33
scenario-34
scenario-35
skills
actions
build-json-api
create-action
handle-errors
validate-params
context
load-context
db
create-changeset
create-repository
define-relation
write-migration
dry-monads
handle-result-pattern
dry-rb
create-operation
create-validation-contract
providers
configure-providers
implement-di
review-security
routing
define-routes
slices
configure-slice
create-slice
extract-slice
review-slice-boundaries
test-slice