diff options
Diffstat (limited to 'java/com/google/gerrit/server/restapi/group/Module.java')
-rw-r--r-- | java/com/google/gerrit/server/restapi/group/Module.java | 94 |
1 files changed, 94 insertions, 0 deletions
diff --git a/java/com/google/gerrit/server/restapi/group/Module.java b/java/com/google/gerrit/server/restapi/group/Module.java new file mode 100644 index 0000000000..741c3da774 --- /dev/null +++ b/java/com/google/gerrit/server/restapi/group/Module.java @@ -0,0 +1,94 @@ +// Copyright (C) 2013 The Android Open Source Project +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package com.google.gerrit.server.restapi.group; + +import static com.google.gerrit.server.group.GroupResource.GROUP_KIND; +import static com.google.gerrit.server.group.MemberResource.MEMBER_KIND; +import static com.google.gerrit.server.group.SubgroupResource.SUBGROUP_KIND; + +import com.google.gerrit.extensions.registration.DynamicMap; +import com.google.gerrit.extensions.restapi.RestApiModule; +import com.google.gerrit.server.IdentifiedUser; +import com.google.gerrit.server.ServerInitiated; +import com.google.gerrit.server.UserInitiated; +import com.google.gerrit.server.group.db.GroupsUpdate; +import com.google.gerrit.server.restapi.group.AddMembers.CreateMember; +import com.google.gerrit.server.restapi.group.AddMembers.UpdateMember; +import com.google.gerrit.server.restapi.group.AddSubgroups.CreateSubgroup; +import com.google.gerrit.server.restapi.group.AddSubgroups.UpdateSubgroup; +import com.google.gerrit.server.restapi.group.DeleteMembers.DeleteMember; +import com.google.gerrit.server.restapi.group.DeleteSubgroups.DeleteSubgroup; +import com.google.inject.Provides; + +public class Module extends RestApiModule { + + @Override + protected void configure() { + bind(GroupsCollection.class); + + DynamicMap.mapOf(binder(), GROUP_KIND); + DynamicMap.mapOf(binder(), MEMBER_KIND); + DynamicMap.mapOf(binder(), SUBGROUP_KIND); + + create(GROUP_KIND).to(CreateGroup.class); + get(GROUP_KIND).to(GetGroup.class); + put(GROUP_KIND).to(PutGroup.class); + get(GROUP_KIND, "detail").to(GetDetail.class); + post(GROUP_KIND, "index").to(Index.class); + post(GROUP_KIND, "members").to(AddMembers.class); + post(GROUP_KIND, "members.add").to(AddMembers.class); + post(GROUP_KIND, "members.delete").to(DeleteMembers.class); + post(GROUP_KIND, "groups").to(AddSubgroups.class); + post(GROUP_KIND, "groups.add").to(AddSubgroups.class); + post(GROUP_KIND, "groups.delete").to(DeleteSubgroups.class); + get(GROUP_KIND, "description").to(GetDescription.class); + put(GROUP_KIND, "description").to(PutDescription.class); + delete(GROUP_KIND, "description").to(PutDescription.class); + get(GROUP_KIND, "name").to(GetName.class); + put(GROUP_KIND, "name").to(PutName.class); + get(GROUP_KIND, "owner").to(GetOwner.class); + put(GROUP_KIND, "owner").to(PutOwner.class); + get(GROUP_KIND, "options").to(GetOptions.class); + put(GROUP_KIND, "options").to(PutOptions.class); + get(GROUP_KIND, "log.audit").to(GetAuditLog.class); + + child(GROUP_KIND, "members").to(MembersCollection.class); + create(MEMBER_KIND).to(CreateMember.class); + get(MEMBER_KIND).to(GetMember.class); + put(MEMBER_KIND).to(UpdateMember.class); + delete(MEMBER_KIND).to(DeleteMember.class); + + child(GROUP_KIND, "groups").to(SubgroupsCollection.class); + create(SUBGROUP_KIND).to(CreateSubgroup.class); + get(SUBGROUP_KIND).to(GetSubgroup.class); + put(SUBGROUP_KIND).to(UpdateSubgroup.class); + delete(SUBGROUP_KIND).to(DeleteSubgroup.class); + + factory(GroupsUpdate.Factory.class); + } + + @Provides + @ServerInitiated + GroupsUpdate provideServerInitiatedGroupsUpdate(GroupsUpdate.Factory groupsUpdateFactory) { + return groupsUpdateFactory.create(null); + } + + @Provides + @UserInitiated + GroupsUpdate provideUserInitiatedGroupsUpdate( + GroupsUpdate.Factory groupsUpdateFactory, IdentifiedUser currentUser) { + return groupsUpdateFactory.create(currentUser); + } +} |