All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.lightstreamer.client.ItemUpdate Maven / Gradle / Ivy

/*
 * Copyright (c) 2004-2015 Weswit s.r.l., Via Campanini, 6 - 20124 Milano, Italy.
 * All rights reserved.
 * www.lightstreamer.com
 *
 * This software is the confidential and proprietary information of
 * Weswit s.r.l.
 * You shall not disclose such Confidential Information and shall use it
 * only in accordance with the terms of the license agreement you entered
 * into with Weswit s.r.l.
 */
package com.lightstreamer.client;

import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import java.util.*;

/**
 * Contains all the information related to an update of the field values for an item. 
 * It reports all the new values of the fields. 
* * COMMAND Subscription
* If the involved Subscription is a COMMAND Subscription, then the values for the current * update are meant as relative to the same key.
* Moreover, if the involved Subscription has a two-level behavior enabled, then each update * may be associated with either a first-level or a second-level item. In this case, the reported * fields are always the union of the first-level and second-level fields and each single update * can only change either the first-level or the second-level fields (but for the "command" field, * which is first-level and is always set to "UPDATE" upon a second-level update); note * that the second-level field values are always null until the first second-level update * occurs). When the two-level behavior is enabled, in all methods where a field name has to * be supplied, the following convention should be followed:
*
    *
  • The field name can always be used, both for the first-level and the second-level fields. * In case of name conflict, the first-level field is meant.
  • *
  • The field position can always be used; however, the field positions for the second-level * fields start at the highest position of the first-level field list + 1. If a field schema had * been specified for either first-level or second-level Subscriptions, then client-side knowledge * of the first-level schema length would be required.
  • *
*/ public interface ItemUpdate { /** * Inquiry method that retrieves the name of the item to which this update pertains.
* The name will be null if the related Subscription was initialized using an "Item Group". * @return The name of the item to which this update pertains. * @see Subscription#setItemGroup(String) * @see Subscription#setItems(String[]) */ @Nullable public String getItemName(); /** * Inquiry method that retrieves the position in the "Item List" or "Item Group" of the item to * which this update pertains. * @return The 1-based position of the item to which this update pertains. * @see Subscription#setItemGroup(String) * @see Subscription#setItems(String[]) */ public int getItemPos(); /** * Returns the current value for the specified field * @param fieldName The field name as specified within the "Field List". * @throws IllegalArgumentException if the specified field is not part of the Subscription. * @return The value of the specified field; it can be null in the following cases:
*
    *
  • a null value has been received from the Server, as null is a possible value for a field;
  • *
  • no value has been received for the field yet;
  • *
  • the item is subscribed to with the COMMAND mode and a DELETE command is received * (only the fields used to carry key and command information are valued).
  • *
* @see Subscription#setFields(String[]) */ @Nullable public String getValue(@Nonnull String fieldName); /** * Returns the current value for the specified field * @param fieldPos The 1-based position of the field within the "Field List" or "Field Schema". * @throws IllegalArgumentException if the specified field is not part of the Subscription. * @return The value of the specified field; it can be null in the following cases:
*
    *
  • a null value has been received from the Server, as null is a possible value for a field;
  • *
  • no value has been received for the field yet;
  • *
  • the item is subscribed to with the COMMAND mode and a DELETE command is received * (only the fields used to carry key and command information are valued).
  • *
* @see Subscription#setFieldSchema(String) * @see Subscription#setFields(String[]) */ @Nullable public String getValue(int fieldPos); /** * Inquiry method that asks whether the current update belongs to the item snapshot (which carries * the current item state at the time of Subscription). Snapshot events are sent only if snapshot * information was requested for the items through {@link Subscription#setRequestedSnapshot(String)} * and precede the real time events. Snapshot information take different forms in different * subscription modes and can be spanned across zero, one or several update events. In particular: *
    *
  • if the item is subscribed to with the RAW subscription mode, then no snapshot is * sent by the Server;
  • *
  • if the item is subscribed to with the MERGE subscription mode, then the snapshot consists * of exactly one event, carrying the current value for all fields;
  • *
  • if the item is subscribed to with the DISTINCT subscription mode, then the snapshot * consists of some of the most recent updates; these updates are as many as specified * through {@link Subscription#setRequestedSnapshot(String)}, unless fewer are available;
  • *
  • if the item is subscribed to with the COMMAND subscription mode, then the snapshot * consists of an "ADD" event for each key that is currently present.
  • *
* Note that, in case of two-level behavior, snapshot-related updates for both the first-level item * (which is in COMMAND mode) and any second-level items (which are in MERGE mode) are qualified with * this flag. * @return true if the current update event belongs to the item snapshot; false otherwise. */ public boolean isSnapshot(); /** * Inquiry method that asks whether the value for a field has changed after the reception of the last * update from the Server for an item. If the Subscription mode is COMMAND then the change is meant as * relative to the same key. * @param fieldName The field name as specified within the "Field List". * @throws IllegalArgumentException if the specified field is not part of the Subscription. * @return Unless the Subscription mode is COMMAND, the return value is true in the following cases: *
    *
  • It is the first update for the item;
  • *
  • the new field value is different than the previous field * value received for the item.
  • *
* If the Subscription mode is COMMAND, the return value is true in the following cases: *
    *
  • it is the first update for the involved key value (i.e. the event carries an "ADD" command);
  • *
  • the new field value is different than the previous field value received for the item, * relative to the same key value (the event must carry an "UPDATE" command);
  • *
  • the event carries a "DELETE" command (this applies to all fields other than the field * used to carry key information).
  • *
* In all other cases, the return value is false. * @see Subscription#setFields(String[]) */ public boolean isValueChanged(@Nonnull String fieldName); /** * Inquiry method that asks whether the value for a field has changed after the reception of the last * update from the Server for an item. If the Subscription mode is COMMAND then the change is meant as * relative to the same key. * @param fieldPos The 1-based position of the field within the "Field List" or "Field Schema". * @throws IllegalArgumentException if the specified field is not part of the Subscription. * @return Unless the Subscription mode is COMMAND, the return value is true in the following cases: *
    *
  • It is the first update for the item;
  • *
  • the new field value is different than the previous field * value received for the item.
  • *
* If the Subscription mode is COMMAND, the return value is true in the following cases: *
    *
  • it is the first update for the involved key value (i.e. the event carries an "ADD" command);
  • *
  • the new field value is different than the previous field value received for the item, * relative to the same key value (the event must carry an "UPDATE" command);
  • *
  • the event carries a "DELETE" command (this applies to all fields other than the field * used to carry key information).
  • *
* In all other cases, the return value is false. * @see Subscription#setFieldSchema(String) * @see Subscription#setFields(String[]) */ public boolean isValueChanged(int fieldPos); /** * Inquiry method that gets the difference between the new value and the previous one * as a JSON Patch structure, provided that the Server has used the JSON Patch format * to send this difference, as part of the "delta delivery" mechanism. * This, in turn, requires that:
    *
  • the Data Adapter has explicitly indicated JSON Patch as the privileged type of * compression for this field;
  • *
  • both the previous and new value are suitable for the JSON Patch computation * (i.e. they are valid JSON representations);
  • *
  • the item was subscribed to in MERGE or DISTINCT mode (note that, in case of * two-level behavior, this holds for all fields related with second-level items, * as these items are in MERGE mode);
  • *
  • sending the JSON Patch difference has been evaluated by the Server as more * efficient than sending the full new value.
  • *
* Note that the last condition can be enforced by leveraging the Server's * <jsonpatch_min_length> configuration flag, so that the availability of the * JSON Patch form would only depend on the Client and the Data Adapter. *
When the above conditions are not met, the method just returns null; in this * case, the new value can only be determined through {@link ItemUpdate#getValue}. For instance, * this will always be needed to get the first value received. * * @throws IllegalArgumentException if the specified field is not * part of the Subscription. * * @param fieldName The field name as specified within the "Field List". * * @return A JSON Patch structure representing the difference between * the new value and the previous one, or null if the difference in JSON Patch format * is not available for any reason. * * @see ItemUpdate#getValue */ @Nullable public String getValueAsJSONPatchIfAvailable(String fieldName); /** * Inquiry method that gets the difference between the new value and the previous one * as a JSON Patch structure, provided that the Server has used the JSON Patch format * to send this difference, as part of the "delta delivery" mechanism. * This, in turn, requires that:
    *
  • the Data Adapter has explicitly indicated JSON Patch as the privileged type of * compression for this field;
  • *
  • both the previous and new value are suitable for the JSON Patch computation * (i.e. they are valid JSON representations);
  • *
  • the item was subscribed to in MERGE or DISTINCT mode (note that, in case of * two-level behavior, this holds for all fields related with second-level items, * as these items are in MERGE mode);
  • *
  • sending the JSON Patch difference has been evaluated by the Server as more * efficient than sending the full new value.
  • *
* Note that the last condition can be enforced by leveraging the Server's * <jsonpatch_min_length> configuration flag, so that the availability of the * JSON Patch form would only depend on the Client and the Data Adapter. *
When the above conditions are not met, the method just returns null; in this * case, the new value can only be determined through {@link ItemUpdate#getValue}. For instance, * this will always be needed to get the first value received. * * @throws IllegalArgumentException if the specified field is not * part of the Subscription. * * @param fieldPos The 1-based position of the field within the "Field List" or "Field Schema". * * @return A JSON Patch structure representing the difference between * the new value and the previous one, or null if the difference in JSON Patch format * is not available for any reason. * * @see ItemUpdate#getValue */ @Nullable public String getValueAsJSONPatchIfAvailable(int fieldPos); /** * Returns an immutable Map containing the values for each field changed with the last server update. * The related field name is used as key for the values in the map. * Note that if the Subscription mode of the involved Subscription is COMMAND, then changed fields * are meant as relative to the previous update for the same key. On such tables if a DELETE command * is received, all the fields, excluding the key field, will be present as changed, with null value. * All of this is also true on tables that have the two-level behavior enabled, but in case of * DELETE commands second-level fields will not be iterated. * * @throws IllegalStateException if the Subscription was initialized using a field schema. * * @return An immutable Map containing the values for each field changed with the last server update. * * @see Subscription#setFieldSchema(String) * @see Subscription#setFields(String[]) */ @Nonnull public Map getChangedFields(); /** * Returns an immutable Map containing the values for each field changed with the last server update. * The 1-based field position within the field schema or field list is used as key for the values in the map. * Note that if the Subscription mode of the involved Subscription is COMMAND, then changed fields * are meant as relative to the previous update for the same key. On such tables if a DELETE command * is received, all the fields, excluding the key field, will be present as changed, with null value. * All of this is also true on tables that have the two-level behavior enabled, but in case of * DELETE commands second-level fields will not be iterated. * * @return An immutable Map containing the values for each field changed with the last server update. * * @see Subscription#setFieldSchema(String) * @see Subscription#setFields(String[]) */ @Nonnull public Map getChangedFieldsByPosition(); /** * Returns an immutable Map containing the values for each field in the Subscription. * The related field name is used as key for the values in the map. * * @throws IllegalStateException if the Subscription was initialized using a field schema. * * @return An immutable Map containing the values for each field in the Subscription. * * @see Subscription#setFieldSchema(String) * @see Subscription#setFields(String[]) */ @Nonnull public Map getFields(); /** * Returns an immutable Map containing the values for each field in the Subscription. * The 1-based field position within the field schema or field list is used as key for the values in the map. * * @return An immutable Map containing the values for each field in the Subscription. * * @see Subscription#setFieldSchema(String) * @see Subscription#setFields(String[]) */ @Nonnull public Map getFieldsByPosition(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy