diff options
author | fiaxh <fiaxh@users.noreply.github.com> | 2019-06-21 19:49:17 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-06-21 19:49:17 +0200 |
commit | 23a298dc4b5645c12f2478d3d82bb20f38374c2c (patch) | |
tree | 812dd718bf4e2c9105c523e569b84fb83f37fe91 /xmpp-vala/src/module/stanza_error.vala | |
parent | 34f9677c4e5384c9b823ce76c3dbeb143a3ff625 (diff) | |
parent | 57a7d165e91cbfa1b2b4c10e42958cdc0854e961 (diff) | |
download | dino-23a298dc4b5645c12f2478d3d82bb20f38374c2c.tar.gz dino-23a298dc4b5645c12f2478d3d82bb20f38374c2c.zip |
Merge pull request #579 from hrxi/pr_errors
Add a couple of error primitives for easier error handling
Diffstat (limited to 'xmpp-vala/src/module/stanza_error.vala')
-rw-r--r-- | xmpp-vala/src/module/stanza_error.vala | 43 |
1 files changed, 35 insertions, 8 deletions
diff --git a/xmpp-vala/src/module/stanza_error.vala b/xmpp-vala/src/module/stanza_error.vala index c45ff4e3..651e8d2b 100644 --- a/xmpp-vala/src/module/stanza_error.vala +++ b/xmpp-vala/src/module/stanza_error.vala @@ -2,6 +2,8 @@ using Gee; namespace Xmpp { + private const string ERROR_NS_URI = "urn:ietf:params:xml:ns:xmpp-stanzas"; + public class ErrorStanza { public const string CONDITION_BAD_REQUEST = "bad-request"; public const string CONDITION_CONFLICT = "conflict"; @@ -37,14 +39,14 @@ namespace Xmpp { } public string? text { - get { return error_node.get_deep_string_content("urn:ietf:params:xml:ns:xmpp-stanzas:text"); } + get { return error_node.get_deep_string_content(ERROR_NS_URI + ":text"); } } public string condition { get { Gee.List<StanzaNode> subnodes = error_node.sub_nodes; foreach (StanzaNode subnode in subnodes) { // TODO get subnode by ns - if (subnode.ns_uri == "urn:ietf:params:xml:ns:xmpp-stanzas") { + if (subnode.ns_uri == ERROR_NS_URI) { return subnode.name; } } @@ -52,20 +54,45 @@ namespace Xmpp { } } - public string? original_id { - get { return stanza.get_attribute("id"); } - } - public string type_ { get { return error_node.get_attribute("type"); } } - public StanzaNode stanza; public StanzaNode error_node; public ErrorStanza.from_stanza(StanzaNode stanza) { - this.stanza = stanza; error_node = stanza.get_subnode("error"); } + + public ErrorStanza.build(string type, string condition, string? human_readable, StanzaNode? application_condition) { + error_node = new StanzaNode.build("error") + .put_attribute("type", type) + .put_node(new StanzaNode.build(condition, ERROR_NS_URI).add_self_xmlns()); + if (application_condition != null) { + error_node.put_node(application_condition); + } + if (human_readable != null) { + error_node.put_node(new StanzaNode.build("text", ERROR_NS_URI) + .add_self_xmlns() + .put_attribute("xml:lang", "en") + .put_node(new StanzaNode.text(text)) + ); + } + } + public ErrorStanza.bad_request(string? human_readable = null) { + this.build(TYPE_MODIFY, CONDITION_BAD_REQUEST, human_readable, null); + } + public ErrorStanza.feature_not_implemented(StanzaNode? application_condition = null) { + this.build(TYPE_MODIFY, CONDITION_FEATURE_NOT_IMPLEMENTED, null, application_condition); + } + public ErrorStanza.item_not_found(StanzaNode? application_condition = null) { + this.build(TYPE_CANCEL, CONDITION_ITEM_NOT_FOUND, null, application_condition); + } + public ErrorStanza.not_acceptable(string? human_readable = null) { + this.build(TYPE_MODIFY, CONDITION_NOT_ACCEPTABLE, human_readable, null); + } + public ErrorStanza.service_unavailable() { + this.build(TYPE_CANCEL, CONDITION_SERVICE_UNAVAILABLE, null, null); + } } } |