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 details database relations, associations, and custom queries in Hanami 2.x using rom-rb.
Relations declare how different tables link to one another. Use these association macros:
# app/relations/posts.rb
module MyApp
module Relations
class Posts < Hanami::DB::Relation
schema :posts, infer: true do
# belongs_to relationship
associations do
many_to_one :users, as: :author
end
end
end
end
end# app/relations/users.rb
module MyApp
module Relations
class Users < Hanami::DB::Relation
schema :users, infer: true do
# has_many relationship
associations do
one_to_many :posts, as: :posts
end
end
end
end
endCustom queries are defined directly as public methods in the Relation class. Use standard Sequel query builder patterns (like where, order, select):
class Users < Hanami::DB::Relation
schema :users, infer: true
# Reusable active scope filter
def active
where(status: "active")
end
# Lookup filter by attribute
def by_email(email)
where(email: email)
end
# Sorting query
def newest
order { created_at.desc }
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