aboutsummaryrefslogtreecommitdiff
path: root/xmpp-vala/src/module/iq/module.vala
diff options
context:
space:
mode:
authorMarvin W <git@larma.de>2023-01-31 15:13:12 +0100
committerMarvin W <git@larma.de>2023-02-07 10:50:45 +0100
commitd76e12b215eb62e4eda5a0f92fbf5c1bd7c1848e (patch)
tree8037cd613ccea827d8d1895b82a2c0dd65a75a14 /xmpp-vala/src/module/iq/module.vala
parent18321ed15ce782ff5d1f24de9f2fb459d714d125 (diff)
downloaddino-d76e12b215eb62e4eda5a0f92fbf5c1bd7c1848e.tar.gz
dino-d76e12b215eb62e4eda5a0f92fbf5c1bd7c1848e.zip
Add priority for and allow cancellation of outgoing stanzas
Diffstat (limited to 'xmpp-vala/src/module/iq/module.vala')
-rw-r--r--xmpp-vala/src/module/iq/module.vala11
1 files changed, 7 insertions, 4 deletions
diff --git a/xmpp-vala/src/module/iq/module.vala b/xmpp-vala/src/module/iq/module.vala
index 17cd3f0d..172aa9b1 100644
--- a/xmpp-vala/src/module/iq/module.vala
+++ b/xmpp-vala/src/module/iq/module.vala
@@ -12,22 +12,25 @@ namespace Xmpp.Iq {
private HashMap<string, ResponseListener> responseListeners = new HashMap<string, ResponseListener>();
private HashMap<string, ArrayList<Handler>> namespaceRegistrants = new HashMap<string, ArrayList<Handler>>();
- public async Iq.Stanza send_iq_async(XmppStream stream, Iq.Stanza iq) {
+ public async Iq.Stanza send_iq_async(XmppStream stream, Iq.Stanza iq, int io_priority = Priority.DEFAULT, Cancellable? cancellable = null) throws IOError {
assert(iq.type_ == Iq.Stanza.TYPE_GET || iq.type_ == Iq.Stanza.TYPE_SET);
+ preprocess_outgoing_iq_set_get(stream, iq);
Iq.Stanza? return_stanza = null;
- send_iq(stream, iq, (_, result_iq) => {
+ responseListeners[iq.id] = new ResponseListener((_, result_iq) => {
return_stanza = result_iq;
Idle.add(send_iq_async.callback);
});
+ stream.write_async(iq.stanza, io_priority, cancellable);
yield;
+ cancellable.set_error_if_cancelled();
return return_stanza;
}
public delegate void OnResult(XmppStream stream, Iq.Stanza iq);
- public void send_iq(XmppStream stream, Iq.Stanza iq, owned OnResult? listener = null) {
+ public void send_iq(XmppStream stream, Iq.Stanza iq, owned OnResult? listener = null, int io_priority = Priority.DEFAULT) {
preprocess_outgoing_iq_set_get(stream, iq);
- stream.write(iq.stanza);
+ stream.write(iq.stanza, io_priority);
if (listener != null) {
responseListeners[iq.id] = new ResponseListener((owned) listener);
}