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

org.directwebremoting.datasync.StoreProvider Maven / Gradle / Ivy

Go to download

DWR is easy Ajax for Java. It makes it simple to call Java code directly from Javascript. It gets rid of almost all the boiler plate code between the web browser and your Java code.

The newest version!
/*
 * Copyright 2005 Joe Walker
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.directwebremoting.datasync;

import java.util.List;

import org.directwebremoting.io.Item;
import org.directwebremoting.io.ItemUpdate;
import org.directwebremoting.io.MatchedItems;
import org.directwebremoting.io.RawData;
import org.directwebremoting.io.StoreChangeListener;
import org.directwebremoting.io.StoreRegion;

/**
 * A StoreProvider is something like a {@link java.util.Map} where the API
 * revolves around getting blocks of entries rather than individual entries and
 * it gives you the ability to subscribe to those blocks of data to ask for
 * change updates. These are the types of changes that you would expect from an
 * interface designed for remote access.
 * 

Implementing the {@link StoreProvider} interface is likely to be hard for * many applications. You are advised to begin by extending the * {@link AbstractStoreProvider} helper class. *

In place of {@link java.util.Map.Entry}, StoreProvider uses * {@link org.directwebremoting.io.Item}s as it's way to connect objects with * their primary keys. * @author Joe Walker [joe at getahead dot ltd dot uk] */ public interface StoreProvider { /** * Similar to {@link java.util.Map#get} in fetching items from a Store. * @param itemId The ID of the item to fetch * @return The matched item, or null if it was not found */ Item viewItem(String itemId); /** * Similar to {@link java.util.Map#get} in fetching items from a Store, and * request to stay updated to changes in the region. * @param itemId The ID of the item to fetch * @param listener The listener to be notified of changes * @return The matched item, or null if it was not found */ Item viewItem(String itemId, StoreChangeListener listener); /** * Extract the data referred to by the given region. * @param region A set of filter and sort criteria to restrict the fetched data */ MatchedItems viewRegion(StoreRegion region); /** * Extract the data referred to by the given region, and request to stay * updated to changes in the region. * @param region A set of filter and sort criteria to restrict the fetched data * @param listener The listener to be notified of changes * @return Data that matches the filtering specified in the region. */ MatchedItems viewRegion(StoreRegion region, StoreChangeListener listener); /** * Remove the declaration of interest previously expressed. * @param listener The listener that should no longer be notified */ void unsubscribe(StoreChangeListener listener); /** * Similar to {@link java.util.Map#put} in adding items to a Store. * A value of null is equivalent to removing the item from the store. * Part of the function of put is to convert the data stored in * {@link RawData} into alterations to data in the store. This boiler plate * code is implemented in {@link AbstractStoreProvider}. *

See notes on {@link org.directwebremoting.io.Item#getItemId} * @param itemId The key (or some mapping) to it. * @param rawData Data from the web to be converted and added to the store */ void put(String itemId, RawData rawData); /** * Similar to {@link java.util.Map#put} in adding items to a Store. * A value of null is equivalent to removing the item from the store. * @param itemId The key (or some mapping) to it. * @param value The new object to be added to the store */ void put(String itemId, T value); /** * Make a series of updates to items in the store. * @param changes A list of item IDs along with the attributes to change * and the values to change to */ void update(List changes); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy