Pass organization_id to SnippetsFinder in internal services
What does this MR do and why?
This MR updates internal services to pass organization_id to SnippetsFinder, positioning it immediately after the current_user parameter. This prepares for organization_id to become a required parameter in the future.
The organization_id is obtained from Current.organization.id and passed consistently across all internal services that use SnippetsFinder.
This is MR 3 of 3 in a planned rollout:
MR 1: Web Controllers (4 files) - MERGED ✅
Priority: HIGH - User-facing changes
Files:
app/controllers/dashboard/snippets_controller.rbapp/controllers/explore/snippets_controller.rbapp/controllers/projects/snippets_controller.rbapp/controllers/users_controller.rb
Status: !212826 (merged)
MR 2: API & GraphQL (3 files) - IN REVIEW
Priority: HIGH - External integrations
Files:
lib/api/snippets.rblib/api/project_snippets.rbapp/graphql/resolvers/concerns/resolves_snippets.rb
Status: !213784
MR 3: Internal Services (4 files) - THIS MR
Priority: MEDIUM - Backend functionality
Files:
app/finders/notes_finder.rbapp/services/projects/autocomplete_service.rbapp/services/snippets/count_service.rblib/gitlab/snippet_search_results.rb
Why last? Internal services with less direct user impact.
Specs updated in this MR:
-
spec/finders/notes_finder_spec.rb- added:with_current_organization -
spec/services/projects/autocomplete_service_spec.rb- added:with_current_organization -
spec/services/snippets/count_service_spec.rb- added:with_current_organization -
spec/lib/gitlab/snippet_search_results_spec.rb- added:with_current_organization
References
Related to #570399 Follow-up to !213784
Screenshots or screen recordings
N/A - Backend changes only
How to set up and validate locally
- Ensure the
Current.organizationmiddleware is enabled (should be default) - Run the updated specs to verify they pass:
bundle exec rspec spec/finders/notes_finder_spec.rb bundle exec rspec spec/services/projects/autocomplete_service_spec.rb bundle exec rspec spec/services/snippets/count_service_spec.rb bundle exec rspec spec/lib/gitlab/snippet_search_results_spec.rb
MR acceptance checklist
Evaluate this MR against the MR acceptance checklist. It helps you analyze changes to reduce risks in quality, performance, reliability, security, and maintainability.