summaryrefslogtreecommitdiff
path: root/app/services/boards/lists/create_service.rb
diff options
context:
space:
mode:
Diffstat (limited to 'app/services/boards/lists/create_service.rb')
-rw-r--r--app/services/boards/lists/create_service.rb28
1 files changed, 16 insertions, 12 deletions
diff --git a/app/services/boards/lists/create_service.rb b/app/services/boards/lists/create_service.rb
index 9c7a165776e..a21ceee083f 100644
--- a/app/services/boards/lists/create_service.rb
+++ b/app/services/boards/lists/create_service.rb
@@ -6,17 +6,21 @@ module Boards
include Gitlab::Utils::StrongMemoize
def execute(board)
- List.transaction do
- case type
- when :backlog
- create_backlog(board)
- else
- target = target(board)
- position = next_position(board)
-
- create_list(board, type, target, position)
- end
- end
+ list = case type
+ when :backlog
+ create_backlog(board)
+ else
+ target = target(board)
+ position = next_position(board)
+
+ return ServiceResponse.error(message: _('%{board_target} not found') % { board_target: type.to_s.capitalize }) if target.blank?
+
+ create_list(board, type, target, position)
+ end
+
+ return ServiceResponse.error(message: list.errors.full_messages) unless list.persisted?
+
+ ServiceResponse.success(payload: { list: list })
end
private
@@ -33,7 +37,7 @@ module Boards
def target(board)
strong_memoize(:target) do
- available_labels.find(params[:label_id])
+ available_labels.find_by(id: params[:label_id]) # rubocop: disable CodeReuse/ActiveRecord
end
end