Class LiteralBasedProvider
java.lang.Object
com.lightstreamer.interfaces.metadata.MetadataProviderAdapter
com.lightstreamer.adapters.metadata.LiteralBasedProvider
- All Implemented Interfaces:
- MetadataProvider
Simple full implementation of a Metadata Adapter, made available
 in Lightstreamer SDK. The Adapter is not meant for production use,
 but it can be used as a starting point for real Adapters. 
The class handles Item List specifications, a special case of Item Group name formed by simply concatenating the names of the Items contained in a List in a space separated way. Similarly, the class handles Field List specifications, a special case of Field Schema name formed by concatenating the names of the contained Fields. The handling of Item List and Field List specifications is required by some optional methods in the client APIs that take advantage of Item Lists and Field Lists.
The resource levels are assigned the same for all Items and Users, according with values that can be supplied together with adapter configuration, inside the "metadata_provider" element that defines the Adapter.
The return of the getAllowedMaxBandwidth method can be supplied in a "max_bandwidth" parameter; the return of the getAllowedMaxItemFrequency method can be supplied in a "max_frequency" parameter; the return of the getAllowedBufferSize method can be supplied in a "buffer_size" parameter; the return of the getDistinctSnapshotLength method can be supplied in a "distinct_snapshot_length" parameter; the return of the getMinSourceFrequency method can be supplied in a "prefilter_frequency" parameter. All resource limits not supplied are granted as unlimited, but for distinct_snapshot_length, which defaults as 10.
The return of the modeMayBeAllowed method (i.e. the association of the proper publishing Mode to each Item) can be configured by supplying a list of rules, which define Item families, where all Items in each family share the same set of allowed Modes (but remember that only one out of the MERGE, DISTINCT and COMMAND Modes is supported by the Server for each Item; only the RAW mode is supported without restrictions). Each family is specified by providing a pattern upon which all names of the Items in the family need to match and, optionally, the involved Data Adapter. The description of each family can be supplied with a group of parameters, named "item_family_<n>", "data_adapter_for_item_family_<n>", and "modes_for_item_family_<n>", where <n> is a progressive number, unique for each family. The first parameter specifies the pattern, in java.util.regex.Pattern format, while the second one is optional and specifies the Data Adapter (if missing, the rule applies regardless of the Data Adapter). The third parameter specifies the allowed modes for this family, as a list of names, with commas and spaces as allowed separators. In case more than one rule applies, the one with the smallest progressive is considered and the Item is assigned only to that family. Items that do not belong to any family are not allowed in any Mode; however, if no families are defined at all, then all Items are allowed in all Modes and the Clients should ensure that the same Item cannot be requested in two conflicting Modes.
There are no access restrictions, but an optional User name check is performed if a comma separated list of User names is supplied in an "allowed_users" parameter.
The following snippet shows an example of configuration of this Adapter in adapters.xml:
The class handles Item List specifications, a special case of Item Group name formed by simply concatenating the names of the Items contained in a List in a space separated way. Similarly, the class handles Field List specifications, a special case of Field Schema name formed by concatenating the names of the contained Fields. The handling of Item List and Field List specifications is required by some optional methods in the client APIs that take advantage of Item Lists and Field Lists.
The resource levels are assigned the same for all Items and Users, according with values that can be supplied together with adapter configuration, inside the "metadata_provider" element that defines the Adapter.
The return of the getAllowedMaxBandwidth method can be supplied in a "max_bandwidth" parameter; the return of the getAllowedMaxItemFrequency method can be supplied in a "max_frequency" parameter; the return of the getAllowedBufferSize method can be supplied in a "buffer_size" parameter; the return of the getDistinctSnapshotLength method can be supplied in a "distinct_snapshot_length" parameter; the return of the getMinSourceFrequency method can be supplied in a "prefilter_frequency" parameter. All resource limits not supplied are granted as unlimited, but for distinct_snapshot_length, which defaults as 10.
The return of the modeMayBeAllowed method (i.e. the association of the proper publishing Mode to each Item) can be configured by supplying a list of rules, which define Item families, where all Items in each family share the same set of allowed Modes (but remember that only one out of the MERGE, DISTINCT and COMMAND Modes is supported by the Server for each Item; only the RAW mode is supported without restrictions). Each family is specified by providing a pattern upon which all names of the Items in the family need to match and, optionally, the involved Data Adapter. The description of each family can be supplied with a group of parameters, named "item_family_<n>", "data_adapter_for_item_family_<n>", and "modes_for_item_family_<n>", where <n> is a progressive number, unique for each family. The first parameter specifies the pattern, in java.util.regex.Pattern format, while the second one is optional and specifies the Data Adapter (if missing, the rule applies regardless of the Data Adapter). The third parameter specifies the allowed modes for this family, as a list of names, with commas and spaces as allowed separators. In case more than one rule applies, the one with the smallest progressive is considered and the Item is assigned only to that family. Items that do not belong to any family are not allowed in any Mode; however, if no families are defined at all, then all Items are allowed in all Modes and the Clients should ensure that the same Item cannot be requested in two conflicting Modes.
There are no access restrictions, but an optional User name check is performed if a comma separated list of User names is supplied in an "allowed_users" parameter.
The following snippet shows an example of configuration of this Adapter in adapters.xml:
 
<!-- Mandatory. Define the Metadata Provider. -->
<metadata_provider>
    <!-- Mandatory. Java class name of the adapter. -->
    <adapter_class>com.lightstreamer.adapters.metadata.LiteralBasedProvider</adapter_class>
    ......
    <!-- Optional. List of initialization parameters specific for LiteralBasedProvider. -->
    <!-- Optional.
         Define values to be returned in getAllowedMaxBandwidth(),
         getAllowedMaxItemFrequency(), getAllowedBufferSize() and
         getDistinctSnapshotLength() methods, for any User and Item
         supplied. -->
    <!--
    <param name="max_bandwidth">40</param>
    <param name="max_frequency">3</param>
    <param name="buffer_size">30</param>
    <param name="distinct_snapshot_length">10</param>
     -->
    <!-- Optional.
         Define comma-separated list of User names to be checked
         for allowance by the notifyUser() method. -->
    <!--
    <param name="allowed_users">user123,user456</param>
     -->
    <!-- Optional.
         Define how the modeMayBeAllowed method should behave, by
         associating to each item the modes in which it can be managed
         by the Server.
         Each triple of parameters of the form "item_family_<n>",
         "data_adapter_for_item_family_<n> (optional), and
         "modes_for_item_family_<n>" define respectively the item name
         pattern (in java.util.regex.Pattern format),
         the related Data Adapter, and the allowed
         modes (in comma separated format) for a family of items.
         Each item is assigned to the first family that matches its name
         and (if supplied) the related Data Adapter.
         If no families are specified at all, then modeMayBeAllowed
         always returns true, though this is not recommended, because
         the Server does not support more than one mode out of MERGE,
         DISTINCT, and COMMAND for the same item. In such a case, the
         Server would just manage each item in the mode specified by the
         first Client request it receives for the item and would be up to
         the Clients to ensure that the same item cannot be requested in
         two conflicting Modes. -->
    <param name="item_family_1">item.*</param>
    <param name="data_adapter_for_item_family_1">MyDataAdapter</param>
    <param name="modes_for_item_family_1">MERGE</param>
    <!--
    <param name="item_family_2">portfolio.*</param>
    <param name="modes_for_item_family_2">COMMAND</param>
     -->
</metadata_provider>
 
 
 
 The class, together with the inherited
 MetadataProviderAdapter,
 also provides implementations for old signature versions
 of some methods (in the form of overloads of the current version)
 and it forwards the implementations for the current signature
 versions to the old ones, which involves discarding some arguments
 (with the exception of modeMayBeAllowed, which behaves in a slightly
 different way).
 As a consequence, a custom Metadata Adapter inheriting from this class
 is allowed to stick to old signature versions for its own implementations,
 although the use of the current versions is recommended.
 However, the restrictions related to the
 MetadataProvider
 interface still hold: the custom part of the Adapter is only allowed
 to implement at most one version for each interface method, otherwise
 the Adapter can be refused (the exception, here, is notifyUser,
 which has two current overloaded versions).- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionintgetAllowedBufferSize(String user, String item) Reduced, backward-compatibility version of the buffer size authorization method.intgetAllowedBufferSize(String user, String item, String dataAdapter) Returns the size of the buffer internally used to enqueue subsequent ItemUpdates for the same Item.doublegetAllowedMaxBandwidth(String user) Returns the bandwidth level to be allowed to a User for a push Session.doublegetAllowedMaxItemFrequency(String user, String item) Reduced, backward-compatibility version of the ItemUpdate frequency authorization method.doublegetAllowedMaxItemFrequency(String user, String item, String dataAdapter) Returns the ItemUpdate frequency to be allowed to a User for a specific Item.intReduced, backward-compatibility version of the Snapshot length configuration method.intgetDistinctSnapshotLength(String item, String dataAdapter) Returns the maximum allowed length for a Snapshot of any Item that has been requested with publishing Mode DISTINCT.String[]Reduced, backward-compatibility version of the Item List determination method.String[]Reduced, backward-compatibility version of the Item List determination method.String[]Resolves an Item List specification supplied in a Request.doublegetMinSourceFrequency(String item) Reduced, backward-compatibility version of the Prefilter frequency configuration method.doublegetMinSourceFrequency(String item, String dataAdapter) Returns the minimum ItemEvent frequency from the supplier Data Adapter at which the events for an Item are guaranteed to be delivered to the Clients without loss of information.String[]Reduced, backward-compatibility version of the Field List determination method.String[]Reduced, backward-compatibility version of the Field List determination method.String[]Resolves a Field List specification supplied in a Request.voidReads configuration settings for user and resource constraints.booleanmodeMayBeAllowed(String item, Mode mode) Reduced, backward-compatibility version of the publishing mode allowance method.booleanmodeMayBeAllowed(String item, String dataAdapter, Mode mode) Called by Lightstreamer Kernel to ask for the allowance of a publishing Mode for an Item.voidnotifyUser(String user, String password) Reduced, backward-compatibility version of the User authentication method.voidnotifyUser(String user, String password, Map httpHeaders) Checks if a user is enabled to make Requests to the related Data Providers.voidnotifyUser(String user, String password, Map httpHeaders, String clientPrincipal) Extended version of the User authentication method, invoked by the Server instead of the standard 3-argument one in case it has been instructed (through the <use_client_auth> configuration flag) to acquire the client principal from the client TLS/SSL certificate, if available.Methods inherited from class com.lightstreamer.interfaces.metadata.MetadataProviderAdaptercustomizeUpdate, customizeUpdate, enableUpdateCustomization, enableUpdateCustomization, isModeAllowed, isModeAllowed, isSelected, isSelected, isSelectorAllowed, isSelectorAllowed, notifyMpnDeviceAccess, notifyMpnDeviceTokenChange, notifyMpnSubscriptionActivation, notifyNewSession, notifyNewSession, notifyNewTables, notifySessionClose, notifyTablesClose, notifyUserMessage, wantsTablesNotificationMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface com.lightstreamer.interfaces.metadata.MetadataProvidergetSessionTimeToLive, setListener
- 
Constructor Details- 
LiteralBasedProviderpublic LiteralBasedProvider()Void constructor required by Lightstreamer Kernel.
 
- 
- 
Method Details- 
initReads configuration settings for user and resource constraints. If some setting is missing, the corresponding constraint is not set.- Specified by:
- initin interface- MetadataProvider
- Overrides:
- initin class- MetadataProviderAdapter
- Parameters:
- params- Can contain the configuration settings.
- dir- Not used.
- Throws:
- MetadataProviderException- in case of configuration errors.
 
- 
getItemspublic String[] getItems(String user, String sessionID, String itemList, String dataAdapter) throws ItemsException Resolves an Item List specification supplied in a Request. The names of the Items in the List are returned. The operation is deferred to a reduced version of the method, where the dataAdapter argument is discarded. This also ensures backward compatibility with old adapter classes derived from this one.- Parameters:
- user- A User name.
- sessionID- A Session ID. Not used.
- itemList- An Item List specification.
- dataAdapter- The name of the Data Adapter to which the Item List is targeted.
- Returns:
- An array with the names of the Items in the List.
- Throws:
- ItemsException- never thrown
 
- 
getItemsReduced, backward-compatibility version of the Item List determination method. The operation is deferred to an even more reduced version of the method, where the sessionID argument is discarded. This also ensures backward compatibility with very old adapter classes derived from this one.- Parameters:
- user- A User name.
- sessionID- A Session ID. Not used.
- itemList- An Item List specification.
- Returns:
- An array with the names of the Items in the List.
- Throws:
- ItemsException- never thrown
- See Also:
 
- 
getItemsReduced, backward-compatibility version of the Item List determination method.- Parameters:
- user- A User name. Not used.
- itemList- An Item List specification.
- Returns:
- An array with the names of the Items in the List.
- Throws:
- ItemsException- never thrown.
- See Also:
 
- 
getSchemapublic String[] getSchema(String user, String sessionID, String itemList, String dataAdapter, String fieldList) throws SchemaException Resolves a Field List specification supplied in a Request. The names of the Fields in the List are returned. The operation is deferred to a reduced version of the method, where the dataAdapter argument is discarded. This also ensures backward compatibility with old adapter classes derived from this one.- Parameters:
- user- A User name.
- sessionID- A Session ID. Not used.
- itemList- The specification of the Item List whose Items the Field List is to be applied to.
- dataAdapter- The name of the Data Adapter to which the Item List is targeted.
- fieldList- A Field List specification.
- Returns:
- An array with the names of the Fields in the List.
- Throws:
- SchemaException- never thrown
 
- 
getSchemapublic String[] getSchema(String user, String sessionID, String itemList, String fieldList) throws SchemaException Reduced, backward-compatibility version of the Field List determination method. The operation is deferred to an even more reduced version of the method, where the sessionID argument is discarded. This also ensures backward compatibility with very old adapter classes derived from this one.- Parameters:
- user- A User name.
- sessionID- A Session ID. Not used.
- itemList- The specification of the Item List whose Items the Field List is to be applied to.
- fieldList- A Field List specification.
- Returns:
- An array with the names of the Fields in the List.
- Throws:
- SchemaException- never thrown
- See Also:
 
- 
getSchemaReduced, backward-compatibility version of the Field List determination method.- Parameters:
- user- A User name. Not used.
- itemList- The specification of the Item List whose Items the Field List is to be applied to. Not used.
- fieldList- A Field List specification.
- Returns:
- An array with the names of the Fields in the List.
- Throws:
- SchemaException- never thrown.
- See Also:
 
- 
notifyUserpublic void notifyUser(String user, String password, Map httpHeaders) throws AccessException, CreditsException Checks if a user is enabled to make Requests to the related Data Providers. Note that, for authentication purposes, only the user and password arguments should be consulted.
 The check is deferred to a reduced version of the method, where the httpHeader argument is discarded. This also ensures backward compatibility with very old adapter classes derived from this one.- Specified by:
- notifyUserin interface- MetadataProvider
- Overrides:
- notifyUserin class- MetadataProviderAdapter
- Parameters:
- user- A User name.
- password- An optional password.
- httpHeaders- A Map that contains a name-value pair for each header found in the HTTP request that originated the call. Not used.
- Throws:
- AccessException- if a list of User names has been configured and the supplied name does not belong to the list.
- CreditsException- never thrown.
- See Also:
 
- 
notifyUserReduced, backward-compatibility version of the User authentication method.- Overrides:
- notifyUserin class- MetadataProviderAdapter
- Parameters:
- user- A User name.
- password- An optional password. Not used.
- Throws:
- AccessException- if a list of User names has been configured and the supplied name does not belong to the list.
- CreditsException- never thrown.
- See Also:
 
- 
notifyUserpublic void notifyUser(String user, String password, Map httpHeaders, String clientPrincipal) throws AccessException, CreditsException Extended version of the User authentication method, invoked by the Server instead of the standard 3-argument one in case it has been instructed (through the <use_client_auth> configuration flag) to acquire the client principal from the client TLS/SSL certificate, if available.
 The check is deferred to the standard version of the method, where the clientPrincipal argument is discarded.
 Edition Note:
 https is an optional feature, available depending on Edition and License Type. To know what features are enabled by your license, please see the License tab of the Monitoring Dashboard (by default, available at /dashboard).- Specified by:
- notifyUserin interface- MetadataProvider
- Overrides:
- notifyUserin class- MetadataProviderAdapter
- Parameters:
- user- A User name.
- password- A password optionally required to validate the User.
- httpHeaders- A Map-type value object that contains a name-value pair for each header found in the HTTP request that originated the call.
- clientPrincipal- the identification name reported in the client TLS/SSL certificate supplied on the socket connection used to issue the request that originated the call; it can be null if client has not authenticated itself or the authentication has failed. Not used.
- Throws:
- AccessException- if a list of User names has been configured and the supplied name does not belong to the list.
- CreditsException- never thrown.
 
- 
getAllowedMaxBandwidthReturns the bandwidth level to be allowed to a User for a push Session.- Specified by:
- getAllowedMaxBandwidthin interface- MetadataProvider
- Overrides:
- getAllowedMaxBandwidthin class- MetadataProviderAdapter
- Parameters:
- user- A User name. Not used.
- Returns:
- The bandwidth, in Kbit/sec, as supplied in the Metadata Adapter configuration.
 
- 
getAllowedMaxItemFrequencyReturns the ItemUpdate frequency to be allowed to a User for a specific Item. The operation is deferred to a reduced version of the method, where the dataAdapter argument is discarded. This also ensures backward compatibility with old adapter classes derived from this one.- Specified by:
- getAllowedMaxItemFrequencyin interface- MetadataProvider
- Overrides:
- getAllowedMaxItemFrequencyin class- MetadataProviderAdapter
- Parameters:
- user- A User name. Not used.
- item- An Item Name. Not used.
- dataAdapter- A Data Adapter name. Not used.
- Returns:
- The allowed Update frequency, in Updates/sec, as supplied in the Metadata Adapter configuration.
 
- 
getAllowedMaxItemFrequencyReduced, backward-compatibility version of the ItemUpdate frequency authorization method.- Overrides:
- getAllowedMaxItemFrequencyin class- MetadataProviderAdapter
- Parameters:
- user- A User name. Not used.
- item- An Item Name. Not used.
- Returns:
- The allowed Update frequency, in Updates/sec, as supplied in the Metadata Adapter configuration.
- See Also:
 
- 
getAllowedBufferSizeReturns the size of the buffer internally used to enqueue subsequent ItemUpdates for the same Item. The operation is deferred to a reduced version of the method, where the dataAdapter argument is discarded. This also ensures backward compatibility with old adapter classes derived from this one.- Specified by:
- getAllowedBufferSizein interface- MetadataProvider
- Overrides:
- getAllowedBufferSizein class- MetadataProviderAdapter
- Parameters:
- user- A User name. Not used.
- item- An Item Name. Not used.
- dataAdapter- A Data Adapter name. Not used.
- Returns:
- The allowed buffer size, as supplied in the Metadata Adapter configuration.
 
- 
getAllowedBufferSizeReduced, backward-compatibility version of the buffer size authorization method.- Overrides:
- getAllowedBufferSizein class- MetadataProviderAdapter
- Parameters:
- user- A User name. Not used.
- item- An Item Name. Not used.
- Returns:
- The allowed buffer size, as supplied in the Metadata Adapter configuration.
- See Also:
 
- 
getMinSourceFrequencyReturns the minimum ItemEvent frequency from the supplier Data Adapter at which the events for an Item are guaranteed to be delivered to the Clients without loss of information. In case of an incoming ItemEvent frequency greater than the specified frequency, Lightstreamer Kernel may prefilter the events flow down to this frequency.
 The operation is deferred to a reduced version of the method, where the dataAdapter argument is discarded. This also ensures backward compatibility with old adapter classes derived from this one.- Specified by:
- getMinSourceFrequencyin interface- MetadataProvider
- Overrides:
- getMinSourceFrequencyin class- MetadataProviderAdapter
- Parameters:
- item- An Item Name. Not used.
- dataAdapter- A Data Adapter name. Not used.
- Returns:
- The maximum frequency to be allowed by the prefilter, as supplied in the Metadata Adapter configuration.
 
- 
getMinSourceFrequencyReduced, backward-compatibility version of the Prefilter frequency configuration method.- Overrides:
- getMinSourceFrequencyin class- MetadataProviderAdapter
- Parameters:
- item- An Item Name. Not used.
- Returns:
- The maximum frequency to be allowed by the prefilter, as supplied in the Metadata Adapter configuration.
- See Also:
 
- 
getDistinctSnapshotLengthReturns the maximum allowed length for a Snapshot of any Item that has been requested with publishing Mode DISTINCT. The operation is deferred to a reduced version of the method, where the dataAdapter argument is discarded. This also ensures backward compatibility with old adapter classes derived from this one.- Specified by:
- getDistinctSnapshotLengthin interface- MetadataProvider
- Overrides:
- getDistinctSnapshotLengthin class- MetadataProviderAdapter
- Parameters:
- item- An Item Name. Not used.
- dataAdapter- A Data Adapter name. Not used.
- Returns:
- The maximum allowed length for the Snapshot, as supplied in the Metadata Adapter configuration. In case no value has been supplied, a default value of 10 events is returned, which is thought to be enough to satisfy typical Client requests.
 
- 
getDistinctSnapshotLengthReduced, backward-compatibility version of the Snapshot length configuration method.- Overrides:
- getDistinctSnapshotLengthin class- MetadataProviderAdapter
- Parameters:
- item- An Item Name. Not used.
- Returns:
- The maximum allowed length for the Snapshot, as supplied in the Metadata Adapter configuration. In case no value has been supplied, a default value of 10 events is returned, which is thought to be enough to satisfy typical Client requests.
- See Also:
 
- 
modeMayBeAllowedCalled by Lightstreamer Kernel to ask for the allowance of a publishing Mode for an Item. The operation is first deferred to a reduced version of the method, where the dataAdapter argument is discarded. This ensures backward compatibility with old adapter classes derived from this one.- Specified by:
- modeMayBeAllowedin interface- MetadataProvider
- Overrides:
- modeMayBeAllowedin class- MetadataProviderAdapter
- Parameters:
- item- An Item name.
- dataAdapter- A Data Adapter name.
- mode- A publishing Mode.
- Returns:
- true or false, based on a sequence of rules of the general form <pattern,data_adapter,allowed_modes> supplied in the Adapter configuration. If no rule matches the Item name and the Data Adapter, then false is returned; otherwise, the first matching rule is considered and true is returned only if the related allowed_modes contain the specified Mode. However, if no rules are available at all, then true is always returned. In the latter case, as in any case of loose configuration, conflicting Modes may be both allowed for the same Item, so the Clients should ensure that the same Item cannot be requested in two conflicting Modes.
 
- 
modeMayBeAllowedReduced, backward-compatibility version of the publishing mode allowance method. This version is left to support overriding by old adapter classes derived from this one. If not overridden, the method delegates back to the standard version.- Overrides:
- modeMayBeAllowedin class- MetadataProviderAdapter
- Parameters:
- item- An Item name.
- mode- A publishing Mode.
- Returns:
- true or false only if overridden, otherwise throws.
- See Also:
 
 
-