Search in sources :

Example 6 with BwGroup

use of org.bedework.calfacade.BwGroup in project bw-calendar-engine by Bedework.

the class AdminGroupsDbImpl method addMember.

@Override
public void addMember(final BwGroup group, final BwPrincipal val) throws CalFacadeException {
    final BwGroup ag = findGroup(group.getAccount());
    if (ag == null) {
        throw new CalFacadeException(CalFacadeException.groupNotFound, group.getAccount());
    }
    if (!checkPathForSelf(group, val)) {
        throw new CalFacadeException(CalFacadeException.alreadyOnGroupPath);
    }
    ag.addGroupMember(val);
    cb.addMember(ag, val, true);
}
Also used : BwGroup(org.bedework.calfacade.BwGroup) CalFacadeException(org.bedework.calfacade.exc.CalFacadeException)

Example 7 with BwGroup

use of org.bedework.calfacade.BwGroup in project bw-calendar-engine by Bedework.

the class CardDAVDirImpl method findGroup.

/* Search for a group to ensure it exists
   *
   */
private BwGroup findGroup(final DirConfigProperties dirProps, final String groupName) throws CalFacadeException {
    LdapConfigProperties props = (LdapConfigProperties) dirProps;
    InitialLdapContext ctx = null;
    try {
        ctx = createLdapInitContext(props);
        BasicAttributes matchAttrs = new BasicAttributes(true);
        matchAttrs.put(props.getGroupIdAttr(), groupName);
        String[] idAttr = { props.getGroupIdAttr() };
        BwGroup group = null;
        NamingEnumeration response = ctx.search(props.getGroupContextDn(), matchAttrs, idAttr);
        while (response.hasMore()) {
            if (group != null) {
                throw new CalFacadeException("org.bedework.ldap.groups.multiple.result");
            }
            group = new BwGroup();
            group.setAccount(groupName);
            group.setPrincipalRef(makePrincipalUri(groupName, WhoDefs.whoTypeGroup));
        }
        return group;
    } catch (Throwable t) {
        if (debug) {
            error(t);
        }
        throw new CalFacadeException(t);
    } finally {
        // Close the context to release the connection
        if (ctx != null) {
            closeContext(ctx);
        }
    }
}
Also used : BasicAttributes(javax.naming.directory.BasicAttributes) BwGroup(org.bedework.calfacade.BwGroup) InitialLdapContext(javax.naming.ldap.InitialLdapContext) NamingEnumeration(javax.naming.NamingEnumeration) CalFacadeException(org.bedework.calfacade.exc.CalFacadeException) LdapConfigProperties(org.bedework.calfacade.configs.LdapConfigProperties)

Example 8 with BwGroup

use of org.bedework.calfacade.BwGroup in project bw-calendar-engine by Bedework.

the class CardDAVDirImpl method getGroups.

/* Return all groups for principal == null or all groups for which principal
   * is a member
   *
   */
private Collection<BwGroup> getGroups(final DirConfigProperties dirProps, final BwPrincipal principal) throws CalFacadeException {
    LdapConfigProperties props = (LdapConfigProperties) dirProps;
    InitialLdapContext ctx = null;
    String member = null;
    if (principal != null) {
        if (principal.getKind() == WhoDefs.whoTypeUser) {
            member = getUserEntryValue(props, principal);
        } else if (principal.getKind() == WhoDefs.whoTypeGroup) {
            member = getGroupEntryValue(props, principal);
        }
    }
    try {
        ctx = createLdapInitContext(props);
        BasicAttributes matchAttrs = new BasicAttributes(true);
        if (member != null) {
            matchAttrs.put(props.getGroupMemberAttr(), member);
        }
        String[] idAttr = { props.getGroupIdAttr() };
        ArrayList<BwGroup> groups = new ArrayList<BwGroup>();
        NamingEnumeration response = ctx.search(props.getGroupContextDn(), matchAttrs, idAttr);
        while (response.hasMore()) {
            SearchResult sr = (SearchResult) response.next();
            Attributes attrs = sr.getAttributes();
            Attribute nmAttr = attrs.get(props.getGroupIdAttr());
            if (nmAttr.size() != 1) {
                throw new CalFacadeException("org.bedework.ldap.groups.multiple.result");
            }
            BwGroup group = new BwGroup();
            group.setAccount(nmAttr.get(0).toString());
            group.setPrincipalRef(makePrincipalUri(group.getAccount(), WhoDefs.whoTypeGroup));
            groups.add(group);
        }
        return groups;
    } catch (Throwable t) {
        if (debug) {
            error(t);
        }
        throw new CalFacadeException(t);
    } finally {
        // Close the context to release the connection
        if (ctx != null) {
            closeContext(ctx);
        }
    }
}
Also used : BasicAttributes(javax.naming.directory.BasicAttributes) BwGroup(org.bedework.calfacade.BwGroup) Attribute(javax.naming.directory.Attribute) ArrayList(java.util.ArrayList) BasicAttributes(javax.naming.directory.BasicAttributes) Attributes(javax.naming.directory.Attributes) NamingEnumeration(javax.naming.NamingEnumeration) SearchResult(javax.naming.directory.SearchResult) CalFacadeException(org.bedework.calfacade.exc.CalFacadeException) InitialLdapContext(javax.naming.ldap.InitialLdapContext) LdapConfigProperties(org.bedework.calfacade.configs.LdapConfigProperties)

Example 9 with BwGroup

use of org.bedework.calfacade.BwGroup in project bw-calendar-engine by Bedework.

the class CardDAVDirImpl method getGroupMembers.

/* Find members for given group
   *
   */
private void getGroupMembers(final DirConfigProperties dirProps, final BwGroup group) throws CalFacadeException {
    LdapConfigProperties props = (LdapConfigProperties) dirProps;
    InitialLdapContext ctx = null;
    try {
        ctx = createLdapInitContext(props);
        BasicAttributes matchAttrs = new BasicAttributes(true);
        matchAttrs.put(props.getGroupIdAttr(), group.getAccount());
        String[] memberAttr = { props.getGroupMemberAttr() };
        ArrayList<String> mbrs = null;
        boolean beenHere = false;
        NamingEnumeration response = ctx.search(props.getGroupContextDn(), matchAttrs, memberAttr);
        while (response.hasMore()) {
            SearchResult sr = (SearchResult) response.next();
            Attributes attrs = sr.getAttributes();
            if (beenHere) {
                throw new CalFacadeException("org.bedework.ldap.groups.multiple.result");
            }
            beenHere = true;
            Attribute membersAttr = attrs.get(props.getGroupMemberAttr());
            mbrs = new ArrayList<String>();
            for (int m = 0; m < membersAttr.size(); m++) {
                mbrs.add(membersAttr.get(m).toString());
            }
        }
        // LDAP We need a way to search recursively for groups.
        /* Search for each user in the group */
        String memberContext = props.getGroupMemberContextDn();
        String memberSearchAttr = props.getGroupMemberSearchAttr();
        String[] idAttr = { props.getGroupMemberUserIdAttr(), props.getGroupMemberGroupIdAttr(), "objectclass" };
        for (String mbr : mbrs) {
            if (memberContext != null) {
                matchAttrs = new BasicAttributes(true);
                matchAttrs.put(memberSearchAttr, mbr);
                response = ctx.search(memberContext, matchAttrs, idAttr);
            } else {
                response = ctx.search(memberContext, null, idAttr);
            }
            if (response.hasMore()) {
                SearchResult sr = (SearchResult) response.next();
                Attributes attrs = sr.getAttributes();
                Attribute ocsAttr = attrs.get("objectclass");
                String userOc = props.getUserObjectClass();
                String groupOc = props.getGroupObjectClass();
                boolean isGroup = false;
                for (int oci = 0; oci < ocsAttr.size(); oci++) {
                    String oc = ocsAttr.get(oci).toString();
                    if (userOc.equals(oc)) {
                        break;
                    }
                    if (groupOc.equals(oc)) {
                        isGroup = true;
                        break;
                    }
                }
                BwPrincipal p = null;
                Attribute attr;
                if (isGroup) {
                    p = BwPrincipal.makeGroupPrincipal();
                    attr = attrs.get(props.getGroupMemberGroupIdAttr());
                } else {
                    p = BwPrincipal.makeUserPrincipal();
                    attr = attrs.get(props.getGroupMemberUserIdAttr());
                }
                if (attr.size() != 1) {
                    throw new CalFacadeException("org.bedework.ldap.groups.multiple.result");
                }
                p.setAccount(attr.get(0).toString());
                p.setPrincipalRef(makePrincipalUri(p.getAccount(), p.getKind()));
                group.addGroupMember(p);
            }
        }
    } catch (Throwable t) {
        if (debug) {
            error(t);
        }
        throw new CalFacadeException(t);
    } finally {
        // Close the context to release the connection
        if (ctx != null) {
            closeContext(ctx);
        }
    }
    for (BwGroup g : group.getGroups()) {
        getGroupMembers(props, g);
    }
}
Also used : BasicAttributes(javax.naming.directory.BasicAttributes) BwGroup(org.bedework.calfacade.BwGroup) Attribute(javax.naming.directory.Attribute) BasicAttributes(javax.naming.directory.BasicAttributes) Attributes(javax.naming.directory.Attributes) NamingEnumeration(javax.naming.NamingEnumeration) SearchResult(javax.naming.directory.SearchResult) CalFacadeException(org.bedework.calfacade.exc.CalFacadeException) BwPrincipal(org.bedework.calfacade.BwPrincipal) InitialLdapContext(javax.naming.ldap.InitialLdapContext) LdapConfigProperties(org.bedework.calfacade.configs.LdapConfigProperties)

Example 10 with BwGroup

use of org.bedework.calfacade.BwGroup in project bw-calendar-engine by Bedework.

the class GroupsDbImpl method getAllGroups.

/* (non-Javadoc)
   * @see org.bedework.calfacade.ifs.Groups#getAllGroups(org.bedework.calfacade.BwPrincipal)
   */
@Override
public Collection<BwGroup> getAllGroups(final BwPrincipal val) throws CalFacadeException {
    Collection<BwGroup> groups = getGroups(val);
    Collection<BwGroup> allGroups = new TreeSet<BwGroup>(groups);
    for (BwGroup grp : groups) {
        Collection<BwGroup> gg = getAllGroups(grp);
        if (!gg.isEmpty()) {
            allGroups.addAll(gg);
        }
    }
    return allGroups;
}
Also used : BwGroup(org.bedework.calfacade.BwGroup) TreeSet(java.util.TreeSet)

Aggregations

BwGroup (org.bedework.calfacade.BwGroup)19 CalFacadeException (org.bedework.calfacade.exc.CalFacadeException)10 NamingEnumeration (javax.naming.NamingEnumeration)6 BasicAttributes (javax.naming.directory.BasicAttributes)6 InitialLdapContext (javax.naming.ldap.InitialLdapContext)6 LdapConfigProperties (org.bedework.calfacade.configs.LdapConfigProperties)6 TreeSet (java.util.TreeSet)5 Attribute (javax.naming.directory.Attribute)4 Attributes (javax.naming.directory.Attributes)4 SearchResult (javax.naming.directory.SearchResult)4 BwPrincipal (org.bedework.calfacade.BwPrincipal)4 HibSession (org.bedework.calcorei.HibSession)3 ArrayList (java.util.ArrayList)2 BwAdminGroup (org.bedework.calfacade.svc.BwAdminGroup)1 PrincipalHref (org.bedework.dumprestore.restore.PrincipalHref)1