Class EPPUnhandledNamespacesResponseFilter


  • public class EPPUnhandledNamespacesResponseFilter
    extends java.lang.Object
    EPPUnhandledNamespacesResponseFilter is a utility class used to filter command response extensions, per RFC 9038. Any non-supported command response extensions will be removed from the response and moved to an <extValue> element with the full XML block along with a formatted string <reason>.
    The <value> element contains the full unsupported block of XML whether it be for an object extension or a command / response extension.
    The <reason> element is encoded using the following ABNF:
     REASON        = NAMESPACE-URI " not in login services"
     NAMESPACE-URI = 1*VCHAR
     

    The class does support a no-operation option to simply identify and log non-supported services without removing them from the response or adding <extValue> elements to the result.
    • Constructor Detail

      • EPPUnhandledNamespacesResponseFilter

        public EPPUnhandledNamespacesResponseFilter()
        Default constructor, where the monitor is by default set to EPPUnhandledNamespacesMonitorLogger.
      • EPPUnhandledNamespacesResponseFilter

        public EPPUnhandledNamespacesResponseFilter​(EPPUnhandledNamespacesMonitor aMonitor)
        Constructor that the monitor to use as a parameter.
        Parameters:
        aMonitor - Monitor to use for unhandled namespaces. Set to null if no monitor is desired.
    • Method Detail

      • setMonitor

        public void setMonitor​(EPPUnhandledNamespacesMonitor monitor)
        Gets the monitor to use with the filter.
        Parameters:
        monitor - Monitor to use with the filter. Set to null to not use a monitor.
      • filter

        public EPPResponse filter​(EPPResponse aResponse,
                                  java.util.List<EPPService> aExtServices,
                                  java.lang.Object aData)
                           throws EPPException
        Filter any response extensions that are not supported by the client based on the passed in the extension services (command response extensions) and the response with the pre-filtered extensions.
        Parameters:
        aResponse - Source response
        aExtServices - List of EPPService login extension services (command response extensions) supported by the client.
        aData - Optional data object that will be passed through to the monitor when there is at least one unhandled namespace identified. This is useful to set transaction-level attributes based on the use of unhandled namespaces. Set to null if a data object is not needed.
        Returns:
        Filtered EPPResponse that only contains extensions that the client supports.
        Throws:
        EPPException - Exception filtering the response
      • filter

        public EPPResponse filter​(EPPResponse aResponse,
                                  java.util.List<EPPService> aExtServices,
                                  boolean aNoOp,
                                  java.lang.Object aData)
                           throws EPPException
        Filter any response extensions that are not supported by the client based on the passed in the extension services (command response extensions) and the response with the pre-filtered extensions.
        Parameters:
        aResponse - Source response
        aExtServices - List of EPPService login extension services (command response extensions) supported by the client.
        aNoOp - Set to true to only identify unsupported services by calling the monitor and not moving the unsupported services into the <extValue> elements.
        aData - Optional data object that will be passed through to the monitor when there is at least one unhandled namespace identified. This is useful to set transaction-level attributes based on the use of unhandled namespaces. Set to null if a data object is not needed.
        Returns:
        Filtered EPPResponse that only contains extensions that the client supports.
        Throws:
        EPPException - Exception filtering the response