Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
5db92466
Commit
5db92466
authored
Mar 02, 2017
by
Toon Claes
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Port EE features to v3 API
parent
07df394f
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
60 additions
and
0 deletions
+60
-0
lib/api/v3/entities.rb
lib/api/v3/entities.rb
+6
-0
lib/api/v3/groups.rb
lib/api/v3/groups.rb
+22
-0
spec/requests/api/v3/groups_spec.rb
spec/requests/api/v3/groups_spec.rb
+32
-0
No files found.
lib/api/v3/entities.rb
View file @
5db92466
...
@@ -167,6 +167,12 @@ module API
...
@@ -167,6 +167,12 @@ module API
class
Group
<
Grape
::
Entity
class
Group
<
Grape
::
Entity
expose
:id
,
:name
,
:path
,
:description
,
:visibility_level
expose
:id
,
:name
,
:path
,
:description
,
:visibility_level
expose
:ldap_cn
,
:ldap_access
expose
:ldap_group_links
,
using:
::
API
::
Entities
::
LdapGroupLink
,
if:
lambda
{
|
group
,
options
|
group
.
ldap_group_links
.
any?
}
expose
:lfs_enabled?
,
as: :lfs_enabled
expose
:lfs_enabled?
,
as: :lfs_enabled
expose
:avatar_url
expose
:avatar_url
expose
:web_url
expose
:web_url
...
...
lib/api/v3/groups.rb
View file @
5db92466
...
@@ -11,6 +11,14 @@ module API
...
@@ -11,6 +11,14 @@ module API
optional
:visibility_level
,
type:
Integer
,
desc:
'The visibility level of the group'
optional
:visibility_level
,
type:
Integer
,
desc:
'The visibility level of the group'
optional
:lfs_enabled
,
type:
Boolean
,
desc:
'Enable/disable LFS for the projects in this group'
optional
:lfs_enabled
,
type:
Boolean
,
desc:
'Enable/disable LFS for the projects in this group'
optional
:request_access_enabled
,
type:
Boolean
,
desc:
'Allow users to request member access'
optional
:request_access_enabled
,
type:
Boolean
,
desc:
'Allow users to request member access'
optional
:membership_lock
,
type:
Boolean
,
desc:
'Prevent adding new members to project membership within this group'
optional
:share_with_group_lock
,
type:
Boolean
,
desc:
'Prevent sharing a project with another group within this group'
end
params
:optional_params_ee
do
optional
:ldap_cn
,
type:
String
,
desc:
'LDAP Common Name'
optional
:ldap_access
,
type:
Integer
,
desc:
'A valid access level'
all_or_none_of
:ldap_cn
,
:ldap_access
end
end
params
:statistics_params
do
params
:statistics_params
do
...
@@ -76,13 +84,27 @@ module API
...
@@ -76,13 +84,27 @@ module API
requires
:path
,
type:
String
,
desc:
'The path of the group'
requires
:path
,
type:
String
,
desc:
'The path of the group'
optional
:parent_id
,
type:
Integer
,
desc:
'The parent group id for creating nested group'
optional
:parent_id
,
type:
Integer
,
desc:
'The parent group id for creating nested group'
use
:optional_params
use
:optional_params
use
:optional_params_ee
end
end
post
do
post
do
authorize!
:create_group
authorize!
:create_group
ldap_link_attrs
=
{
cn:
params
.
delete
(
:ldap_cn
),
group_access:
params
.
delete
(
:ldap_access
)
}
group
=
::
Groups
::
CreateService
.
new
(
current_user
,
declared_params
(
include_missing:
false
)).
execute
group
=
::
Groups
::
CreateService
.
new
(
current_user
,
declared_params
(
include_missing:
false
)).
execute
if
group
.
persisted?
if
group
.
persisted?
# NOTE: add backwards compatibility for single ldap link
if
ldap_link_attrs
[
:cn
].
present?
group
.
ldap_group_links
.
create
(
cn:
ldap_link_attrs
[
:cn
],
group_access:
ldap_link_attrs
[
:group_access
]
)
end
present
group
,
with:
Entities
::
Group
,
current_user:
current_user
present
group
,
with:
Entities
::
Group
,
current_user:
current_user
else
else
render_api_error!
(
"Failed to save group
#{
group
.
errors
.
messages
}
"
,
400
)
render_api_error!
(
"Failed to save group
#{
group
.
errors
.
messages
}
"
,
400
)
...
...
spec/requests/api/v3/groups_spec.rb
View file @
5db92466
...
@@ -17,6 +17,7 @@ describe API::V3::Groups, api: true do
...
@@ -17,6 +17,7 @@ describe API::V3::Groups, api: true do
before
do
before
do
group1
.
add_owner
(
user1
)
group1
.
add_owner
(
user1
)
group2
.
add_owner
(
user2
)
group2
.
add_owner
(
user2
)
group1
.
ldap_group_links
.
create
cn:
'ldap-group'
,
group_access:
Gitlab
::
Access
::
MASTER
,
provider:
'ldap'
end
end
describe
"GET /groups"
do
describe
"GET /groups"
do
...
@@ -37,6 +38,14 @@ describe API::V3::Groups, api: true do
...
@@ -37,6 +38,14 @@ describe API::V3::Groups, api: true do
expect
(
json_response
.
length
).
to
eq
(
1
)
expect
(
json_response
.
length
).
to
eq
(
1
)
expect
(
json_response
)
expect
(
json_response
)
.
to
satisfy_one
{
|
group
|
group
[
'name'
]
==
group1
.
name
}
.
to
satisfy_one
{
|
group
|
group
[
'name'
]
==
group1
.
name
}
expect
(
json_response
.
first
[
'ldap_cn'
]).
to
eq
(
group1
.
ldap_cn
)
expect
(
json_response
.
first
[
'ldap_access'
]).
to
eq
(
group1
.
ldap_access
)
ldap_group_link
=
json_response
.
first
[
'ldap_group_links'
].
first
expect
(
ldap_group_link
[
'cn'
]).
to
eq
(
group1
.
ldap_cn
)
expect
(
ldap_group_link
[
'group_access'
]).
to
eq
(
group1
.
ldap_access
)
expect
(
ldap_group_link
[
'provider'
]).
to
eq
(
'ldap'
)
end
end
it
"does not include statistics"
do
it
"does not include statistics"
do
...
@@ -453,6 +462,29 @@ describe API::V3::Groups, api: true do
...
@@ -453,6 +462,29 @@ describe API::V3::Groups, api: true do
expect
(
response
).
to
have_http_status
(
400
)
expect
(
response
).
to
have_http_status
(
400
)
end
end
it
"creates an ldap_group_link if ldap_cn and ldap_access are supplied"
do
group_attributes
=
attributes_for
(
:group
,
ldap_cn:
'ldap-group'
,
ldap_access:
Gitlab
::
Access
::
DEVELOPER
)
expect
{
post
v3_api
(
"/groups"
,
admin
),
group_attributes
}.
to
change
{
LdapGroupLink
.
count
}.
by
(
1
)
end
end
end
describe
"PUT /groups"
do
context
"when authenticated as user without group permissions"
do
it
"does not create group"
do
put
v3_api
(
"/groups/
#{
group2
.
id
}
"
,
user1
),
attributes_for
(
:group
)
expect
(
response
.
status
).
to
eq
(
404
)
end
end
context
"when authenticated as user with group permissions"
do
it
"updates group"
do
group2
.
update
(
owner:
user2
)
put
v3_api
(
"/groups/
#{
group2
.
id
}
"
,
user2
),
{
name:
'Renamed'
}
expect
(
response
.
status
).
to
eq
(
200
)
expect
(
group2
.
reload
.
name
).
to
eq
(
'Renamed'
)
end
end
end
end
end
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment