3 * Copyright (C) 2007 EDIT
4 * European Distributed Institute of Taxonomy
5 * http://www.e-taxonomy.eu
7 * The contents of this file are subject to the Mozilla Public License Version 1.1
8 * See LICENSE.TXT at the top of this package for the full license terms.
11 package eu
.etaxonomy
.cdm
.api
.service
;
13 import java
.util
.ArrayList
;
14 import java
.util
.List
;
16 import org
.hibernate
.criterion
.Criterion
;
17 import org
.springframework
.beans
.factory
.annotation
.Autowired
;
18 import org
.springframework
.security
.core
.GrantedAuthority
;
19 import org
.springframework
.stereotype
.Service
;
20 import org
.springframework
.transaction
.annotation
.Propagation
;
21 import org
.springframework
.transaction
.annotation
.Transactional
;
22 import org
.springframework
.util
.Assert
;
24 import eu
.etaxonomy
.cdm
.model
.common
.Group
;
25 import eu
.etaxonomy
.cdm
.model
.common
.User
;
26 import eu
.etaxonomy
.cdm
.persistence
.dao
.common
.IGroupDao
;
27 import eu
.etaxonomy
.cdm
.persistence
.dao
.common
.IUserDao
;
28 import eu
.etaxonomy
.cdm
.persistence
.query
.MatchMode
;
29 import eu
.etaxonomy
.cdm
.persistence
.query
.OrderHint
;
33 * @created Mar 9, 2011
37 @Transactional(propagation
= Propagation
.SUPPORTS
, readOnly
= true)
38 public class GroupService
extends ServiceBase
<Group
,IGroupDao
> implements IGroupService
{
40 protected IUserDao userDao
;
43 * @see org.springframework.security.provisioning.GroupManager#findAllGroups()
46 public List
<String
> findAllGroups() {
47 return dao
.listNames(null,null);
51 * @see org.springframework.security.provisioning.GroupManager#findUsersInGroup(java.lang.String)
54 public List
<String
> findUsersInGroup(String groupName
) {
55 Assert
.hasText(groupName
);
56 Group group
= dao
.findGroupByName(groupName
);
58 List
<String
> users
= dao
.listMembers(group
, null, null);
64 * @see org.springframework.security.provisioning.GroupManager#createGroup(java.lang.String, java.util.List)
67 @Transactional(readOnly
=false)
68 public void createGroup(String groupName
, List
<GrantedAuthority
> authorities
) {
69 Assert
.hasText(groupName
);
70 Assert
.notNull(authorities
);
72 Group group
= Group
.NewInstance(groupName
);
74 for(GrantedAuthority authority
: authorities
) {
75 group
.getGrantedAuthorities().add(authority
);
82 * @see org.springframework.security.provisioning.GroupManager#deleteGroup(java.lang.String)
85 @Transactional(readOnly
=false)
86 public void deleteGroup(String groupName
) {
87 Assert
.hasText(groupName
);
89 Group group
= dao
.findGroupByName(groupName
);
94 * @see org.springframework.security.provisioning.GroupManager#renameGroup(java.lang.String, java.lang.String)
97 @Transactional(readOnly
=false)
98 public void renameGroup(String oldName
, String newName
) {
99 Assert
.hasText(oldName
);
100 Assert
.hasText(newName
);
102 Group group
= dao
.findGroupByName(oldName
);
104 group
.setName(newName
);
109 * @see org.springframework.security.provisioning.GroupManager#addUserToGroup(java.lang.String, java.lang.String)
112 @Transactional(readOnly
=false)
113 public void addUserToGroup(String username
, String groupName
) {
114 Assert
.hasText(username
);
115 Assert
.hasText(groupName
);
117 Group group
= dao
.findGroupByName(groupName
);
118 User user
= userDao
.findUserByUsername(username
);
120 if(group
.addMember(user
)) {
126 * @see org.springframework.security.provisioning.GroupManager#removeUserFromGroup(java.lang.String, java.lang.String)
129 @Transactional(readOnly
=false)
130 public void removeUserFromGroup(String username
, String groupName
) {
131 Assert
.hasText(username
);
132 Assert
.hasText(groupName
);
134 Group group
= dao
.findGroupByName(groupName
);
135 User user
= userDao
.findUserByUsername(username
);
137 if(group
.removeMember(user
)) {
143 * @see org.springframework.security.provisioning.GroupManager#findGroupAuthorities(java.lang.String)
146 public List
<GrantedAuthority
> findGroupAuthorities(String groupName
) {
147 Assert
.hasText(groupName
);
148 Group group
= dao
.findGroupByName(groupName
);
150 return new ArrayList
<GrantedAuthority
>(group
.getGrantedAuthorities());
154 * @see org.springframework.security.provisioning.GroupManager#addGroupAuthority(java.lang.String, org.springframework.security.core.GrantedAuthority)
157 @Transactional(readOnly
=false)
158 public void addGroupAuthority(String groupName
, GrantedAuthority authority
) {
159 Assert
.hasText(groupName
);
160 Assert
.notNull(authority
);
162 Group group
= dao
.findGroupByName(groupName
);
163 if(group
.getGrantedAuthorities().add(authority
)) {
169 * @see org.springframework.security.provisioning.GroupManager#removeGroupAuthority(java.lang.String, org.springframework.security.core.GrantedAuthority)
172 @Transactional(readOnly
=false)
173 public void removeGroupAuthority(String groupName
,
174 GrantedAuthority authority
) {
175 Assert
.hasText(groupName
);
176 Assert
.notNull(authority
);
178 Group group
= dao
.findGroupByName(groupName
);
180 if(group
.getGrantedAuthorities().remove(authority
)) {
186 * @see eu.etaxonomy.cdm.api.service.ServiceBase#setDao(eu.etaxonomy.cdm.persistence.dao.common.ICdmEntityDao)
190 protected void setDao(IGroupDao dao
) {
195 public void setUserDao(IUserDao userDao
){
196 this.userDao
= userDao
;
199 @Transactional(readOnly
= true)
200 public List
<Group
> listByName(String queryString
,MatchMode matchmode
, List
<Criterion
> criteria
, Integer pageSize
, Integer pageNumber
, List
<OrderHint
> orderHints
, List
<String
> propertyPaths
) {
201 Integer numberOfResults
= dao
.countByName(queryString
, matchmode
, criteria
);
203 List
<Group
> results
= new ArrayList
<Group
>();
204 if(numberOfResults
> 0) {
205 results
= dao
.findByName(queryString
, matchmode
, criteria
, pageSize
, pageNumber
, orderHints
, propertyPaths
);