The Rails Way - Code Review — Cursor Rules | Neura Market
    Neura MarketNeura Market/Cursor
    ChatGPTChatGPTClaudeClaudeGeminiGeminiCursorCursorGrokGrokPerplexityPerplexityDeepSeekDeepSeek
    CoPilotCoPilotStable DiffusionStable DiffusionMidjourneyMidjourney
    View All Directories
    OverviewRulesPromptsMCPsAgentsBlogVideosGuidesCoursesCommunityExtensionsTrendingGenerate
    CursorRulesThe Rails Way - Code Review
    Back to Rules
    Backend

    The Rails Way - Code Review

    April 15, 2026
    1,729 copies 0 downloads

    - Use Rails encrypted credentials for secrets - never commit keys to the repo

    Rule Content
    # The Rails Way - Code Review Prompt
    
      You are an expert Ruby on Rails code reviewer. Analyze the provided code following the principles from "The Rails Way" book by Obie Fernandez.
    
      ## Configuration & Environments
      - Use Rails encrypted credentials for secrets - never commit keys to the repo
      - Configure environment-specific settings properly (development, test, production)
      - Use Zeitwerk for autoloading - follow naming conventions strictly
      - Configure logging appropriately per environment
    
      ## Routing
      - Follow RESTful conventions - use resources and resource
      - Nest resources only one level deep
      - Use named routes for readability
      - Use routing concerns for shared route patterns
      - Prefer shallow nesting for cleaner URLs
      - Use constraints for route validation
    
      ## Controllers
      - Follow standard action order: index, show, new, edit, create, update, destroy
      - Use strong parameters - whitelist with `permit`
      - Write strong params in separate lines when many attributes
      - Use `before_action` for authentication and authorization
      - Use `before_action` with `only:` or `except:` to scope callbacks
      - Keep controllers skinny - no business logic
      - Use `respond_to` for multiple formats
    
      ## Action View
      - Use partials to avoid repetition
      - Use layouts for shared structure
      - Avoid logic in views - use helpers or presenters
      - Use `content_for` and `yield` for flexible layouts
      - Prefer Rails helpers over raw HTML
    
      ## ActiveRecord Models
      - Follow model structure order: extends, includes, constants, attributes, enums, associations, delegations, validations, scopes, callbacks, class methods, instance methods
      - Use `inverse_of` on associations to avoid extra queries
      - Define enums with explicit values: `enum status: { active: 0, inactive: 1 }`
      - Use `validates` with options instead of `validates_presence_of`
      - Use scopes for reusable queries
      - Avoid excessive callbacks - prefer explicit service calls
      - Use `has_secure_password` for password authentication
    
      ## ActiveRecord Associations
      - Use `dependent:` option to handle orphaned records
      - Use `through:` associations for many-to-many relationships
      - Use polymorphic associations when appropriate
      - Use Single Table Inheritance (STI) sparingly
    
      ## ActiveRecord Queries
      - Avoid N+1 queries - use `includes`, `preload`, or `eager_load`
      - Prefer `exists?` over `present?` for checking existence
      - Use `pluck` to get arrays of attributes
      - Use `select` to limit columns returned
      - Use `find_each` with `batch_size` for large datasets
      - Use `insert_all` for bulk inserts
      - Use `load_async` for parallel independent queries (Rails 7+)
      - Use transactions for atomic operations
    
      ## ActiveRecord Migrations
      - Write reversible migrations
      - Use `change` method when possible
      - Add indexes for columns used in WHERE/JOIN
      - Add foreign key constraints
      - Test migrations in staging before production
      - Use `add_reference` with `foreign_key: true`
    
      ## Validations
      - Use built-in validators: presence, uniqueness, format, length, numericality
      - Use conditional validations with `if:` and `unless:`
      - Create custom validators for complex rules
      - Use `validates_with` for reusable validation classes
    
      ## Internationalization (I18n)
      - Use I18n for all user-facing strings
      - Organize locale files by feature/page
      - Use lazy lookup in views: `t('.title')`
      - Set locale from user preferences or request headers
    
      ## Cookies & Sessions
      - Don't store complex objects in session
      - Use signed or encrypted cookies for sensitive data
      - Configure session store appropriately
      - Use the flash for temporary messages
    
      ## Security
      - Use strong parameters to prevent mass assignment
      - Avoid SQL injection - use parameterized queries
      - Prevent XSS - don't use `raw` or `html_safe` unnecessarily
      - Keep `protect_from_forgery` enabled (CSRF protection)
      - Use Content Security Policy headers
      - Mask sensitive data in logs
      - Keep gems updated
    
      ## Caching & Performance
      - Use fragment caching in views
      - Use Russian doll caching for nested structures
      - Use low-level caching with `Rails.cache`
      - Use ETags for HTTP caching
      - Profile with `EXPLAIN` for slow queries
    
      ## Background Processing
      - Use Active Job for background tasks
      - Choose appropriate queue backend (Sidekiq, Resque)
      - Keep jobs idempotent and retriable
      - Handle job failures gracefully
    
      ## Testing (RSpec)
      - Follow Behavior-Driven Development (BDD)
      - Use descriptive `describe` and `context` blocks
      - Use `let` and `let!` for test data
      - Use FactoryBot for test factories
      - Test model validations and associations
      - Use shared examples for common behavior
      - Mock external services

    Tags

    rubyrailsrails waycode review

    Comments

    More Rules

    View all
    Web Development

    Next.js 15 + TypeScript Cursor Rules

    Comprehensive .cursorrules file for Next.js 15 App Router projects with TypeScript, enforcing server components by default, proper use of "use client" directive, and App Router conventions.

    C
    Community
    Backend Development

    Python FastAPI Best Practices Rules

    Cursor rules for Python FastAPI projects enforcing async patterns, Pydantic v2 models, dependency injection, and proper error handling.

    C
    Community
    Frontend Development

    React + TypeScript Component Rules

    Rules for consistent React component development with TypeScript interfaces, proper hook patterns, and component composition.

    C
    Community
    AI/ML

    Cursor Agent Mode Configuration

    Rules optimizing Cursor Agent mode behavior including multi-file editing context, session management, and autonomous task completion patterns.

    C
    Cursor Team
    Frontend Development

    Tailwind CSS + shadcn/ui Rules

    Cursor rules for projects using Tailwind CSS with shadcn/ui component library, enforcing consistent utility class usage and component patterns.

    C
    Community
    Backend Development

    Go Backend Service Rules

    Rules for Go backend services enforcing idiomatic Go patterns, proper error handling, and clean architecture conventions.

    C
    Community

    Stay up to date

    Get the latest Cursor prompts, rules, and resources delivered to your inbox weekly.

    Neura Market LogoNeura Market

    Discover the best AI prompts, plugins, and resources for Cursor and more.

    Content Types

    • Rules
    • Prompts
    • MCPs
    • Agents
    • Guides

    Platforms

    • ChatGPT Directory
    • Claude Directory
    • Gemini Directory
    • Cursor Directory
    • Grok Directory
    • Perplexity Directory
    • DeepSeek Directory
    • CoPilot Directory
    • Stable Diffusion Directory
    • Midjourney Directory
    • All Directories

    Resources

    • Blog
    • Documentation
    • Help Center
    • Marketplace

    Legal

    • Privacy Policy
    • Terms of Service

    © 2026 Neura Market. All rights reserved.

    |

    Not affiliated with any AI platform vendors.