Commit 4e7ac11c authored by Philip Cunningham's avatar Philip Cunningham

Extract and use AuthorizesProject concern

Observed common pattern and extracted general functionality.
parent b3f5fa02
# frozen_string_literal: true
module Mutations
module AuthorizesProject
include ResolvesProject
def authorized_find_project!(full_path:)
authorized_find!(full_path: full_path)
end
private
def find_object(full_path:)
resolve_project(full_path: full_path)
end
end
end
...@@ -5,7 +5,7 @@ module Mutations ...@@ -5,7 +5,7 @@ module Mutations
class Create < BaseMutation class Create < BaseMutation
InvalidGlobalID = Class.new(StandardError) InvalidGlobalID = Class.new(StandardError)
include ResolvesProject include AuthorizesProject
graphql_name 'DastOnDemandScanCreate' graphql_name 'DastOnDemandScanCreate'
...@@ -24,7 +24,7 @@ module Mutations ...@@ -24,7 +24,7 @@ module Mutations
authorize :create_on_demand_dast_scan authorize :create_on_demand_dast_scan
def resolve(full_path:, dast_site_profile_id:) def resolve(full_path:, dast_site_profile_id:)
project = authorized_find!(full_path: full_path) project = authorized_find_project!(full_path: full_path)
dast_site_profile = find_dast_site_profile(project: project, dast_site_profile_id: dast_site_profile_id) dast_site_profile = find_dast_site_profile(project: project, dast_site_profile_id: dast_site_profile_id)
dast_site = dast_site_profile.dast_site dast_site = dast_site_profile.dast_site
...@@ -41,10 +41,6 @@ module Mutations ...@@ -41,10 +41,6 @@ module Mutations
private private
def find_object(full_path:)
resolve_project(full_path: full_path)
end
def find_dast_site_profile(project:, dast_site_profile_id:) def find_dast_site_profile(project:, dast_site_profile_id:)
project project
.dast_site_profiles .dast_site_profiles
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
module Mutations module Mutations
module DastScannerProfiles module DastScannerProfiles
class Create < BaseMutation class Create < BaseMutation
include ResolvesProject include AuthorizesProject
graphql_name 'DastScannerProfileCreate' graphql_name 'DastScannerProfileCreate'
...@@ -30,7 +30,7 @@ module Mutations ...@@ -30,7 +30,7 @@ module Mutations
authorize :create_on_demand_dast_scan authorize :create_on_demand_dast_scan
def resolve(full_path:, profile_name:, spider_timeout: nil, target_timeout: nil) def resolve(full_path:, profile_name:, spider_timeout: nil, target_timeout: nil)
project = authorized_find!(full_path: full_path) project = authorized_find_project!(full_path: full_path)
service = ::DastScannerProfiles::CreateService.new(project, current_user) service = ::DastScannerProfiles::CreateService.new(project, current_user)
result = service.execute(name: profile_name, spider_timeout: spider_timeout, target_timeout: target_timeout) result = service.execute(name: profile_name, spider_timeout: spider_timeout, target_timeout: target_timeout)
...@@ -41,12 +41,6 @@ module Mutations ...@@ -41,12 +41,6 @@ module Mutations
{ errors: result.errors } { errors: result.errors }
end end
end end
private
def find_object(full_path:)
resolve_project(full_path: full_path)
end
end end
end end
end end
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
module Mutations module Mutations
module DastSiteProfiles module DastSiteProfiles
class Create < BaseMutation class Create < BaseMutation
include ResolvesProject include AuthorizesProject
graphql_name 'DastSiteProfileCreate' graphql_name 'DastSiteProfileCreate'
...@@ -26,7 +26,7 @@ module Mutations ...@@ -26,7 +26,7 @@ module Mutations
authorize :create_on_demand_dast_scan authorize :create_on_demand_dast_scan
def resolve(full_path:, profile_name:, target_url: nil) def resolve(full_path:, profile_name:, target_url: nil)
project = authorized_find!(full_path: full_path) project = authorized_find_project!(full_path: full_path)
service = ::DastSiteProfiles::CreateService.new(project, current_user) service = ::DastSiteProfiles::CreateService.new(project, current_user)
result = service.execute(name: profile_name, target_url: target_url) result = service.execute(name: profile_name, target_url: target_url)
...@@ -37,12 +37,6 @@ module Mutations ...@@ -37,12 +37,6 @@ module Mutations
{ errors: result.errors } { errors: result.errors }
end end
end end
private
def find_object(full_path:)
resolve_project(full_path: full_path)
end
end end
end end
end end
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
module Mutations module Mutations
module DastSiteProfiles module DastSiteProfiles
class Delete < BaseMutation class Delete < BaseMutation
include ResolvesProject include AuthorizesProject
graphql_name 'DastSiteProfileDelete' graphql_name 'DastSiteProfileDelete'
...@@ -18,7 +18,7 @@ module Mutations ...@@ -18,7 +18,7 @@ module Mutations
authorize :create_on_demand_dast_scan authorize :create_on_demand_dast_scan
def resolve(full_path:, id:) def resolve(full_path:, id:)
project = authorized_find!(full_path: full_path) project = authorized_find_project!(full_path: full_path)
dast_site_profile = find_dast_site_profile(project: project, global_id: id) dast_site_profile = find_dast_site_profile(project: project, global_id: id)
return { errors: dast_site_profile.errors.full_messages } unless dast_site_profile.destroy return { errors: dast_site_profile.errors.full_messages } unless dast_site_profile.destroy
...@@ -28,10 +28,6 @@ module Mutations ...@@ -28,10 +28,6 @@ module Mutations
private private
def find_object(full_path:)
resolve_project(full_path: full_path)
end
def find_dast_site_profile(project:, global_id:) def find_dast_site_profile(project:, global_id:)
project.dast_site_profiles.find(global_id.model_id) project.dast_site_profiles.find(global_id.model_id)
end end
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
module Mutations module Mutations
module DastSiteProfiles module DastSiteProfiles
class Update < BaseMutation class Update < BaseMutation
include ResolvesProject include AuthorizesProject
graphql_name 'DastSiteProfileUpdate' graphql_name 'DastSiteProfileUpdate'
...@@ -30,7 +30,7 @@ module Mutations ...@@ -30,7 +30,7 @@ module Mutations
authorize :create_on_demand_dast_scan authorize :create_on_demand_dast_scan
def resolve(full_path:, **service_args) def resolve(full_path:, **service_args)
project = authorized_find!(full_path: full_path) project = authorized_find_project!(full_path: full_path)
service = ::DastSiteProfiles::UpdateService.new(project, current_user) service = ::DastSiteProfiles::UpdateService.new(project, current_user)
result = service.execute(service_args) result = service.execute(service_args)
...@@ -41,12 +41,6 @@ module Mutations ...@@ -41,12 +41,6 @@ module Mutations
{ errors: result.errors } { errors: result.errors }
end end
end end
private
def find_object(full_path:)
resolve_project(full_path: full_path)
end
end end
end end
end end
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