1. 24 Oct, 2016 6 commits
    • Timothy Andrew's avatar
      Implement third round of review comments from @DouweM. · db0182e2
      Timothy Andrew authored
      Extract/mutate `params` in the `execute` method of the API services,
      rather than in `initialize`.
      db0182e2
    • Timothy Andrew's avatar
      Implement second round of review comments from @DouweM. · 1051087a
      Timothy Andrew authored
      - Pass `developers_and_merge` and `developers_can_push` in `params`
        instead of using keyword arguments.
      
      - Refactor a slightly complex boolean check to a simple `nil?` check.
      1051087a
    • Timothy Andrew's avatar
      Implement review comments from @DouweM. · b803bc7b
      Timothy Andrew authored
      b803bc7b
    • Timothy Andrew's avatar
      Implement review comments from @dbalexandre. · cef10ef7
      Timothy Andrew authored
      1. Don't have any EE-only code in CE. Ok to have CE-only code in EE.
      
      2. Use `case` instead of `if/elsif`
      cef10ef7
    • Timothy Andrew's avatar
      Update CHANGELOG · b116df7e
      Timothy Andrew authored
      b116df7e
    • Timothy Andrew's avatar
      Fix branch protection API. · f79f3a1d
      Timothy Andrew authored
      1. Previously, we were not removing existing access levels before
         creating new ones. This is not a problem for EE, but _is_ for CE,
         since we restrict the number of access levels in CE to 1.
      
      2. The correct approach is:
      
          CE -> delete all access levels before updating a protected branch
          EE -> delete developer access levels if "developers_can_{merge,push}" is switched off
      
      3. The dispatch is performed by checking if a "length: 1" validation is
         present on the access levels or not.
      
      4. Another source of problems was that we didn't put multiple queries in
         a transaction. If the `destroy_all` passes, but the `update` fails,
         we should have a rollback.
      
      5. Modifying the API to provide users direct access to CRUD access
         levels will make things a lot simpler.
      
      6. Create `create/update` services separately for this API, which
         perform the necessary data translation, before calling the regular
         `create/update` services. The translation code was getting too large
         for the API endpoint itself, so this move makes sense.
      f79f3a1d
  2. 22 Oct, 2016 13 commits
  3. 21 Oct, 2016 21 commits