gitlab-org--gitlab-foss/app/helpers
Timothy Andrew 60245bbe22 Refactor `Gitlab::GitAccess`
1. Don't use case statements for dispatch anymore. This leads to a lot
   of duplication, and makes the logic harder to follow.

2. Remove duplicated logic.

    - For example, the `can_push_to_branch?` exists, but we also have a
      different way of checking the same condition within `change_access_check`.

    - This kind of duplication is removed, and the `can_push_to_branch?`
      method is used in both places.

3. Move checks returning true/false to `UserAccess`.

    - All public methods in `GitAccess` now return an instance of
      `GitAccessStatus`. Previously, some methods would return
      true/false as well, which was confusing.

    - It makes sense for these kinds of checks to be at the level of a
      user, so the `UserAccess` class was repurposed for this. The prior
      `UserAccess.allowed?` classmethod is converted into an instance
      method.

    - All external uses of these checks have been migrated to use the
      `UserAccess` class

4. Move the "change_access_check" into a separate class.

    - Create the `GitAccess::ChangeAccessCheck` class to run these
      checks, which are quite substantial.

    - `ChangeAccessCheck` returns an instance of `GitAccessStatus` as
      well.

5. Break out the boolean logic in `ChangeAccessCheck` into `if/else`
   chains - this seems more readable.

6. I can understand that this might look like overkill for !4892, but I
   think this is a good opportunity to clean it up.

    - http://martinfowler.com/bliki/OpportunisticRefactoring.html
2016-07-13 13:24:56 +05:30
..
appearances_helper.rb
application_helper.rb
application_settings_helper.rb
auth_helper.rb
blob_helper.rb
branches_helper.rb Refactor `Gitlab::GitAccess` 2016-07-13 13:24:56 +05:30
broadcast_messages_helper.rb
button_helper.rb
ci_status_helper.rb
commits_helper.rb
compare_helper.rb
dashboard_helper.rb
diff_helper.rb
dropdowns_helper.rb
emails_helper.rb
events_helper.rb
explore_helper.rb
external_wiki_helper.rb
form_helper.rb
git_helper.rb
gitlab_markdown_helper.rb
gitlab_routing_helper.rb
graph_helper.rb
groups_helper.rb
icons_helper.rb
import_helper.rb
issuables_helper.rb
issues_helper.rb
javascript_helper.rb
kerberos_spnego_helper.rb
labels_helper.rb
members_helper.rb
merge_requests_helper.rb
milestones_helper.rb
namespaces_helper.rb
nav_helper.rb
notes_helper.rb
notifications_helper.rb
page_layout_helper.rb
preferences_helper.rb
projects_helper.rb
runners_helper.rb
search_helper.rb
selects_helper.rb
snippets_helper.rb
sorting_helper.rb
submodule_helper.rb
tab_helper.rb
tags_helper.rb
time_helper.rb
todos_helper.rb
tree_helper.rb
triggers_helper.rb
version_check_helper.rb
visibility_level_helper.rb
workhorse_helper.rb