Skip to content
Snippets Groups Projects
Select Git revision
  • move-gl-dropdown
  • improve-table-pagination-spec
  • move-markdown-preview
  • winh-fix-merge-request-spec
  • master default
  • index-namespaces-lower-name
  • winh-single-karma-test
  • 10-3-stable
  • 36782-replace-team-user-role-with-add_role-user-in-specs
  • winh-modal-internal-state
  • tz-ide-file-icons
  • 38869-milestone-select
  • update-autodevops-template
  • jivl-activate-repo-cookie-preferences
  • qa-add-deploy-key
  • docs-move-article-ldap
  • 40780-choose-file
  • 22643-manual-job-page
  • refactor-cluster-show-page-conservative
  • dm-sidekiq-versioning
  • v10.4.0.pre
  • v10.3.0
  • v10.3.0-rc5
  • v10.3.0-rc4
  • v10.3.0-rc3
  • v10.3.0-rc2
  • v10.2.5
  • v10.3.0-rc1
  • v10.0.7
  • v10.1.5
  • v10.2.4
  • v10.2.3
  • v10.2.2
  • v10.2.1
  • v10.3.0.pre
  • v10.2.0
  • v10.2.0-rc4
  • v10.2.0-rc3
  • v10.1.4
  • v10.2.0-rc2
40 results

protected_branch.rb

Forked from GitLab.org / GitLab FOSS
Source project has a limited visibility.
  • Timothy Andrew's avatar
    0a8aeb46
    Use `Gitlab::Access` to protected branch access levels. · 0a8aeb46
    Timothy Andrew authored
    1. It makes sense to reuse these constants since we had them duplicated
       in the previous enum implementation. This also simplifies our
       `check_access` implementation, because we can use
       `project.team.max_member_access` directly.
    
    2. Use `accepts_nested_attributes_for` to create push/merge access
       levels. This was a bit fiddly to set up, but this simplifies our code
       by quite a large amount. We can even get rid of
       `ProtectedBranches::BaseService`.
    
    3. Move API handling back into the API (previously in
       `ProtectedBranches::BaseService#translate_api_params`.
    
    4. The protected branch services now return a `ProtectedBranch` rather
       than `true/false`.
    
    5. Run `load_protected_branches` on-demand in the `create` action, to
       prevent it being called unneccessarily.
    
    6. "Masters" is pre-selected as the default option for "Allowed to Push"
       and "Allowed to Merge".
    
    7. These changes were based on a review from @rymai in !5081.
    0a8aeb46
    History
    Use `Gitlab::Access` to protected branch access levels.
    Timothy Andrew authored
    1. It makes sense to reuse these constants since we had them duplicated
       in the previous enum implementation. This also simplifies our
       `check_access` implementation, because we can use
       `project.team.max_member_access` directly.
    
    2. Use `accepts_nested_attributes_for` to create push/merge access
       levels. This was a bit fiddly to set up, but this simplifies our code
       by quite a large amount. We can even get rid of
       `ProtectedBranches::BaseService`.
    
    3. Move API handling back into the API (previously in
       `ProtectedBranches::BaseService#translate_api_params`.
    
    4. The protected branch services now return a `ProtectedBranch` rather
       than `true/false`.
    
    5. Run `load_protected_branches` on-demand in the `create` action, to
       prevent it being called unneccessarily.
    
    6. "Masters" is pre-selected as the default option for "Allowed to Push"
       and "Allowed to Merge".
    
    7. These changes were based on a review from @rymai in !5081.