CtrlK
BlogDocsLog inGet started
Tessl Logo

igmarin/rails-agent-skills

Curated library of 41 public AI agent skills for Ruby on Rails development. Organized by category: planning, testing, code-quality, ddd, engines, infrastructure, api, patterns, context, and orchestration. Covers code review, architecture, security, testing (RSpec), engines, service objects, DDD patterns, and TDD automation. Repository workflows remain documented in GitHub but are intentionally excluded from the Tessl tile.

95

1.77x
Quality

93%

Does it follow best practices?

Impact

96%

1.77x

Average score across 41 eval scenarios

SecuritybySnyk

Passed

No known issues

Overview
Quality
Evals
Security
Files

SKILL.mdskills/infrastructure/version-api/

name:
version-api
license:
MIT
description:
Implements REST API versioning strategies in Rails, covering URL path versioning, header-based versioning, deprecation policies, and maintaining backward compatibility across versions. Use when adding a new API version (v1, v2), planning API evolution, setting deprecation or sunset policies, or ensuring backward compatibility for existing consumers.
metadata:
{"version":"1.0.0","user-invocable":"true"}

Version API

Implement versioning strategies for Rails APIs.

Quick Reference

ConcernFile
Route namespacesconfig/routes.rb
Header versioningapp/controllers/concerns/api_versioning.rb
Deprecation headersapp/controllers/concerns/deprecatable.rb
Compatibility specsspec/requests/api/backward_compatibility_spec.rb

HARD-GATE

ALWAYS maintain backward compatibility for at least one major version
NEVER remove endpoints without deprecation period
ALWAYS version in URL path (/api/v1/) or Accept header, never in body

Core Process

  1. Choose strategy — URL path (/api/v1/) for public APIs; Accept header for internal/private APIs. See strategies.md for header-based versioning details and trade-offs.
  2. Add route namespace — Wrap new version resources in a namespace :v2 block in config/routes.rb:
    namespace :v1 do
      resources :users
    end
    
    namespace :v2 do
      resources :users
    end
  3. Create controllers — Inherit from the previous version's controller and override only changed actions:
    module V2
      class UsersController < V1::UsersController
        def index
          render json: User.all, only: [:id, :name, :email, :phone]
        end
      end
    end
    See EXAMPLES.md for additional inheritance patterns.
  4. Apply deprecation — Include Deprecatable in old-version controllers to emit Sunset and Deprecation response headers automatically via a before_action:
    module V1
      class UsersController < ApplicationController
        include Deprecatable
        # Override sunset_date on the class to set the retirement date:
        # def self.sunset_date = Date.new(2025, 6, 1)
      end
    end
  5. Run compatibility specs — Execute bundle exec rspec spec/requests/api/backward_compatibility_spec.rb to confirm no regressions before merging.
  6. Update documentation — Record the sunset date and migration guide for deprecated endpoints. See workflow.md for the full deprecation communication workflow.

Output Style

  1. Define versioning strategy explicitly.
  2. Document inheritance strategy.
  3. Show route definition and deprecation headers.
  4. Include compatibility specs to prevent breakage.
  5. Language — Must be in English unless explicitly requested otherwise.

Integration

SkillWhen to chain
generate-api-collectionWhen generating the updated API endpoints
test-engineWhen verifying specs for regressions

skills

infrastructure

README.md

server.json

tile.json