Class ModuleSourceProviderBase

  • All Implemented Interfaces:
    java.io.Serializable, ModuleSourceProvider
    Direct Known Subclasses:
    UrlModuleSourceProvider

    public abstract class ModuleSourceProviderBase
    extends java.lang.Object
    implements ModuleSourceProvider, java.io.Serializable
    A base implementation for all module script providers that actually load module scripts. Performs validation of identifiers, allows loading from preferred locations (attempted before require.paths), from require.paths itself, and from fallback locations (attempted after require.paths). Note that while this base class strives to be as generic as possible, it does have loading from an URI built into its design, for the simple reason that the require.paths is defined in terms of URIs.
    See Also:
    Serialized Form
    • Method Summary

      All Methods Instance Methods Concrete Methods 
      Modifier and Type Method Description
      ModuleSource loadSource​(java.lang.String moduleId, Scriptable paths, java.lang.Object validator)
      Returns the script source of the requested module.
      ModuleSource loadSource​(java.net.URI uri, java.net.URI base, java.lang.Object validator)
      Returns the script source of the requested module from the given URI.
      • Methods inherited from class java.lang.Object

        equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
    • Constructor Detail

      • ModuleSourceProviderBase

        public ModuleSourceProviderBase()
    • Method Detail

      • loadSource

        public ModuleSource loadSource​(java.lang.String moduleId,
                                       Scriptable paths,
                                       java.lang.Object validator)
                                throws java.io.IOException,
                                       java.net.URISyntaxException
        Description copied from interface: ModuleSourceProvider
        Returns the script source of the requested module. More specifically, it resolves the module ID to a resource. If it can not resolve it, null is returned. If the caller passes a non-null validator, and the source provider recognizes it, and the validator applies to the same resource that the provider would use to load the source, and the validator validates the current cached representation of the resource (using whatever semantics for validation that this source provider implements), then ModuleSourceProvider.NOT_MODIFIED should be returned. Otherwise, it should return a ModuleSource object with the actual source text of the module, preferrably a validator for it, and a security domain, where applicable.
        Specified by:
        loadSource in interface ModuleSourceProvider
        Parameters:
        moduleId - the ID of the module. An implementation must only accept an absolute ID, starting with a term.
        paths - the value of the require() function's "paths" attribute. If the require() function is sandboxed, it will be null, otherwise it will be a JavaScript Array object. It is up to the provider implementation whether and how it wants to honor the contents of the array.
        validator - a validator for an existing loaded and cached module. This will either be null, or an object that this source provider returned earlier as part of a ModuleSource. It can be used to validate the existing cached module and avoid reloading it.
        Returns:
        a script representing the code of the module. Null should be returned if the script is not found. ModuleSourceProvider.NOT_MODIFIED should be returned if the passed validator validates the current representation of the module (the currently cached module script).
        Throws:
        java.io.IOException - if there was an I/O problem reading the script
        java.net.URISyntaxException - if the final URI could not be constructed.
      • loadSource

        public ModuleSource loadSource​(java.net.URI uri,
                                       java.net.URI base,
                                       java.lang.Object validator)
                                throws java.io.IOException,
                                       java.net.URISyntaxException
        Description copied from interface: ModuleSourceProvider
        Returns the script source of the requested module from the given URI. The URI is absolute but does not contain a file name extension such as ".js", which may be specific to the ModuleSourceProvider implementation.

        If the resource is not found, null is returned. If the caller passes a non-null validator, and the source provider recognizes it, and the validator applies to the same resource that the provider would use to load the source, and the validator validates the current cached representation of the resource (using whatever semantics for validation that this source provider implements), then ModuleSourceProvider.NOT_MODIFIED should be returned. Otherwise, it should return a ModuleSource object with the actual source text of the module, preferrably a validator for it, and a security domain, where applicable.

        Specified by:
        loadSource in interface ModuleSourceProvider
        Parameters:
        uri - the absolute URI from which to load the module source, but without an extension such as ".js".
        base - the module path base URI from which uri was derived.
        validator - a validator for an existing loaded and cached module. This will either be null, or an object that this source provider returned earlier as part of a ModuleSource. It can be used to validate the existing cached module and avoid reloading it.
        Returns:
        a script representing the code of the module. Null should be returned if the script is not found. ModuleSourceProvider.NOT_MODIFIED should be returned if the passed validator validates the current representation of the module (the currently cached module script).
        Throws:
        java.io.IOException - if there was an I/O problem reading the script
        java.net.URISyntaxException - if the final URI could not be constructed