]> git.argeo.org Git - lgpl/argeo-commons.git/blob - UserFilter.java
04c275647c62751dfe17213cb458ebb47f5df473
[lgpl/argeo-commons.git] / UserFilter.java
1 package org.argeo.cms.ui.workbench.internal.useradmin.providers;
2
3 import static org.argeo.eclipse.ui.EclipseUiUtils.notEmpty;
4
5 import org.argeo.cms.util.useradmin.UserAdminUtils;
6 import org.argeo.node.NodeConstants;
7 import org.argeo.osgi.useradmin.LdifName;
8 import org.eclipse.jface.viewers.Viewer;
9 import org.eclipse.jface.viewers.ViewerFilter;
10 import org.osgi.service.useradmin.User;
11
12 public class UserFilter extends ViewerFilter {
13 private static final long serialVersionUID = 5082509381672880568L;
14
15 private String searchString;
16 private boolean showSystemRole = true;
17
18 private final String[] knownProps = { LdifName.dn.name(),
19 LdifName.cn.name(), LdifName.givenName.name(), LdifName.sn.name(),
20 LdifName.uid.name(), LdifName.description.name(),
21 LdifName.mail.name() };
22
23 public void setSearchText(String s) {
24 // ensure that the value can be used for matching
25 if (notEmpty(s))
26 searchString = ".*" + s.toLowerCase() + ".*";
27 else
28 searchString = ".*";
29 }
30
31 public void setShowSystemRole(boolean showSystemRole) {
32 this.showSystemRole = showSystemRole;
33 }
34
35 @Override
36 public boolean select(Viewer viewer, Object parentElement, Object element) {
37 User user = (User) element;
38 if (!showSystemRole
39 && user.getName().matches(
40 ".*(" + NodeConstants.ROLES_BASEDN + ")"))
41 // UserAdminUtils.getProperty(user, LdifName.dn.name())
42 // .toLowerCase().endsWith(AuthConstants.ROLES_BASEDN))
43 return false;
44
45 if (searchString == null || searchString.length() == 0)
46 return true;
47
48 if (user.getName().matches(searchString))
49 return true;
50
51 for (String key : knownProps) {
52 String currVal = UserAdminUtils.getProperty(user, key);
53 if (notEmpty(currVal)
54 && currVal.toLowerCase().matches(searchString))
55 return true;
56 }
57 return false;
58 }
59
60 }