Skip to content

Commit

Permalink
New method for getting sponsored members and their sponsors
Browse files Browse the repository at this point in the history
* We want to create a new method, which returns sponsored members and their sponsors for specific VO.
* The method returns list of sponsored members (RichMembers) and for each of them list of users, who sponsor this sponsored member.
* The returned object also have to be filtered - the method returns to the sponsor only members, who are sponsored by this sponsor.
  • Loading branch information
HejdaJakub committed Oct 7, 2020
1 parent 7a2a224 commit f246ac5
Show file tree
Hide file tree
Showing 9 changed files with 206 additions and 11 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
package cz.metacentrum.perun.core.api;

import java.util.List;
import java.util.Objects;

/**
* Sponsored member with list of his sponsors (for GUI)
*
* @author Jakub Hejda <[email protected]>
*/
public class MemberWithSponsors {
private RichMember member;
private List<User> sponsors;

/**
* Constructor
*/
public MemberWithSponsors() {
}

/**
* Constructor
*/
public MemberWithSponsors(RichMember member) {
this.member = member;
}

public Member getMember() {
return member;
}

public void setMember(RichMember member) {
this.member = member;
}

public List<User> getSponsors() {
return sponsors;
}

public void setSponsors(List<User> sponsors) {
this.sponsors = sponsors;
}

@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
MemberWithSponsors that = (MemberWithSponsors) o;
return Objects.equals(member, that.member);
}

@Override
public int hashCode() {
return Objects.hash(member);
}
}
18 changes: 18 additions & 0 deletions perun-base/src/main/resources/perun-roles.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2323,6 +2323,24 @@ perun_policies:
include_policies:
- default_policy

getSponsoredMembersAndTheirSponsors_Vo_policy:
policy_roles:
- VOADMIN: Vo
- VOOBSERVER: Vo
- PERUNOBSERVER:
- SPONSOR: Vo
include_policies:
- default_policy

filter-getSponsoredMembersAndTheirSponsors_Vo_policy:
policy_roles:
- VOADMIN: Vo
- VOOBSERVER: Vo
- PERUNOBSERVER:
- SPONSOR: Member
include_policies:
- default_policy

extendExpirationForSponsoredMember_Member_User_policy:
policy_roles:
- REGISTRAR:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1271,6 +1271,18 @@ public interface MembersManager {
*/
List<RichMember> getSponsoredMembers(PerunSession sess, Vo vo) throws PrivilegeException, VoNotExistsException;

/**
* Gets list of sponsored members with sponsors.
*
* @param sess session
* @param vo virtual organization from which are the sponsored members chosen
* @param attrNames list of attrNames for selected attributes
* @throws VoNotExistsException if given VO does not exist
* @throws PrivilegeException if not VOADMIN, VOOBSERVER, PERUNOBSERVER or SPONSOR
* @return list of members with sponsors
*/
List<MemberWithSponsors> getSponsoredMembersAndTheirSponsors(PerunSession sess, Vo vo, List<String> attrNames) throws VoNotExistsException, PrivilegeException, AttributeNotExistsException;

/**
* Extends expiration date. Sponsored members cannot apply for membership extension, this method allows a sponsor to extend it.
* @param session actor
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,11 @@
import cz.metacentrum.perun.core.api.Group;
import cz.metacentrum.perun.core.api.Member;
import cz.metacentrum.perun.core.api.MemberGroupStatus;
import cz.metacentrum.perun.core.api.MemberWithSponsors;
import cz.metacentrum.perun.core.api.PerunSession;
import cz.metacentrum.perun.core.api.Resource;
import cz.metacentrum.perun.core.api.RichMember;
import cz.metacentrum.perun.core.api.RichUser;
import cz.metacentrum.perun.core.api.SpecificUserType;
import cz.metacentrum.perun.core.api.Status;
import cz.metacentrum.perun.core.api.User;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,6 @@
import cz.metacentrum.perun.audit.events.MembersManagerEvents.MemberDisabled;
import cz.metacentrum.perun.audit.events.MembersManagerEvents.MemberExpired;
import cz.metacentrum.perun.audit.events.MembersManagerEvents.MemberInvalidated;
import cz.metacentrum.perun.audit.events.MembersManagerEvents.MemberSuspended;
import cz.metacentrum.perun.audit.events.MembersManagerEvents.MemberUnsuspended;
import cz.metacentrum.perun.audit.events.MembersManagerEvents.MemberValidated;
import cz.metacentrum.perun.audit.events.MembersManagerEvents.MemberValidatedFailed;
import cz.metacentrum.perun.audit.events.MembersManagerEvents.SponsoredMemberSet;
Expand Down Expand Up @@ -67,9 +65,7 @@
import cz.metacentrum.perun.core.api.exceptions.NotGroupMemberException;
import cz.metacentrum.perun.core.api.exceptions.ParentGroupNotExistsException;
import cz.metacentrum.perun.core.api.exceptions.PasswordCreationFailedException;
import cz.metacentrum.perun.core.api.exceptions.PasswordOperationTimeoutException;
import cz.metacentrum.perun.core.api.exceptions.PasswordStrengthException;
import cz.metacentrum.perun.core.api.exceptions.PasswordStrengthFailedException;
import cz.metacentrum.perun.core.api.exceptions.RelationExistsException;
import cz.metacentrum.perun.core.api.exceptions.SubjectNotExistsException;
import cz.metacentrum.perun.core.api.exceptions.UserExtSourceExistsException;
Expand All @@ -82,30 +78,26 @@
import cz.metacentrum.perun.core.api.exceptions.WrongReferenceAttributeValueException;
import cz.metacentrum.perun.core.bl.MembersManagerBl;
import cz.metacentrum.perun.core.bl.PerunBl;
import cz.metacentrum.perun.core.impl.Auditer;
import cz.metacentrum.perun.core.impl.PerunSessionImpl;
import cz.metacentrum.perun.core.impl.Utils;
import cz.metacentrum.perun.core.implApi.ExtSourceApi;
import cz.metacentrum.perun.core.implApi.ExtSourceSimpleApi;
import cz.metacentrum.perun.core.implApi.MembersManagerImplApi;
import cz.metacentrum.perun.core.implApi.modules.attributes.AbstractMembershipExpirationRulesModule;
import cz.metacentrum.perun.core.implApi.modules.pwdmgr.PasswordManagerModule;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.sql.Timestamp;
import java.text.SimpleDateFormat;
import java.time.Instant;
import java.time.LocalDate;
import java.time.ZoneId;
import java.time.format.DateTimeFormatter;
import java.time.temporal.ChronoUnit;
import java.time.temporal.TemporalUnit;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Collections;
import java.util.Date;
import java.util.GregorianCalendar;
import java.util.HashMap;
import java.util.HashSet;
import java.util.LinkedHashMap;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
import cz.metacentrum.perun.core.api.ExtSource;
import cz.metacentrum.perun.core.api.Group;
import cz.metacentrum.perun.core.api.Member;
import cz.metacentrum.perun.core.api.MemberWithSponsors;
import cz.metacentrum.perun.core.api.MembersManager;
import cz.metacentrum.perun.core.api.PerunSession;
import cz.metacentrum.perun.core.api.Resource;
Expand Down Expand Up @@ -35,9 +36,7 @@
import cz.metacentrum.perun.core.api.exceptions.MemberNotValidYetException;
import cz.metacentrum.perun.core.api.exceptions.ParentGroupNotExistsException;
import cz.metacentrum.perun.core.api.exceptions.PasswordCreationFailedException;
import cz.metacentrum.perun.core.api.exceptions.PasswordOperationTimeoutException;
import cz.metacentrum.perun.core.api.exceptions.PasswordStrengthException;
import cz.metacentrum.perun.core.api.exceptions.PasswordStrengthFailedException;
import cz.metacentrum.perun.core.api.exceptions.PrivilegeException;
import cz.metacentrum.perun.core.api.exceptions.ResourceNotExistsException;
import cz.metacentrum.perun.core.api.exceptions.UserExtSourceNotExistsException;
Expand All @@ -53,6 +52,7 @@
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.util.stream.Collectors;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
Expand Down Expand Up @@ -1341,6 +1341,32 @@ public List<RichMember> getSponsoredMembers(PerunSession sess, Vo vo) throws Pri
return membersManagerBl.convertMembersToRichMembers(sess, membersManagerBl.getSponsoredMembers(sess, vo));
}

@Override
public List<MemberWithSponsors> getSponsoredMembersAndTheirSponsors(PerunSession sess, Vo vo, List<String> attrNames) throws VoNotExistsException, PrivilegeException, AttributeNotExistsException {
Utils.checkPerunSession(sess);
Utils.notNull(vo, "vo");

perunBl.getVosManagerBl().checkVoExists(sess, vo);

//Authorization
if(!AuthzResolver.authorizedInternal(sess, "getSponsoredMembersAndTheirSponsors_Vo_policy", vo)) {
throw new PrivilegeException(sess, "getSponsoredMembersAndTheirSponsors");
}

List<AttributeDefinition> attrsDef = new ArrayList<>();
for (String attrName : attrNames) {
attrsDef.add(getPerunBl().getAttributesManagerBl().getAttributeDefinition(sess, attrName));
}

List<RichMember> richMembers = membersManagerBl.convertMembersToRichMembersWithAttributes(sess, getSponsoredMembers(sess, vo), attrsDef);
richMembers = membersManagerBl.filterOnlyAllowedAttributes(sess, richMembers, null, true);

return richMembers.stream()
.filter(member -> AuthzResolver.authorizedInternal(sess, "filter-getSponsoredMembersAndTheirSponsors_Vo_policy", member, vo))
.map(member -> convertMemberToMemberWithSponsors(sess, member))
.collect(Collectors.toList());
}

@Override
public String extendExpirationForSponsoredMember(PerunSession sess, Member sponsoredMember, User sponsorUser) throws PrivilegeException, MemberNotExistsException, UserNotExistsException {
Utils.checkPerunSession(sess);
Expand Down Expand Up @@ -1381,6 +1407,20 @@ public void removeSponsor(PerunSession sess, Member sponsoredMember, User sponso
membersManagerBl.removeSponsor(sess,sponsoredMember, sponsorToRemove);
}

/**
* Converts member to member with sponsors and sets all his sponsors.
*
* @param sess perun session
* @param member sponsored member
* @return member with sponsors
*/
private MemberWithSponsors convertMemberToMemberWithSponsors(PerunSession sess, RichMember member) {
MemberWithSponsors memberWithSponsors = new MemberWithSponsors(member);
List<User> sponsors = getPerunBl().getUsersManagerBl().getSponsors(sess, member);
memberWithSponsors.setSponsors(sponsors);
return memberWithSponsors;
}

/**
* Gets the membersManagerBl for this instance.
*
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,10 +11,12 @@
import cz.metacentrum.perun.core.api.Group;
import cz.metacentrum.perun.core.api.GroupsManager;
import cz.metacentrum.perun.core.api.Member;
import cz.metacentrum.perun.core.api.MemberWithSponsors;
import cz.metacentrum.perun.core.api.MembersManager;
import cz.metacentrum.perun.core.api.PerunBean;
import cz.metacentrum.perun.core.api.Resource;
import cz.metacentrum.perun.core.api.RichMember;
import cz.metacentrum.perun.core.api.RichUser;
import cz.metacentrum.perun.core.api.Role;
import cz.metacentrum.perun.core.api.SpecificUserType;
import cz.metacentrum.perun.core.api.Status;
Expand Down Expand Up @@ -171,6 +173,31 @@ public void getSponsoredMembers() throws Exception {
assertTrue(sponsoredMembers.contains(sponsoredMember2));
}

@Test
public void getSponsoredMembersAndTheirSponsors() throws Exception {
System.out.println(CLASS_NAME + "getSponsoredMembersAndTheirSponsors");

Member sponsorMember = setUpSponsor(createdVo);
User sponsorUser = perun.getUsersManagerBl().getUserByMember(sess, sponsorMember);
Group sponsors = new Group("sponsors","users able to sponsor");
sponsors = perun.getGroupsManagerBl().createGroup(sess,createdVo,sponsors);
AuthzResolverBlImpl.setRole(sess, sponsors, createdVo, Role.SPONSOR);
perun.getGroupsManagerBl().addMember(sess,sponsors,sponsorMember);

Map<String, String> userName = new HashMap<>();
userName.put("guestName", "Ing. Jan Novák");
Member sponsoredMember = perun.getMembersManagerBl().createSponsoredMember(sess, createdVo, "dummy", userName, "secret", sponsorUser, false);

ArrayList<String> attrNames = new ArrayList<>();
attrNames.add("urn:perun:user:attribute-def:def:preferredMail");

List<MemberWithSponsors> memberWithSponsors = perun.getMembersManager().getSponsoredMembersAndTheirSponsors(sess, createdVo, attrNames);

assertEquals(memberWithSponsors.get(0).getMember(), sponsoredMember);
assertEquals(memberWithSponsors.get(0).getSponsors().get(0), sponsorUser);
assertTrue(memberWithSponsors.get(0).getSponsors().size() == 1);
}

@Test
public void createMember() throws Exception {
System.out.println(CLASS_NAME + "createMemberSync");
Expand Down
31 changes: 31 additions & 0 deletions perun-openapi/openapi.yml
Original file line number Diff line number Diff line change
Expand Up @@ -924,6 +924,12 @@ components:
items:
type: integer

MemberWithSponsors:
type: object
properties:
member: { $ref: '#/components/schemas/RichMember' }
sponsors: { type: array, items: { $ref: '#/components/schemas/User' }}

RTMessage:
type: object
properties:
Expand Down Expand Up @@ -997,6 +1003,15 @@ components:
items:
type: string

ListOfMemberWithSponsorsResponse:
description: "returns List<MemberWithSponsors>"
content:
application/json:
schema:
type: array
items:
$ref: "#/components/schemas/MemberWithSponsors"

MapStringStringResponse:
description: "returns Map<String,String>"
content:
Expand Down Expand Up @@ -7843,6 +7858,22 @@ paths:
default:
$ref: '#/components/responses/ExceptionResponse'

/json/membersManager/getSponsoredMembersAndTheirSponsors:
get:
tags:
- MembersManager
operationId: getSponsoredMembersAndTheirSponsors
summary: Gets list of members with sponsors.
parameters:
- $ref: '#/components/parameters/voId'
- $ref: '#/components/parameters/attrNames'
responses:
'200':
$ref: '#/components/responses/ListOfMemberWithSponsorsResponse'
default:
$ref: '#/components/responses/ExceptionResponse'


/json/membersManager/createSponsoredMember/withFullName:
post:
tags:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -378,6 +378,23 @@ public List<RichMember> call(ApiCaller ac, Deserializer params) throws PerunExce
}
},

/*#
* Gets list of sponsored members with sponsors.
*
* @param vo int id of virtual organization from which are the sponsored members chosen
* @param attrNames List<String> list of attribute names
* @throw VoNotExistsException if given VO does not exist
* @return List<MemberWithSponsors> list of members with sponsors
*/
getSponsoredMembersAndTheirSponsors {
@Override
public List<MemberWithSponsors> call(ApiCaller ac, Deserializer params) throws PerunException {
Vo vo = ac.getVoById(params.readInt("vo"));
List<String> attrNames = params.contains("attrNames") ? params.readList("attrNames",String.class) : null;
return ac.getMembersManager().getSponsoredMembersAndTheirSponsors(ac.getSession(), vo, attrNames);
}
},

/*#
* Gets users sponsoring a given user in a VO.
*
Expand Down

0 comments on commit f246ac5

Please sign in to comment.