Interface AssetContentNotificationSession
- All Superinterfaces:
AutoCloseable, Closeable, OsidSession, OsidSession
This session defines methods to receive notifications on adds/changes
to AssetContents in this Repository . This also includes
existing asset contents that may appear or disappear due to changes in the
Repository hier archy, 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
AssetContentLookupSession .
-
Method Summary
Modifier and TypeMethodDescriptionvoidacknowledgeAssetContentNotification(Id notificationId) Acknowledge an asset content notification.booleanTests if this user can register forAssetContentnotifications.Gets theRepositoryassociated with this session.Gets theRepositoryIdassociated with this session.voidregisterForChangedAssetContent(Id assetContentId) Register for notifications of an updated asset content.voidRegister for notifications of updated asset contents.voidRegister for notifications of updated asset contents for the given asset..voidregisterForDeletedAssetContent(Id assetContentId) Registers for notification of a deleted asset content.voidRegisters for notification of deleted asset contents.voidRegister for notifications of deleted asset contents for the given asset..voidRegister for notifications of new asset contents.voidregisterForNewAssetContentsForAsset(Id assetId) Register for notifications of new asset contents for the given asset..voidReliable notifications are desired.voidUnreliable notifications are desired.voidFederates the view for methods in this session.voidIsolates the view for methods in this session.Methods inherited from interface OsidSession
closeMethods inherited from interface OsidSession
getAuthenticatedAgent, getAuthenticatedAgentId, getClockRate, getDate, getEffectiveAgent, getEffectiveAgentId, getFormatType, getLocale, isAuthenticated, startTransaction, supportsTransactionsModifier and TypeMethodDescriptionGets the agent authenticated to this session.Gets theIdof the agent authenticated to this session.Gets the rate of the service clock.getDate()Gets the service date which may be the current date or the effective date in which this session exists.Gets the effective agent in use by this session.Gets theIdof the effective agent in use by this session.Gets theDisplayTextformatTypepreference in effect for this session.Gets the locale indicating the localization preferences in effect for this session.booleanTests if an agent is authenticated to this session.Starts a new transaction for this sesson.booleanTests for the availability of transactions.
-
Method Details
-
getRepositoryId
Id getRepositoryId()Gets theRepositoryIdassociated with this session.- Returns:
- the
Repository Idassociated with this session - Compliance:
mandatory- This method must be implemented.
-
getRepository
Gets theRepositoryassociated with this session.- Returns:
- the repository
- Throws:
OperationFailedException- unable to complete requestPermissionDeniedException- authorization failure- Compliance:
mandatory- This method must be implemented.
-
canRegisterForAssetContentNotifications
boolean canRegisterForAssetContentNotifications()Tests if this user can register forAssetContentnotifications. 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 aPERMISSION_DENIED.This is intended as a hint to an application that may opt not to offer notification operations.- Returns:
falseif notification methods are not authorized,trueotherwise- Compliance:
mandatory- This method must be implemented.
-
useFederatedRepositoryView
void useFederatedRepositoryView()Federates the view for methods in this session. A federated view will include asset contents in repositories which are children of this repository in the repository hierarchy.- Compliance:
mandatory- This method is must be implemented.
-
useIsolatedRepositoryView
void useIsolatedRepositoryView()Isolates the view for methods in this session. An isolated view restricts notifications to this repository only.- Compliance:
mandatory- This method is must be implemented.
-
reliableAssetContentNotifications
void reliableAssetContentNotifications()Reliable notifications are desired. In reliable mode, notifications are to be acknowledged usingacknowledgeAssetContentNotification().- Compliance:
mandatory- This method is must be implemented.
-
unreliableAssetContentNotifications
void unreliableAssetContentNotifications()Unreliable notifications are desired. In unreliable mode, notifications do not need to be acknowledged.- Compliance:
mandatory- This method is must be implemented.
-
acknowledgeAssetContentNotification
void acknowledgeAssetContentNotification(Id notificationId) throws OperationFailedException, PermissionDeniedException Acknowledge an asset content notification.- Parameters:
notificationId- theIdof the notification- Throws:
OperationFailedException- unable to complete requestPermissionDeniedException- authorization failure- Compliance:
mandatory- This method must be implemented.
-
registerForNewAssetContents
Register for notifications of new asset contents.AssetContentReceiver.newAssetContents()is invoked when a newAssetContentappears in this repository.- Throws:
OperationFailedException- unable to complete requestPermissionDeniedException- authorization failure- Compliance:
mandatory- This method must be implemented.
-
registerForNewAssetContentsForAsset
void registerForNewAssetContentsForAsset(Id assetId) throws OperationFailedException, PermissionDeniedException Register for notifications of new asset contents for the given asset..AssetContentReceiver.newAssetContents()is invoked when a newAssetContentappears in this repository.- Parameters:
assetId- theIdof theAssetto monitor- Throws:
NullArgumentException-assetIdisnullOperationFailedException- unable to complete requestPermissionDeniedException- authorization failure- Compliance:
mandatory- This method must be implemented.
-
registerForChangedAssetContents
Register for notifications of updated asset contents.AssetContentReceiver.changedAssetContents()is invoked when anAssetContentin this repository is changed.- Throws:
OperationFailedException- unable to complete requestPermissionDeniedException- authorization failure- Compliance:
mandatory- This method must be implemented.
-
registerForChhangedAssetContentsForAsset
void registerForChhangedAssetContentsForAsset(Id assetId) throws OperationFailedException, PermissionDeniedException Register for notifications of updated asset contents for the given asset..AssetContentReceiver.changedAssetContents()is invoked when a newAssetContentin this repository is changed.- Parameters:
assetId- theIdof theAssetto monitor- Throws:
NullArgumentException-assetIdisnullOperationFailedException- unable to complete requestPermissionDeniedException- authorization failure- Compliance:
mandatory- This method must be implemented.
-
registerForChangedAssetContent
void registerForChangedAssetContent(Id assetContentId) throws OperationFailedException, PermissionDeniedException Register for notifications of an updated asset content.AssetContentReceiver.changedAssetContents()is invoked when the specifiedAssetContentin this repository is changed.- Parameters:
assetContentId- theIdof theAssetContentto monitor- Throws:
NullArgumentException-assetContentIdisnullOperationFailedException- unable to complete requestPermissionDeniedException- authorization failure- Compliance:
mandatory- This method must be implemented.
-
registerForDeletedAssetContents
Registers for notification of deleted asset contents.AssetContentReceiver.deletedAssetContents()is invoked when an asset content is deleted or removed from this repository.- Throws:
OperationFailedException- unable to complete requestPermissionDeniedException- authorization failure- Compliance:
mandatory- This method must be implemented.
-
registerForDeletedAssetContentsForAsset
void registerForDeletedAssetContentsForAsset(Id assetId) throws OperationFailedException, PermissionDeniedException Register for notifications of deleted asset contents for the given asset..AssetContentReceiver.deletedAssetContents()is invoked when anAssetContentin this repository is deleted or removed.- Parameters:
assetId- theIdof theAssetto monitor- Throws:
NullArgumentException-assetIdisnullOperationFailedException- unable to complete requestPermissionDeniedException- authorization failure- Compliance:
mandatory- This method must be implemented.
-
registerForDeletedAssetContent
void registerForDeletedAssetContent(Id assetContentId) throws OperationFailedException, PermissionDeniedException Registers for notification of a deleted asset content.AssetContentReceiver.deletedAssetContents()is invoked when the specified asset content is deleted or removed from this repository.- Parameters:
assetContentId- theIdof theAssetContentto monitor- Throws:
NullArgumentException-assetContentIdisnullOperationFailedException- unable to complete requestPermissionDeniedException- authorization failure- Compliance:
mandatory- This method must be implemented.
-