mirror of
https://github.com/scm-manager/scm-manager.git
synced 2025-11-13 08:55:44 +01:00
added create-group subcommand
This commit is contained in:
@@ -0,0 +1,207 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2010, Sebastian Sdorra
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of SCM-Manager; nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived from this
|
||||||
|
* software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* http://bitbucket.org/sdorra/scm-manager
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
package sonia.scm.cli.cmd;
|
||||||
|
|
||||||
|
//~--- non-JDK imports --------------------------------------------------------
|
||||||
|
|
||||||
|
import org.kohsuke.args4j.Option;
|
||||||
|
|
||||||
|
import sonia.scm.client.ScmClientSession;
|
||||||
|
import sonia.scm.group.Group;
|
||||||
|
|
||||||
|
//~--- JDK imports ------------------------------------------------------------
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author Sebastian Sdorra
|
||||||
|
*/
|
||||||
|
@Command("create-group")
|
||||||
|
public class CreateGroupSubCommand extends TemplateSubCommand
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getDescription()
|
||||||
|
{
|
||||||
|
return description;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public List<String> getMembers()
|
||||||
|
{
|
||||||
|
return members;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getName()
|
||||||
|
{
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getType()
|
||||||
|
{
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- set methods ----------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param description
|
||||||
|
*/
|
||||||
|
public void setDescription(String description)
|
||||||
|
{
|
||||||
|
this.description = description;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param members
|
||||||
|
*/
|
||||||
|
public void setMembers(List<String> members)
|
||||||
|
{
|
||||||
|
this.members = members;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param name
|
||||||
|
*/
|
||||||
|
public void setName(String name)
|
||||||
|
{
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @param type
|
||||||
|
*/
|
||||||
|
public void setType(String type)
|
||||||
|
{
|
||||||
|
this.type = type;
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- methods --------------------------------------------------------------
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method description
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
protected void run()
|
||||||
|
{
|
||||||
|
Group group = new Group();
|
||||||
|
|
||||||
|
group.setName(name);
|
||||||
|
group.setDescription(description);
|
||||||
|
group.setType(type);
|
||||||
|
group.setMembers(members);
|
||||||
|
|
||||||
|
ScmClientSession session = createSession();
|
||||||
|
|
||||||
|
session.getGroupHandler().create(group);
|
||||||
|
|
||||||
|
Map<String, Object> env = new HashMap<String, Object>();
|
||||||
|
|
||||||
|
env.put("group", group);
|
||||||
|
renderTemplate(env, GetGroupSubCommand.TEMPLATE);
|
||||||
|
}
|
||||||
|
|
||||||
|
//~--- fields ---------------------------------------------------------------
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
@Option(
|
||||||
|
name = "--description",
|
||||||
|
usage = "optionGroupDescription",
|
||||||
|
aliases = { "-d" }
|
||||||
|
)
|
||||||
|
private String description;
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
@Option(
|
||||||
|
name = "--member",
|
||||||
|
usage = "optionGroupMember",
|
||||||
|
aliases = { "-m" }
|
||||||
|
)
|
||||||
|
private List<String> members;
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
@Option(
|
||||||
|
name = "--name",
|
||||||
|
usage = "optionGroupName",
|
||||||
|
required = true,
|
||||||
|
aliases = { "-n" }
|
||||||
|
)
|
||||||
|
private String name;
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
@Option(
|
||||||
|
name = "--type",
|
||||||
|
usage = "optionGroupType",
|
||||||
|
aliases = { "-t" }
|
||||||
|
)
|
||||||
|
private String type = "xml";
|
||||||
|
}
|
||||||
@@ -52,3 +52,4 @@ sonia.scm.cli.cmd.ModifyUserSubCommand
|
|||||||
# group
|
# group
|
||||||
sonia.scm.cli.cmd.ListGroupsSubCommand
|
sonia.scm.cli.cmd.ListGroupsSubCommand
|
||||||
sonia.scm.cli.cmd.GetGroupSubCommand
|
sonia.scm.cli.cmd.GetGroupSubCommand
|
||||||
|
sonia.scm.cli.cmd.CreateGroupSubCommand
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
Name: ${group.name}
|
Name: ${group.name}
|
||||||
Type: ${group.type}
|
Type: ${group.type}
|
||||||
Description: ${group.description}
|
Description: ${group.description!""}
|
||||||
Creation-Date: ${group.creationDate!""?string}
|
Creation-Date: ${group.creationDate!""?string}
|
||||||
Last-Modified: ${group.lastModified!""?string}
|
Last-Modified: ${group.lastModified!""?string}
|
||||||
Members:
|
Members:
|
||||||
|
|||||||
@@ -44,7 +44,7 @@ optionRepositoryContact = Repository contact
|
|||||||
optionRepositoryDescription = Repository description
|
optionRepositoryDescription = Repository description
|
||||||
optionRepositoryPublic = Repository public readable
|
optionRepositoryPublic = Repository public readable
|
||||||
|
|
||||||
optionPermissionGroup = Gtoup
|
optionPermissionGroup = Group
|
||||||
optionPermissionName = Group or user name
|
optionPermissionName = Group or user name
|
||||||
optionPermissionType = Permission type (READ,WRITE or OWNER)
|
optionPermissionType = Permission type (READ,WRITE or OWNER)
|
||||||
|
|
||||||
@@ -55,6 +55,11 @@ optionUserPassword = Password
|
|||||||
optionUserType = Type
|
optionUserType = Type
|
||||||
optionUserAdmin = Administrator
|
optionUserAdmin = Administrator
|
||||||
|
|
||||||
|
optionGroupName = Name
|
||||||
|
optionGroupDescription = Description
|
||||||
|
optionGroupType = Type
|
||||||
|
optionGroupMember = Member
|
||||||
|
|
||||||
repositoryNotFound = The repository is not available
|
repositoryNotFound = The repository is not available
|
||||||
userNotFound = The user could not be found
|
userNotFound = The user could not be found
|
||||||
groupNotFoun = The group could not be found
|
groupNotFoun = The group could not be found
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
<#list groups as group>
|
<#list groups as group>
|
||||||
Name: ${group.name}
|
Name: ${group.name}
|
||||||
Type: ${group.type}
|
Type: ${group.type}
|
||||||
Description: ${group.description}
|
Description: ${group.description!""}
|
||||||
Creation-Date: ${group.creationDate!""?string}
|
Creation-Date: ${group.creationDate!""?string}
|
||||||
Last-Modified: ${group.lastModified!""?string}
|
Last-Modified: ${group.lastModified!""?string}
|
||||||
Members:
|
Members:
|
||||||
@@ -10,4 +10,5 @@ Members:
|
|||||||
${member}
|
${member}
|
||||||
</#list>
|
</#list>
|
||||||
</#if>
|
</#if>
|
||||||
|
|
||||||
</#list>
|
</#list>
|
||||||
Reference in New Issue
Block a user