Search in sources :

Example 1 with QueryString

use of com.okta.commons.http.QueryString in project okta-commons-java by okta.

the class HttpClientRequestFactory method getFullyQualifiedUri.

private URI getFullyQualifiedUri(Request request) {
    StringBuilder sb = new StringBuilder();
    sb.append(request.getResourceUrl().normalize());
    QueryString query = request.getQueryString();
    if (query != null && !query.isEmpty()) {
        sb.append("?").append(query.toString());
    }
    return URI.create(sb.toString());
}
Also used : QueryString(com.okta.commons.http.QueryString)

Example 2 with QueryString

use of com.okta.commons.http.QueryString in project okta-sdk-java by okta.

the class DefaultDataStore method save.

@SuppressWarnings("unchecked")
private <T extends Resource, R extends Resource> R save(String href, final T resource, final T parentResource, HttpHeaders requestHeaders, final Class<? extends R> returnType, final QueryString qs, final boolean create) {
    Assert.hasText(href, "href argument cannot be null or empty.");
    Assert.notNull(resource, "resource argument cannot be null.");
    Assert.notNull(returnType, "returnType class cannot be null.");
    Assert.isInstanceOf(AbstractResource.class, resource);
    Assert.isTrue(!CollectionResource.class.isAssignableFrom(resource.getClass()), "Collections cannot be persisted.");
    final CanonicalUri uri = canonicalize(href, qs);
    final AbstractResource abstractResource = (AbstractResource) resource;
    // Most Okta endpoints do not support partial update, we can revisit in the future.
    final Map<String, Object> props = resourceConverter.convert(abstractResource, false);
    FilterChain chain = new DefaultFilterChain(this.filters, req -> {
        CanonicalUri uri1 = req.getUri();
        String href1 = uri1.getAbsolutePath();
        QueryString qs1 = uri1.getQuery();
        HttpHeaders httpHeaders = req.getHttpHeaders();
        // create == POST
        HttpMethod method = HttpMethod.POST;
        if (!create) {
            method = HttpMethod.PUT;
        }
        InputStream body;
        long length = 0;
        if (resource instanceof VoidResource) {
            body = new ByteArrayInputStream(new byte[0]);
        } else if (resource instanceof FileResource) {
            body = new ByteArrayInputStream(new byte[0]);
            httpHeaders.add("x-fileLocation", ((FileResource) resource).getLocation());
            httpHeaders.add("x-fileFormDataName", ((FileResource) resource).getFormDataName());
        } else {
            ByteArrayOutputStream bodyOut = new ByteArrayOutputStream();
            mapMarshaller.marshal(bodyOut, req.getData());
            body = new ByteArrayInputStream(bodyOut.toByteArray());
            length = bodyOut.size();
        }
        Request request = new DefaultRequest(method, href1, qs1, httpHeaders, body, length);
        Response response = execute(request);
        Map<String, Object> responseBody = getBody(response);
        if (Collections.isEmpty(responseBody)) {
            // Okta response with 200 for deactivate requests (i.e. /api/v1/apps/<id>/lifecycle/deactivate)
            if (response.getHttpStatus() == 202 || response.getHttpStatus() == 200 || response.getHttpStatus() == 201 || response.getHttpStatus() == 204) {
                // 202 means that the request has been accepted for processing, but the processing has not been completed. Therefore we do not have a response setBody.
                responseBody = java.util.Collections.emptyMap();
            } else {
                throw new IllegalStateException("Unable to obtain resource data from the API server.");
            }
        }
        ResourceAction responseAction = getPostAction(req, response);
        return new DefaultResourceDataResult(responseAction, uri1, returnType, responseBody);
    });
    ResourceAction action = create ? ResourceAction.CREATE : ResourceAction.UPDATE;
    ResourceDataRequest request = new DefaultResourceDataRequest(action, uri, canonicalizeParent(parentResource), returnType, getResourceClass(parentResource), props, requestHeaders);
    DefaultResourceDataResult result = (DefaultResourceDataResult) chain.filter(request);
    Map<String, Object> data = result.getData();
    // ensure the caller's argument is updated with what is returned from the server if the types are the same:
    if (returnType.isAssignableFrom(abstractResource.getClass())) {
        abstractResource.setInternalProperties(data);
    }
    return resourceFactory.instantiate(returnType, data);
}
Also used : HttpHeaders(com.okta.commons.http.HttpHeaders) DefaultRequest(com.okta.commons.http.DefaultRequest) QueryString(com.okta.commons.http.QueryString) ByteArrayInputStream(java.io.ByteArrayInputStream) InputStream(java.io.InputStream) FileResource(com.okta.sdk.resource.FileResource) Request(com.okta.commons.http.Request) DefaultRequest(com.okta.commons.http.DefaultRequest) AbstractResource(com.okta.sdk.impl.resource.AbstractResource) QueryString(com.okta.commons.http.QueryString) ByteArrayOutputStream(java.io.ByteArrayOutputStream) Response(com.okta.commons.http.Response) DefaultCanonicalUri(com.okta.sdk.impl.http.support.DefaultCanonicalUri) CanonicalUri(com.okta.sdk.impl.http.CanonicalUri) VoidResource(com.okta.sdk.resource.VoidResource) ByteArrayInputStream(java.io.ByteArrayInputStream) HttpMethod(com.okta.commons.http.HttpMethod)

Example 3 with QueryString

use of com.okta.commons.http.QueryString in project okta-sdk-java by okta.

the class DefaultDataStore method save.

@Override
public <T extends Resource> void save(String href, T resource, T parentResource, Map<String, Object> queryParameters, Map<String, List<String>> headerParameters) {
    Assert.hasText(href, HREF_REQD_MSG);
    save(href, resource, parentResource, headers(headerParameters), getResourceClass(resource), new QueryString(queryParameters), false);
}
Also used : QueryString(com.okta.commons.http.QueryString)

Example 4 with QueryString

use of com.okta.commons.http.QueryString in project okta-sdk-java by okta.

the class DefaultCanonicalUri method create.

public static CanonicalUri create(String href, Map<String, ?> queryParams) {
    Assert.hasText(href, "href argument cannot be null or empty.");
    QueryString query = null;
    if (!Collections.isEmpty(queryParams)) {
        // create a copy so we don't manipulate the argument
        query = new QueryString(queryParams);
        int questionMarkIndex = href.lastIndexOf('?');
        if (questionMarkIndex >= 0) {
            String queryString = href.substring(questionMarkIndex + 1);
            href = href.substring(0, questionMarkIndex);
            if (Strings.hasLength(queryString)) {
                // the query values from the href portion are explicit and therefore take precedence over
                // any values in the queryParams argument:
                QueryString queryStringFromHref = QueryString.create(queryString);
                if (queryStringFromHref != null) {
                    query.putAll(queryStringFromHref);
                }
            }
        }
    }
    return new DefaultCanonicalUri(href, query);
}
Also used : QueryString(com.okta.commons.http.QueryString) QueryString(com.okta.commons.http.QueryString)

Aggregations

QueryString (com.okta.commons.http.QueryString)4 DefaultRequest (com.okta.commons.http.DefaultRequest)1 HttpHeaders (com.okta.commons.http.HttpHeaders)1 HttpMethod (com.okta.commons.http.HttpMethod)1 Request (com.okta.commons.http.Request)1 Response (com.okta.commons.http.Response)1 CanonicalUri (com.okta.sdk.impl.http.CanonicalUri)1 DefaultCanonicalUri (com.okta.sdk.impl.http.support.DefaultCanonicalUri)1 AbstractResource (com.okta.sdk.impl.resource.AbstractResource)1 FileResource (com.okta.sdk.resource.FileResource)1 VoidResource (com.okta.sdk.resource.VoidResource)1 ByteArrayInputStream (java.io.ByteArrayInputStream)1 ByteArrayOutputStream (java.io.ByteArrayOutputStream)1 InputStream (java.io.InputStream)1