Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added client credentials changes #670

Merged
merged 2 commits into from
Oct 16, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
11 changes: 11 additions & 0 deletions src/main/java/com/auth0/client/mgmt/filter/ClientFilter.java
Original file line number Diff line number Diff line change
Expand Up @@ -71,4 +71,15 @@ public ClientFilter withFields(String fields, boolean includeFields) {
super.withFields(fields, includeFields);
return this;
}

/**
* Filter by custom query
*
* @param query the query string using Lucene query syntax
* @return this filter instance
*/
public ClientFilter withQuery(String query) {
parameters.put("q", query);
return this;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -51,4 +51,15 @@ public OrganizationClientGrantsFilter withTotals(boolean includeTotals) {
parameters.put("include_totals", includeTotals);
return this;
}

/**
* Filter by grant IDs
*
* @param grantIds comma-separated list of grant IDs to filter results on.
* @return this filter instance
*/
public OrganizationClientGrantsFilter withGrantIds(String grantIds) {
parameters.put("grant_ids", grantIds);
return this;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -33,4 +33,28 @@ public ResourceServersFilter withTotals(boolean includeTotals) {
return this;
}

/**
* Filter by specific identifier IDs (i.e. audience)
*
* @param identifiers the identifier IDs to filter by
* @return this filter instance
*/
public ResourceServersFilter withIdentifiers(String identifiers) {
parameters.put("identifiers", identifiers);
return this;
}

/**
* Filter by checkpoint pagination support
*
* @param from the starting index identifier
* @param take the number of items to retrieve
* @return this filter instance
*/
public ResourceServersFilter withCheckpointPagination(String from, int take) {
parameters.put("from", from);
parameters.put("take", take);
return this;
}

}
18 changes: 18 additions & 0 deletions src/main/java/com/auth0/json/mgmt/client/Client.java
Original file line number Diff line number Diff line change
Expand Up @@ -102,6 +102,8 @@ public class Client {
private String complianceLevel;
@JsonProperty("require_proof_of_possession")
private Boolean requireProofOfPossession;
@JsonProperty("default_organization")
private ClientDefaultOrganization defaultOrganization;

/**
* Getter for the name of the tenant this client belongs to.
Expand Down Expand Up @@ -889,5 +891,21 @@ public Boolean getRequireProofOfPossession() {
public void setRequireProofOfPossession(Boolean requireProofOfPossession) {
this.requireProofOfPossession = requireProofOfPossession;
}

/**
* Getter for the default organization configuration.
* @return the default organization configuration.
*/
public ClientDefaultOrganization getDefaultOrganization() {
return defaultOrganization;
}

/**
* Setter for the default organization configuration.
* @param defaultOrganization the default organization configuration to set.
*/
public void setDefaultOrganization(ClientDefaultOrganization defaultOrganization) {
this.defaultOrganization = defaultOrganization;
}
}

Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
package com.auth0.json.mgmt.client;

import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonProperty;

import java.util.List;

@JsonIgnoreProperties(ignoreUnknown = true)
@JsonInclude(JsonInclude.Include.NON_NULL)
public class ClientDefaultOrganization {
@JsonProperty("flows")
private List<String> flows;
@JsonProperty("organization_id")
private String organizationId;

public ClientDefaultOrganization() {

}

public ClientDefaultOrganization(List<String> flows, String organizationId) {
this.flows = flows;
this.organizationId = organizationId;
}

/**
* Getter for the supported flows.
* @return the supported flows.
*/
public List<String> getFlows() {
return flows;
}

/**
* Setter for the supported flows.
* @param flows the supported flows to set.
*/
public void setFlows(List<String> flows) {
this.flows = flows;
}

/**
* Getter for the organization_id.
* @return the organization_id.
*/
public String getOrganizationId() {
return organizationId;
}

/**
* Setter for the organization_id.
* @param organizationId the organization_id to set.
*/
public void setOrganizationId(String organizationId) {
this.organizationId = organizationId;
}
}
19 changes: 19 additions & 0 deletions src/test/java/com/auth0/client/mgmt/ClientsEntityTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -125,6 +125,25 @@ public void shouldListClientsWithAdditionalProperties() throws Exception {
assertThat(response.getItems(), hasSize(2));
}

@Test
public void shouldListClientsWithQuery() throws Exception {
ClientFilter filter = new ClientFilter().withQuery("client_grant.organization_id:" + "org_123");
Request<ClientsPage> request = api.clients().list(filter);
assertThat(request, is(notNullValue()));

server.jsonResponse(MGMT_CLIENTS_PAGED_LIST, 200);
ClientsPage response = request.execute().getBody();
RecordedRequest recordedRequest = server.takeRequest();

assertThat(recordedRequest, hasMethodAndPath(HttpMethod.GET, "/api/v2/clients"));
assertThat(recordedRequest, hasHeader("Content-Type", "application/json"));
assertThat(recordedRequest, hasHeader("Authorization", "Bearer apiToken"));
assertThat(recordedRequest, hasQueryParameter("q", "client_grant.organization_id:" + "org_123"));

assertThat(response, is(notNullValue()));
assertThat(response.getItems(), hasSize(2));
}

@Test
public void shouldThrowOnGetClientWithNullId() {
verifyThrows(IllegalArgumentException.class,
Expand Down
136 changes: 132 additions & 4 deletions src/test/java/com/auth0/client/mgmt/OrganizationEntityTest.java
Original file line number Diff line number Diff line change
@@ -1,11 +1,15 @@
package com.auth0.client.mgmt;

import com.auth0.client.MockServer;
import com.auth0.client.mgmt.filter.FieldsFilter;
import com.auth0.client.mgmt.filter.InvitationsFilter;
import com.auth0.client.mgmt.filter.OrganizationClientGrantsFilter;
import com.auth0.client.mgmt.filter.PageFilter;
import com.auth0.client.mgmt.filter.*;
import com.auth0.exception.Auth0Exception;
import com.auth0.json.mgmt.client.Client;
import com.auth0.json.mgmt.client.ClientDefaultOrganization;
import com.auth0.json.mgmt.client.ClientsPage;
import com.auth0.json.mgmt.clientgrants.ClientGrant;
import com.auth0.json.mgmt.clientgrants.ClientGrantsPage;
import com.auth0.json.mgmt.organizations.*;
import com.auth0.json.mgmt.resourceserver.ResourceServer;
import com.auth0.json.mgmt.roles.RolesPage;
import com.auth0.net.Request;
import com.auth0.net.client.HttpMethod;
Expand Down Expand Up @@ -1082,6 +1086,32 @@ public void shouldListClientGrantsWithFilter() throws Exception {
assertThat(response.getItems(), hasSize(1));
}

@Test
public void shouldListClientGrantsWithGrantIds() throws Exception {
OrganizationClientGrantsFilter filter = new OrganizationClientGrantsFilter();
filter
.withClientId("clientId")
.withAudience("https://api-identifier/")
.withGrantIds("cgr_123456789012,cgr_abcdefghijkl");

Request<OrganizationClientGrantsPage> request = api.organizations().listClientGrants("orgId", filter);
assertThat(request, is(notNullValue()));

server.jsonResponse(ORGANIZATION_CLIENT_GRANTS_PAGED_LIST, 200);
OrganizationClientGrantsPage response = request.execute().getBody();
RecordedRequest recordedRequest = server.takeRequest();

assertThat(recordedRequest, hasMethodAndPath(HttpMethod.GET, "/api/v2/organizations/orgId/client-grants"));
assertThat(recordedRequest, hasHeader("Content-Type", "application/json"));
assertThat(recordedRequest, hasHeader("Authorization", "Bearer apiToken"));
assertThat(recordedRequest, hasQueryParameter("grant_ids", "cgr_123456789012,cgr_abcdefghijkl"));
assertThat(recordedRequest, hasQueryParameter("audience", "https://api-identifier/"));
assertThat(recordedRequest, hasQueryParameter("client_id", "clientId"));

assertThat(response, is(notNullValue()));
assertThat(response.getItems(), hasSize(1));
}

@Test
public void shouldThrowOnGetClientGrantsWithNullOrgId() {
verifyThrows(IllegalArgumentException.class,
Expand Down Expand Up @@ -1153,4 +1183,102 @@ public void shouldThrowOnDeleteClientGreatWithNullGrant() {
() -> api.organizations().deleteClientGrant("org_1213", null),
"'client grant ID' cannot be null!");
}

@Test
public void testClientGrantsWithOrg() throws Auth0Exception {

Organization organization = null;
ResourceServer resourceServer = null;
Client client = null;
ClientGrant clientGrant = null;
OrganizationClientGrant organizationClientGrant = null;

try {
//Create organization
organization = givenAnOrganization();

//Create resource server
resourceServer = givenAResourceServer();

//Create client
client = createNewClient(organization.getId());

//Create client grants
clientGrant = createNewClientGrant(client, resourceServer);

//Associates the grant with an organization.
organizationClientGrant = api.organizations().addClientGrant(organization.getId(), new CreateOrganizationClientGrantRequestBody(clientGrant.getId())).execute().getBody();

ClientFilter clientFilter = new ClientFilter();
clientFilter.withQuery("client_grant.organization_id:" + organization.getId());

// List all clients associated with a ClientGrant given an organizationID as query param
ClientsPage clientsPage = api.clients().list(clientFilter).execute().getBody();

for (Client c : clientsPage.getItems()) {
assertThat(organization.getId(), is(c.getDefaultOrganization().getOrganizationId()));
}

OrganizationClientGrantsFilter filter = new OrganizationClientGrantsFilter();
filter.withGrantIds(clientGrant.getId());

// List all ClientGrants given a list of grant_ids as query param
OrganizationClientGrantsPage organizationClientGrantsPage = api.organizations().listClientGrants(organization.getId(), filter).execute().getBody();

assertThat(organizationClientGrantsPage.getItems().size(), is(1));
assertThat(organizationClientGrantsPage.getItems().get(0).getClientId(), is(clientGrant.getClientId()));

// Remove the associated ClientGrants
api.organizations().deleteClientGrant(organization.getId(), organizationClientGrant.getId()).execute();

// List all ClientGrants which should be an empty list since grant has been removed from the organization.
OrganizationClientGrantsPage organizationClientGrantsPage1 = api.organizations().listClientGrants(organization.getId(), filter).execute().getBody();
assertThat(organizationClientGrantsPage1.getItems().size(), is(0));

// Delete the ClientGrant.
api.clientGrants().delete(clientGrant.getId()).execute();

// Retrieve the ClientGrant and ensure error is return since grant has been deleted.
ClientGrantsPage clientGrantsPage = api.clientGrants().list(new ClientGrantsFilter().withClientId(clientGrant.getId())).execute().getBody();
assertThat(clientGrantsPage.getItems().size(), is(0));
}
catch (Exception ex){
ex.printStackTrace();
}
}

private ClientGrant createNewClientGrant(Client client, ResourceServer resourceServer) throws Auth0Exception {
ClientGrant clientGrant = new ClientGrant();
clientGrant.setClientId(client.getClientId());
clientGrant.setAudience(resourceServer.getIdentifier());
clientGrant.setScope(Arrays.asList("create:resource", "create:organization_client_grants"));
clientGrant.setAllowAnyOrganization(true);
clientGrant.setOrganizationUsage("allow");

return api.clientGrants().create(client.getClientId(), resourceServer.getIdentifier(), new String[]{"create:resource", "create:organization_client_grants"}).execute().getBody();
}

private Client createNewClient(String orgId) throws Auth0Exception {
Client client = new Client("Test Client (" + System.currentTimeMillis() + ")");
client.setDescription("This is just a test client.");
client.setOrganizationUsage("allow");
client.setDefaultOrganization(new ClientDefaultOrganization(Arrays.asList("client_credentials"), orgId));

return api.clients().create(client).execute().getBody();
}

private Organization givenAnOrganization() throws Auth0Exception {
Organization organization = new Organization();
organization.setName("test-organization");
organization.setDisplayName("test-organization");

return api.organizations().create(organization).execute().getBody();
}

private ResourceServer givenAResourceServer() throws Auth0Exception {
ResourceServer resourceServer = new ResourceServer("https://www.tanyaisawesome.com");
resourceServer.setName("tanyaisawesome");

return api.resourceServers().create(resourceServer).execute().getBody();
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,52 @@ public void shouldListResourceServerWithTotals() throws Exception {
assertThat(response.getLimit(), is(50));
}

@Test
public void shouldListResourceServerWithIdentifiers() throws Exception {
ResourceServersFilter filter = new ResourceServersFilter().withIdentifiers("identifier");
Request<ResourceServersPage> request = api.resourceServers().list(filter);
assertThat(request, is(notNullValue()));

server.jsonResponse(MGMT_RESOURCE_SERVERS_PAGED_LIST, 200);
ResourceServersPage response = request.execute().getBody();
RecordedRequest recordedRequest = server.takeRequest();

assertThat(recordedRequest, hasMethodAndPath(HttpMethod.GET, "/api/v2/resource-servers"));
assertThat(recordedRequest, hasHeader("Content-Type", "application/json"));
assertThat(recordedRequest, hasHeader("Authorization", "Bearer apiToken"));
assertThat(recordedRequest, hasQueryParameter("identifiers", "identifier"));

assertThat(response, is(notNullValue()));
assertThat(response.getItems(), hasSize(2));
assertThat(response.getStart(), is(0));
assertThat(response.getLength(), is(14));
assertThat(response.getTotal(), is(14));
assertThat(response.getLimit(), is(50));
}

@Test
public void shouldListResourceServerWithCheckpointPagination() throws Exception {
ResourceServersFilter filter = new ResourceServersFilter().withCheckpointPagination("tokenId2", 5);
Request<ResourceServersPage> request = api.resourceServers().list(filter);
assertThat(request, is(notNullValue()));

server.jsonResponse(MGMT_RESOURCE_SERVERS_PAGED_LIST, 200);
ResourceServersPage response = request.execute().getBody();
RecordedRequest recordedRequest = server.takeRequest();

assertThat(recordedRequest, hasMethodAndPath(HttpMethod.GET, "/api/v2/resource-servers"));
assertThat(recordedRequest, hasHeader("Content-Type", "application/json"));
assertThat(recordedRequest, hasHeader("Authorization", "Bearer apiToken"));
assertThat(recordedRequest, hasQueryParameter("from", "tokenId2"));
assertThat(recordedRequest, hasQueryParameter("take", "5"));
assertThat(response, is(notNullValue()));
assertThat(response.getItems(), hasSize(2));
assertThat(response.getStart(), is(0));
assertThat(response.getLength(), is(14));
assertThat(response.getTotal(), is(14));
assertThat(response.getLimit(), is(50));
}

@Test
public void shouldUpdateResourceServer() throws Exception {
ResourceServer resourceServer = new ResourceServer("https://api.my-company.com/api/v2/");
Expand Down
Loading
Loading