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 GroupServiceImpl
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
);
96 * @see org.springframework.security.provisioning.GroupManager#renameGroup(java.lang.String, java.lang.String)
99 @Transactional(readOnly
=false)
100 public void renameGroup(String oldName
, String newName
) {
101 Assert
.hasText(oldName
);
102 Assert
.hasText(newName
);
104 Group group
= dao
.findGroupByName(oldName
);
106 group
.setName(newName
);
111 * @see org.springframework.security.provisioning.GroupManager#addUserToGroup(java.lang.String, java.lang.String)
114 @Transactional(readOnly
=false)
115 public void addUserToGroup(String username
, String groupName
) {
116 Assert
.hasText(username
);
117 Assert
.hasText(groupName
);
119 Group group
= dao
.findGroupByName(groupName
);
120 User user
= userDao
.findUserByUsername(username
);
122 if(group
!= null || user
!= null){
123 if(group
.addMember(user
)) {
130 * @see org.springframework.security.provisioning.GroupManager#removeUserFromGroup(java.lang.String, java.lang.String)
133 @Transactional(readOnly
=false)
134 public void removeUserFromGroup(String username
, String groupName
) {
135 Assert
.hasText(username
);
136 Assert
.hasText(groupName
);
138 Group group
= dao
.findGroupByName(groupName
);
139 User user
= userDao
.findUserByUsername(username
);
141 if(group
!= null || user
!= null){
142 if(group
.removeMember(user
)){
149 * @see org.springframework.security.provisioning.GroupManager#findGroupAuthorities(java.lang.String)
152 public List
<GrantedAuthority
> findGroupAuthorities(String groupName
) {
153 Assert
.hasText(groupName
);
154 Group group
= dao
.findGroupByName(groupName
);
157 return new ArrayList
<GrantedAuthority
>(group
.getGrantedAuthorities());
160 return new ArrayList
<GrantedAuthority
>();
164 * @see org.springframework.security.provisioning.GroupManager#addGroupAuthority(java.lang.String, org.springframework.security.core.GrantedAuthority)
167 @Transactional(readOnly
=false)
168 public void addGroupAuthority(String groupName
, GrantedAuthority authority
) {
169 Assert
.hasText(groupName
);
170 Assert
.notNull(authority
);
172 Group group
= dao
.findGroupByName(groupName
);
175 if(group
.getGrantedAuthorities().add(authority
)){
182 * @see org.springframework.security.provisioning.GroupManager#removeGroupAuthority(java.lang.String, org.springframework.security.core.GrantedAuthority)
185 @Transactional(readOnly
=false)
186 public void removeGroupAuthority(String groupName
,
187 GrantedAuthority authority
) {
188 Assert
.hasText(groupName
);
189 Assert
.notNull(authority
);
191 Group group
= dao
.findGroupByName(groupName
);
194 if(group
.getGrantedAuthorities().remove(authority
)) {
201 * @see eu.etaxonomy.cdm.api.service.ServiceBase#setDao(eu.etaxonomy.cdm.persistence.dao.common.ICdmEntityDao)
205 protected void setDao(IGroupDao dao
) {
210 public void setUserDao(IUserDao userDao
){
211 this.userDao
= userDao
;
214 @Transactional(readOnly
= true)
215 public List
<Group
> listByName(String queryString
,MatchMode matchmode
, List
<Criterion
> criteria
, Integer pageSize
, Integer pageNumber
, List
<OrderHint
> orderHints
, List
<String
> propertyPaths
) {
216 Integer numberOfResults
= dao
.countByName(queryString
, matchmode
, criteria
);
218 List
<Group
> results
= new ArrayList
<Group
>();
219 if(numberOfResults
> 0) {
220 results
= dao
.findByName(queryString
, matchmode
, criteria
, pageSize
, pageNumber
, orderHints
, propertyPaths
);