Commit 3ff4bf36 authored by GitLab Bot's avatar GitLab Bot

Merge remote-tracking branch 'upstream/master' into ce-to-ee-2018-10-01

# Conflicts:
#	app/models/merge_request.rb

[ci skip]
parents 25c8d7ce 0ef1060e
import Vue from 'vue'; import Vue from 'vue';
import sanitize from 'sanitize-html';
import issuableApp from './components/app.vue'; import issuableApp from './components/app.vue';
import '../vue_shared/vue_resource_interceptor'; import '../vue_shared/vue_resource_interceptor';
document.addEventListener('DOMContentLoaded', () => { export default function initIssueableApp() {
const initialDataEl = document.getElementById('js-issuable-app-initial-data'); const initialDataEl = document.getElementById('js-issuable-app-initial-data');
const props = JSON.parse(initialDataEl.innerHTML.replace(/"/g, '"')); const props = JSON.parse(sanitize(initialDataEl.textContent).replace(/"/g, '"'));
return new Vue({ return new Vue({
el: document.getElementById('js-issuable-app'), el: document.getElementById('js-issuable-app'),
...@@ -17,4 +18,4 @@ document.addEventListener('DOMContentLoaded', () => { ...@@ -17,4 +18,4 @@ document.addEventListener('DOMContentLoaded', () => {
}); });
}, },
}); });
}); }
...@@ -3,9 +3,10 @@ import Issue from '~/issue'; ...@@ -3,9 +3,10 @@ import Issue from '~/issue';
import ShortcutsIssuable from '~/behaviors/shortcuts/shortcuts_issuable'; import ShortcutsIssuable from '~/behaviors/shortcuts/shortcuts_issuable';
import ZenMode from '~/zen_mode'; import ZenMode from '~/zen_mode';
import '~/notes/index'; import '~/notes/index';
import '~/issue_show/index'; import initIssueableApp from '~/issue_show';
export default function () { export default function () {
initIssueableApp();
new Issue(); // eslint-disable-line no-new new Issue(); // eslint-disable-line no-new
new ShortcutsIssuable(); // eslint-disable-line no-new new ShortcutsIssuable(); // eslint-disable-line no-new
new ZenMode(); // eslint-disable-line no-new new ZenMode(); // eslint-disable-line no-new
......
<script> <script>
import { Link } from '@gitlab-org/gitlab-ui';
import Icon from '../../icon.vue'; import Icon from '../../icon.vue';
import { numberToHumanSize } from '../../../../lib/utils/number_utils'; import { numberToHumanSize } from '../../../../lib/utils/number_utils';
export default { export default {
components: { components: {
'gl-link': Link,
Icon, Icon,
}, },
props: { props: {
...@@ -37,7 +39,7 @@ export default { ...@@ -37,7 +39,7 @@ export default {
({{ fileSizeReadable }}) ({{ fileSizeReadable }})
</template> </template>
</p> </p>
<a <gl-link
:href="path" :href="path"
class="btn btn-default" class="btn btn-default"
rel="nofollow" rel="nofollow"
...@@ -49,7 +51,7 @@ export default { ...@@ -49,7 +51,7 @@ export default {
css-classes="float-left append-right-8" css-classes="float-left append-right-8"
/> />
{{ __('Download') }} {{ __('Download') }}
</a> </gl-link>
</div> </div>
</div> </div>
</template> </template>
...@@ -18,12 +18,14 @@ ...@@ -18,12 +18,14 @@
*/ */
import { Link } from '@gitlab-org/gitlab-ui';
import userAvatarImage from './user_avatar_image.vue'; import userAvatarImage from './user_avatar_image.vue';
import tooltip from '../../directives/tooltip'; import tooltip from '../../directives/tooltip';
export default { export default {
name: 'UserAvatarLink', name: 'UserAvatarLink',
components: { components: {
'gl-link': Link,
userAvatarImage, userAvatarImage,
}, },
directives: { directives: {
...@@ -83,7 +85,7 @@ export default { ...@@ -83,7 +85,7 @@ export default {
</script> </script>
<template> <template>
<a <gl-link
:href="linkHref" :href="linkHref"
class="user-avatar-link"> class="user-avatar-link">
<user-avatar-image <user-avatar-image
...@@ -99,5 +101,5 @@ export default { ...@@ -99,5 +101,5 @@ export default {
:title="tooltipText" :title="tooltipText"
:tooltip-placement="tooltipPlacement" :tooltip-placement="tooltipPlacement"
>{{ username }}</span> >{{ username }}</span>
</a> </gl-link>
</template> </template>
...@@ -59,7 +59,7 @@ ...@@ -59,7 +59,7 @@
} }
@include media-breakpoint-up(sm) { @include media-breakpoint-up(sm) {
.btn:first-of-type { .btn:nth-child(1) {
margin-left: auto; margin-left: auto;
} }
} }
......
...@@ -109,6 +109,15 @@ class ApplicationController < ActionController::Base ...@@ -109,6 +109,15 @@ class ApplicationController < ActionController::Base
request.env['rack.session.options'][:expire_after] = Settings.gitlab['unauthenticated_session_expire_delay'] request.env['rack.session.options'][:expire_after] = Settings.gitlab['unauthenticated_session_expire_delay']
end end
def render(*args)
super.tap do
# Set a header for custom error pages to prevent them from being intercepted by gitlab-workhorse
if response.content_type == 'text/html' && (400..599).cover?(response.status)
response.headers['X-GitLab-Custom-Error'] = '1'
end
end
end
protected protected
def append_info_to_payload(payload) def append_info_to_payload(payload)
......
...@@ -12,6 +12,7 @@ class EventsFinder ...@@ -12,6 +12,7 @@ class EventsFinder
# Arguments: # Arguments:
# source - which user or project to looks for events on # source - which user or project to looks for events on
# current_user - only return events for projects visible to this user # current_user - only return events for projects visible to this user
# WARNING: does not consider project feature visibility!
# params: # params:
# action: string # action: string
# target_type: string # target_type: string
......
...@@ -3,6 +3,7 @@ ...@@ -3,6 +3,7 @@
# Get user activity feed for projects common for a user and a logged in user # Get user activity feed for projects common for a user and a logged in user
# #
# - current_user: The user viewing the events # - current_user: The user viewing the events
# WARNING: does not consider project feature visibility!
# - user: The user for which to load the events # - user: The user for which to load the events
# - params: # - params:
# - offset: The page of events to return # - offset: The page of events to return
......
...@@ -33,7 +33,8 @@ module BlobViewer ...@@ -33,7 +33,8 @@ module BlobViewer
end end
def homepage def homepage
json_data['homepage'] url = json_data['homepage']
url if Gitlab::UrlSanitizer.valid?(url)
end end
def npm_url def npm_url
......
...@@ -10,5 +10,9 @@ module Ci ...@@ -10,5 +10,9 @@ module Ci
alias_attribute :secret_value, :value alias_attribute :secret_value, :value
validates :key, uniqueness: { scope: :pipeline_id } validates :key, uniqueness: { scope: :pipeline_id }
def hook_attrs
{ key: key, value: value }
end
end end
end end
...@@ -154,6 +154,8 @@ class Event < ActiveRecord::Base ...@@ -154,6 +154,8 @@ class Event < ActiveRecord::Base
end end
end end
# rubocop:disable Metrics/CyclomaticComplexity
# rubocop:disable Metrics/PerceivedComplexity
def visible_to_user?(user = nil) def visible_to_user?(user = nil)
if push? || commit_note? if push? || commit_note?
Ability.allowed?(user, :download_code, project) Ability.allowed?(user, :download_code, project)
...@@ -165,12 +167,18 @@ class Event < ActiveRecord::Base ...@@ -165,12 +167,18 @@ class Event < ActiveRecord::Base
Ability.allowed?(user, :read_issue, note? ? note_target : target) Ability.allowed?(user, :read_issue, note? ? note_target : target)
elsif merge_request? || merge_request_note? elsif merge_request? || merge_request_note?
Ability.allowed?(user, :read_merge_request, note? ? note_target : target) Ability.allowed?(user, :read_merge_request, note? ? note_target : target)
elsif personal_snippet_note?
Ability.allowed?(user, :read_personal_snippet, note_target)
elsif project_snippet_note?
Ability.allowed?(user, :read_project_snippet, note_target)
elsif milestone? elsif milestone?
Ability.allowed?(user, :read_project, project) Ability.allowed?(user, :read_milestone, project)
else else
false # No other event types are visible false # No other event types are visible
end end
end end
# rubocop:enable Metrics/PerceivedComplexity
# rubocop:enable Metrics/CyclomaticComplexity
def project_name def project_name
if project if project
...@@ -312,6 +320,10 @@ class Event < ActiveRecord::Base ...@@ -312,6 +320,10 @@ class Event < ActiveRecord::Base
note? && target && target.for_snippet? note? && target && target.for_snippet?
end end
def personal_snippet_note?
note? && target && target.for_personal_snippet?
end
def note_target def note_target
target.noteable target.noteable
end end
......
...@@ -3,6 +3,16 @@ ...@@ -3,6 +3,16 @@
class WebHook < ActiveRecord::Base class WebHook < ActiveRecord::Base
include Sortable include Sortable
attr_encrypted :token,
mode: :per_attribute_iv,
algorithm: 'aes-256-gcm',
key: Settings.attr_encrypted_db_key_base_truncated
attr_encrypted :url,
mode: :per_attribute_iv,
algorithm: 'aes-256-gcm',
key: Settings.attr_encrypted_db_key_base_truncated
has_many :web_hook_logs, dependent: :destroy # rubocop:disable Cop/ActiveRecordDependent has_many :web_hook_logs, dependent: :destroy # rubocop:disable Cop/ActiveRecordDependent
validates :url, presence: true, public_url: { allow_localhost: lambda(&:allow_local_requests?), validates :url, presence: true, public_url: { allow_localhost: lambda(&:allow_local_requests?),
...@@ -27,4 +37,38 @@ class WebHook < ActiveRecord::Base ...@@ -27,4 +37,38 @@ class WebHook < ActiveRecord::Base
def allow_local_requests? def allow_local_requests?
false false
end end
# In 11.4, the web_hooks table has both `token` and `encrypted_token` fields.
# Ensure that the encrypted version always takes precedence if present.
alias_method :attr_encrypted_token, :token
def token
attr_encrypted_token.presence || read_attribute(:token)
end
# In 11.4, the web_hooks table has both `token` and `encrypted_token` fields.
# Pending a background migration to encrypt all fields, we should just clear
# the unencrypted value whenever the new value is set.
alias_method :'attr_encrypted_token=', :'token='
def token=(value)
self.attr_encrypted_token = value
write_attribute(:token, nil)
end
# In 11.4, the web_hooks table has both `url` and `encrypted_url` fields.
# Ensure that the encrypted version always takes precedence if present.
alias_method :attr_encrypted_url, :url
def url
attr_encrypted_url.presence || read_attribute(:url)
end
# In 11.4, the web_hooks table has both `url` and `encrypted_url` fields.
# Pending a background migration to encrypt all fields, we should just clear
# the unencrypted value whenever the new value is set.
alias_method :'attr_encrypted_url=', :'url='
def url=(value)
self.attr_encrypted_url = value
write_attribute(:url, nil)
end
end end
...@@ -7,7 +7,10 @@ class MergeRequest < ActiveRecord::Base ...@@ -7,7 +7,10 @@ class MergeRequest < ActiveRecord::Base
include Noteable include Noteable
include Referable include Referable
include Presentable include Presentable
<<<<<<< HEAD
include Elastic::MergeRequestsSearch include Elastic::MergeRequestsSearch
=======
>>>>>>> upstream/master
include IgnorableColumn include IgnorableColumn
include TimeTrackable include TimeTrackable
include ManualInverseAssociation include ManualInverseAssociation
......
...@@ -14,8 +14,8 @@ module Clusters ...@@ -14,8 +14,8 @@ module Clusters
else else
check_timeout check_timeout
end end
rescue Kubeclient::HttpError => ke rescue Kubeclient::HttpError
app.make_errored!("Kubernetes error: #{ke.message}") unless app.errored? app.make_errored!("Kubernetes error") unless app.errored?
end end
private private
...@@ -27,7 +27,7 @@ module Clusters ...@@ -27,7 +27,7 @@ module Clusters
end end
def on_failed def on_failed
app.make_errored!(installation_errors || 'Installation silently failed') app.make_errored!('Installation failed')
ensure ensure
remove_installation_pod remove_installation_pod
end end
......
...@@ -12,10 +12,10 @@ module Clusters ...@@ -12,10 +12,10 @@ module Clusters
ClusterWaitForAppInstallationWorker.perform_in( ClusterWaitForAppInstallationWorker.perform_in(
ClusterWaitForAppInstallationWorker::INTERVAL, app.name, app.id) ClusterWaitForAppInstallationWorker::INTERVAL, app.name, app.id)
rescue Kubeclient::HttpError => ke rescue Kubeclient::HttpError
app.make_errored!("Kubernetes error: #{ke.message}") app.make_errored!("Kubernetes error.")
rescue StandardError => e rescue StandardError
app.make_errored!("Can't start installation process. #{e.message}") app.make_errored!("Can't start installation process.")
end end
end end
end end
......
...@@ -9,7 +9,7 @@ ...@@ -9,7 +9,7 @@
.project-empty-note-panel .project-empty-note-panel
%div{ class: [container_class, ("limit-container-width" unless fluid_layout)] } %div{ class: [container_class, ("limit-container-width" unless fluid_layout)] }
.prepend-top-20 .prepend-top-20
%h4 %h4.append-bottom-20
= _('The repository for this project is empty') = _('The repository for this project is empty')
- if @project.can_current_user_push_code? - if @project.can_current_user_push_code?
......
---
title: Set a header for custom error pages to prevent them from being intercepted
by gitlab-workhorse
merge_request: 21870
author: David Piegza
type: fixed
---
title: Fixes modal button alignment
merge_request: 22024
author: Jacopo Beschi @jacopo-beschi
type: fixed
---
title: Encrypt webhook tokens and URLs in the database
merge_request: 21645
author:
type: security
---
title: Add link component to DownloadViewer component
merge_request: 21987
author: George Tsiolis
type: other
---
title: Add link component to UserAvatarLink component
merge_request: 21986
author: George Tsiolis
type: other
---
title: Redact confidential events in the API
merge_request:
author:
type: security
---
title: Improve empty project placeholder for non-members and members without write access
merge_request: 21977
author: George Tsiolis
type: other
---
title: Enable frozen string in lib/api and lib/backup
merge_request:
author: gfyoung
type: performance
---
title: pipeline webhook event now contain pipeline variables
merge_request: 18171
author: Pierre Tardy
type: added
---
title: Set timeout for syntax highlighting
merge_request:
author:
type: security
---
title: Sanitize JSON data properly to fix XSS on Issue details page
merge_request:
author:
type: security
---
title: Fix xss vulnerability sourced from package.json
merge_request:
author:
type: security
# frozen_string_literal: true
class AddAttrEncryptedColumnsToWebHook < ActiveRecord::Migration
include Gitlab::Database::MigrationHelpers
DOWNTIME = false
def change
add_column :web_hooks, :encrypted_token, :string
add_column :web_hooks, :encrypted_token_iv, :string
add_column :web_hooks, :encrypted_url, :string
add_column :web_hooks, :encrypted_url_iv, :string
end
end
# frozen_string_literal: true
class EncryptWebHooksColumns < ActiveRecord::Migration
include Gitlab::Database::MigrationHelpers
DOWNTIME = false
BATCH_SIZE = 10000
RANGE_SIZE = 100
MIGRATION = 'EncryptColumns'
COLUMNS = [:token, :url]
WebHook = ::Gitlab::BackgroundMigration::Models::EncryptColumns::WebHook
disable_ddl_transaction!
def up
WebHook.each_batch(of: BATCH_SIZE) do |relation, index|
delay = index * 2.minutes
relation.each_batch(of: RANGE_SIZE) do |relation|
range = relation.pluck('MIN(id)', 'MAX(id)').first
args = [WebHook, COLUMNS, *range]
BackgroundMigrationWorker.perform_in(delay, MIGRATION, args)
end
end
end
def down
# noop
end
end
...@@ -3045,6 +3045,10 @@ ActiveRecord::Schema.define(version: 20180920043317) do ...@@ -3045,6 +3045,10 @@ ActiveRecord::Schema.define(version: 20180920043317) do
t.boolean "job_events", default: false, null: false t.boolean "job_events", default: false, null: false
t.boolean "confidential_note_events" t.boolean "confidential_note_events"
t.text "push_events_branch_filter" t.text "push_events_branch_filter"
t.string "encrypted_token"
t.string "encrypted_token_iv"
t.string "encrypted_url"
t.string "encrypted_url_iv"
end end
add_index "web_hooks", ["project_id"], name: "index_web_hooks_on_project_id", using: :btree add_index "web_hooks", ["project_id"], name: "index_web_hooks_on_project_id", using: :btree
......
...@@ -968,7 +968,13 @@ X-Gitlab-Event: Pipeline Hook ...@@ -968,7 +968,13 @@ X-Gitlab-Event: Pipeline Hook
], ],
"created_at": "2016-08-12 15:23:28 UTC", "created_at": "2016-08-12 15:23:28 UTC",
"finished_at": "2016-08-12 15:26:29 UTC", "finished_at": "2016-08-12 15:26:29 UTC",
"duration": 63 "duration": 63,
"variables": [
{
"key": "NESTOR_PROD_ENVIRONMENT",
"value": "us-west-1"
}
]
}, },
"user":{ "user":{
"name": "Administrator", "name": "Administrator",
......
# frozen_string_literal: true
module API module API
class AccessRequests < Grape::API class AccessRequests < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
class API < Grape::API class API < Grape::API
include APIGuard include APIGuard
......
# frozen_string_literal: true
# Guard API with OAuth 2.0 Access Token # Guard API with OAuth 2.0 Access Token
require 'rack/oauth2' require 'rack/oauth2'
......
# frozen_string_literal: true
module API module API
# External applications API # External applications API
class Applications < Grape::API class Applications < Grape::API
......
# frozen_string_literal: true
module API module API
class Avatar < Grape::API class Avatar < Grape::API
resource :avatar do resource :avatar do
......
# frozen_string_literal: true
module API module API
class AwardEmoji < Grape::API class AwardEmoji < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
class Badges < Grape::API class Badges < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
class Boards < Grape::API class Boards < Grape::API
include BoardsResponses include BoardsResponses
......
# frozen_string_literal: true
module API module API
module BoardsResponses module BoardsResponses
extend ActiveSupport::Concern extend ActiveSupport::Concern
......
# frozen_string_literal: true
require 'mime/types' require 'mime/types'
module API module API
......
# frozen_string_literal: true
module API module API
class BroadcastMessages < Grape::API class BroadcastMessages < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
class CircuitBreakers < Grape::API class CircuitBreakers < Grape::API
before { authenticated_as_admin! } before { authenticated_as_admin! }
......
# frozen_string_literal: true
require 'mime/types' require 'mime/types'
module API module API
......
# frozen_string_literal: true
require 'mime/types' require 'mime/types'
module API module API
......
# frozen_string_literal: true
module API module API
module CustomAttributesEndpoints module CustomAttributesEndpoints
extend ActiveSupport::Concern extend ActiveSupport::Concern
......
# frozen_string_literal: true
module API module API
class DeployKeys < Grape::API class DeployKeys < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
# Deployments RESTful API endpoints # Deployments RESTful API endpoints
class Deployments < Grape::API class Deployments < Grape::API
......
# frozen_string_literal: true
module API module API
class Discussions < Grape::API class Discussions < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
module Entities module Entities
class WikiPageBasic < Grape::Entity class WikiPageBasic < Grape::Entity
......
# frozen_string_literal: true
module API module API
# Environments RESTfull API endpoints # Environments RESTfull API endpoints
class Environments < Grape::API class Environments < Grape::API
......
# frozen_string_literal: true
module API module API
class Events < Grape::API class Events < Grape::API
include PaginationParams include PaginationParams
...@@ -16,12 +18,27 @@ module API ...@@ -16,12 +18,27 @@ module API
desc: 'Return events sorted in ascending and descending order' desc: 'Return events sorted in ascending and descending order'
end end
RedactedEvent = OpenStruct.new(target_title: 'Confidential event').freeze
def redact_events(events)
events.map do |event|
if event.visible_to_user?(current_user)
event
else
RedactedEvent
end
end
end
# rubocop: disable CodeReuse/ActiveRecord # rubocop: disable CodeReuse/ActiveRecord
def present_events(events) def present_events(events, redact: true)
events = events.reorder(created_at: params[:sort]) events = events.reorder(created_at: params[:sort])
.with_associations .with_associations
present paginate(events), with: Entities::Event events = paginate(events)
events = redact_events(events) if redact
present events, with: Entities::Event
end end
# rubocop: enable CodeReuse/ActiveRecord # rubocop: enable CodeReuse/ActiveRecord
end end
...@@ -44,7 +61,8 @@ module API ...@@ -44,7 +61,8 @@ module API
events = EventsFinder.new(params.merge(source: current_user, current_user: current_user)).execute.preload(:author, :target) events = EventsFinder.new(params.merge(source: current_user, current_user: current_user)).execute.preload(:author, :target)
present_events(events) # Since we're viewing our own events, redaction is unnecessary
present_events(events, redact: false)
end end
# rubocop: enable CodeReuse/ActiveRecord # rubocop: enable CodeReuse/ActiveRecord
end end
......
# frozen_string_literal: true
module API module API
class Features < Grape::API class Features < Grape::API
before { authenticated_as_admin! } before { authenticated_as_admin! }
......
# frozen_string_literal: true
module API module API
class Files < Grape::API class Files < Grape::API
FILE_ENDPOINT_REQUIREMENTS = API::PROJECT_ENDPOINT_REQUIREMENTS.merge(file_path: API::NO_SLASH_URL_PART_REGEX) FILE_ENDPOINT_REQUIREMENTS = API::PROJECT_ENDPOINT_REQUIREMENTS.merge(file_path: API::NO_SLASH_URL_PART_REGEX)
......
# frozen_string_literal: true
module API module API
class GroupBoards < Grape::API class GroupBoards < Grape::API
include BoardsResponses include BoardsResponses
......
# frozen_string_literal: true
module API module API
class GroupMilestones < Grape::API class GroupMilestones < Grape::API
include MilestoneResponses include MilestoneResponses
......
# frozen_string_literal: true
module API module API
class GroupVariables < Grape::API class GroupVariables < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
class Groups < Grape::API class Groups < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
module Helpers module Helpers
prepend EE::API::Helpers prepend EE::API::Helpers
...@@ -394,9 +396,10 @@ module API ...@@ -394,9 +396,10 @@ module API
# lifted from https://github.com/rails/rails/blob/master/actionpack/lib/action_dispatch/middleware/debug_exceptions.rb#L60 # lifted from https://github.com/rails/rails/blob/master/actionpack/lib/action_dispatch/middleware/debug_exceptions.rb#L60
trace = exception.backtrace trace = exception.backtrace
message = "\n#{exception.class} (#{exception.message}):\n" message = ["\n#{exception.class} (#{exception.message}):\n"]
message << exception.annoted_source_code.to_s if exception.respond_to?(:annoted_source_code) message << exception.annoted_source_code.to_s if exception.respond_to?(:annoted_source_code)
message << " " << trace.join("\n ") message << " " << trace.join("\n ")
message = message.join
API.logger.add Logger::FATAL, message API.logger.add Logger::FATAL, message
......
# frozen_string_literal: true
module API module API
module Helpers module Helpers
module BadgesHelpers module BadgesHelpers
......
# frozen_string_literal: true
module API module API
module Helpers module Helpers
module CommonHelpers module CommonHelpers
......
# frozen_string_literal: true
module API module API
module Helpers module Helpers
module CustomAttributes module CustomAttributes
......
# frozen_string_literal: true
module API module API
module Helpers module Helpers
module CustomValidators module CustomValidators
......
# frozen_string_literal: true
module API module API
module Helpers module Helpers
module HeadersHelpers module HeadersHelpers
......
# frozen_string_literal: true
module API module API
module Helpers module Helpers
module InternalHelpers module InternalHelpers
......
# frozen_string_literal: true
# rubocop:disable GitlabSecurity/PublicSend # rubocop:disable GitlabSecurity/PublicSend
module API module API
......
# frozen_string_literal: true
module API module API
module Helpers module Helpers
module NotesHelpers module NotesHelpers
......
# frozen_string_literal: true
module API module API
module Helpers module Helpers
module Pagination module Pagination
......
# frozen_string_literal: true
module API module API
module Helpers module Helpers
module ProjectSnapshotsHelpers module ProjectSnapshotsHelpers
......
# frozen_string_literal: true
module API module API
module Helpers module Helpers
module ProjectsHelpers module ProjectsHelpers
......
# frozen_string_literal: true
module API module API
module Helpers module Helpers
module RelatedResourcesHelpers module RelatedResourcesHelpers
......
# frozen_string_literal: true
module API module API
module Helpers module Helpers
module Runner module Runner
......
# frozen_string_literal: true
module API module API
# Internal access API # Internal access API
class Internal < Grape::API class Internal < Grape::API
......
# frozen_string_literal: true
module API module API
class Issues < Grape::API class Issues < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
class JobArtifacts < Grape::API class JobArtifacts < Grape::API
before { authenticate_non_get! } before { authenticate_non_get! }
......
# frozen_string_literal: true
module API module API
class Jobs < Grape::API class Jobs < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
# Keys API # Keys API
class Keys < Grape::API class Keys < Grape::API
......
# frozen_string_literal: true
module API module API
class Labels < Grape::API class Labels < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
class Lint < Grape::API class Lint < Grape::API
namespace :ci do namespace :ci do
......
# frozen_string_literal: true
module API module API
class Markdown < Grape::API class Markdown < Grape::API
params do params do
......
# frozen_string_literal: true
module API module API
class Members < Grape::API class Members < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
# MergeRequestDiff API # MergeRequestDiff API
class MergeRequestDiffs < Grape::API class MergeRequestDiffs < Grape::API
......
# frozen_string_literal: true
module API module API
class MergeRequests < Grape::API class MergeRequests < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
module MilestoneResponses module MilestoneResponses
extend ActiveSupport::Concern extend ActiveSupport::Concern
......
# frozen_string_literal: true
module API module API
class Namespaces < Grape::API class Namespaces < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
class Notes < Grape::API class Notes < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
# notification_settings API # notification_settings API
class NotificationSettings < Grape::API class NotificationSettings < Grape::API
......
# frozen_string_literal: true
module API module API
class PagesDomains < Grape::API class PagesDomains < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
# Concern for declare pagination params. # Concern for declare pagination params.
# #
......
# frozen_string_literal: true
module API module API
class PipelineSchedules < Grape::API class PipelineSchedules < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
class Pipelines < Grape::API class Pipelines < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
class ProjectExport < Grape::API class ProjectExport < Grape::API
before do before do
......
# frozen_string_literal: true
module API module API
class ProjectHooks < Grape::API class ProjectHooks < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
class ProjectImport < Grape::API class ProjectImport < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
class ProjectMilestones < Grape::API class ProjectMilestones < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
module API module API
class ProjectSnapshots < Grape::API class ProjectSnapshots < Grape::API
helpers ::API::Helpers::ProjectSnapshotsHelpers helpers ::API::Helpers::ProjectSnapshotsHelpers
......
# frozen_string_literal: true
module API module API
class ProjectSnippets < Grape::API class ProjectSnippets < Grape::API
include PaginationParams include PaginationParams
......
# frozen_string_literal: true
require_dependency 'declarative_policy' require_dependency 'declarative_policy'
module API module API
......
# frozen_string_literal: true
module API module API
module ProjectsRelationBuilder module ProjectsRelationBuilder
extend ActiveSupport::Concern extend ActiveSupport::Concern
......
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment