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
module Api
module Changesets
class CreateUser < ROM::Changeset::Create
map do |attrs|
now = Time.now
attrs.merge(created_at: now, updated_at: now)
end
end
end
endclass UpdateUser < ROM::Changeset::Update
map do |attrs|
attrs.merge(updated_at: Time.now)
end
def allowed_keys
[:name, :email, :role]
end
# Never allow these fields to be mass-updated
def disallowed_keys
[:encrypted_password, :admin, :id]
end
endclass CreateUser < ROM::Changeset::Create
map do |attrs|
attrs.merge(created_at: Time.now)
end
def default_contract
Users::CreateContract.new
end
endThe changeset calls the contract before persisting. If validation fails, the changeset raises a ROM::CommandError.
# Chain: validate → set defaults → persist
users.changeset(CreateUser, attrs)
.map { |attrs| attrs.merge(created_by: current_user.id) }
.commitRSpec.describe Api::Changesets::CreateUser do
let(:changeset) { user_repo.users.changeset(described_class, attrs) }
context "with valid attrs" do
let(:attrs) { { email: "test@example.com", name: "Test" } }
it "creates a user with timestamps" do
result = changeset.commit
expect(result.email).to eq("test@example.com")
expect(result.created_at).to be_a(Time)
end
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