Commit 1ca8771b authored by Mario Celi's avatar Mario Celi

Split issue param declaration from negatable params

- Remove unused optional_issue_not_params_ee
- Declare negatable and optional issues arams separately
- Clean param allowed input types
parent 13ffceb2
...@@ -14,22 +14,25 @@ module EE ...@@ -14,22 +14,25 @@ module EE
mutually_exclusive :epic_id, :epic_iid mutually_exclusive :epic_id, :epic_iid
end end
params :common_negatable_optional_params_ee do params :negatable_issue_filter_params_ee do
optional :weight, type: Integer, desc: 'Return issues without the specified weight'
optional :iteration_id, types: [Integer, String], optional :iteration_id, types: [Integer, String],
integer_or_custom_value: ::Iteration::Predefined::ALL.map { |iteration| iteration.name.downcase }, integer_or_custom_value: ::Iteration::Predefined::ALL.map { |iteration| iteration.name.downcase },
desc: 'Return issues which are assigned to the iteration with the given ID' desc: 'Return issues which are assigned to the iteration with the given ID'
optional :iteration_title, type: String, optional :iteration_title, type: String,
desc: 'Return issues which are assigned to the iteration with the given title' desc: 'Return issues which are not assigned to the iteration with the given title'
mutually_exclusive :iteration_id, :iteration_title mutually_exclusive :iteration_id, :iteration_title
end end
params :negatable_issue_filter_params_ee do params :issues_stats_params_ee do
optional :weight, type: Integer, desc: 'Return issues without the specified weight'
end
params :optional_issues_params_ee do
optional :weight, types: [Integer, String], integer_none_any: true, desc: 'The weight of the issue' optional :weight, types: [Integer, String], integer_none_any: true, desc: 'The weight of the issue'
optional :epic_id, types: [Integer, String], integer_none_any: true, desc: 'The ID of an epic associated with the issues' optional :epic_id, types: [Integer, String], integer_none_any: true, desc: 'The ID of an epic associated with the issues'
optional :iteration_id, types: [Integer, String],
integer_or_custom_value: ::Iteration::Predefined::ALL.map { |iteration| iteration.name.downcase },
desc: 'Return issues which are assigned to the iteration with the given ID'
optional :iteration_title, type: String,
desc: 'Return issues which are assigned to the iteration with the given title'
mutually_exclusive :iteration_id, :iteration_title
end end
end end
......
...@@ -5,19 +5,13 @@ module API ...@@ -5,19 +5,13 @@ module API
module IssuesHelpers module IssuesHelpers
extend Grape::API::Helpers extend Grape::API::Helpers
params :common_negatable_optional_params_ee do
end
params :negatable_issue_filter_params_ee do params :negatable_issue_filter_params_ee do
end end
params :optional_issue_params_ee do params :optional_issue_params_ee do
end end
params :optional_issues_params_ee do params :issues_stats_params_ee do
end
params :optional_issue_not_params_ee do
end end
def self.update_params_at_least_one_of def self.update_params_at_least_one_of
......
...@@ -11,7 +11,25 @@ module API ...@@ -11,7 +11,25 @@ module API
feature_category :issue_tracking feature_category :issue_tracking
helpers do helpers do
params :common_negatable_optional_params do params :negatable_issue_filter_params do
optional :labels, type: Array[String], coerce_with: ::API::Validations::Types::CommaSeparatedToArray.coerce, desc: 'Comma-separated list of label names'
optional :milestone, type: String, desc: 'Milestone title'
optional :iids, type: Array[Integer], coerce_with: ::API::Validations::Types::CommaSeparatedToIntegerArray.coerce, desc: 'The IID array of issues'
optional :author_id, type: Integer, desc: 'Return issues which are not authored by the user with the given ID'
optional :author_username, type: String, desc: 'Return issues which are not authored by the user with the given username'
mutually_exclusive :author_id, :author_username
optional :assignee_id, type: Integer, desc: 'Return issues which are assigned to the user with the given ID'
optional :assignee_username, type: Array[String], check_assignees_count: true,
coerce_with: Validations::Validators::CheckAssigneesCount.coerce,
desc: 'Return issues which are assigned to the user with the given username'
mutually_exclusive :assignee_id, :assignee_username
use :negatable_issue_filter_params_ee
end
params :issues_stats_params do
optional :labels, type: Array[String], coerce_with: ::API::Validations::Types::CommaSeparatedToArray.coerce, desc: 'Comma-separated list of label names' optional :labels, type: Array[String], coerce_with: ::API::Validations::Types::CommaSeparatedToArray.coerce, desc: 'Comma-separated list of label names'
optional :milestone, type: String, desc: 'Milestone title' optional :milestone, type: String, desc: 'Milestone title'
optional :iids, type: Array[Integer], coerce_with: ::API::Validations::Types::CommaSeparatedToIntegerArray.coerce, desc: 'The IID array of issues' optional :iids, type: Array[Integer], coerce_with: ::API::Validations::Types::CommaSeparatedToIntegerArray.coerce, desc: 'The IID array of issues'
...@@ -27,32 +45,23 @@ module API ...@@ -27,32 +45,23 @@ module API
optional :assignee_username, type: Array[String], check_assignees_count: true, optional :assignee_username, type: Array[String], check_assignees_count: true,
coerce_with: Validations::Validators::CheckAssigneesCount.coerce, coerce_with: Validations::Validators::CheckAssigneesCount.coerce,
desc: 'Return issues which are assigned to the user with the given username' desc: 'Return issues which are assigned to the user with the given username'
use :common_negatable_optional_params_ee
mutually_exclusive :assignee_id, :assignee_username mutually_exclusive :assignee_id, :assignee_username
end
params :negatable_issue_filter_params do
optional :not, type: Hash do
use :common_negatable_optional_params
use :negatable_issue_filter_params_ee
end
end
params :issues_stats_params do
use :common_negatable_optional_params
use :optional_issues_params_ee
use :negatable_issue_filter_params
optional :created_after, type: DateTime, desc: 'Return issues created after the specified time' optional :created_after, type: DateTime, desc: 'Return issues created after the specified time'
optional :created_before, type: DateTime, desc: 'Return issues created before the specified time' optional :created_before, type: DateTime, desc: 'Return issues created before the specified time'
optional :updated_after, type: DateTime, desc: 'Return issues updated after the specified time' optional :updated_after, type: DateTime, desc: 'Return issues updated after the specified time'
optional :updated_before, type: DateTime, desc: 'Return issues updated before the specified time' optional :updated_before, type: DateTime, desc: 'Return issues updated before the specified time'
optional :not, type: Hash do
use :negatable_issue_filter_params
end
optional :scope, type: String, values: %w[created-by-me assigned-to-me created_by_me assigned_to_me all], optional :scope, type: String, values: %w[created-by-me assigned-to-me created_by_me assigned_to_me all],
desc: 'Return issues for the given scope: `created_by_me`, `assigned_to_me` or `all`' desc: 'Return issues for the given scope: `created_by_me`, `assigned_to_me` or `all`'
optional :my_reaction_emoji, type: String, desc: 'Return issues reacted by the authenticated user by the given emoji' optional :my_reaction_emoji, type: String, desc: 'Return issues reacted by the authenticated user by the given emoji'
optional :confidential, type: Boolean, desc: 'Filter confidential or public issues' optional :confidential, type: Boolean, desc: 'Filter confidential or public issues'
use :issues_stats_params_ee
end end
params :issues_params do params :issues_params do
......
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