Class HalClientImpl

  • All Implemented Interfaces:
    HalClient, org.refcodes.net.OauthTokenAccessor, org.refcodes.net.OauthTokenAccessor.OauthTokenBuilder<HalClient>, org.refcodes.net.OauthTokenAccessor.OauthTokenMutator, org.refcodes.net.OauthTokenAccessor.OauthTokenProperty


    public class HalClientImpl
    extends Object
    implements HalClient
    Implementation of the HalClient using the HttpRestServer (HttpRestServerImpl) under the hood.
    • Constructor Detail

      • HalClientImpl

        public HalClientImpl​(String aHalUrl)
                      throws MalformedURLException
        Instantiates the HalClient with no authorization credentials passed.
        Parameters:
        aHalUrl - The URL pointing to the HAL-Endpoint.
        Throws:
        MalformedURLException - Thrown to indicate that a malformed OAuth URL has occurred.
      • HalClientImpl

        public HalClientImpl​(String aHalUrl,
                             org.refcodes.net.OauthToken aOauthToken)
                      throws MalformedURLException
        Instantiates the HalClient with a valid OauthToken passed.
        Parameters:
        aHalUrl - The URL pointing to the HAL-Endpoint.
        aOauthToken - The OAuth-Token to be used when authorizing against the HAL-Endpoint.
        Throws:
        MalformedURLException - Thrown to indicate that a malformed OAuth URL has occurred.
      • HalClientImpl

        public HalClientImpl​(String aHalUrl,
                             String aOauthUrl,
                             String aOauthClientId,
                             String aOauthClientSecret,
                             String aOauthUserName,
                             String aOauthUserSecret)
                      throws org.refcodes.net.HttpStatusException,
                             MalformedURLException
        Instantiates the HalClient with no authorization credentials passed.
        Parameters:
        aHalUrl - The URL pointing to the HAL-Endpoint.
        aOauthUrl - The URL pointing to the OAuth authentication endpoint.
        aOauthClientId - The assigned OAuth client ID.
        aOauthClientSecret - The client's OAuth secret.
        aOauthUserName - The OAuth authorization user name.
        aOauthUserSecret - The OAuth authorization user secret.
        Throws:
        org.refcodes.net.HttpStatusException - Thrown in case a HTTP response was of an erroneous status when requesting the OAuth URL.
        MalformedURLException - Thrown to indicate that a malformed OAuth URL has occurred.
      • HalClientImpl

        public HalClientImpl​(org.refcodes.net.Url aHalUrl)
                      throws MalformedURLException
        Instantiates the HalClient with no authorization credentials passed.
        Parameters:
        aHalUrl - The URL pointing to the HAL-Endpoint.
        Throws:
        MalformedURLException - Thrown to indicate that a malformed OAuth URL has occurred.
      • HalClientImpl

        public HalClientImpl​(org.refcodes.net.Url aHalUrl,
                             org.refcodes.net.OauthToken aOauthToken)
                      throws MalformedURLException
        Instantiates the HalClient with a valid OauthToken passed.
        Parameters:
        aHalUrl - The URL pointing to the HAL-Endpoint.
        aOauthToken - The OAuth-Token to be used when authorizing against the HAL-Endpoint.
        Throws:
        MalformedURLException - Thrown to indicate that a malformed OAuth URL has occurred.
      • HalClientImpl

        public HalClientImpl​(org.refcodes.net.Url aHalUrl,
                             org.refcodes.net.Url aOauthUrl,
                             String aOauthClientId,
                             String aOauthClientSecret,
                             String aOauthUserName,
                             String aOauthUserSecret)
                      throws org.refcodes.net.HttpStatusException,
                             MalformedURLException
        Instantiates the HalClient with no authorization credentials passed.
        Parameters:
        aHalUrl - The URL pointing to the HAL-Endpoint.
        aOauthUrl - The URL pointing to the OAuth authentication endpoint.
        aOauthClientId - The assigned OAuth client ID.
        aOauthClientSecret - The client's OAuth secret.
        aOauthUserName - The OAuth authorization user name.
        aOauthUserSecret - The OAuth authorization user secret.
        Throws:
        org.refcodes.net.HttpStatusException - Thrown in case a HTTP response was of an erroneous status when requesting the OAuth URL.
        MalformedURLException - Thrown to indicate that a malformed OAuth URL has occurred.
    • Method Detail

      • create

        public HalData create​(String aEntity,
                              HalData aProperties)
                       throws org.refcodes.net.HttpStatusException
        Creates a new entitie's element (row) at the HAL resource consisting of the properties as of the provided CanonicalMap.
        Specified by:
        create in interface HalClient
        Parameters:
        aEntity - The entity for which to create the element (row).
        aProperties - The CanonicalMap containing the properties of the entity be created.
        Returns:
        A HalData with the newly created element (row).
        Throws:
        org.refcodes.net.HttpStatusException - Thrown in case a HTTP response was of an erroneous status.
      • read

        public HalData read​(String aEntity,
                            Long aId,
                            TraversalMode aMode,
                            org.refcodes.net.FormFields aQueryFields)
                     throws org.refcodes.net.HttpStatusException
        Retrieves the properties with the according values for the given entity with the given ID from the HAL resource.
        Specified by:
        read in interface HalClient
        Parameters:
        aEntity - The entity for which to retrieve the properties.
        aId - The ID of the entity for which to retrieve the properties.
        aMode - The mode for handling HREF resources, e.g. load them as well or ignore them.
        aQueryFields - The query fields to be appended to the requesting URL.
        Returns:
        A CanonicalMap with the property names assigned to the according values.
        Throws:
        org.refcodes.net.HttpStatusException - Thrown in case a HTTP response was of an erroneous status.
      • readAll

        public HalDataPage readAll​(String aEntity,
                                   TraversalMode aMode,
                                   org.refcodes.net.FormFields aQueryFields)
                            throws org.refcodes.net.HttpStatusException
        Retrieves the properties with the according values of all elements (rows) for the given entity from the HAL resource.
        Specified by:
        readAll in interface HalClient
        Parameters:
        aEntity - The entity for which to retrieve the properties of all elements (rows).
        aMode - The mode for handling HREF resources, e.g. load them as well or ignore them.
        aQueryFields - The query fields to be appended to the requesting URL.
        Returns:
        A HalData list of type HalDataPage containing one HalData instance per element (row).
        Throws:
        org.refcodes.net.HttpStatusException - Thrown in case a HTTP response was of an erroneous status.
      • update

        public HalData update​(String aEntity,
                              String aId,
                              HalData aProperties)
                       throws org.refcodes.net.HttpStatusException
        Updates an existing entitie's element (row) at the HAL resource using the properties as of the provided CanonicalMap.
        Specified by:
        update in interface HalClient
        Parameters:
        aEntity - The entity for which to update the element (row).
        aId - The ID of the element (row) of the entity to be updated.
        aProperties - The CanonicalMap containing the properties of the entity to be updated.
        Returns:
        The updated representation of the entitie's element (row).
        Throws:
        org.refcodes.net.HttpStatusException - Thrown in case a HTTP response was of an erroneous status.
      • delete

        public boolean delete​(String aEntity,
                              String aId)
                       throws org.refcodes.net.HttpStatusException
        Deletes an entitie's element (row) from the HAL resource.
        Specified by:
        delete in interface HalClient
        Parameters:
        aEntity - The entity for which to delete the element (row).
        aId - The ID of the element (row) of the entity to be deleted.
        Returns:
        True in case the element (row) has been deleted, false if there was none such element (row) at the HAL resource (the expectation is satisfied now as there is no element (row) with the given ID in the HAL resource after the operation).
        Throws:
        org.refcodes.net.HttpStatusException - Thrown in case a HTTP response was of an erroneous status.
      • entities

        public String[] entities​()
                          throws org.refcodes.net.HttpStatusException
        Determines the entities provided by the HAL resource.
        Specified by:
        entities in interface HalClient
        Returns:
        A String array with the according entity names.
        Throws:
        org.refcodes.net.HttpStatusException - Thrown in case a HTTP response was of an erroneous status.
      • introspect

        public HalStruct introspect​(String aEntity,
                                    TraversalMode aMode)
                             throws org.refcodes.net.HttpStatusException
        Introspects the provided entity at the HAL resource and returns an instance of the CanonicalMap representing the reflected data structure.
        Specified by:
        introspect in interface HalClient
        Parameters:
        aEntity - The entity to be introspected.
        aMode - The mode of operation whilst introspecting an entity: You may include MetaData as of TraversalMode.IMPORT_CHILDREN_KEEP_DANGLING_HREFS or just retrieve the plain data structure without Meta-Data as of TraversalMode.IMPORT_CHILDREN.
        Returns:
        A CanonicalMap instance representing the structure of the entity, e.g. providing the attribute names and the data types as well as other constraints representing the layout of the entity (think of a class defining the layout of its instances).
        Throws:
        org.refcodes.net.HttpStatusException - Thrown in case a HTTP response was of an erroneous status.
      • getExcludeEntities

        public String[] getExcludeEntities​()
        Gets the names of the entities to be excluded by the HalClient.
        Specified by:
        getExcludeEntities in interface HalClient
        Returns:
        The entities to be excluded.
      • getIncludeEntities

        public String[] getIncludeEntities​()
        Gets the names of the entities to be included by the HalClient.
        Specified by:
        getIncludeEntities in interface HalClient
        Returns:
        The entities to be included.
      • getOauthToken

        public org.refcodes.net.OauthToken getOauthToken​()
        Specified by:
        getOauthToken in interface org.refcodes.net.OauthTokenAccessor
      • setExcludeEntities

        public void setExcludeEntities​(String[] theEntities)
        Sets the names of the entities to be excluded by the HalClient.
        Specified by:
        setExcludeEntities in interface HalClient
        Parameters:
        theEntities - The entities to be excluded.
      • setIncludeEntities

        public void setIncludeEntities​(String[] theEntities)
        Sets the names of the entities to be included by the HalClient.
        Specified by:
        setIncludeEntities in interface HalClient
        Parameters:
        theEntities - The entities to be included.
      • setOauthToken

        public void setOauthToken​(org.refcodes.net.OauthToken aOauthToken)
        Specified by:
        setOauthToken in interface org.refcodes.net.OauthTokenAccessor.OauthTokenMutator