opaque_id 1.6.0 → 1.7.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.ruby-version +1 -0
- data/lib/generators/opaque_id/install_generator.rb +13 -0
- data/lib/generators/opaque_id/templates/migration.rb.tt +3 -3
- data/lib/opaque_id/model.rb +2 -2
- data/lib/opaque_id/version.rb +1 -1
- metadata +2 -34
- data/.cursor/rules/create-prd.md +0 -56
- data/.cursor/rules/generate-tasks.md +0 -60
- data/.cursor/rules/process-task-list.md +0 -47
- data/.release-please-manifest.json +0 -3
- data/.rubocop.yml +0 -31
- data/CHANGELOG.md +0 -355
- data/CODE_OF_CONDUCT.md +0 -132
- data/README.md +0 -1676
- data/docs/.gitignore +0 -5
- data/docs/404.html +0 -25
- data/docs/Gemfile +0 -31
- data/docs/Gemfile.lock +0 -335
- data/docs/_config.yml +0 -153
- data/docs/_data/navigation.yml +0 -132
- data/docs/_includes/footer_custom.html +0 -8
- data/docs/_includes/head_custom.html +0 -67
- data/docs/algorithms.md +0 -412
- data/docs/alphabets.md +0 -524
- data/docs/api-reference.md +0 -597
- data/docs/assets/css/custom.scss +0 -751
- data/docs/assets/images/favicon.svg +0 -17
- data/docs/assets/images/og-image.svg +0 -65
- data/docs/configuration.md +0 -551
- data/docs/development.md +0 -570
- data/docs/getting-started.md +0 -259
- data/docs/index.md +0 -135
- data/docs/installation.md +0 -380
- data/docs/performance.md +0 -491
- data/docs/robots.txt +0 -11
- data/docs/security.md +0 -601
- data/docs/usage.md +0 -417
- data/docs/use-cases.md +0 -572
- data/release-please-config.json +0 -56
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA256:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: e8ecaac8e253d608534f43358e65fe09a3046dadba2018d851ecc35b132ec92b
         | 
| 4 | 
            +
              data.tar.gz: d39a09eea529bb1a9f62ab327a7177c3c8ebf2a45bff765a26f039bc62ae16ae
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: dc213093a081f2d5e329c42be5e7a78da843d423941e77299c79099f6972a42be201282f12ce896d09b9b114a349b41f11980382299ef7fdc0c27073833845f4
         | 
| 7 | 
            +
              data.tar.gz: 38c3d3d9795a5617effcfbeec5f7cd1557df2791af05b77f7527b73ec8be66d3c1e8bc4a82d5c89705d5472d2db78a6e6070af3746ad2e9a6b6d9d807efb7cbe
         | 
    
        data/.ruby-version
    ADDED
    
    | @@ -0,0 +1 @@ | |
| 1 | 
            +
            3.4.5
         | 
| @@ -15,8 +15,12 @@ module OpaqueId | |
| 15 15 | 
             
                  class_option :column_name, type: :string, default: 'opaque_id',
         | 
| 16 16 | 
             
                                             desc: 'Name of the column to add'
         | 
| 17 17 |  | 
| 18 | 
            +
                  class_option :limit, type: :numeric, default: 21,
         | 
| 19 | 
            +
                                       desc: 'Column limit for the opaque_id string (default: 21)'
         | 
| 20 | 
            +
             | 
| 18 21 | 
             
                  def create_migration_file
         | 
| 19 22 | 
             
                    if model_name.present?
         | 
| 23 | 
            +
                      validate_limit_option
         | 
| 20 24 | 
             
                      table_name = model_name.tableize
         | 
| 21 25 | 
             
                      migration_template 'migration.rb.tt',
         | 
| 22 26 | 
             
                                         "db/migrate/add_opaque_id_to_#{table_name}.rb"
         | 
| @@ -26,11 +30,20 @@ module OpaqueId | |
| 26 30 | 
             
                      say 'Usage: rails generate opaque_id:install ModelName', :red
         | 
| 27 31 | 
             
                      say 'Example: rails generate opaque_id:install User', :green
         | 
| 28 32 | 
             
                      say 'Example: rails generate opaque_id:install Post --column-name=public_id', :green
         | 
| 33 | 
            +
                      say 'Example: rails generate opaque_id:install Post --limit=25', :green
         | 
| 29 34 | 
             
                    end
         | 
| 30 35 | 
             
                  end
         | 
| 31 36 |  | 
| 32 37 | 
             
                  private
         | 
| 33 38 |  | 
| 39 | 
            +
                  def validate_limit_option
         | 
| 40 | 
            +
                    # Default OpaqueId length is 18, so limit should be at least that
         | 
| 41 | 
            +
                    return unless options[:limit] < 18
         | 
| 42 | 
            +
             | 
| 43 | 
            +
                    say "Warning: Column limit (#{options[:limit]}) is less than the default OpaqueId length (18).", :yellow
         | 
| 44 | 
            +
                    say 'Consider using --limit=21 or higher to avoid truncation issues.', :yellow
         | 
| 45 | 
            +
                  end
         | 
| 46 | 
            +
             | 
| 34 47 | 
             
                  def add_include_to_model
         | 
| 35 48 | 
             
                    model_path = "app/models/#{model_name.underscore}.rb"
         | 
| 36 49 |  | 
| @@ -1,6 +1,6 @@ | |
| 1 | 
            -
            class AddOpaqueIdTo<%=  | 
| 1 | 
            +
            class AddOpaqueIdTo<%= model_name.tableize.camelize %> < ActiveRecord::Migration[<%= ActiveRecord::Migration.current_version %>]
         | 
| 2 2 | 
             
              def change
         | 
| 3 | 
            -
                add_column :<%=  | 
| 4 | 
            -
                add_index :<%=  | 
| 3 | 
            +
                add_column :<%= model_name.tableize %>, :<%= options[:column_name] %>, :string, limit: <%= options[:limit] %>
         | 
| 4 | 
            +
                add_index :<%= model_name.tableize %>, :<%= options[:column_name] %>, unique: true
         | 
| 5 5 | 
             
              end
         | 
| 6 6 | 
             
            end
         | 
    
        data/lib/opaque_id/model.rb
    CHANGED
    
    | @@ -30,7 +30,7 @@ module OpaqueId | |
| 30 30 | 
             
                  end
         | 
| 31 31 |  | 
| 32 32 | 
             
                  def opaque_id_length
         | 
| 33 | 
            -
                    @opaque_id_length ||=  | 
| 33 | 
            +
                    @opaque_id_length ||= 18
         | 
| 34 34 | 
             
                  end
         | 
| 35 35 |  | 
| 36 36 | 
             
                  def opaque_id_length=(value)
         | 
| @@ -38,7 +38,7 @@ module OpaqueId | |
| 38 38 | 
             
                  end
         | 
| 39 39 |  | 
| 40 40 | 
             
                  def opaque_id_alphabet
         | 
| 41 | 
            -
                    @opaque_id_alphabet ||= OpaqueId:: | 
| 41 | 
            +
                    @opaque_id_alphabet ||= OpaqueId::SLUG_LIKE_ALPHABET
         | 
| 42 42 | 
             
                  end
         | 
| 43 43 |  | 
| 44 44 | 
             
                  def opaque_id_alphabet=(value)
         | 
    
        data/lib/opaque_id/version.rb
    CHANGED
    
    
    
        metadata
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: opaque_id
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 1. | 
| 4 | 
            +
              version: 1.7.7
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Joe Nyaggah
         | 
| @@ -115,47 +115,15 @@ executables: [] | |
| 115 115 | 
             
            extensions: []
         | 
| 116 116 | 
             
            extra_rdoc_files: []
         | 
| 117 117 | 
             
            files:
         | 
| 118 | 
            -
            - ".cursor/rules/create-prd.md"
         | 
| 119 | 
            -
            - ".cursor/rules/generate-tasks.md"
         | 
| 120 | 
            -
            - ".cursor/rules/process-task-list.md"
         | 
| 121 118 | 
             
            - ".cursorignore"
         | 
| 122 | 
            -
            - ". | 
| 123 | 
            -
            - ".rubocop.yml"
         | 
| 124 | 
            -
            - CHANGELOG.md
         | 
| 125 | 
            -
            - CODE_OF_CONDUCT.md
         | 
| 119 | 
            +
            - ".ruby-version"
         | 
| 126 120 | 
             
            - LICENSE.txt
         | 
| 127 | 
            -
            - README.md
         | 
| 128 121 | 
             
            - Rakefile
         | 
| 129 | 
            -
            - docs/.gitignore
         | 
| 130 | 
            -
            - docs/404.html
         | 
| 131 | 
            -
            - docs/Gemfile
         | 
| 132 | 
            -
            - docs/Gemfile.lock
         | 
| 133 | 
            -
            - docs/_config.yml
         | 
| 134 | 
            -
            - docs/_data/navigation.yml
         | 
| 135 | 
            -
            - docs/_includes/footer_custom.html
         | 
| 136 | 
            -
            - docs/_includes/head_custom.html
         | 
| 137 | 
            -
            - docs/algorithms.md
         | 
| 138 | 
            -
            - docs/alphabets.md
         | 
| 139 | 
            -
            - docs/api-reference.md
         | 
| 140 | 
            -
            - docs/assets/css/custom.scss
         | 
| 141 | 
            -
            - docs/assets/images/favicon.svg
         | 
| 142 | 
            -
            - docs/assets/images/og-image.svg
         | 
| 143 | 
            -
            - docs/configuration.md
         | 
| 144 | 
            -
            - docs/development.md
         | 
| 145 | 
            -
            - docs/getting-started.md
         | 
| 146 | 
            -
            - docs/index.md
         | 
| 147 | 
            -
            - docs/installation.md
         | 
| 148 | 
            -
            - docs/performance.md
         | 
| 149 | 
            -
            - docs/robots.txt
         | 
| 150 | 
            -
            - docs/security.md
         | 
| 151 | 
            -
            - docs/usage.md
         | 
| 152 | 
            -
            - docs/use-cases.md
         | 
| 153 122 | 
             
            - lib/generators/opaque_id/install_generator.rb
         | 
| 154 123 | 
             
            - lib/generators/opaque_id/templates/migration.rb.tt
         | 
| 155 124 | 
             
            - lib/opaque_id.rb
         | 
| 156 125 | 
             
            - lib/opaque_id/model.rb
         | 
| 157 126 | 
             
            - lib/opaque_id/version.rb
         | 
| 158 | 
            -
            - release-please-config.json
         | 
| 159 127 | 
             
            homepage: https://github.com/nyaggah/opaque_id
         | 
| 160 128 | 
             
            licenses:
         | 
| 161 129 | 
             
            - MIT
         | 
    
        data/.cursor/rules/create-prd.md
    DELETED
    
    | @@ -1,56 +0,0 @@ | |
| 1 | 
            -
            # Rule: Generating a Product Requirements Document (PRD)
         | 
| 2 | 
            -
             | 
| 3 | 
            -
            ## Goal
         | 
| 4 | 
            -
             | 
| 5 | 
            -
            To guide an AI assistant in creating a detailed Product Requirements Document (PRD) in Markdown format, based on an initial user prompt. The PRD should be clear, actionable, and suitable for a junior developer to understand and implement the feature.
         | 
| 6 | 
            -
             | 
| 7 | 
            -
            ## Process
         | 
| 8 | 
            -
             | 
| 9 | 
            -
            1.  **Receive Initial Prompt:** The user provides a brief description or request for a new feature or functionality.
         | 
| 10 | 
            -
            2.  **Ask Clarifying Questions:** Before writing the PRD, the AI *must* ask clarifying questions to gather sufficient detail. The goal is to understand the "what" and "why" of the feature, not necessarily the "how" (which the developer will figure out). Make sure to provide options in letter/number lists so I can respond easily with my selections.
         | 
| 11 | 
            -
            3.  **Generate PRD:** Based on the initial prompt and the user's answers to the clarifying questions, generate a PRD using the structure outlined below.
         | 
| 12 | 
            -
            4.  **Save PRD:** Save the generated document as `[n]-prd-[feature-name].md` inside the `/tasks` directory. (Where `n` is a zero-padded 4-digit sequence starting from 0001, e.g., `0001-prd-user-authentication.md`, `0002-prd-dashboard.md`, etc.)
         | 
| 13 | 
            -
             | 
| 14 | 
            -
            ## Clarifying Questions (Examples)
         | 
| 15 | 
            -
             | 
| 16 | 
            -
            The AI should adapt its questions based on the prompt, but here are some common areas to explore:
         | 
| 17 | 
            -
             | 
| 18 | 
            -
            *   **Problem/Goal:** "What problem does this feature solve for the user?" or "What is the main goal we want to achieve with this feature?"
         | 
| 19 | 
            -
            *   **Target User:** "Who is the primary user of this feature?"
         | 
| 20 | 
            -
            *   **Core Functionality:** "Can you describe the key actions a user should be able to perform with this feature?"
         | 
| 21 | 
            -
            *   **User Stories:** "Could you provide a few user stories? (e.g., As a [type of user], I want to [perform an action] so that [benefit].)"
         | 
| 22 | 
            -
            *   **Acceptance Criteria:** "How will we know when this feature is successfully implemented? What are the key success criteria?"
         | 
| 23 | 
            -
            *   **Scope/Boundaries:** "Are there any specific things this feature *should not* do (non-goals)?"
         | 
| 24 | 
            -
            *   **Data Requirements:** "What kind of data does this feature need to display or manipulate?"
         | 
| 25 | 
            -
            *   **Design/UI:** "Are there any existing design mockups or UI guidelines to follow?" or "Can you describe the desired look and feel?"
         | 
| 26 | 
            -
            *   **Edge Cases:** "Are there any potential edge cases or error conditions we should consider?"
         | 
| 27 | 
            -
             | 
| 28 | 
            -
            ## PRD Structure
         | 
| 29 | 
            -
             | 
| 30 | 
            -
            The generated PRD should include the following sections:
         | 
| 31 | 
            -
             | 
| 32 | 
            -
            1.  **Introduction/Overview:** Briefly describe the feature and the problem it solves. State the goal.
         | 
| 33 | 
            -
            2.  **Goals:** List the specific, measurable objectives for this feature.
         | 
| 34 | 
            -
            3.  **User Stories:** Detail the user narratives describing feature usage and benefits.
         | 
| 35 | 
            -
            4.  **Functional Requirements:** List the specific functionalities the feature must have. Use clear, concise language (e.g., "The system must allow users to upload a profile picture."). Number these requirements.
         | 
| 36 | 
            -
            5.  **Non-Goals (Out of Scope):** Clearly state what this feature will *not* include to manage scope.
         | 
| 37 | 
            -
            6.  **Design Considerations (Optional):** Link to mockups, describe UI/UX requirements, or mention relevant components/styles if applicable.
         | 
| 38 | 
            -
            7.  **Technical Considerations (Optional):** Mention any known technical constraints, dependencies, or suggestions (e.g., "Should integrate with the existing Auth module").
         | 
| 39 | 
            -
            8.  **Success Metrics:** How will the success of this feature be measured? (e.g., "Increase user engagement by 10%", "Reduce support tickets related to X").
         | 
| 40 | 
            -
            9.  **Open Questions:** List any remaining questions or areas needing further clarification.
         | 
| 41 | 
            -
             | 
| 42 | 
            -
            ## Target Audience
         | 
| 43 | 
            -
             | 
| 44 | 
            -
            Assume the primary reader of the PRD is a **junior developer**. Therefore, requirements should be explicit, unambiguous, and avoid jargon where possible. Provide enough detail for them to understand the feature's purpose and core logic.
         | 
| 45 | 
            -
             | 
| 46 | 
            -
            ## Output
         | 
| 47 | 
            -
             | 
| 48 | 
            -
            *   **Format:** Markdown (`.md`)
         | 
| 49 | 
            -
            *   **Location:** `/tasks/`
         | 
| 50 | 
            -
            *   **Filename:** `[n]-prd-[feature-name].md`
         | 
| 51 | 
            -
             | 
| 52 | 
            -
            ## Final instructions
         | 
| 53 | 
            -
             | 
| 54 | 
            -
            1. Do NOT start implementing the PRD
         | 
| 55 | 
            -
            2. Make sure to ask the user clarifying questions
         | 
| 56 | 
            -
            3. Take the user's answers to the clarifying questions and improve the PRD
         | 
| @@ -1,60 +0,0 @@ | |
| 1 | 
            -
            # Rule: Generating a Task List from a PRD
         | 
| 2 | 
            -
             | 
| 3 | 
            -
            ## Goal
         | 
| 4 | 
            -
             | 
| 5 | 
            -
            To guide an AI assistant in creating a detailed, step-by-step task list in Markdown format based on an existing Product Requirements Document (PRD). The task list should guide a developer through implementation.
         | 
| 6 | 
            -
             | 
| 7 | 
            -
            ## Output
         | 
| 8 | 
            -
             | 
| 9 | 
            -
            - **Format:** Markdown (`.md`)
         | 
| 10 | 
            -
            - **Location:** `/tasks/`
         | 
| 11 | 
            -
            - **Filename:** `tasks-[prd-file-name].md` (e.g., `tasks-0001-prd-user-profile-editing.md`)
         | 
| 12 | 
            -
             | 
| 13 | 
            -
            ## Process
         | 
| 14 | 
            -
             | 
| 15 | 
            -
            1.  **Receive PRD Reference:** The user points the AI to a specific PRD file
         | 
| 16 | 
            -
            2.  **Analyze PRD:** The AI reads and analyzes the functional requirements, user stories, and other sections of the specified PRD.
         | 
| 17 | 
            -
            3.  **Assess Current State:** Review the existing codebase to understand existing infrastructre, architectural patterns and conventions. Also, identify any existing components or features that already exist and could be relevant to the PRD requirements. Then, identify existing related files, components, and utilities that can be leveraged or need modification.
         | 
| 18 | 
            -
            4.  **Phase 1: Generate Parent Tasks:** Based on the PRD analysis and current state assessment, create the file and generate the main, high-level tasks required to implement the feature. Use your judgement on how many high-level tasks to use. It's likely to be about five tasks. Present these tasks to the user in the specified format (without sub-tasks yet). Inform the user: "I have generated the high-level tasks based on the PRD. Ready to generate the sub-tasks? Respond with 'Go' to proceed."
         | 
| 19 | 
            -
            5.  **Wait for Confirmation:** Pause and wait for the user to respond with "Go".
         | 
| 20 | 
            -
            6.  **Phase 2: Generate Sub-Tasks:** Once the user confirms, break down each parent task into smaller, actionable sub-tasks necessary to complete the parent task. Ensure sub-tasks logically follow from the parent task, cover the implementation details implied by the PRD, and consider existing codebase patterns where relevant without being constrained by them.
         | 
| 21 | 
            -
            7.  **Identify Relevant Files:** Based on the tasks and PRD, identify potential files that will need to be created or modified. List these under the `Relevant Files` section, including corresponding test files if applicable.
         | 
| 22 | 
            -
            8.  **Generate Final Output:** Combine the parent tasks, sub-tasks, relevant files, and notes into the final Markdown structure.
         | 
| 23 | 
            -
            9.  **Save Task List:** Save the generated document in the `/tasks/` directory with the filename `tasks-[prd-file-name].md`, where `[prd-file-name]` matches the base name of the input PRD file (e.g., if the input was `0001-prd-user-profile-editing.md`, the output is `tasks-0001-prd-user-profile-editing.md`).
         | 
| 24 | 
            -
             | 
| 25 | 
            -
            ## Output Format
         | 
| 26 | 
            -
             | 
| 27 | 
            -
            The generated task list _must_ follow this structure:
         | 
| 28 | 
            -
             | 
| 29 | 
            -
            ```markdown
         | 
| 30 | 
            -
            ## Relevant Files
         | 
| 31 | 
            -
             | 
| 32 | 
            -
            - `path/to/potential/file1.ts` - Brief description of why this file is relevant (e.g., Contains the main component for this feature).
         | 
| 33 | 
            -
            - `path/to/file1.test.ts` - Unit tests for `file1.ts`.
         | 
| 34 | 
            -
            - `path/to/another/file.tsx` - Brief description (e.g., API route handler for data submission).
         | 
| 35 | 
            -
            - `path/to/another/file.test.tsx` - Unit tests for `another/file.tsx`.
         | 
| 36 | 
            -
            - `lib/utils/helpers.ts` - Brief description (e.g., Utility functions needed for calculations).
         | 
| 37 | 
            -
            - `lib/utils/helpers.test.ts` - Unit tests for `helpers.ts`.
         | 
| 38 | 
            -
             | 
| 39 | 
            -
            ### Notes
         | 
| 40 | 
            -
             | 
| 41 | 
            -
            - Unit tests should typically be placed alongside the code files they are testing (e.g., `MyComponent.tsx` and `MyComponent.test.tsx` in the same directory).
         | 
| 42 | 
            -
            - Use `npx jest [optional/path/to/test/file]` to run tests. Running without a path executes all tests found by the Jest configuration.
         | 
| 43 | 
            -
             | 
| 44 | 
            -
            ## Tasks
         | 
| 45 | 
            -
             | 
| 46 | 
            -
            - [ ] 1.0 Parent Task Title
         | 
| 47 | 
            -
              - [ ] 1.1 [Sub-task description 1.1]
         | 
| 48 | 
            -
              - [ ] 1.2 [Sub-task description 1.2]
         | 
| 49 | 
            -
            - [ ] 2.0 Parent Task Title
         | 
| 50 | 
            -
              - [ ] 2.1 [Sub-task description 2.1]
         | 
| 51 | 
            -
            - [ ] 3.0 Parent Task Title (may not require sub-tasks if purely structural or configuration)
         | 
| 52 | 
            -
            ```
         | 
| 53 | 
            -
             | 
| 54 | 
            -
            ## Interaction Model
         | 
| 55 | 
            -
             | 
| 56 | 
            -
            The process explicitly requires a pause after generating parent tasks to get user confirmation ("Go") before proceeding to generate the detailed sub-tasks. This ensures the high-level plan aligns with user expectations before diving into details.
         | 
| 57 | 
            -
             | 
| 58 | 
            -
            ## Target Audience
         | 
| 59 | 
            -
             | 
| 60 | 
            -
            Assume the primary reader of the task list is a **junior developer** who will implement the feature with awareness of the existing codebase context.
         | 
| @@ -1,47 +0,0 @@ | |
| 1 | 
            -
            # Task List Management
         | 
| 2 | 
            -
             | 
| 3 | 
            -
            Guidelines for managing task lists in markdown files to track progress on completing a PRD
         | 
| 4 | 
            -
             | 
| 5 | 
            -
            ## Task Implementation
         | 
| 6 | 
            -
            - **One sub-task at a time:** Do **NOT** start the next sub‑task until you ask the user for permission and they say "yes" or "y"
         | 
| 7 | 
            -
            - **Completion protocol:**  
         | 
| 8 | 
            -
              1. When you finish a **sub‑task**, immediately mark it as completed by changing `[ ]` to `[x]`.
         | 
| 9 | 
            -
              2. If **all** subtasks underneath a parent task are now `[x]`, follow this sequence:
         | 
| 10 | 
            -
                - **First**: Run the full test suite (`pytest`, `npm test`, `bin/rails test`, etc.)
         | 
| 11 | 
            -
                - **Only if all tests pass**: Stage changes (`git add .`)
         | 
| 12 | 
            -
                - **Clean up**: Remove any temporary files and temporary code before committing
         | 
| 13 | 
            -
                - **Commit**: Use a descriptive commit message that:
         | 
| 14 | 
            -
                  - Uses conventional commit format (`feat:`, `fix:`, `refactor:`, etc.)
         | 
| 15 | 
            -
                  - Summarizes what was accomplished in the parent task
         | 
| 16 | 
            -
                  - Lists key changes and additions
         | 
| 17 | 
            -
                  - References the task number and PRD context
         | 
| 18 | 
            -
                  - **Formats the message as a single-line command using `-m` flags**, e.g.:
         | 
| 19 | 
            -
             | 
| 20 | 
            -
                    ```
         | 
| 21 | 
            -
                    git commit -m "feat: add payment validation logic" -m "- Validates card type and expiry" -m "- Adds unit tests for edge cases" -m "Related to T123 in PRD"
         | 
| 22 | 
            -
                    ```
         | 
| 23 | 
            -
              3. Once all the subtasks are marked completed and changes have been committed, mark the **parent task** as completed.
         | 
| 24 | 
            -
            - Stop after each sub‑task and wait for the user's go‑ahead.
         | 
| 25 | 
            -
             | 
| 26 | 
            -
            ## Task List Maintenance
         | 
| 27 | 
            -
             | 
| 28 | 
            -
            1. **Update the task list as you work:**
         | 
| 29 | 
            -
               - Mark tasks and subtasks as completed (`[x]`) per the protocol above.
         | 
| 30 | 
            -
               - Add new tasks as they emerge.
         | 
| 31 | 
            -
             | 
| 32 | 
            -
            2. **Maintain the "Relevant Files" section:**
         | 
| 33 | 
            -
               - List every file created or modified.
         | 
| 34 | 
            -
               - Give each file a one‑line description of its purpose.
         | 
| 35 | 
            -
             | 
| 36 | 
            -
            ## AI Instructions
         | 
| 37 | 
            -
             | 
| 38 | 
            -
            When working with task lists, the AI must:
         | 
| 39 | 
            -
             | 
| 40 | 
            -
            1. Regularly update the task list file after finishing any significant work.
         | 
| 41 | 
            -
            2. Follow the completion protocol:
         | 
| 42 | 
            -
               - Mark each finished **sub‑task** `[x]`.
         | 
| 43 | 
            -
               - Mark the **parent task** `[x]` once **all** its subtasks are `[x]`.
         | 
| 44 | 
            -
            3. Add newly discovered tasks.
         | 
| 45 | 
            -
            4. Keep "Relevant Files" accurate and up to date.
         | 
| 46 | 
            -
            5. Before starting work, check which sub‑task is next.
         | 
| 47 | 
            -
            6. After implementing a sub‑task, update the file and then pause for user approval.
         | 
    
        data/.rubocop.yml
    DELETED
    
    | @@ -1,31 +0,0 @@ | |
| 1 | 
            -
            AllCops:
         | 
| 2 | 
            -
              NewCops: enable
         | 
| 3 | 
            -
              SuggestExtensions: false
         | 
| 4 | 
            -
             | 
| 5 | 
            -
            # Disable some cops that are too strict for this gem
         | 
| 6 | 
            -
            Style/Documentation:
         | 
| 7 | 
            -
              Enabled: false
         | 
| 8 | 
            -
             | 
| 9 | 
            -
            Metrics/MethodLength:
         | 
| 10 | 
            -
              Max: 15
         | 
| 11 | 
            -
              Exclude:
         | 
| 12 | 
            -
                - "test/**/*"
         | 
| 13 | 
            -
             | 
| 14 | 
            -
            Metrics/AbcSize:
         | 
| 15 | 
            -
              Max: 20
         | 
| 16 | 
            -
              Exclude:
         | 
| 17 | 
            -
                - "test/**/*"
         | 
| 18 | 
            -
             | 
| 19 | 
            -
            Metrics/ModuleLength:
         | 
| 20 | 
            -
              Max: 120
         | 
| 21 | 
            -
             | 
| 22 | 
            -
            Metrics/BlockLength:
         | 
| 23 | 
            -
              Max: 70
         | 
| 24 | 
            -
             | 
| 25 | 
            -
            Metrics/ClassLength:
         | 
| 26 | 
            -
              Max: 200
         | 
| 27 | 
            -
              Exclude:
         | 
| 28 | 
            -
                - "test/**/*"
         | 
| 29 | 
            -
             | 
| 30 | 
            -
            Gemspec/DevelopmentDependencies:
         | 
| 31 | 
            -
              Enabled: false
         |