Methods
AddRequest | (o: Request, a{sv}: Properties) | → | nothing | |
RemoveRequest | (o: Request, s: Error, s: Message) | → | nothing |
Description
This interface can be implemented by a Handler to be notified about requests for channels that it is likely to be asked to handle.
Methods
AddRequest (o: Request, a{sv}: Properties) → nothing
Parameters
- Request — o
- Properties — a{sv} (Qualified_Property_Value_Map)
Rationale:
Some of the properties of the ChannelRequest. To avoid race conditions, this dictionary MUST NOT include properties whose values could subsequently change. It SHOULD include as many properties as possible, given that constraint.
In particular, the properties Requests, UserActionTime and Account MUST be included.
Called by the ChannelDispatcher to indicate that channels have been requested, and that if the request is successful, they will probably be handled by this Handler. The ChannelDispatcher SHOULD only call this method on one handler per request.
Rationale:
If the request succeeds and is given to the expected Handler, the Requests_Satisfied parameter to HandleChannels can be used to match the channel to a previous AddRequest call.
Rationale:
If the request fails, the expected handler is notified by the channel dispatcher calling its RemoveRequest method.
Rationale:
The channel dispatcher SHOULD remember which handler was notified, and if the channel request succeeds, it SHOULD dispatch the channels to the expected handler, unless the channels do not match that handler's HandlerChannelFilter. If the channels are not dispatched to the expected handler, the handler that was expected is notified by the channel dispatcher calling its RemoveRequest method with the NotYours error.
Rationale:
Handlers SHOULD NOT return an error from this method; errors returned from this method SHOULD NOT alter the channel dispatcher's behaviour.
Rationale:
RemoveRequest (o: Request, s: Error, s: Message) → nothing
Parameters
- Request — o
- Error — s (DBus_Error_Name)
- Message — s
The name of the D-Bus error with which the request failed.
If this is org.freedesktop.Telepathy.Error.NotYours
,
this indicates that the request succeeded, but all the resulting
channels were given to some other handler.
Called by the ChannelDispatcher to indicate that a request previously passed to AddRequest has failed and should be disregarded.
Handlers SHOULD NOT return an error from this method; errors returned from this method SHOULD NOT alter the channel dispatcher's behaviour.