plugins/solid/skills/solid-ruby/SKILL.md
SOLID principles for Ruby 3.3+ and Rails 8. Files < 100 lines, contracts separated, modular architecture. Modules MANDATORY.
npx skillsauth add fusengine/agents solid-rubyInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Before ANY implementation, use TeamCreate to spawn 3 agents:
Before writing ANY new code:
app/modules/core/services/, app/modules/core/contracts/app/modules/core/| Layer | Location | Max Lines |
|-------|----------|-----------|
| Controllers | app/modules/[feature]/controllers/ | 50 |
| Services | app/modules/[feature]/services/ | 100 |
| Repositories | app/modules/[feature]/repositories/ | 100 |
| Contracts | app/modules/[feature]/contracts/ | 30 |
| Models | app/modules/[feature]/models/ | 50 |
| Shared | app/modules/core/{services,contracts,concerns}/ | - |
NEVER use flat app/ structure - always app/modules/[feature]/
| Rule | Value |
|------|-------|
| File limit | 100 lines (split at 90) |
| Controllers | < 50 lines, delegate to services |
| Contracts | contracts/ directory ONLY (duck typing modules) |
| YARD doc | Every public method documented |
| Frozen string | # frozen_string_literal: true in every file |
| Concerns | Use for shared behavior (like interfaces) |
| Topic | Reference | When to consult | |-------|-----------|-----------------| | SOLID Overview | solid-principles.md | Quick reference | | SRP | single-responsibility.md | Fat classes | | OCP | open-closed.md | Adding strategies | | LSP | liskov-substitution.md | Contracts | | ISP | interface-segregation.md | Fat modules | | DIP | dependency-inversion.md | Injection | | Architecture | architecture-patterns.md | Modular Rails |
| Template | When to use | |----------|-------------| | module.md | Feature module structure | | service.md | Business logic service | | contract.md | Duck typing contracts | | model.md | Active Record model | | error.md | Custom exceptions | | test.md | RSpec tests |
| Anti-Pattern | Fix |
|--------------|-----|
| Files > 100 lines | Split at 90 |
| Business logic in models | Extract to service |
| Fat controllers | Delegate to services |
| Flat app/ structure | Use app/modules/[feature]/ |
| God classes | Split by responsibility |
development
Use when optimizing entity-based / semantic SEO 2026. Covers entity maps, Google Knowledge Graph resolution, salience scoring, passage-level ranking, about/sameAs/knowsAbout schema, Cloud Natural Language API validation.
development
Use when running SEO, GEO, schema, Core Web Vitals, sitemap, hreflang, E-E-A-T, AI Overviews, technical SEO, or structured data tasks. Covers full-site audits, single-page analysis, schema markup, content quality, AI search optimization, local SEO, sitemap/robots, internal linking, semantic clustering, and search experience.
development
Use when optimizing search experience (SXO). Covers intent matching, user personas, user stories, page-type analysis, dwell time, scroll depth, pogo-sticking prevention.
development
Use when optimizing local SEO. Covers Google Business Profile, NAP consistency, citations, reviews acquisition, Local Pack ranking, location pages, LocalBusiness schema.