gitlab-org--gitlab-foss/app/finders
Thong Kuah f82c9dbe44 Use finder to decide to show note to user
Given the note is about how to interpret ancestor clusters, use the
finder which actually knows if there are any ancestor clusters to find
out if the note should be shown, rather than passing the same info via a
view to a helper

Added note about Kaminari.paginate_array

Link to followup issue too
2018-12-17 09:51:53 +13:00
..
admin
autocomplete Whitelist none method from ActiveRecord::Querying 2018-10-31 15:46:36 -03:00
concerns Whitelist none method from ActiveRecord::Querying 2018-10-31 15:46:36 -03:00
projects/serverless Introduce Knative Serverless Tab 2018-12-06 18:08:49 +00:00
README.md
access_requests_finder.rb
applications_finder.rb Disable offense on the appropriate line only !22296 2018-10-19 08:28:44 +09:00
awarded_emoji_finder.rb
branches_finder.rb Feature improved branch filter sorting 2018-10-11 14:25:30 +00:00
cluster_ancestors_finder.rb Use finder to decide to show note to user 2018-12-17 09:51:53 +13:00
clusters_finder.rb Abstract out project out of ClustersController 2018-11-01 19:36:58 +13:00
contributed_projects_finder.rb
environments_finder.rb
events_finder.rb Rails5: Passing a class as a value in an Active Record query is deprecated 2018-11-17 16:14:36 +01:00
fork_projects_finder.rb
group_descendants_finder.rb Fix default sorting for subgroups and projects list 2018-11-14 14:47:09 +01:00
group_finder.rb
group_labels_finder.rb Add subscribe filter to labels page 2018-10-04 10:24:50 +02:00
group_members_finder.rb
group_projects_finder.rb
groups_finder.rb Whitelist none method from ActiveRecord::Querying 2018-10-31 15:46:36 -03:00
issuable_finder.rb Remove trailing whitespace 2018-12-07 09:11:21 +00:00
issues_finder.rb Whitelist none method from ActiveRecord::Querying 2018-10-31 15:46:36 -03:00
joined_groups_finder.rb
labels_finder.rb Whitelist none method from ActiveRecord::Querying 2018-10-31 15:46:36 -03:00
license_template_finder.rb Backport project template API to CE 2018-10-05 11:34:43 +01:00
members_finder.rb
merge_request_target_project_finder.rb
merge_requests_finder.rb Remove vestigial method from MergeRequestsFinder 2018-10-04 10:40:16 +01:00
milestones_finder.rb Whitelist none method from ActiveRecord::Querying 2018-10-31 15:46:36 -03:00
notes_finder.rb Resolve "Filter discussion (tab) by comments or activity in issues and merge requests" 2018-10-23 09:49:45 +00:00
pending_todos_finder.rb Clean up ActiveRecord code in TodoService 2018-10-08 15:19:12 +02:00
personal_access_tokens_finder.rb Remove PersonalAccessTokensFinder#find_by method 2018-11-05 11:36:45 +01:00
personal_projects_finder.rb
pipeline_schedules_finder.rb
pipelines_finder.rb Rename project's pipelines relation 2018-12-05 14:39:15 +00:00
projects_finder.rb Whitelist none method from ActiveRecord::Querying 2018-10-31 15:46:36 -03:00
remote_mirror_finder.rb Send a notification email on mirror update errors 2018-12-11 23:08:17 -03:00
runner_jobs_finder.rb
snippets_finder.rb Rewrite SnippetsFinder to improve performance 2018-11-05 14:28:29 +01:00
tags_finder.rb
template_finder.rb Backport project template API to CE 2018-10-05 11:34:43 +01:00
todos_finder.rb Clean up ActiveRecord code in TodoService 2018-10-08 15:19:12 +02:00
union_finder.rb
user_finder.rb Make getting a user by the username case insensitive 2018-10-18 09:06:44 +00:00
user_recent_events_finder.rb Resolve "Add new "Overview" tab on user profile page" 2018-10-04 07:55:37 +00:00
users_finder.rb Make getting a user by the username case insensitive 2018-10-18 09:06:44 +00:00
users_with_pending_todos_finder.rb Clean up ActiveRecord code in TodoService 2018-10-08 15:19:12 +02:00

README.md

Finders

This type of classes responsible for collection items based on different conditions. To prevent lookup methods in models like this:

class Project
  def issues_for_user_filtered_by(user, filter)
    # A lot of logic not related to project model itself
  end
end

issues = project.issues_for_user_filtered_by(user, params)

Better use this:

issues = IssuesFinder.new(project, user, filter).execute

It will help keep models thiner.