gitlab-org--gitlab-foss/app/finders
Yorick Peterse 7a233b37cd
Remove code for dynamically generating routes
This adds a database migration that creates routes for any projects and
namespaces that don't already have one. We also remove the runtime code
for dynamically creating routes, as this is no longer necessary.
2018-07-25 16:41:29 +02:00
..
admin Remove code for dynamically generating routes 2018-07-25 16:41:29 +02:00
concerns
README.md
access_requests_finder.rb
autocomplete_users_finder.rb
branches_finder.rb
clusters_finder.rb
contributed_projects_finder.rb
environments_finder.rb
events_finder.rb
fork_projects_finder.rb
group_descendants_finder.rb
group_finder.rb
group_members_finder.rb
group_projects_finder.rb
groups_finder.rb Add min_access_level filter to groups API 2018-07-23 20:57:50 +02:00
issuable_finder.rb Add locked state to merge request API 2018-06-28 07:12:00 -07:00
issues_finder.rb
joined_groups_finder.rb
labels_finder.rb
members_finder.rb
merge_request_target_project_finder.rb
merge_requests_finder.rb Add locked state to merge request API 2018-06-28 07:12:00 -07:00
milestones_finder.rb
move_to_project_finder.rb
notes_finder.rb
personal_access_tokens_finder.rb
personal_projects_finder.rb Add an option to have a private profile on GitLab 2018-07-24 12:46:19 +00:00
pipeline_schedules_finder.rb
pipelines_finder.rb Add pipeline lists to GraphQL 2018-07-04 10:53:39 +02:00
projects_finder.rb Add min_access_level filter to projects API 2018-07-23 20:57:50 +02:00
runner_jobs_finder.rb
snippets_finder.rb
tags_finder.rb
todos_finder.rb Revert "Merge branch 'ee-5481-epic-todos' into 'master'" 2018-07-11 18:33:24 +02:00
union_finder.rb
user_recent_events_finder.rb Add an option to have a private profile on GitLab 2018-07-24 12:46:19 +00:00
users_finder.rb

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.