blob: fef8235628d5aa05f8988a32325336e61f3e8698 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
# frozen_string_literal: true
module Projects
module Alerting
class NotificationsController < Projects::ApplicationController
respond_to :json
skip_before_action :verify_authenticity_token
skip_before_action :project
prepend_before_action :repository, :project_without_auth
def create
token = extract_alert_manager_token(request)
result = notify_service.execute(token)
head result.http_status
end
private
def project_without_auth
@project ||= Project
.find_by_full_path("#{params[:namespace_id]}/#{params[:project_id]}")
end
def extract_alert_manager_token(request)
Doorkeeper::OAuth::Token.from_bearer_authorization(request)
end
def notify_service
notify_service_class.new(project, current_user, notification_payload)
end
def notify_service_class
# We are tracking the consolidation of these services in
# https://gitlab.com/groups/gitlab-org/-/epics/3360
# to get rid of this workaround.
if Projects::Prometheus::Alerts::NotifyService.processable?(notification_payload)
Projects::Prometheus::Alerts::NotifyService
else
Projects::Alerting::NotifyService
end
end
def notification_payload
@notification_payload ||= params.permit![:notification]
end
end
end
end
|