org.eclipse.leshan.server.observation.ObservationRegistry Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of leshan-all Show documentation
Show all versions of leshan-all Show documentation
A LWM2M client and server based on Californium (CoAP) all in one.
/*******************************************************************************
* Copyright (c) 2013-2015 Sierra Wireless and others.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* and Eclipse Distribution License v1.0 which accompany this distribution.
*
* The Eclipse Public License is available at
* http://www.eclipse.org/legal/epl-v10.html
* and the Eclipse Distribution License is available at
* http://www.eclipse.org/org/documents/edl-v10.html.
*
* Contributors:
* Sierra Wireless - initial API and implementation
*******************************************************************************/
package org.eclipse.leshan.server.observation;
import java.util.Set;
import org.eclipse.leshan.core.observation.Observation;
import org.eclipse.leshan.server.client.Client;
/**
* A registry for keeping track of observed resources implemented by LWM2M Clients.
*
*/
public interface ObservationRegistry {
/**
* Adds an observation of resource(s) to the registry.
*
* @param observation the observation
*/
void addObservation(Observation observation);
/**
* Cancels all active observations of resource(s) implemented by a particular LWM2M Client.
*
* As a consequence the LWM2M Client will stop sending notifications about updated values of resources in scope of
* the canceled observation.
*
* @param client the LWM2M Client to cancel observations for
* @return the number of canceled observations
*/
int cancelObservations(Client client);
/**
* Cancels all active observations for the given resource of a given client.
*
* As a consequence the LWM2M Client will stop sending notifications about updated values of resources in scope of
* the canceled observation.
*
* @param client the LWM2M Client to cancel observation for
* @param resourcepath resource to cancel observation for
* @return the number of canceled observations
*/
int cancelObservations(Client client, String resourcepath);
/**
* Cancels an observation.
*
* As a consequence the LWM2M Client will stop sending notifications about updated values of resources in scope of
* the canceled observation.
*
* @param observation the observation to cancel.
*/
void cancelObservation(Observation observation);
/**
* Get all running observation for a given client
*
* @return an unmodifiable set of observation
*/
Set getObservations(Client client);
void addListener(ObservationRegistryListener listener);
void removeListener(ObservationRegistryListener listener);
}