use of org.alfresco.rest.api.tests.client.PublicApiException in project alfresco-remote-api by Alfresco.
the class TestPeople method testGetPerson.
@Test
public void testGetPerson() throws Exception {
final String person1 = account1PersonIt.next();
final String person2 = account1PersonIt.next();
final String person3 = account2PersonIt.next();
// Test Case cloud-2192
// should be able to see oneself
{
publicApiClient.setRequestContext(new RequestContext(account1.getId(), person1));
Person resp = people.getPerson(person1);
Person person1Entity = repoService.getPerson(person1);
check(person1Entity, resp);
}
// should be able to see another user in the same domain, and be able to see full profile
{
publicApiClient.setRequestContext(new RequestContext(account1.getId(), person2));
Person resp = people.getPerson(person1);
Person person1Entity = repoService.getPerson(person1);
Map<String, Boolean> respCapabilities = resp.getCapabilities();
assertNotNull("Check if capabilities are present", respCapabilities);
check(person1Entity, resp);
}
// "-me-" user
{
publicApiClient.setRequestContext(new RequestContext(account1.getId(), person1));
Person resp = people.getPerson(org.alfresco.rest.api.People.DEFAULT_USER);
Person person1Entity = repoService.getPerson(person1);
Map<String, Boolean> respCapabilities = resp.getCapabilities();
assertNotNull("Check if capabilities are present", respCapabilities);
assertTrue("Check if -me- user is mutable", respCapabilities.get("isMutable"));
check(person1Entity, resp);
}
// shouldn't be able to see another user in another domain
publicApiClient.setRequestContext(new RequestContext(account1.getId(), person3));
try {
people.getPerson(person1);
fail("");
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_UNAUTHORIZED, e.getHttpResponse().getStatusCode());
}
RepoService.TestPerson testP = account1.createUser();
String personId = testP.getId();
String desc = "<B>Nice person</B>";
account1.addUserDescription(personId, desc);
publicApiClient.setRequestContext(new RequestContext(account1.getId(), personId));
Person resp = publicApiClient.people().getPerson(personId);
assertEquals(resp.getId(), personId);
assertEquals(resp.getDescription(), desc);
}
use of org.alfresco.rest.api.tests.client.PublicApiException in project alfresco-remote-api by Alfresco.
the class TestPeople method testListPeopleWithAspectNamesAndProperties.
@Test
public void testListPeopleWithAspectNamesAndProperties() throws PublicApiException {
publicApiClient.setRequestContext(new RequestContext(account3.getId(), account3Admin, "admin"));
personBob = new Person();
personBob.setId("bob@" + account3.getId());
personBob.setUserName(personBob.getId());
personBob.setFirstName("Bob");
personBob.setLastName("Cratchit");
personBob.setEmail("bob.cratchit@example.com");
personBob.setPassword("password");
personBob.setEnabled(true);
personBob.setProperties(Collections.singletonMap("papi:lunch", "Magical sandwich"));
people.create(personBob);
// Are aspectNames and properties left absent when not required?
{
PublicApiClient.ListResponse<Person> resp = listPeople(Collections.emptyMap(), 200);
assertNull(resp.getList().get(0).getAspectNames());
assertNull(resp.getList().get(0).getProperties());
}
// Are aspectNames and properties populated when requested?
{
Map<String, String> parameters = Collections.singletonMap("include", "aspectNames,properties");
PublicApiClient.ListResponse<Person> resp = listPeople(parameters, 200);
Person bob = resp.getList().stream().filter(p -> p.getUserName().equals(personBob.getId())).findFirst().get();
assertNotNull(bob.getAspectNames());
assertTrue(bob.getAspectNames().contains("papi:lunchable"));
assertNotNull(bob.getProperties());
assertEquals("Magical sandwich", bob.getProperties().get("papi:lunch"));
}
}
use of org.alfresco.rest.api.tests.client.PublicApiException in project alfresco-remote-api by Alfresco.
the class TestPeople method testUpdatePersonPasswordByAdmin.
@Test
public void testUpdatePersonPasswordByAdmin() throws PublicApiException {
final String personId = account3.createUser().getId();
final String networkId = account3.getId();
publicApiClient.setRequestContext(new RequestContext(networkId, account3Admin, "admin"));
String invalidPassword = "invalidPassword";
String updatedPassword = "newPassword";
people.update("people", personId, null, null, "{\n" + " \"password\": \"" + updatedPassword + "\"\n" + "}", null, "Expected 200 response when updating " + personId, 200);
publicApiClient.setRequestContext(new RequestContext(networkId, personId, invalidPassword));
try {
this.people.getPerson(personId);
fail("");
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_UNAUTHORIZED, e.getHttpResponse().getStatusCode());
}
publicApiClient.setRequestContext(new RequestContext(networkId, personId, updatedPassword));
this.people.getPerson(personId);
publicApiClient.setRequestContext(new RequestContext(networkId, account3Admin, "admin"));
// update with another new password but note that oldPassword is ignored (even if sent by admin)
String updatedPassword2 = "newPassword2";
people.update(personId, qjson("{ `password`:`" + updatedPassword2 + "`, `oldPassword`:`rubbish` }"), 200);
publicApiClient.setRequestContext(new RequestContext(networkId, personId, updatedPassword));
try {
this.people.getPerson(personId);
fail("");
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_UNAUTHORIZED, e.getHttpResponse().getStatusCode());
}
publicApiClient.setRequestContext(new RequestContext(networkId, personId, updatedPassword2));
this.people.getPerson(personId);
// -ve: update with no new password
people.update(personId, qjson("{ `password`:`` }"), 400);
people.update(personId, qjson("{ `password`:null }"), 400);
}
use of org.alfresco.rest.api.tests.client.PublicApiException in project alfresco-remote-api by Alfresco.
the class TestPersonSites method testPersonSites.
@Test
public void testPersonSites() throws Exception {
Set<MemberOfSite> personSites = new TreeSet<MemberOfSite>();
// Get last site for use with personRemoveSite
TestSite personRemoveSite = sites.get(sites.size() - 1);
sites.remove(sites.size() - 1);
personSites.addAll(network1.getSiteMemberships(person11.getId()));
// Create some sites
personSites.addAll(TenantUtil.runAsUserTenant(new TenantRunAsWork<List<MemberOfSite>>() {
@Override
public List<MemberOfSite> doWork() throws Exception {
List<MemberOfSite> expectedSites = new ArrayList<MemberOfSite>();
TestSite site = network1.createSite(SiteVisibility.PRIVATE);
expectedSites.add(new MemberOfSite(site, SiteRole.SiteManager));
site = network1.createSite(SiteVisibility.PUBLIC);
expectedSites.add(new MemberOfSite(site, SiteRole.SiteManager));
site = network1.createSite(SiteVisibility.MODERATED);
expectedSites.add(new MemberOfSite(site, SiteRole.SiteManager));
return expectedSites;
}
}, person11.getId(), network1.getId()));
personSites.addAll(TenantUtil.runAsUserTenant(new TenantRunAsWork<List<MemberOfSite>>() {
@Override
public List<MemberOfSite> doWork() throws Exception {
List<MemberOfSite> expectedSites = new ArrayList<MemberOfSite>();
TestSite site = network1.createSite(SiteVisibility.PRIVATE);
site.inviteToSite(person11.getId(), SiteRole.SiteConsumer);
expectedSites.add(new MemberOfSite(site, SiteRole.SiteConsumer));
site = network1.createSite(SiteVisibility.PUBLIC);
site.inviteToSite(person11.getId(), SiteRole.SiteConsumer);
expectedSites.add(new MemberOfSite(site, SiteRole.SiteConsumer));
site = network1.createSite(SiteVisibility.MODERATED);
site.inviteToSite(person11.getId(), SiteRole.SiteConsumer);
expectedSites.add(new MemberOfSite(site, SiteRole.SiteConsumer));
return expectedSites;
}
}, person12.getId(), network1.getId()));
final List<MemberOfSite> expectedSites = new ArrayList<MemberOfSite>(personSites);
Sites sitesProxy = publicApiClient.sites();
// unknown user
try {
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11.getId()));
sitesProxy.getPersonSites(GUID.generate(), null);
fail("");
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
// Test Case cloud-2200
// Test Case cloud-2213
// user should be able to list their sites
{
int skipCount = 0;
int maxItems = 2;
Paging paging = getPaging(skipCount, maxItems, expectedSites.size(), expectedSites.size());
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11.getId()));
ListResponse<MemberOfSite> resp = sitesProxy.getPersonSites(person11.getId(), createParams(paging, null));
checkList(expectedSites.subList(skipCount, skipCount + paging.getExpectedPaging().getCount()), paging.getExpectedPaging(), resp);
}
{
int skipCount = 2;
int maxItems = 8;
Paging paging = getPaging(skipCount, maxItems, expectedSites.size(), expectedSites.size());
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11.getId()));
ListResponse<MemberOfSite> resp = sitesProxy.getPersonSites(person11.getId(), createParams(paging, null));
checkList(expectedSites.subList(skipCount, skipCount + paging.getExpectedPaging().getCount()), paging.getExpectedPaging(), resp);
}
// "-me-" user
{
int skipCount = 0;
int maxItems = 2;
Paging paging = getPaging(skipCount, maxItems, expectedSites.size(), expectedSites.size());
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11.getId()));
ListResponse<MemberOfSite> resp = sitesProxy.getPersonSites(org.alfresco.rest.api.People.DEFAULT_USER, createParams(paging, null));
checkList(expectedSites.subList(skipCount, skipCount + paging.getExpectedPaging().getCount()), paging.getExpectedPaging(), resp);
}
// a user in another tenant should not be able to list a user's sites
try {
int skipCount = 0;
int maxItems = 2;
Paging paging = getPaging(skipCount, maxItems, expectedSites.size(), null);
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person21.getId()));
sitesProxy.getPersonSites(person11.getId(), createParams(paging, null));
fail("");
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_UNAUTHORIZED, e.getHttpResponse().getStatusCode());
}
// Test case cloud-1488
{
MemberOfSite memberOfSite = expectedSites.get(0);
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11.getId()));
MemberOfSite ret = sitesProxy.getPersonSite(person11.getId(), memberOfSite.getSiteId());
memberOfSite.expected(ret);
}
try {
MemberOfSite memberOfSite = expectedSites.get(0);
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11.getId()));
sitesProxy.getPersonSite(GUID.generate(), memberOfSite.getSiteId());
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
try {
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11.getId()));
sitesProxy.getPersonSite(person11.getId(), GUID.generate());
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
// unknown person id
try {
MemberOfSite memberOfSite = expectedSites.get(0);
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11.getId()));
sitesProxy.getPersonSite(GUID.generate(), memberOfSite.getSiteId());
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
try {
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11.getId()));
sitesProxy.getPersonSite(person11.getId(), GUID.generate());
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
{
// Tests removing a person from the site
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11.getId()));
sitesProxy.remove("people", person11.getId(), "sites", personRemoveSite.getSiteId(), "Unable to DELETE a person site");
try {
sitesProxy.getPersonSite(person11.getId(), personRemoveSite.getSiteId());
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
}
// Not allowed methods
try {
MemberOfSite memberOfSite = expectedSites.get(0);
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11.getId()));
sitesProxy.create("people", person11.getId(), "sites", memberOfSite.getSiteId(), null, "Unable to POST to a person site");
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_METHOD_NOT_ALLOWED, e.getHttpResponse().getStatusCode());
}
try {
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11.getId()));
sitesProxy.create("people", person11.getId(), "sites", null, null, "Unable to POST to person sites");
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_METHOD_NOT_ALLOWED, e.getHttpResponse().getStatusCode());
}
try {
MemberOfSite memberOfSite = expectedSites.get(0);
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11.getId()));
sitesProxy.update("people", person11.getId(), "sites", memberOfSite.getSiteId(), null, "Unable to PUT a person site");
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_METHOD_NOT_ALLOWED, e.getHttpResponse().getStatusCode());
}
try {
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11.getId()));
sitesProxy.update("people", person11.getId(), "sites", null, null, "Unable to PUT person sites");
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_METHOD_NOT_ALLOWED, e.getHttpResponse().getStatusCode());
}
try {
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11.getId()));
sitesProxy.remove("people", person11.getId(), "sites", null, "Unable to DELETE person sites");
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_METHOD_NOT_ALLOWED, e.getHttpResponse().getStatusCode());
}
}
use of org.alfresco.rest.api.tests.client.PublicApiException in project alfresco-remote-api by Alfresco.
the class TestSiteMembershipRequests method testValidRequests.
@Test
public void testValidRequests() throws Exception {
final List<SiteMembershipRequest> expectedSiteMembershipRequests = new ArrayList<SiteMembershipRequest>();
{
// GET
// cloud-2531
// user has no site membership requests
{
log("cloud-2531");
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11Id));
int skipCount = 0;
int maxItems = 2;
Paging paging = getPaging(skipCount, maxItems, expectedSiteMembershipRequests.size(), expectedSiteMembershipRequests.size());
ListResponse<SiteMembershipRequest> resp = siteMembershipRequestsProxy.getSiteMembershipRequests(person11Id, createParams(paging, null));
checkList(expectedSiteMembershipRequests.subList(skipCount, skipCount + paging.getExpectedPaging().getCount()), paging.getExpectedPaging(), resp);
}
{
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11Id));
int skipCount = 0;
Paging paging = getPaging(skipCount, null, expectedSiteMembershipRequests.size(), expectedSiteMembershipRequests.size());
ListResponse<SiteMembershipRequest> resp = siteMembershipRequestsProxy.getSiteMembershipRequests(person11Id, createParams(paging, null));
checkList(expectedSiteMembershipRequests.subList(skipCount, skipCount + paging.getExpectedPaging().getCount()), paging.getExpectedPaging(), resp);
}
// POSTs
// cloud-2502
// cloud-2510
{
log("cloud-2502");
log("cloud-2510");
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11Id));
// moderated site
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(person1ModeratedSites.get(0).getSiteId());
siteMembershipRequest.setMessage("Please can I join your site?");
final SiteMembershipRequest moderatedSiteResponse = siteMembershipRequestsProxy.createSiteMembershipRequest("-me-", siteMembershipRequest);
expectedSiteMembershipRequests.add(moderatedSiteResponse);
siteMembershipRequest.expected(moderatedSiteResponse);
// public site
siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(person1PublicSites.get(0).getSiteId());
siteMembershipRequest.setMessage("Please can I join your site?");
SiteMembershipRequest ret = siteMembershipRequestsProxy.createSiteMembershipRequest(person11Id, siteMembershipRequest);
siteMembershipRequest.expected(ret);
// test we have a moderated site request only
// cloud-2532
{
log("cloud-2532");
int skipCount = 0;
int maxItems = 4;
Paging paging = getPaging(skipCount, maxItems, expectedSiteMembershipRequests.size(), expectedSiteMembershipRequests.size());
ListResponse<SiteMembershipRequest> resp = siteMembershipRequestsProxy.getSiteMembershipRequests(person11Id, createParams(paging, null));
checkList(expectedSiteMembershipRequests, paging.getExpectedPaging(), resp);
}
// test against the underlying invitation service
List<Invitation> invitations = repoService.getModeratedSiteInvitations(network1.getId(), person11Id, person11Id, null);
assertEquals(1, invitations.size());
Invitation invitation = invitations.get(0);
assertTrue(invitation instanceof ModeratedInvitation);
ModeratedInvitation moderatedInvitation = (ModeratedInvitation) invitation;
String siteId = moderatedInvitation.getResourceName();
Invitation.InvitationType invitationType = moderatedInvitation.getInvitationType();
Invitation.ResourceType resourceType = moderatedInvitation.getResourceType();
String inviteeId = moderatedInvitation.getInviteeUserName();
assertEquals(person11Id, inviteeId);
assertEquals(Invitation.ResourceType.WEB_SITE, resourceType);
assertEquals(Invitation.InvitationType.MODERATED, invitationType);
assertEquals(person1ModeratedSites.get(0).getSiteId(), siteId);
// test that personId is a member of the public site
assertTrue(person1PublicSites.get(0).isMember(person11Id));
// cloud-2534
// approve the moderated site invitation and check that it is gone from the list
{
log("cloud-2534");
TenantUtil.runAsUserTenant(new TenantRunAsWork<Void>() {
@Override
public Void doWork() throws Exception {
repoService.approveSiteInvitation(person11Id, moderatedSiteResponse.getId());
expectedSiteMembershipRequests.remove(0);
return null;
}
}, person12Id, network1.getId());
// make sure the outstanding request has gone
int skipCount = 0;
int maxItems = 4;
Paging paging = getPaging(skipCount, maxItems, expectedSiteMembershipRequests.size(), expectedSiteMembershipRequests.size());
ListResponse<SiteMembershipRequest> resp = siteMembershipRequestsProxy.getSiteMembershipRequests(person11Id, createParams(paging, null));
checkList(expectedSiteMembershipRequests, paging.getExpectedPaging(), resp);
}
}
// user from another network - un-authorised
try {
log("cloud-2511");
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person24Id));
// moderated site
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(person1ModeratedSites.get(0).getSiteId());
siteMembershipRequest.setMessage("Please can I join your site?");
siteMembershipRequestsProxy.createSiteMembershipRequest(person24Id, siteMembershipRequest);
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_UNAUTHORIZED, e.getHttpResponse().getStatusCode());
}
// cloud-2512
// cloud-2535
// invitee from another network
{
log("cloud-2512");
log("cloud-2535");
log("cloud-2536");
final List<SiteMembershipRequest> person4ExpectedSiteMembershipRequests = new ArrayList<SiteMembershipRequest>();
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person24Id));
{
// public site
try {
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(person1PublicSites.get(0).getSiteId());
siteMembershipRequest.setMessage("Please can I join your site?");
siteMembershipRequestsProxy.createSiteMembershipRequest(person24Id, siteMembershipRequest);
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_UNAUTHORIZED, e.getHttpResponse().getStatusCode());
}
}
{
// moderated site
try {
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(person1ModeratedSites.get(0).getSiteId());
siteMembershipRequest.setMessage("Please can I join your site?");
siteMembershipRequestsProxy.createSiteMembershipRequest(person24Id, siteMembershipRequest);
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_UNAUTHORIZED, e.getHttpResponse().getStatusCode());
}
try {
int skipCount = 0;
int maxItems = 2;
Paging paging = getPaging(skipCount, maxItems, expectedSiteMembershipRequests.size(), expectedSiteMembershipRequests.size());
siteMembershipRequestsProxy.getSiteMembershipRequests(person24Id, createParams(paging, null));
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_UNAUTHORIZED, e.getHttpResponse().getStatusCode());
}
}
{
// private site
try {
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(person1PrivateSites.get(0).getSiteId());
siteMembershipRequest.setMessage("Please can I join your site?");
siteMembershipRequestsProxy.createSiteMembershipRequest(person24Id, siteMembershipRequest);
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_UNAUTHORIZED, e.getHttpResponse().getStatusCode());
}
try {
int skipCount = 0;
int maxItems = 2;
Paging paging = getPaging(skipCount, maxItems, expectedSiteMembershipRequests.size(), expectedSiteMembershipRequests.size());
siteMembershipRequestsProxy.getSiteMembershipRequests(person24Id, createParams(paging, null));
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_UNAUTHORIZED, e.getHttpResponse().getStatusCode());
}
}
}
// cloud-2513
try {
log("cloud-2513");
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11Id));
// unknown site
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(GUID.generate());
siteMembershipRequest.setMessage("Please can I join your site?");
siteMembershipRequestsProxy.createSiteMembershipRequest(person11Id, siteMembershipRequest);
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
try {
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11Id));
// private site
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(person1PrivateSites.get(0).getSiteId());
siteMembershipRequest.setMessage("Please can I join your site?");
siteMembershipRequestsProxy.createSiteMembershipRequest(person11Id, siteMembershipRequest);
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
try {
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11Id));
// moderated site in another network
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(person4ModeratedSites.get(0).getSiteId());
siteMembershipRequest.setMessage("Please can I join your site?");
siteMembershipRequestsProxy.createSiteMembershipRequest(person11Id, siteMembershipRequest);
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
// cloud-2514
try {
log("cloud-2514");
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11Id));
// already joined the site
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(person1ModeratedSites.get(0).getSiteId());
siteMembershipRequest.setMessage("Please can I join your site?");
siteMembershipRequestsProxy.createSiteMembershipRequest(person11Id, siteMembershipRequest);
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_BAD_REQUEST, e.getHttpResponse().getStatusCode());
}
try {
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11Id));
// already requested to join the site but not yet joined
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(person1ModeratedSites.get(0).getSiteId());
siteMembershipRequest.setMessage("Please can I join your site?");
siteMembershipRequestsProxy.createSiteMembershipRequest(person11Id, siteMembershipRequest);
siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(person1ModeratedSites.get(0).getSiteId());
siteMembershipRequest.setMessage("Please can I join your site?");
siteMembershipRequestsProxy.createSiteMembershipRequest(person11Id, siteMembershipRequest);
fail();
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_BAD_REQUEST, e.getHttpResponse().getStatusCode());
}
// cloud-2538
// blank message
{
log("cloud-2538");
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11Id));
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(person1ModeratedSites.get(1).getSiteId());
siteMembershipRequest.setMessage("");
SiteMembershipRequest ret = siteMembershipRequestsProxy.createSiteMembershipRequest(person11Id, siteMembershipRequest);
expectedSiteMembershipRequests.add(ret);
}
// GETs
// cloud-2501
// cloud-2509
// test paging
{
log("cloud-2501");
log("cloud-2509");
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11Id));
// add some more site membership requests to moderated sites
for (int i = 1; i < person1ModeratedSites.size(); i++) {
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(person1ModeratedSites.get(i).getSiteId());
siteMembershipRequest.setMessage("Please can I join your site?");
try {
SiteMembershipRequest ret = siteMembershipRequestsProxy.createSiteMembershipRequest(person11Id, siteMembershipRequest);
expectedSiteMembershipRequests.add(ret);
siteMembershipRequest.expected(ret);
} catch (PublicApiException e) {
// this is ok, already created
}
}
Collections.sort(expectedSiteMembershipRequests);
{
int skipCount = 0;
int maxItems = 2;
Paging paging = getPaging(skipCount, maxItems, expectedSiteMembershipRequests.size(), expectedSiteMembershipRequests.size());
ListResponse<SiteMembershipRequest> resp = siteMembershipRequestsProxy.getSiteMembershipRequests(person11Id, createParams(paging, null));
checkList(expectedSiteMembershipRequests.subList(skipCount, skipCount + paging.getExpectedPaging().getCount()), paging.getExpectedPaging(), resp);
skipCount = 2;
maxItems = 5;
paging = getPaging(skipCount, maxItems, expectedSiteMembershipRequests.size(), expectedSiteMembershipRequests.size());
resp = siteMembershipRequestsProxy.getSiteMembershipRequests(person11Id, createParams(paging, null));
checkList(expectedSiteMembershipRequests.subList(skipCount, skipCount + paging.getExpectedPaging().getCount()), paging.getExpectedPaging(), resp);
skipCount = 5;
maxItems = 10;
paging = getPaging(skipCount, maxItems, expectedSiteMembershipRequests.size(), expectedSiteMembershipRequests.size());
resp = siteMembershipRequestsProxy.getSiteMembershipRequests(person11Id, createParams(paging, null));
checkList(expectedSiteMembershipRequests.subList(skipCount, skipCount + paging.getExpectedPaging().getCount()), paging.getExpectedPaging(), resp);
skipCount = 0;
maxItems = expectedSiteMembershipRequests.size();
paging = getPaging(skipCount, maxItems, expectedSiteMembershipRequests.size(), expectedSiteMembershipRequests.size());
resp = siteMembershipRequestsProxy.getSiteMembershipRequests(person11Id, createParams(paging, null));
checkList(expectedSiteMembershipRequests.subList(skipCount, skipCount + paging.getExpectedPaging().getCount()), paging.getExpectedPaging(), resp);
}
// skipCount is greater than the number of site membership requests in the list
{
int skipCount = 1000;
int maxItems = 2;
Paging paging = getPaging(skipCount, maxItems, expectedSiteMembershipRequests.size(), expectedSiteMembershipRequests.size());
ListResponse<SiteMembershipRequest> resp = siteMembershipRequestsProxy.getSiteMembershipRequests(person11Id, createParams(paging, null));
checkList(sublist(expectedSiteMembershipRequests, skipCount, skipCount + paging.getExpectedPaging().getCount()), paging.getExpectedPaging(), resp);
}
// cloud-2537
// -me- user
{
log("cloud-2537");
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11Id));
int skipCount = 0;
int maxItems = 2;
Paging paging = getPaging(skipCount, maxItems, expectedSiteMembershipRequests.size(), expectedSiteMembershipRequests.size());
ListResponse<SiteMembershipRequest> resp = siteMembershipRequestsProxy.getSiteMembershipRequests("-me-", createParams(paging, null));
checkList(expectedSiteMembershipRequests.subList(skipCount, skipCount + paging.getExpectedPaging().getCount()), paging.getExpectedPaging(), resp);
}
}
// DELETEs
// cloud-2504
{
log("cloud-2504");
SiteMembershipRequest request = getSiteMembershipRequest(network1.getId(), person11Id, person11Id);
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11Id));
siteMembershipRequestsProxy.cancelSiteMembershipRequest(person11Id, request.getId());
expectedSiteMembershipRequests.remove(request);
Collections.sort(expectedSiteMembershipRequests);
// cloud-2533
// check that the site membership request has gone
log("cloud-2533");
int skipCount = 0;
int maxItems = Integer.MAX_VALUE;
Paging paging = getPaging(skipCount, maxItems, expectedSiteMembershipRequests.size(), expectedSiteMembershipRequests.size());
ListResponse<SiteMembershipRequest> resp = siteMembershipRequestsProxy.getSiteMembershipRequests(person11Id, createParams(paging, null));
checkList(expectedSiteMembershipRequests, paging.getExpectedPaging(), resp);
// try to cancel the same request
try {
log("cloud-2528");
siteMembershipRequestsProxy.cancelSiteMembershipRequest(person11Id, request.getId());
fail("");
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
}
// cloud-2529
// cancel a site membership request that has been rejected
{
log("cloud-2529");
final String siteId = person1ModeratedSites.get(1).getSiteId();
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person14Id));
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(siteId);
siteMembershipRequest.setMessage("Please can I join your site?");
SiteMembershipRequest moderatedSiteResponse = siteMembershipRequestsProxy.createSiteMembershipRequest(person14Id, siteMembershipRequest);
expectedSiteMembershipRequests.add(moderatedSiteResponse);
Collections.sort(expectedSiteMembershipRequests);
siteMembershipRequest.expected(moderatedSiteResponse);
TenantUtil.runAsUserTenant(new TenantRunAsWork<Void>() {
@Override
public Void doWork() throws Exception {
Invitation invitation = repoService.rejectSiteInvitation(person14Id, siteId);
assertNotNull(invitation);
return null;
}
}, person12Id, network1.getId());
// try to cancel the request
try {
siteMembershipRequestsProxy.cancelSiteMembershipRequest(person14Id, siteId);
fail("");
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
}
// cloud-2530
// cancel a site membership request that has been approved
{
log("cloud-2530");
final String siteId = person1ModeratedSites.get(2).getSiteId();
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person14Id));
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(siteId);
siteMembershipRequest.setMessage("Please can I join your site?");
SiteMembershipRequest moderatedSiteResponse = siteMembershipRequestsProxy.createSiteMembershipRequest(person14Id, siteMembershipRequest);
expectedSiteMembershipRequests.add(moderatedSiteResponse);
Collections.sort(expectedSiteMembershipRequests);
siteMembershipRequest.expected(moderatedSiteResponse);
TenantUtil.runAsUserTenant(new TenantRunAsWork<Void>() {
@Override
public Void doWork() throws Exception {
Invitation invitation = repoService.approveSiteInvitation(person14Id, siteId);
assertNotNull(invitation);
return null;
}
}, person12Id, network1.getId());
// try to cancel the request
try {
siteMembershipRequestsProxy.cancelSiteMembershipRequest(person14Id, siteId);
fail("");
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
}
// PUTs
// cloud-2503
// cloud-2517
// cloud-2518
{
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person14Id));
// merged these tests
// cloud-2503: use -me- pseudo user
// cloud-2517: initially no message
log("cloud-2503");
log("cloud-2517");
// create a request without a message
String siteId = person1ModeratedSites.get(7).getSiteId();
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(siteId);
SiteMembershipRequest request = siteMembershipRequestsProxy.createSiteMembershipRequest(person14Id, siteMembershipRequest);
assertNotNull(request);
// update it, with a message
request.setMessage("Please can I join your site?");
SiteMembershipRequest updated = siteMembershipRequestsProxy.updateSiteMembershipRequest(person14Id, request);
request.expected(updated);
// check it's updated
int skipCount = 0;
int maxItems = 2;
Paging paging = getPaging(skipCount, maxItems, expectedSiteMembershipRequests.size(), expectedSiteMembershipRequests.size());
ListResponse<SiteMembershipRequest> resp = siteMembershipRequestsProxy.getSiteMembershipRequests(person14Id, createParams(paging, null));
List<SiteMembershipRequest> requests = resp.getList();
assertTrue(requests.size() > 0);
int idx = requests.indexOf(request);
SiteMembershipRequest toCheck = requests.get(idx);
updated.expected(toCheck);
// cloud-2518
// update it again, with ammended message
log("cloud-2518");
request.setMessage("Please can I join your site, pretty please?");
updated = siteMembershipRequestsProxy.updateSiteMembershipRequest(person14Id, request);
request.expected(updated);
// check it's updated
skipCount = 0;
maxItems = 2;
paging = getPaging(skipCount, maxItems, expectedSiteMembershipRequests.size(), expectedSiteMembershipRequests.size());
resp = siteMembershipRequestsProxy.getSiteMembershipRequests(person14Id, createParams(paging, null));
requests = resp.getList();
assertTrue(requests.size() > 0);
idx = requests.indexOf(request);
toCheck = requests.get(idx);
updated.expected(toCheck);
}
// cloud-2515 - no changes
{
log("cloud-2515");
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person14Id));
// create a request
String siteId = person1ModeratedSites.get(8).getSiteId();
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(siteId);
siteMembershipRequest.setMessage("Please can I join your site?");
SiteMembershipRequest request = siteMembershipRequestsProxy.createSiteMembershipRequest(person14Id, siteMembershipRequest);
assertNotNull(request);
// update it, with no changes
SiteMembershipRequest updated = siteMembershipRequestsProxy.updateSiteMembershipRequest(person14Id, request);
// should not have changed
request.expected(updated);
}
// cloud-2516 - unknown person id
try {
log("cloud-2516");
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11Id));
// get an outstanding request
int skipCount = 0;
int maxItems = 2;
Paging paging = getPaging(skipCount, maxItems, expectedSiteMembershipRequests.size(), expectedSiteMembershipRequests.size());
ListResponse<SiteMembershipRequest> resp = siteMembershipRequestsProxy.getSiteMembershipRequests(person11Id, createParams(paging, null));
List<SiteMembershipRequest> requests = resp.getList();
assertTrue(requests.size() > 0);
SiteMembershipRequest request = requests.get(0);
siteMembershipRequestsProxy.updateSiteMembershipRequest(GUID.generate(), request);
fail("");
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
// cloud-2521 - unknown site membership request
try {
log("cloud-2521");
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person11Id));
SiteMembershipRequest request = new SiteMembershipRequest();
request.setId(GUID.generate());
siteMembershipRequestsProxy.updateSiteMembershipRequest(person11Id, request);
fail("");
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
// cloud-2522
// update a site membership request that has been rejected
{
log("cloud-2522");
String siteId = person1ModeratedSites.get(5).getSiteId();
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person14Id));
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(siteId);
siteMembershipRequest.setMessage("Please can I join your site?");
SiteMembershipRequest moderatedSiteResponse = siteMembershipRequestsProxy.createSiteMembershipRequest(person14Id, siteMembershipRequest);
expectedSiteMembershipRequests.add(moderatedSiteResponse);
Collections.sort(expectedSiteMembershipRequests);
siteMembershipRequest.expected(moderatedSiteResponse);
repoService.rejectSiteInvitation(person14Id, siteId);
// try to update the request
try {
siteMembershipRequestsProxy.updateSiteMembershipRequest(siteId, moderatedSiteResponse);
fail("");
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
}
// cloud-2523
// update a site membership request that has been approved
{
log("cloud-2523");
String siteId = person1ModeratedSites.get(6).getSiteId();
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person14Id));
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(siteId);
siteMembershipRequest.setMessage("Please can I join your site?");
SiteMembershipRequest moderatedSiteResponse = siteMembershipRequestsProxy.createSiteMembershipRequest(person14Id, siteMembershipRequest);
expectedSiteMembershipRequests.add(moderatedSiteResponse);
Collections.sort(expectedSiteMembershipRequests);
siteMembershipRequest.expected(moderatedSiteResponse);
repoService.approveSiteInvitation(person14Id, siteId);
// try to update the request
try {
siteMembershipRequestsProxy.updateSiteMembershipRequest(siteId, moderatedSiteResponse);
fail("");
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
}
{
// cloud-2539 - probing attack tests
log("cloud-2539");
// i) create site membership request to a moderated site
// ii) site owner changes the site to a private site
// iii) re-issue create site membership request should be a 404
{
final List<SiteMembershipRequest> person2ExpectedSiteMembershipRequests = new ArrayList<SiteMembershipRequest>();
final TestSite site = person1ModeratedSites.get(0);
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person13Id));
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(site.getSiteId());
siteMembershipRequest.setMessage("Please can I join your site?");
siteMembershipRequestsProxy.createSiteMembershipRequest(person13Id, siteMembershipRequest);
TenantUtil.runAsUserTenant(new TenantRunAsWork<Void>() {
@Override
public Void doWork() throws Exception {
site.setSiteVisibility(SiteVisibility.PRIVATE);
return null;
}
}, person12Id, network1.getId());
// Can we still GET it? Should be a 404 (private site)
try {
siteMembershipRequestsProxy.getSiteMembershipRequest(person13Id, siteMembershipRequest.getId());
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
// GET should not contain the site
{
int skipCount = 0;
int maxItems = 10;
assertEquals(0, person2ExpectedSiteMembershipRequests.size());
Paging paging = getPaging(skipCount, maxItems, person2ExpectedSiteMembershipRequests.size(), person2ExpectedSiteMembershipRequests.size());
ListResponse<SiteMembershipRequest> resp = siteMembershipRequestsProxy.getSiteMembershipRequests(person13Id, createParams(paging, null));
checkList(sublist(person2ExpectedSiteMembershipRequests, skipCount, skipCount + paging.getExpectedPaging().getCount()), paging.getExpectedPaging(), resp);
}
try {
siteMembershipRequestsProxy.createSiteMembershipRequest(person13Id, siteMembershipRequest);
fail("");
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
}
// i) create site membership request to a public site
// ii) site owner changes the site to a private site
// iii) re-issue create site membership request should be a 404
{
final TestSite site = person1PublicSites.get(0);
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person13Id));
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(site.getSiteId());
siteMembershipRequest.setMessage("Please can I join your site?");
siteMembershipRequestsProxy.createSiteMembershipRequest(person13Id, siteMembershipRequest);
TenantUtil.runAsUserTenant(new TenantRunAsWork<Void>() {
@Override
public Void doWork() throws Exception {
site.setSiteVisibility(SiteVisibility.PRIVATE);
return null;
}
}, person12Id, network1.getId());
try {
siteMembershipRequestsProxy.createSiteMembershipRequest(person13Id, siteMembershipRequest);
fail("");
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
try {
siteMembershipRequestsProxy.updateSiteMembershipRequest(person13Id, siteMembershipRequest);
fail("");
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
try {
siteMembershipRequestsProxy.cancelSiteMembershipRequest(person13Id, siteMembershipRequest.getId());
fail("");
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
}
}
// i) create site membership request to a moderated site
// ii) site owner accepts the request -> user is now a member of the site
// iii) site owner changes the site to a private site
// iv) re-issue create site membership request should be a 404
{
final TestSite site = person1ModeratedSites.get(1);
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person13Id));
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(site.getSiteId());
siteMembershipRequest.setMessage("Please can I join your site?");
siteMembershipRequestsProxy.createSiteMembershipRequest(person13Id, siteMembershipRequest);
// approve the site invitation request and convert the site to a private site
TenantUtil.runAsUserTenant(new TenantRunAsWork<Void>() {
@Override
public Void doWork() throws Exception {
repoService.approveSiteInvitation(person13Id, site.getSiteId());
site.setSiteVisibility(SiteVisibility.PRIVATE);
return null;
}
}, person12Id, network1.getId());
try {
siteMembershipRequestsProxy.createSiteMembershipRequest(person13Id, siteMembershipRequest);
fail("");
} catch (PublicApiException e) {
assertEquals(HttpStatus.SC_NOT_FOUND, e.getHttpResponse().getStatusCode());
}
}
// blank message in POST and PUT
{
final TestSite site = person1ModeratedSites.get(2);
publicApiClient.setRequestContext(new RequestContext(network1.getId(), person13Id));
SiteMembershipRequest siteMembershipRequest = new SiteMembershipRequest();
siteMembershipRequest.setId(site.getSiteId());
siteMembershipRequest.setMessage("");
SiteMembershipRequest created = siteMembershipRequestsProxy.createSiteMembershipRequest(person13Id, siteMembershipRequest);
SiteMembershipRequest updated = siteMembershipRequestsProxy.updateSiteMembershipRequest(person13Id, siteMembershipRequest);
assertTrue(updated.getModifiedAt().after(created.getCreatedAt()));
}
}
}
Aggregations