Commit ed30646b authored by Heinrich Lee Yu's avatar Heinrich Lee Yu

Merge branch 'board_api' into 'master'

Expose hide_backlog_list and hide_closed_list to project and group boards REST API

See merge request gitlab-org/gitlab!49815
parents 6dfa0b27 f6cd7adb
---
title: Expose hide_backlog_list and hide_closed_list to project and group boards REST API
merge_request: 49815
author: Mathieu Parent
type: added
...@@ -279,7 +279,7 @@ Example response: ...@@ -279,7 +279,7 @@ Example response:
} }
``` ```
## Update a group issue board **(PREMIUM)** ## Update a group issue board
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/5954) in GitLab 11.1. > [Introduced](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/5954) in GitLab 11.1.
...@@ -289,15 +289,17 @@ Updates a Group Issue Board. ...@@ -289,15 +289,17 @@ Updates a Group Issue Board.
PUT /groups/:id/boards/:board_id PUT /groups/:id/boards/:board_id
``` ```
| Attribute | Type | Required | Description | | Attribute | Type | Required | Description |
| ------------------- | -------------- | -------- | ----------- | | ---------------------------- | -------------- | -------- | ----------- |
| `id` | integer/string | yes | The ID or [URL-encoded path of the group](README.md#namespaced-path-encoding) owned by the authenticated user | | `id` | integer/string | yes | The ID or [URL-encoded path of the group](README.md#namespaced-path-encoding) owned by the authenticated user |
| `board_id` | integer | yes | The ID of a board | | `board_id` | integer | yes | The ID of a board |
| `name` | string | no | The new name of the board | | `name` | string | no | The new name of the board |
| `assignee_id` | integer | no | The assignee the board should be scoped to | | `hide_backlog_list` | boolean | no | Hide the Open list |
| `milestone_id` | integer | no | The milestone the board should be scoped to | | `hide_closed_list` | boolean | no | Hide the Closed list |
| `labels` | string | no | Comma-separated list of label names which the board should be scoped to | | `assignee_id` **(PREMIUM)** | integer | no | The assignee the board should be scoped to |
| `weight` | integer | no | The weight range from 0 to 9, to which the board should be scoped to | | `milestone_id` **(PREMIUM)** | integer | no | The milestone the board should be scoped to |
| `labels` **(PREMIUM)** | string | no | Comma-separated list of label names which the board should be scoped to |
| `weight` **(PREMIUM)** | integer | no | The weight range from 0 to 9, to which the board should be scoped to |
```shell ```shell
curl --request PUT --header "PRIVATE-TOKEN: <your_access_token>" "https://gitlab.example.com/api/v4/groups/5/boards/1?name=new_name&milestone_id=44&assignee_id=1&labels=GroupLabel&weight=4" curl --request PUT --header "PRIVATE-TOKEN: <your_access_token>" "https://gitlab.example.com/api/v4/groups/5/boards/1?name=new_name&milestone_id=44&assignee_id=1&labels=GroupLabel&weight=4"
......
...@@ -16,9 +16,7 @@ module EE ...@@ -16,9 +16,7 @@ module EE
exactly_one_of :label_id, :milestone_id, :iteration_id, :assignee_id exactly_one_of :label_id, :milestone_id, :iteration_id, :assignee_id
end end
# Overrides API::BoardsResponses update_params params :update_params_ee do
params :update_params do
optional :name, type: String, desc: 'The board name'
optional :assignee_id, type: Integer, desc: 'The ID of a user to associate with board' optional :assignee_id, type: Integer, desc: 'The ID of a user to associate with board'
optional :milestone_id, type: Integer, desc: 'The ID of a milestone to associate with board' optional :milestone_id, type: Integer, desc: 'The ID of a milestone to associate with board'
optional :labels, type: String, desc: 'Comma-separated list of label names' optional :labels, type: String, desc: 'Comma-separated list of label names'
......
...@@ -39,19 +39,6 @@ module EE ...@@ -39,19 +39,6 @@ module EE
create_board create_board
end end
desc 'Update a group board' do
detail 'This feature was introduced in 11.0'
success ::API::Entities::Board
end
params do
use :update_params
end
put '/:board_id' do
authorize!(:admin_board, board_parent)
update_board
end
desc 'Delete a group board' do desc 'Delete a group board' do
detail 'This feature was introduced in 10.4' detail 'This feature was introduced in 10.4'
success ::API::Entities::Board success ::API::Entities::Board
......
...@@ -7,10 +7,10 @@ module API ...@@ -7,10 +7,10 @@ module API
prepend_if_ee('EE::API::BoardsResponses') # rubocop: disable Cop/InjectEnterpriseEditionModule prepend_if_ee('EE::API::BoardsResponses') # rubocop: disable Cop/InjectEnterpriseEditionModule
before { authenticate! }
feature_category :boards feature_category :boards
before { authenticate! }
helpers do helpers do
def board_parent def board_parent
user_project user_project
......
...@@ -80,10 +80,20 @@ module API ...@@ -80,10 +80,20 @@ module API
requires :label_id, type: Integer, desc: 'The ID of an existing label' requires :label_id, type: Integer, desc: 'The ID of an existing label'
end end
params :update_params do params :update_params_ce do
optional :name, type: String, desc: 'The board name'
optional :hide_backlog_list, type: Grape::API::Boolean, desc: 'Hide the Open list'
optional :hide_closed_list, type: Grape::API::Boolean, desc: 'Hide the Closed list'
end
params :update_params_ee do
# Configurable issue boards are not available in CE/EE Core. # Configurable issue boards are not available in CE/EE Core.
# https://docs.gitlab.com/ee/user/project/issue_board.html#configurable-issue-boards # https://docs.gitlab.com/ee/user/project/issue_board.html#configurable-issue-boards
optional :name, type: String, desc: 'The board name' end
params :update_params do
use :update_params_ce
use :update_params_ee
end end
end end
end end
......
...@@ -5,6 +5,8 @@ module API ...@@ -5,6 +5,8 @@ module API
class Board < Grape::Entity class Board < Grape::Entity
expose :id expose :id
expose :name expose :name
expose :hide_backlog_list
expose :hide_closed_list
expose :project, using: Entities::BasicProjectDetails expose :project, using: Entities::BasicProjectDetails
expose :lists, using: Entities::List do |board| expose :lists, using: Entities::List do |board|
......
...@@ -9,9 +9,7 @@ module API ...@@ -9,9 +9,7 @@ module API
feature_category :boards feature_category :boards
before do before { authenticate! }
authenticate!
end
helpers do helpers do
def board_parent def board_parent
...@@ -22,28 +20,40 @@ module API ...@@ -22,28 +20,40 @@ module API
params do params do
requires :id, type: String, desc: 'The ID of a group' requires :id, type: String, desc: 'The ID of a group'
end end
resource :groups, requirements: API::NAMESPACE_OR_PROJECT_REQUIREMENTS do resource :groups, requirements: API::NAMESPACE_OR_PROJECT_REQUIREMENTS do
segment ':id/boards' do segment ':id/boards' do
desc 'Get all group boards' do
detail 'This feature was introduced in 10.6'
success Entities::Board
end
params do
use :pagination
end
get '/' do
authorize!(:read_board, user_group)
present paginate(board_parent.boards.with_associations), with: Entities::Board
end
desc 'Find a group board' do desc 'Find a group board' do
detail 'This feature was introduced in 10.6' detail 'This feature was introduced in 10.6'
success ::API::Entities::Board success Entities::Board
end end
get '/:board_id' do get '/:board_id' do
authorize!(:read_board, user_group) authorize!(:read_board, user_group)
present board, with: ::API::Entities::Board present board, with: Entities::Board
end end
desc 'Get all group boards' do desc 'Update a group board' do
detail 'This feature was introduced in 10.6' detail 'This feature was introduced in 11.0'
success Entities::Board success Entities::Board
end end
params do params do
use :pagination use :update_params
end end
get '/' do put '/:board_id' do
authorize!(:read_board, user_group) authorize!(:admin_board, board_parent)
present paginate(board_parent.boards.with_associations), with: Entities::Board
update_board
end end
end end
......
...@@ -53,17 +53,6 @@ RSpec.describe API::Boards do ...@@ -53,17 +53,6 @@ RSpec.describe API::Boards do
end end
end end
describe "PUT /projects/:id/boards/:board_id" do
let(:url) { "/projects/#{board_parent.id}/boards/#{board.id}" }
it 'updates the issue board' do
put api(url, user), params: { name: 'changed board name' }
expect(response).to have_gitlab_http_status(:ok)
expect(json_response['name']).to eq('changed board name')
end
end
describe "DELETE /projects/:id/boards/:board_id" do describe "DELETE /projects/:id/boards/:board_id" do
let(:url) { "/projects/#{board_parent.id}/boards/#{board.id}" } let(:url) { "/projects/#{board_parent.id}/boards/#{board.id}" }
......
...@@ -44,16 +44,35 @@ RSpec.shared_examples 'group and project boards' do |route_definition, ee = fals ...@@ -44,16 +44,35 @@ RSpec.shared_examples 'group and project boards' do |route_definition, ee = fals
expect_schema_match_for(response, 'public_api/v4/boards', ee) expect_schema_match_for(response, 'public_api/v4/boards', ee)
end end
end
end
describe "GET #{route_definition}/:board_id" do describe "GET #{route_definition}/:board_id" do
let(:url) { "#{root_url}/#{board.id}" } let(:url) { "#{root_url}/#{board.id}" }
it 'get a single board by id' do it 'get a single board by id' do
get api(url, user) get api(url, user)
expect_schema_match_for(response, 'public_api/v4/board', ee) expect_schema_match_for(response, 'public_api/v4/board', ee)
end end
end end
describe "PUT #{route_definition}/:board_id" do
let(:url) { "#{root_url}/#{board.id}" }
it 'updates the board name' do
put api(url, user), params: { name: 'changed board name' }
expect(response).to have_gitlab_http_status(:ok)
expect(json_response['name']).to eq('changed board name')
end
it 'updates the issue board booleans' do
put api(url, user), params: { hide_backlog_list: true, hide_closed_list: true }
expect(response).to have_gitlab_http_status(:ok)
expect(json_response['hide_backlog_list']).to eq(true)
expect(json_response['hide_closed_list']).to eq(true)
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