Search in sources :

Example 1 with SCIMUser

use of org.apache.syncope.ext.scimv2.api.data.SCIMUser in project syncope by apache.

the class SCIMDataBinder method toUserTO.

public UserTO toUserTO(final SCIMUser user) {
    if (!USER_SCHEMAS.equals(user.getSchemas()) && !ENTERPRISE_USER_SCHEMAS.equals(user.getSchemas())) {
        throw new BadRequestException(ErrorType.invalidValue);
    }
    UserTO userTO = new UserTO();
    userTO.setRealm(SyncopeConstants.ROOT_REALM);
    userTO.setKey(user.getId());
    userTO.setPassword(user.getPassword());
    userTO.setUsername(user.getUserName());
    SCIMConf conf = confManager.get();
    if (conf.getUserConf() != null) {
        if (conf.getUserConf().getName() != null && user.getName() != null) {
            if (conf.getUserConf().getName().getFamilyName() != null && user.getName().getFamilyName() != null) {
                userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getUserConf().getName().getFamilyName()).value(user.getName().getFamilyName()).build());
            }
            if (conf.getUserConf().getName().getFormatted() != null && user.getName().getFormatted() != null) {
                userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getUserConf().getName().getFormatted()).value(user.getName().getFormatted()).build());
            }
            if (conf.getUserConf().getName().getGivenName() != null && user.getName().getGivenName() != null) {
                userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getUserConf().getName().getGivenName()).value(user.getName().getGivenName()).build());
            }
            if (conf.getUserConf().getName().getHonorificPrefix() != null && user.getName().getHonorificPrefix() != null) {
                userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getUserConf().getName().getHonorificPrefix()).value(user.getName().getHonorificPrefix()).build());
            }
            if (conf.getUserConf().getName().getHonorificSuffix() != null && user.getName().getHonorificSuffix() != null) {
                userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getUserConf().getName().getHonorificSuffix()).value(user.getName().getHonorificSuffix()).build());
            }
            if (conf.getUserConf().getName().getMiddleName() != null && user.getName().getMiddleName() != null) {
                userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getUserConf().getName().getMiddleName()).value(user.getName().getMiddleName()).build());
            }
        }
        if (conf.getUserConf().getDisplayName() != null && user.getDisplayName() != null) {
            userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getUserConf().getDisplayName()).value(user.getDisplayName()).build());
        }
        if (conf.getUserConf().getNickName() != null && user.getNickName() != null) {
            userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getUserConf().getNickName()).value(user.getNickName()).build());
        }
        if (conf.getUserConf().getProfileUrl() != null && user.getProfileUrl() != null) {
            userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getUserConf().getProfileUrl()).value(user.getProfileUrl()).build());
        }
        if (conf.getUserConf().getTitle() != null && user.getTitle() != null) {
            userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getUserConf().getTitle()).value(user.getTitle()).build());
        }
        if (conf.getUserConf().getUserType() != null && user.getUserType() != null) {
            userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getUserConf().getUserType()).value(user.getUserType()).build());
        }
        if (conf.getUserConf().getPreferredLanguage() != null && user.getPreferredLanguage() != null) {
            userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getUserConf().getPreferredLanguage()).value(user.getPreferredLanguage()).build());
        }
        if (conf.getUserConf().getLocale() != null && user.getLocale() != null) {
            userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getUserConf().getLocale()).value(user.getLocale()).build());
        }
        if (conf.getUserConf().getTimezone() != null && user.getTimezone() != null) {
            userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getUserConf().getTimezone()).value(user.getTimezone()).build());
        }
        fill(userTO.getPlainAttrs(), conf.getUserConf().getEmails(), user.getEmails());
        fill(userTO.getPlainAttrs(), conf.getUserConf().getPhoneNumbers(), user.getPhoneNumbers());
        fill(userTO.getPlainAttrs(), conf.getUserConf().getIms(), user.getIms());
        fill(userTO.getPlainAttrs(), conf.getUserConf().getPhotos(), user.getPhotos());
        user.getAddresses().stream().filter(address -> address.getType() != null).forEach(address -> {
            Optional<SCIMUserAddressConf> addressConf = conf.getUserConf().getAddresses().stream().filter(object -> address.getType().equals(object.getType().name())).findFirst();
            if (addressConf.isPresent()) {
                if (addressConf.get().getFormatted() != null && address.getFormatted() != null) {
                    userTO.getPlainAttrs().add(new AttrTO.Builder().schema(addressConf.get().getFormatted()).value(address.getFormatted()).build());
                }
                if (addressConf.get().getStreetAddress() != null && address.getStreetAddress() != null) {
                    userTO.getPlainAttrs().add(new AttrTO.Builder().schema(addressConf.get().getStreetAddress()).value(address.getStreetAddress()).build());
                }
                if (addressConf.get().getLocality() != null && address.getLocality() != null) {
                    userTO.getPlainAttrs().add(new AttrTO.Builder().schema(addressConf.get().getLocality()).value(address.getLocality()).build());
                }
                if (addressConf.get().getRegion() != null && address.getFormatted() != null) {
                    userTO.getPlainAttrs().add(new AttrTO.Builder().schema(addressConf.get().getFormatted()).value(address.getFormatted()).build());
                }
                if (addressConf.get().getPostalCode() != null && address.getPostalCode() != null) {
                    userTO.getPlainAttrs().add(new AttrTO.Builder().schema(addressConf.get().getPostalCode()).value(address.getPostalCode()).build());
                }
                if (addressConf.get().getCountry() != null && address.getCountry() != null) {
                    userTO.getPlainAttrs().add(new AttrTO.Builder().schema(addressConf.get().getCountry()).value(address.getCountry()).build());
                }
            }
        });
        for (int i = 0; i < user.getX509Certificates().size(); i++) {
            Value certificate = user.getX509Certificates().get(i);
            if (conf.getUserConf().getX509Certificates().size() > i) {
                userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getUserConf().getX509Certificates().get(i)).value(certificate.getValue()).build());
            }
        }
    }
    if (conf.getEnterpriseUserConf() != null) {
        if (conf.getEnterpriseUserConf().getEmployeeNumber() != null && user.getEnterpriseInfo().getEmployeeNumber() != null) {
            userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getEnterpriseUserConf().getEmployeeNumber()).value(user.getEnterpriseInfo().getEmployeeNumber()).build());
        }
        if (conf.getEnterpriseUserConf().getCostCenter() != null && user.getEnterpriseInfo().getCostCenter() != null) {
            userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getEnterpriseUserConf().getCostCenter()).value(user.getEnterpriseInfo().getCostCenter()).build());
        }
        if (conf.getEnterpriseUserConf().getOrganization() != null && user.getEnterpriseInfo().getOrganization() != null) {
            userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getEnterpriseUserConf().getOrganization()).value(user.getEnterpriseInfo().getOrganization()).build());
        }
        if (conf.getEnterpriseUserConf().getDivision() != null && user.getEnterpriseInfo().getDivision() != null) {
            userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getEnterpriseUserConf().getDivision()).value(user.getEnterpriseInfo().getDivision()).build());
        }
        if (conf.getEnterpriseUserConf().getDepartment() != null && user.getEnterpriseInfo().getDepartment() != null) {
            userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getEnterpriseUserConf().getDepartment()).value(user.getEnterpriseInfo().getDepartment()).build());
        }
        if (conf.getEnterpriseUserConf().getManager() != null && conf.getEnterpriseUserConf().getManager().getKey() != null && user.getEnterpriseInfo().getManager() != null && user.getEnterpriseInfo().getManager().getValue() != null) {
            userTO.getPlainAttrs().add(new AttrTO.Builder().schema(conf.getEnterpriseUserConf().getManager().getKey()).value(user.getEnterpriseInfo().getManager().getValue()).build());
        }
    }
    user.getGroups().forEach(group -> {
        userTO.getMemberships().add(new MembershipTO.Builder().group(group.getValue()).build());
    });
    user.getRoles().forEach(role -> {
        userTO.getRoles().add(role.getValue());
    });
    return userTO;
}
Also used : Arrays(java.util.Arrays) BadRequestException(org.apache.syncope.ext.scimv2.api.BadRequestException) Group(org.apache.syncope.ext.scimv2.api.data.Group) AttrTO(org.apache.syncope.common.lib.to.AttrTO) EntityTOUtils(org.apache.syncope.common.lib.EntityTOUtils) SCIMUserAddressConf(org.apache.syncope.common.lib.scim.SCIMUserAddressConf) ErrorType(org.apache.syncope.ext.scimv2.api.type.ErrorType) LoggerFactory(org.slf4j.LoggerFactory) OrderByClause(org.apache.syncope.core.persistence.api.dao.search.OrderByClause) SCIMUserAddress(org.apache.syncope.ext.scimv2.api.data.SCIMUserAddress) Autowired(org.springframework.beans.factory.annotation.Autowired) HashMap(java.util.HashMap) StringUtils(org.apache.commons.lang3.StringUtils) ArrayList(java.util.ArrayList) Map(java.util.Map) SCIMUserManager(org.apache.syncope.ext.scimv2.api.data.SCIMUserManager) MembershipTO(org.apache.syncope.common.lib.to.MembershipTO) SCIMComplexValue(org.apache.syncope.ext.scimv2.api.data.SCIMComplexValue) SyncopeConstants(org.apache.syncope.common.lib.SyncopeConstants) SCIMGroup(org.apache.syncope.ext.scimv2.api.data.SCIMGroup) Logger(org.slf4j.Logger) SearchCond(org.apache.syncope.core.persistence.api.dao.search.SearchCond) Value(org.apache.syncope.ext.scimv2.api.data.Value) SCIMUserName(org.apache.syncope.ext.scimv2.api.data.SCIMUserName) SCIMEnterpriseInfo(org.apache.syncope.ext.scimv2.api.data.SCIMEnterpriseInfo) Set(java.util.Set) GroupTO(org.apache.syncope.common.lib.to.GroupTO) AuthDataAccessor(org.apache.syncope.core.spring.security.AuthDataAccessor) Function(org.apache.syncope.ext.scimv2.api.type.Function) SCIMUser(org.apache.syncope.ext.scimv2.api.data.SCIMUser) List(java.util.List) Meta(org.apache.syncope.ext.scimv2.api.data.Meta) Component(org.springframework.stereotype.Component) Resource(org.apache.syncope.ext.scimv2.api.type.Resource) SCIMComplexConf(org.apache.syncope.common.lib.scim.SCIMComplexConf) SCIMConf(org.apache.syncope.common.lib.scim.SCIMConf) AnyDAO(org.apache.syncope.core.persistence.api.dao.AnyDAO) SCIMConfManager(org.apache.syncope.core.logic.scim.SCIMConfManager) Member(org.apache.syncope.ext.scimv2.api.data.Member) Optional(java.util.Optional) UserTO(org.apache.syncope.common.lib.to.UserTO) MembershipCond(org.apache.syncope.core.persistence.api.dao.search.MembershipCond) Collections(java.util.Collections) UserTO(org.apache.syncope.common.lib.to.UserTO) SCIMUserAddressConf(org.apache.syncope.common.lib.scim.SCIMUserAddressConf) MembershipTO(org.apache.syncope.common.lib.to.MembershipTO) SCIMComplexValue(org.apache.syncope.ext.scimv2.api.data.SCIMComplexValue) Value(org.apache.syncope.ext.scimv2.api.data.Value) BadRequestException(org.apache.syncope.ext.scimv2.api.BadRequestException) SCIMConf(org.apache.syncope.common.lib.scim.SCIMConf)

Example 2 with SCIMUser

use of org.apache.syncope.ext.scimv2.api.data.SCIMUser in project syncope by apache.

the class UserServiceImpl method replace.

@Override
public Response replace(final String id, final SCIMUser user) {
    if (!id.equals(user.getId())) {
        throw new BadRequestException(ErrorType.invalidPath, "Expected " + id + ", found " + user.getId());
    }
    ResponseBuilder builder = checkETag(Resource.User, id);
    if (builder != null) {
        return builder.build();
    }
    ProvisioningResult<UserTO> result = userLogic().update(AnyOperations.diff(binder().toUserTO(user), userLogic().read(id), false), false);
    return updateResponse(result.getEntity().getKey(), binder().toSCIMUser(result.getEntity(), uriInfo.getAbsolutePathBuilder().path(result.getEntity().getKey()).build().toASCIIString(), Collections.<String>emptyList(), Collections.<String>emptyList()));
}
Also used : UserTO(org.apache.syncope.common.lib.to.UserTO) BadRequestException(org.apache.syncope.ext.scimv2.api.BadRequestException) ResponseBuilder(javax.ws.rs.core.Response.ResponseBuilder)

Example 3 with SCIMUser

use of org.apache.syncope.ext.scimv2.api.data.SCIMUser in project syncope by apache.

the class SCIMITCase method createGroup.

@Test
public void createGroup() {
    assumeTrue(SCIMDetector.isSCIMAvailable(webClient()));
    String displayName = UUID.randomUUID().toString();
    SCIMGroup group = new SCIMGroup(null, null, displayName);
    group.getMembers().add(new Member("1417acbe-cbf6-4277-9372-e75e04f97000", null, null));
    assertNull(group.getId());
    assertEquals(displayName, group.getDisplayName());
    Response response = webClient().path("Groups").post(group);
    assertEquals(Response.Status.CREATED.getStatusCode(), response.getStatus());
    group = response.readEntity(SCIMGroup.class);
    assertNotNull(group.getId());
    assertTrue(response.getLocation().toASCIIString().endsWith(group.getId()));
    assertEquals(1, group.getMembers().size());
    assertEquals("1417acbe-cbf6-4277-9372-e75e04f97000", group.getMembers().get(0).getValue());
    response = webClient().path("Users").path("1417acbe-cbf6-4277-9372-e75e04f97000").get();
    assertEquals(Response.Status.OK.getStatusCode(), response.getStatus());
    SCIMUser user = response.readEntity(SCIMUser.class);
    assertEquals("1417acbe-cbf6-4277-9372-e75e04f97000", user.getId());
    response = webClient().path("Groups").post(group);
    assertEquals(Response.Status.CONFLICT.getStatusCode(), response.getStatus());
    SCIMError error = response.readEntity(SCIMError.class);
    assertEquals(Response.Status.CONFLICT.getStatusCode(), error.getStatus());
    assertEquals(ErrorType.uniqueness, error.getScimType());
}
Also used : ListResponse(org.apache.syncope.ext.scimv2.api.data.ListResponse) Response(javax.ws.rs.core.Response) SCIMGroup(org.apache.syncope.ext.scimv2.api.data.SCIMGroup) SCIMUser(org.apache.syncope.ext.scimv2.api.data.SCIMUser) SCIMError(org.apache.syncope.ext.scimv2.api.data.SCIMError) Member(org.apache.syncope.ext.scimv2.api.data.Member) Test(org.junit.jupiter.api.Test)

Example 4 with SCIMUser

use of org.apache.syncope.ext.scimv2.api.data.SCIMUser in project syncope by apache.

the class SCIMITCase method read.

@Test
public void read() throws IOException {
    assumeTrue(SCIMDetector.isSCIMAvailable(webClient()));
    Response response = webClient().path("Users").path("missing").get();
    assertEquals(Response.Status.NOT_FOUND.getStatusCode(), response.getStatus());
    SCIMError error = response.readEntity(SCIMError.class);
    assertEquals(Response.Status.NOT_FOUND.getStatusCode(), error.getStatus());
    response = webClient().path("Users").path("1417acbe-cbf6-4277-9372-e75e04f97000").get();
    assertEquals(Response.Status.OK.getStatusCode(), response.getStatus());
    assertEquals(SCIMConstants.APPLICATION_SCIM_JSON, StringUtils.substringBefore(response.getHeaderString(HttpHeaders.CONTENT_TYPE), ";"));
    SCIMUser user = response.readEntity(SCIMUser.class);
    assertNotNull(user);
    assertEquals("1417acbe-cbf6-4277-9372-e75e04f97000", user.getId());
    assertEquals("rossini", user.getUserName());
    assertFalse(user.getGroups().isEmpty());
    assertFalse(user.getRoles().isEmpty());
    response = webClient().path("Users").path("1417acbe-cbf6-4277-9372-e75e04f97000").query("attributes", "groups").get();
    assertEquals(Response.Status.OK.getStatusCode(), response.getStatus());
    assertEquals(SCIMConstants.APPLICATION_SCIM_JSON, StringUtils.substringBefore(response.getHeaderString(HttpHeaders.CONTENT_TYPE), ";"));
    user = response.readEntity(SCIMUser.class);
    assertNotNull(user);
    assertEquals("1417acbe-cbf6-4277-9372-e75e04f97000", user.getId());
    assertNull(user.getUserName());
    assertFalse(user.getGroups().isEmpty());
    assertTrue(user.getRoles().isEmpty());
}
Also used : ListResponse(org.apache.syncope.ext.scimv2.api.data.ListResponse) Response(javax.ws.rs.core.Response) SCIMUser(org.apache.syncope.ext.scimv2.api.data.SCIMUser) SCIMError(org.apache.syncope.ext.scimv2.api.data.SCIMError) Test(org.junit.jupiter.api.Test)

Example 5 with SCIMUser

use of org.apache.syncope.ext.scimv2.api.data.SCIMUser in project syncope by apache.

the class SCIMITCase method search.

@Test
public void search() {
    assumeTrue(SCIMDetector.isSCIMAvailable(webClient()));
    // invalid filter
    Response response = webClient().path("Groups").query("filter", "invalid").get();
    assertEquals(Response.Status.BAD_REQUEST.getStatusCode(), response.getStatus());
    SCIMError error = response.readEntity(SCIMError.class);
    assertEquals(Response.Status.BAD_REQUEST.getStatusCode(), error.getStatus());
    assertEquals(ErrorType.invalidFilter, error.getScimType());
    // eq
    response = webClient().path("Groups").query("filter", "displayName eq \"additional\"").get();
    assertEquals(Response.Status.OK.getStatusCode(), response.getStatus());
    assertEquals(SCIMConstants.APPLICATION_SCIM_JSON, StringUtils.substringBefore(response.getHeaderString(HttpHeaders.CONTENT_TYPE), ";"));
    ListResponse<SCIMGroup> groups = response.readEntity(new GenericType<ListResponse<SCIMGroup>>() {
    });
    assertNotNull(groups);
    assertEquals(1, groups.getTotalResults());
    SCIMGroup additional = groups.getResources().get(0);
    assertEquals("additional", additional.getDisplayName());
    // eq via POST
    SCIMSearchRequest request = new SCIMSearchRequest("displayName eq \"additional\"", null, null, null, null);
    response = webClient().path("Groups").path("/.search").post(request);
    assertEquals(Response.Status.OK.getStatusCode(), response.getStatus());
    assertEquals(SCIMConstants.APPLICATION_SCIM_JSON, StringUtils.substringBefore(response.getHeaderString(HttpHeaders.CONTENT_TYPE), ";"));
    groups = response.readEntity(new GenericType<ListResponse<SCIMGroup>>() {
    });
    assertNotNull(groups);
    assertEquals(1, groups.getTotalResults());
    additional = groups.getResources().get(0);
    assertEquals("additional", additional.getDisplayName());
    // gt
    UserTO newUser = userService.create(UserITCase.getUniqueSampleTO("scimsearch@syncope.apache.org"), true).readEntity(new GenericType<ProvisioningResult<UserTO>>() {
    }).getEntity();
    Date value = new Date(newUser.getCreationDate().getTime() - 1000);
    response = webClient().path("Users").query("filter", "meta.created gt \"" + DATE_FORMAT.get().format(value) + "\"").get();
    assertEquals(Response.Status.OK.getStatusCode(), response.getStatus());
    assertEquals(SCIMConstants.APPLICATION_SCIM_JSON, StringUtils.substringBefore(response.getHeaderString(HttpHeaders.CONTENT_TYPE), ";"));
    ListResponse<SCIMUser> users = response.readEntity(new GenericType<ListResponse<SCIMUser>>() {
    });
    assertNotNull(users);
    assertEquals(1, users.getTotalResults());
    SCIMUser newSCIMUser = users.getResources().get(0);
    assertEquals(newUser.getUsername(), newSCIMUser.getUserName());
}
Also used : GenericType(javax.ws.rs.core.GenericType) SCIMGroup(org.apache.syncope.ext.scimv2.api.data.SCIMGroup) ListResponse(org.apache.syncope.ext.scimv2.api.data.ListResponse) SCIMUser(org.apache.syncope.ext.scimv2.api.data.SCIMUser) Date(java.util.Date) ListResponse(org.apache.syncope.ext.scimv2.api.data.ListResponse) Response(javax.ws.rs.core.Response) UserTO(org.apache.syncope.common.lib.to.UserTO) SCIMError(org.apache.syncope.ext.scimv2.api.data.SCIMError) SCIMSearchRequest(org.apache.syncope.ext.scimv2.api.data.SCIMSearchRequest) Test(org.junit.jupiter.api.Test)

Aggregations

SCIMUser (org.apache.syncope.ext.scimv2.api.data.SCIMUser)10 Response (javax.ws.rs.core.Response)7 ListResponse (org.apache.syncope.ext.scimv2.api.data.ListResponse)7 Test (org.junit.jupiter.api.Test)7 UserTO (org.apache.syncope.common.lib.to.UserTO)5 SCIMGroup (org.apache.syncope.ext.scimv2.api.data.SCIMGroup)5 SCIMComplexValue (org.apache.syncope.ext.scimv2.api.data.SCIMComplexValue)4 SCIMConf (org.apache.syncope.common.lib.scim.SCIMConf)3 BadRequestException (org.apache.syncope.ext.scimv2.api.BadRequestException)3 Group (org.apache.syncope.ext.scimv2.api.data.Group)3 Member (org.apache.syncope.ext.scimv2.api.data.Member)3 SCIMError (org.apache.syncope.ext.scimv2.api.data.SCIMError)3 SCIMUserName (org.apache.syncope.ext.scimv2.api.data.SCIMUserName)3 Value (org.apache.syncope.ext.scimv2.api.data.Value)3 ArrayList (java.util.ArrayList)2 Arrays (java.util.Arrays)2 Collections (java.util.Collections)2 HashMap (java.util.HashMap)2 List (java.util.List)2 Map (java.util.Map)2