1. 24 May, 2016 4 commits
    • Valery Sizov's avatar
      Merge branch 'es_update_guide_addition' into 'master' · b84ab91a
      Valery Sizov authored
      Add one more ES note to 8.8 update guide
      
      
      
      See merge request !406
      b84ab91a
    • Robert Speicher's avatar
      Merge branch 'ce/merge-rubocop-changes' into 'master' · dde8875e
      Robert Speicher authored
      Merge Rubocop changes introduced in CE
      
      This MR merges rubocop changes introduced in EE in https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/4261 and also fixes offenses detected after enabling these cops.
      
      See merge request !414
      dde8875e
    • Grzegorz Bizon's avatar
      47931f8c
    • Robert Speicher's avatar
      Merge branch 'complexity/enable-multiple-rubocop-cops' into 'master' · fb2577cd
      Robert Speicher authored
      Enable multiple Rubocop cops that can be enabled
      
      See https://gitlab.com/gitlab-org/gitlab-ce/issues/17406
      
      This enabled following cops:
      
      ```text
      Lint/CircularArgumentReference:
        Description: Default values in optional keyword arguments and optional ordinal arguments
      ----------------
      Lint/ConditionPosition:
        Description: Checks for condition placed in a confusing position relative to the keyword.
        StyleGuide: https://github.com/bbatsov/ruby-style-guide#same-line-condition
      ----------------
      Lint/Debugger:
        Description: Check for debugger calls.
      ----------------
      Lint/DefEndAlignment:
        Description: Align ends corresponding to defs correctly.
      ----------------
      Lint/DuplicateMethods:
        Description: Check for duplicate method definitions.
      ----------------
      Lint/DuplicatedKey:
        Description: Check for duplicate keys in hash literals.
      ----------------
      Lint/EachWithObjectArgument:
        Description: Check for immutable argument given to each_with_object.
      ----------------
      Lint/ElseLayout:
        Description: Check for odd code arrangement in an else block.
      ----------------
      Lint/EmptyEnsure:
        Description: Checks for empty ensure block.
      ----------------
      Lint/EmptyInterpolation:
        Description: Checks for empty string interpolation.
      ----------------
      Lint/EndAlignment:
        Description: Align ends correctly.
      ----------------
      Lint/EndInMethod:
        Description: END blocks should not be placed inside method definitions.
      ----------------
      Lint/EnsureReturn:
        Description: Do not use return in an ensure block.
        StyleGuide: https://github.com/bbatsov/ruby-style-guide#no-return-ensure
      ----------------
      Lint/Eval:
        Description: The use of eval represents a serious security risk.
      ----------------
      Lint/FloatOutOfRange:
        Description: Catches floating-point literals too large or small for Ruby to represent.
      ----------------
      Lint/FormatParameterMismatch:
        Description: The number of parameters to format/sprint must match the fields.
      ----------------
      Lint/ImplicitStringConcatenation:
        Description: Checks for adjacent string literals on the same line, which could better
          be represented as a single string literal.
      ----------------
      Lint/InvalidCharacterLiteral:
        Description: Checks for invalid character literals with a non-escaped whitespace character.
      ----------------
      Lint/LiteralInInterpolation:
        Description: Checks for literals used in interpolation.
      ----------------
      Lint/NestedMethodDefinition:
        Description: Do not use nested method definitions.
        StyleGuide: https://github.com/bbatsov/ruby-style-guide#no-nested-methods
      ----------------
      Lint/NextWithoutAccumulator:
        Description: Do not omit the accumulator when calling `next` in a `reduce`/`inject`
          block.
      ----------------
      Lint/RandOne:
        Description: Checks for `rand(1)` calls. Such calls always return `0` and most likely
          a mistake.
      ----------------
      Lint/RequireParentheses:
        Description: Use parentheses in the method call to avoid confusion about precedence.
      ----------------
      Lint/UnreachableCode:
        Description: Unreachable code.
      ----------------
      Lint/UselessComparison:
        Description: Checks for comparison of something with itself.
      ----------------
      Lint/UselessElseWithoutRescue:
        Description: Checks for useless `else` in `begin..end` without `rescue`.
      ----------------
      Lint/UselessSetterCall:
        Description: Checks for useless setter call to a local variable.
      ----------------
      Lint/Void:
        Description: Possible use of operator/literal/variable in void context.
      ----------------
      Performance/DoubleStartEndWith:
        Description: Use `str.{start,end}_with?(x, ..., y, ...)` instead of `str.{start,end}_with?(x,
          ...) || str.{start,end}_with?(y, ...)`.
      ----------------
      Performance/RedundantSortBy:
        Description: Use `sort` instead of `sort_by { |x| x }`.
      ----------------
      Rails/FindBy:
        Description: Prefer find_by over where.first.
        Include:
        - app/models/**/*.rb
      ----------------
      Rails/FindEach:
        Description: Prefer all.find_each over all.find.
        Include:
        - app/models/**/*.rb
      ----------------
      Rails/PluralizationGrammar:
        Description: Checks for incorrect grammar when using methods like `3.day.ago`.
      ----------------
      Rails/ScopeArgs:
        Description: Checks the arguments of ActiveRecord scopes.
        Include:
        - app/models/**/*.rb
      ```
      
      See merge request !4261
      fb2577cd
  2. 23 May, 2016 1 commit
  3. 21 May, 2016 3 commits
    • Gabriel Mazetto's avatar
      Merge branch 'feature/geo-single-signout' into 'master' · 97c33da9
      Gabriel Mazetto authored
      Geo: Single Sign Out
      
      Implements Single Sign Out for Geo (#76).
      
      Initial proposal was to generate a hash based on the `access_token`, but that created a O(N) cost against a desirable O(1), as a new `access_token` is generated for each new login. To overcome that cost we would need to send a "public identifier" to help retrieve the correct `access_token` and provide that during login process.
      
      This is also how most Single Sign On implementations works (they provide some sort of session_id, that we notify every node to invalidate, during sign out process).
      
      As I don't want to modify our OAuth table (that is managed by doorkeeper) nor change the way our login process work, the solution is to encrypt the `access_token` using a symmetric key known by both nodes, and expire the `access_token` after the logout to prevent replay attacks (otherwise we would need to send a `nounce` and store that on primary). 
      
      The key is based on `Gitlab::Application.secrets.db_key_base` which we already use to encrypt database attributes and is synced between both nodes. We communicate sending a `state` parameter which is known terminology in OAuth protocol.
      
      Although this is implemented with Geo only in mind, we can backport to CE (with minimal changes) and provide as a "non-standard" way of single sign off for applications that integrate with GitLab.
      
      Fixes #522 
      
      See merge request !380
      97c33da9
    • Gabriel Mazetto's avatar
      Fixed specs · 33d52209
      Gabriel Mazetto authored
      33d52209
    • Gabriel Mazetto's avatar
      More codestyle changes 💄 · 5475a96c
      Gabriel Mazetto authored
      5475a96c
  4. 20 May, 2016 5 commits
  5. 19 May, 2016 5 commits
  6. 18 May, 2016 8 commits
  7. 17 May, 2016 2 commits
  8. 16 May, 2016 12 commits