Search in sources :

Example 36 with Member

use of cz.metacentrum.perun.core.api.Member in project perun by CESNET.

the class UsersManagerEntryIntegrationTest method getVosWhereUserIsNotAdminButHisGroupIs.

@Test
public void getVosWhereUserIsNotAdminButHisGroupIs() throws Exception {
    System.out.println(CLASS_NAME + "getVosWhereUserIsNotAdminButHisGroupIs");
    Member member = setUpMember(vo);
    User user = perun.getUsersManagerBl().getUserByMember(sess, member);
    Group group = setUpGroup(vo, member);
    perun.getVosManager().addAdmin(sess, vo, group);
    List<Vo> vos = usersManager.getVosWhereUserIsAdmin(sess, user);
    assertTrue("our user should be admin in one VO", vos.size() >= 1);
}
Also used : Group(cz.metacentrum.perun.core.api.Group) User(cz.metacentrum.perun.core.api.User) RichUser(cz.metacentrum.perun.core.api.RichUser) Vo(cz.metacentrum.perun.core.api.Vo) Member(cz.metacentrum.perun.core.api.Member) AbstractPerunIntegrationTest(cz.metacentrum.perun.core.AbstractPerunIntegrationTest) Test(org.junit.Test)

Example 37 with Member

use of cz.metacentrum.perun.core.api.Member in project perun by CESNET.

the class UsersManagerEntryIntegrationTest method getAssociatedResourcesForFacility.

@Test
public void getAssociatedResourcesForFacility() throws Exception {
    System.out.println(CLASS_NAME + "getAssociatedResourcesForFacility");
    Member member = setUpMember(vo);
    User user = usersManager.getUserByMember(sess, member);
    Group group = setUpGroup(vo, member);
    Facility facility = setUpFacility();
    Resource resource = setUpResource(facility, vo);
    perun.getResourcesManager().assignGroupToResource(sess, group, resource, false, true, false);
    List<Resource> resources = perun.getUsersManagerBl().getAssociatedResources(sess, facility, user);
    assertThat(resources).containsExactly(resource);
}
Also used : Group(cz.metacentrum.perun.core.api.Group) User(cz.metacentrum.perun.core.api.User) RichUser(cz.metacentrum.perun.core.api.RichUser) Resource(cz.metacentrum.perun.core.api.Resource) Facility(cz.metacentrum.perun.core.api.Facility) Member(cz.metacentrum.perun.core.api.Member) AbstractPerunIntegrationTest(cz.metacentrum.perun.core.AbstractPerunIntegrationTest) Test(org.junit.Test)

Example 38 with Member

use of cz.metacentrum.perun.core.api.Member in project perun by CESNET.

the class EventServiceResolverImpl method resolveEvent.

// ----- methods -------------------------------------
@Override
public Map<Facility, Set<Service>> resolveEvent(AuditEvent event) throws InvalidEventMessageException, ServiceNotExistsException, PrivilegeException {
    log.info("Event - I am going to process event: {}", event);
    Map<Facility, Set<Service>> result = new HashMap<Facility, Set<Service>>();
    if (event instanceof EngineIgnoreEvent) {
        log.info("Event ignored {} facilities will be returned", result.size());
        return result;
    }
    // GET All Beans (only PerunBeans) from message
    List<PerunBean> listOfBeans = new ArrayList<PerunBean>();
    listOfBeans = AuditParser.parseLog(event.getMessage());
    // Prepare variables
    AttributeDefinition attributeDefinition = null;
    Facility facility = null;
    Resource resource = null;
    Group group = null;
    User user = null;
    Member member = null;
    Service service = null;
    Host host = null;
    // TODO: What about more than 1 resources, or more than 1 facilities etc. ?
    for (PerunBean pb : listOfBeans) {
        if (pb instanceof AttributeDefinition) {
            attributeDefinition = (AttributeDefinition) pb;
        } else if (pb instanceof Facility) {
            facility = (Facility) pb;
        } else if (pb instanceof Resource) {
            resource = (Resource) pb;
        } else if (pb instanceof Group) {
            group = (Group) pb;
        } else if (pb instanceof User) {
            user = (User) pb;
        } else if (pb instanceof Member) {
            member = (Member) pb;
        } else if (pb instanceof Service) {
            service = (Service) pb;
        } else if (pb instanceof Host) {
            host = (Host) pb;
        }
    }
    // If there is any attribute, so create AttributeDefinition
    if (attributeDefinition != null) {
        log.debug("Attribute found in event. {}.", attributeDefinition);
    }
    List<Facility> facilitiesResolvedFromEvent = new ArrayList<Facility>();
    List<Resource> resourcesResolvedFromEvent = new ArrayList<Resource>();
    List<Service> servicesResolvedFromEvent = new ArrayList<Service>();
    if (perunSession == null) {
        perunSession = perun.getPerunSession(new PerunPrincipal(dispatcherProperties.getProperty("perun.principal.name"), dispatcherProperties.getProperty("perun.principal.extSourceName"), dispatcherProperties.getProperty("perun.principal.extSourceType")), new PerunClient());
    }
    // Try to find FACILITY in event
    if (facility != null) {
        try {
            log.debug("Facility found in event. {}.", facility);
            facilitiesResolvedFromEvent.add(facility);
            resourcesResolvedFromEvent.addAll(perun.getFacilitiesManager().getAssignedResources(perunSession, facility));
        } catch (FacilityNotExistsException ex) {
            log.warn("Non-existing facility found while resolving event. id={}", facility.getId());
        }
    } else {
        // Try to find RESOURCE in event
        if (resource != null) {
            resourcesResolvedFromEvent.add(resource);
        } else {
            // Try to find GROUP in event
            if (group != null) {
                try {
                    resourcesResolvedFromEvent = perun.getResourcesManager().getAssignedResources(perunSession, group);
                } catch (GroupNotExistsException ex) {
                    log.warn("Non-existing group found while resolving event. id={}", group.getId());
                }
            } else {
                // try to find USER in event
                if (user != null) {
                    try {
                        resourcesResolvedFromEvent = perun.getUsersManager().getAllowedResources(perunSession, user);
                    } catch (UserNotExistsException ex) {
                        log.warn("Non-existing user found while resolving event. id={}", user.getId());
                    }
                } else {
                    // try to find MEMBER in event
                    if (member != null) {
                        try {
                            resourcesResolvedFromEvent = perun.getResourcesManager().getAllowedResources(perunSession, member);
                        } catch (MemberNotExistsException ex) {
                            log.warn("Non-existing member found while resolving event. id={}", member.getId());
                        }
                    } else {
                        // try to find HOST in event
                        if (host != null) {
                            try {
                                log.debug("Host found in event.id= {}.", host.getId());
                                facility = perun.getFacilitiesManager().getFacilityForHost(perunSession, host);
                                facilitiesResolvedFromEvent.add(facility);
                                resourcesResolvedFromEvent.addAll(perun.getFacilitiesManager().getAssignedResources(perunSession, facility));
                            } catch (FacilityNotExistsException ex) {
                                log.warn("Host on non-existing facility found while resolving event. Host id={}", host.getId());
                            } catch (HostNotExistsException ex) {
                                log.warn("Non-existing host found while resolving event. id={}", host.getId());
                            }
                        } else {
                            log.warn("No match found for this event. Event={}", event);
                        }
                    }
                }
            }
        }
    }
    // TODO resolve more than one service
    if (service != null) {
        servicesResolvedFromEvent.add(service);
    }
    for (Resource r : resourcesResolvedFromEvent) {
        Facility facilityResolvedFromEvent;
        List<Service> servicesResolvedFromResource;
        try {
            facilityResolvedFromEvent = perun.getResourcesManager().getFacility(perunSession, r);
            servicesResolvedFromResource = perun.getResourcesManager().getAssignedServices(perunSession, r);
            // process only services resolved from event if any
            if (!servicesResolvedFromEvent.isEmpty())
                servicesResolvedFromResource.retainAll(servicesResolvedFromEvent);
        } catch (ResourceNotExistsException ex) {
            log.error("Non-existing resource found while resolving event. Resource={}", r);
            // skip to next resource
            continue;
        }
        for (Service s : servicesResolvedFromResource) {
            if (attributeDefinition != null) {
                // remove from future processing services
                // which don't require the found attribute
                // TODO (CHECKME) This method can raise
                // ServiceNotExistsException. Is it ok? Or it must be
                // catch?
                List<AttributeDefinition> serviceRequiredAttributes = perun.getAttributesManager().getRequiredAttributesDefinition(perunSession, s);
                if (!serviceRequiredAttributes.contains(attributeDefinition))
                    continue;
            }
            if (!result.containsKey(facilityResolvedFromEvent)) {
                Set<Service> servicesToPut = new HashSet<Service>();
                servicesToPut.add(s);
                result.put(facilityResolvedFromEvent, servicesToPut);
            } else {
                result.get(facilityResolvedFromEvent).add(s);
            }
        }
    }
    log.info("{} facilities will be returned", result.size());
    return result;
}
Also used : Group(cz.metacentrum.perun.core.api.Group) HashSet(java.util.HashSet) Set(java.util.Set) User(cz.metacentrum.perun.core.api.User) HashMap(java.util.HashMap) UserNotExistsException(cz.metacentrum.perun.core.api.exceptions.UserNotExistsException) ArrayList(java.util.ArrayList) AttributeDefinition(cz.metacentrum.perun.core.api.AttributeDefinition) FacilityNotExistsException(cz.metacentrum.perun.core.api.exceptions.FacilityNotExistsException) PerunPrincipal(cz.metacentrum.perun.core.api.PerunPrincipal) Member(cz.metacentrum.perun.core.api.Member) HashSet(java.util.HashSet) MemberNotExistsException(cz.metacentrum.perun.core.api.exceptions.MemberNotExistsException) GroupNotExistsException(cz.metacentrum.perun.core.api.exceptions.GroupNotExistsException) HostNotExistsException(cz.metacentrum.perun.core.api.exceptions.HostNotExistsException) Resource(cz.metacentrum.perun.core.api.Resource) Service(cz.metacentrum.perun.core.api.Service) Host(cz.metacentrum.perun.core.api.Host) ResourceNotExistsException(cz.metacentrum.perun.core.api.exceptions.ResourceNotExistsException) EngineIgnoreEvent(cz.metacentrum.perun.audit.events.EngineIgnoreEvent) PerunBean(cz.metacentrum.perun.core.api.PerunBean) PerunClient(cz.metacentrum.perun.core.api.PerunClient) Facility(cz.metacentrum.perun.core.api.Facility)

Example 39 with Member

use of cz.metacentrum.perun.core.api.Member in project perun by CESNET.

the class AttributesManagerBlImpl method getResourceAttributes.

/**
 * Returns all relevant Resource RichAttributes for given user and facility.
 * 1. Finds members for given user
 * 2. For each allowed member finds its allowed resources
 * 3. Finds assigned resources to given facility
 * 4. Keeps only resources that are in both lists
 * 5. For those resources returns theirs rich attributes
 * Each rich attribute is returned only once.
 *
 * @param sess     session
 * @param user     user
 * @param facility facility
 * @param attrDef  type of attribute that will be returned
 * @return List of RichAttributes
 */
private List<RichAttribute> getResourceAttributes(PerunSession sess, User user, Facility facility, AttributeDefinition attrDef) throws AttributeNotExistsException, WrongAttributeAssignmentException {
    List<RichAttribute> listOfRichAttributes = new ArrayList<>();
    List<Member> members = getPerunBl().getMembersManagerBl().getMembersByUser(sess, user);
    List<Resource> resourcesFromUser = new ArrayList<>();
    for (Member memberElement : members) {
        if (getPerunBl().getMembersManagerBl().isMemberAllowed(sess, memberElement)) {
            resourcesFromUser.addAll(getPerunBl().getResourcesManagerBl().getAllowedResources(sess, memberElement));
        }
    }
    List<Resource> resourcesFromFacility = getPerunBl().getFacilitiesManagerBl().getAssignedResources(sess, facility);
    resourcesFromUser.retainAll(resourcesFromFacility);
    resourcesFromUser = new ArrayList<>(new HashSet<>(resourcesFromUser));
    for (Resource resourceElement : resourcesFromUser) {
        listOfRichAttributes.addAll(getResourceAttributes(sess, resourceElement, attrDef));
    }
    listOfRichAttributes = new ArrayList<>(new HashSet<>(listOfRichAttributes));
    return listOfRichAttributes;
}
Also used : RichAttribute(cz.metacentrum.perun.core.api.RichAttribute) ArrayList(java.util.ArrayList) AttributeSetForGroupAndResource(cz.metacentrum.perun.audit.events.AttributesManagerEvents.AttributeSetForGroupAndResource) AttributeRemovedForGroupAndResource(cz.metacentrum.perun.audit.events.AttributesManagerEvents.AttributeRemovedForGroupAndResource) AllAttributesRemovedForResource(cz.metacentrum.perun.audit.events.AttributesManagerEvents.AllAttributesRemovedForResource) AttributeRemovedForResource(cz.metacentrum.perun.audit.events.AttributesManagerEvents.AttributeRemovedForResource) Resource(cz.metacentrum.perun.core.api.Resource) AttributeSetForResource(cz.metacentrum.perun.audit.events.AttributesManagerEvents.AttributeSetForResource) AllAttributesRemovedForGroupAndResource(cz.metacentrum.perun.audit.events.AttributesManagerEvents.AllAttributesRemovedForGroupAndResource) AttributeSetForResourceAndMember(cz.metacentrum.perun.audit.events.AttributesManagerEvents.AttributeSetForResourceAndMember) AllAttributesRemovedForResourceAndMember(cz.metacentrum.perun.audit.events.AttributesManagerEvents.AllAttributesRemovedForResourceAndMember) Member(cz.metacentrum.perun.core.api.Member) AttributeSetForMember(cz.metacentrum.perun.audit.events.AttributesManagerEvents.AttributeSetForMember) AllAttributesRemovedForMember(cz.metacentrum.perun.audit.events.AttributesManagerEvents.AllAttributesRemovedForMember) AttributeRemovedForMember(cz.metacentrum.perun.audit.events.AttributesManagerEvents.AttributeRemovedForMember) AttributeRemovedForResourceAndMember(cz.metacentrum.perun.audit.events.AttributesManagerEvents.AttributeRemovedForResourceAndMember) HashSet(java.util.HashSet)

Example 40 with Member

use of cz.metacentrum.perun.core.api.Member in project perun by CESNET.

the class AttributesManagerBlImpl method getMemberResourceAttributes.

// --------------------------------MEMBER-RESOURCE-------------------------------
/**
 * Returns all relevant MemberResource RichAttributes for given user.
 * That means, returns all MemberResource rich attributes for those members, who belong to the given user and are allowed,
 * and for those resources that can those members access.
 * Each rich attribute is returned only once.
 *
 * @param sess    session
 * @param user    user
 * @param attrDef type of attribute that will be returned
 * @return List of RichAttribute
 */
private List<RichAttribute> getMemberResourceAttributes(PerunSession sess, User user, AttributeDefinition attrDef) throws AttributeNotExistsException, WrongAttributeAssignmentException, MemberResourceMismatchException {
    List<RichAttribute> listOfRichAttributes = new ArrayList<>();
    List<Member> members = getPerunBl().getMembersManagerBl().getMembersByUser(sess, user);
    for (Member memberElement : members) {
        listOfRichAttributes.addAll(getMemberResourceAttributes(sess, memberElement, attrDef));
    }
    listOfRichAttributes = new ArrayList<>(new HashSet<>(listOfRichAttributes));
    return listOfRichAttributes;
}
Also used : RichAttribute(cz.metacentrum.perun.core.api.RichAttribute) ArrayList(java.util.ArrayList) AttributeSetForResourceAndMember(cz.metacentrum.perun.audit.events.AttributesManagerEvents.AttributeSetForResourceAndMember) AllAttributesRemovedForResourceAndMember(cz.metacentrum.perun.audit.events.AttributesManagerEvents.AllAttributesRemovedForResourceAndMember) Member(cz.metacentrum.perun.core.api.Member) AttributeSetForMember(cz.metacentrum.perun.audit.events.AttributesManagerEvents.AttributeSetForMember) AllAttributesRemovedForMember(cz.metacentrum.perun.audit.events.AttributesManagerEvents.AllAttributesRemovedForMember) AttributeRemovedForMember(cz.metacentrum.perun.audit.events.AttributesManagerEvents.AttributeRemovedForMember) AttributeRemovedForResourceAndMember(cz.metacentrum.perun.audit.events.AttributesManagerEvents.AttributeRemovedForResourceAndMember) HashSet(java.util.HashSet)

Aggregations

Member (cz.metacentrum.perun.core.api.Member)573 Test (org.junit.Test)369 AbstractPerunIntegrationTest (cz.metacentrum.perun.core.AbstractPerunIntegrationTest)331 RichMember (cz.metacentrum.perun.core.api.RichMember)258 User (cz.metacentrum.perun.core.api.User)238 Group (cz.metacentrum.perun.core.api.Group)183 ArrayList (java.util.ArrayList)153 Vo (cz.metacentrum.perun.core.api.Vo)149 Attribute (cz.metacentrum.perun.core.api.Attribute)137 RichUser (cz.metacentrum.perun.core.api.RichUser)108 Resource (cz.metacentrum.perun.core.api.Resource)93 Facility (cz.metacentrum.perun.core.api.Facility)73 InternalErrorException (cz.metacentrum.perun.core.api.exceptions.InternalErrorException)69 LinkedHashMap (java.util.LinkedHashMap)66 HashSet (java.util.HashSet)65 UserExtSource (cz.metacentrum.perun.core.api.UserExtSource)56 RichGroup (cz.metacentrum.perun.core.api.RichGroup)52 LocalDate (java.time.LocalDate)52 Candidate (cz.metacentrum.perun.core.api.Candidate)51 HashMap (java.util.HashMap)50