diff options
Diffstat (limited to 'app/graphql/resolvers/alert_management')
3 files changed, 31 insertions, 2 deletions
diff --git a/app/graphql/resolvers/alert_management/alert_resolver.rb b/app/graphql/resolvers/alert_management/alert_resolver.rb index dc9b1dbb5f4..c3219d9cdc3 100644 --- a/app/graphql/resolvers/alert_management/alert_resolver.rb +++ b/app/graphql/resolvers/alert_management/alert_resolver.rb @@ -19,7 +19,7 @@ module Resolvers required: false argument :search, GraphQL::STRING_TYPE, - description: 'Search criteria for filtering alerts. This will search on title, description, service, monitoring_tool.', + description: 'Search query for title, description, service, or monitoring_tool.', required: false argument :assignee_username, GraphQL::STRING_TYPE, diff --git a/app/graphql/resolvers/alert_management/alert_status_counts_resolver.rb b/app/graphql/resolvers/alert_management/alert_status_counts_resolver.rb index 96ea4610aff..8fc0f9fd1ff 100644 --- a/app/graphql/resolvers/alert_management/alert_status_counts_resolver.rb +++ b/app/graphql/resolvers/alert_management/alert_status_counts_resolver.rb @@ -6,7 +6,7 @@ module Resolvers type Types::AlertManagement::AlertStatusCountsType, null: true argument :search, GraphQL::STRING_TYPE, - description: 'Search criteria for filtering alerts. This will search on title, description, service, monitoring_tool.', + description: 'Search query for title, description, service, or monitoring_tool.', required: false argument :assignee_username, GraphQL::STRING_TYPE, diff --git a/app/graphql/resolvers/alert_management/integrations_resolver.rb b/app/graphql/resolvers/alert_management/integrations_resolver.rb new file mode 100644 index 00000000000..4d1fe367277 --- /dev/null +++ b/app/graphql/resolvers/alert_management/integrations_resolver.rb @@ -0,0 +1,29 @@ +# frozen_string_literal: true + +module Resolvers + module AlertManagement + class IntegrationsResolver < BaseResolver + alias_method :project, :synchronized_object + + type Types::AlertManagement::IntegrationType.connection_type, null: true + + def resolve(**args) + http_integrations + prometheus_integrations + end + + private + + def prometheus_integrations + return [] unless Ability.allowed?(current_user, :admin_project, project) + + Array(project.prometheus_service) + end + + def http_integrations + return [] unless Ability.allowed?(current_user, :admin_operations, project) + + ::AlertManagement::HttpIntegrationsFinder.new(project, {}).execute + end + end + end +end |