OSID Logo
OSID Specifications
mapping package
Version 3.0.0
Release Candidate Preview
Interfaceosid.mapping.LocationNotificationSession
Implementsosid.OsidSession
Description

This session defines methods to receive notifications on adds/changes to Location objects in this Map. This also includes existing locations that may appear or disappear due to changes in the Location hierarchy, This session is intended for consumers needing to synchronize their state with this service without the use of polling. Notifications are cancelled when this session is closed.

The two views defined in this session correspond to the views in the LocationLookupSession.

MethodgetMapId
Description

Gets the Map Id associated with this session.

Returnosid.id.Idthe Map Id associated with this session
CompliancemandatoryThis method must be implemented.
MethodgetMap
Description

Gets the Map associated with this session.

Returnosid.mapping.Mapthe map
ErrorsOPERATION_FAILEDunable to complete request
PERMISSION_DENIEDauthorization failure
CompliancemandatoryThis method must be implemented.
MethodcanRegisterForLocationNotifications
Description

Tests if this user can register for Location notifications. A return of true does not guarantee successful authorization. A return of false indicates that it is known all methods in this session will result in a PERMISSION_DENIED. This is intended as a hint to an application that may opt not to offer notification operations.

Returnboolean false if notification methods are not authorized, true otherwise
CompliancemandatoryThis method must be implemented.
MethoduseFederatedMapView
Description

Federates the view for methods in this session. A federated view will include locations in maps which are children of this map in the map hierarchy.

CompliancemandatoryThis method is must be implemented.
MethoduseIsolatedMapView
Description

Isolates the view for methods in this session. An isolated view restricts notifications to this map only.

CompliancemandatoryThis method is must be implemented.
MethodreliableLocationNotifications
Description

Reliable notifications are desired. In reliable mode, notifications are to be acknowledged using acknowledgeLocationNotification() .

CompliancemandatoryThis method is must be implemented.
MethodunreliableLocationNotifications
Description

Unreliable notifications are desired. In unreliable mode, notifications do not need to be acknowledged.

CompliancemandatoryThis method is must be implemented.
MethodacknowledgeLocationNotification
Description

Acknowledge a location notification.

Parametersosid.id.IdnotificationIdthe Id of the notification
ErrorsOPERATION_FAILEDunable to complete request
PERMISSION_DENIEDauthorization failure
CompliancemandatoryThis method must be implemented.
MethodregisterForNewLocations
Description

Register for notifications of new locations. LocationReceiver.newLocations() is invoked when a new Location appears in this map.

ErrorsOPERATION_FAILEDunable to complete request
PERMISSION_DENIEDauthorization failure
CompliancemandatoryThis method must be implemented.
MethodregisterForChangedLocations
Description

Registers for notification of updated locations. LocationReceiver.changedLocations() is invoked when a location in this map is changed.

ErrorsOPERATION_FAILEDunable to complete request
PERMISSION_DENIEDauthorization failure
CompliancemandatoryThis method must be implemented.
MethodregisterForChangedLocation
Description

Registers for notification of an updated location. LocationReceiver.changedLocations() is invoked when the specified location in this map is changed.

Parametersosid.id.IdlocationIdthe Id of the Location to monitor
ErrorsNULL_ARGUMENT locationId is null
OPERATION_FAILEDunable to complete request
PERMISSION_DENIEDauthorization failure
CompliancemandatoryThis method must be implemented.
MethodregisterForDeletedLocations
Description

Registers for notification of deleted locations. LocationReceiver.deletedLocations() is invoked when a location is deleted or removed from this map.

ErrorsOPERATION_FAILEDunable to complete request
PERMISSION_DENIEDauthorization failure
CompliancemandatoryThis method must be implemented.
MethodregisterForDeletedLocation
Description

Registers for notification of a deleted location. LocationReceiver.deletedLocations() is invoked when the specified location is deleted or removed from this map.

Parametersosid.id.IdlocationIdthe Id of the Location to monitor
ErrorsNULL_ARGUMENT locationId is null
OPERATION_FAILEDunable to complete request
PERMISSION_DENIEDauthorization failure
CompliancemandatoryThis method must be implemented.
MethodregisterForChangedLocationHierarchy
Description

Registers for notification of an updated location hierarchy structure. LocationReceiver.changedChildOfLocations() is invoked when a node experiences a change in its children.

ErrorsOPERATION_FAILEDunable to complete request
PERMISSION_DENIEDauthorization failure
CompliancemandatoryThis method must be implemented.
MethodregisterForChangedLocationHierarchyForAncestors
Description

Registers for notification of an updated location hierarchy structure. LocationReceiver.changedChildOfLocations() is invoked when the specified node or any of its ancestors experiences a change in its children.

Parametersosid.id.IdlocationIdthe Id of the Location node to monitor
ErrorsNULL_ARGUMENT locationId is null
OPERATION_FAILEDunable to complete request
PERMISSION_DENIEDauthorization failure
CompliancemandatoryThis method must be implemented.
MethodregisterForChangedLocationHierarchyForDescendants
Description

Registers for notification of an updated location hierarchy structure. LocationReceiver.changedChildOfLocations() is invoked when the specified node or any of its descendants experiences a change in its children.

Parametersosid.id.IdlocationIdthe Id of the Location node to monitor
ErrorsNULL_ARGUMENT locationId is null
OPERATION_FAILEDunable to complete request
PERMISSION_DENIEDauthorization failure
CompliancemandatoryThis method must be implemented.