aboutsummaryrefslogtreecommitdiff
path: root/client/src/entity/jid.vala
diff options
context:
space:
mode:
authorfiaxh <git@mx.ax.lt>2017-03-02 15:37:32 +0100
committerfiaxh <git@mx.ax.lt>2017-03-02 15:37:32 +0100
commit56bc45ce4d07a7a9a415e9dc8ad2f7c3f3c9e48d (patch)
tree0bd0c2c80cb81179c26282fb3fbe8fd22983f40b /client/src/entity/jid.vala
downloaddino-56bc45ce4d07a7a9a415e9dc8ad2f7c3f3c9e48d.tar.gz
dino-56bc45ce4d07a7a9a415e9dc8ad2f7c3f3c9e48d.zip
Initial commit
Diffstat (limited to 'client/src/entity/jid.vala')
-rw-r--r--client/src/entity/jid.vala91
1 files changed, 91 insertions, 0 deletions
diff --git a/client/src/entity/jid.vala b/client/src/entity/jid.vala
new file mode 100644
index 00000000..aab31b98
--- /dev/null
+++ b/client/src/entity/jid.vala
@@ -0,0 +1,91 @@
+public class Dino.Entities.Jid : Object {
+ public string? localpart { get; set; }
+ public string domainpart { get; set; }
+ public string? resourcepart { get; set; }
+
+ public Jid? bare_jid {
+ owned get { return new Jid(@"$localpart@$domainpart"); }
+ }
+
+ private string jid { get; private set; }
+
+ public Jid(string jid) {
+ Jid? parsed = Jid.parse(jid);
+ string? localpart = parsed != null ? parsed.localpart : null;
+ string domainpart = parsed != null ? parsed.domainpart : jid;
+ string? resourcepart = parsed != null ? parsed.resourcepart : null;
+ Jid.components(localpart, domainpart, resourcepart);
+ }
+
+ public Jid.with_resource(string bare_jid, string resource) {
+ Jid? parsed = Jid.parse(bare_jid);
+ print(parsed.localpart + "\n");
+ print(parsed.domainpart + "\n");
+ Jid.components(parsed.localpart, parsed.domainpart, resourcepart);
+ }
+
+ public Jid.components(string? localpart, string domainpart, string? resourcepart) {
+ string jid = domainpart;
+ if (localpart != null) {
+ jid = @"$localpart@$jid";
+ }
+ if (resourcepart != null) {
+ jid = @"$jid/$resourcepart";
+ }
+ this.jid = jid;
+ this.localpart = localpart;
+ this.domainpart = domainpart;
+ this.resourcepart = resourcepart;
+ }
+
+ public static Jid? parse(string jid) {
+ int slash_index = jid.index_of("/");
+ string resourcepart = slash_index == -1 ? null : jid.slice(slash_index + 1, jid.length);
+ string bare_jid = slash_index == -1 ? jid : jid.slice(0, slash_index);
+ int at_index = bare_jid.index_of("@");
+ string localpart = at_index == -1 ? null : bare_jid.slice(0, at_index);
+ string domainpart = at_index == -1 ? bare_jid : bare_jid.slice(at_index + 1, bare_jid.length);
+
+ if (domainpart == "") return null;
+ if (slash_index != -1 && resourcepart == "") return null;
+ if (at_index != -1 && localpart == "") return null;
+
+ return new Jid.components(localpart, domainpart, resourcepart);
+ }
+
+ public bool is_bare() {
+ return localpart != null && resourcepart == null;
+ }
+
+ public bool is_full() {
+ return localpart != null && resourcepart != null;
+ }
+
+ public string to_string() {
+ return jid;
+ }
+
+ public bool equals_bare(Jid jid) {
+ return equals_bare_func(this, jid);
+ }
+
+ public bool equals(Jid jid) {
+ return equals_func(this, jid);
+ }
+
+ public static new bool equals_bare_func(Jid jid1, Jid jid2) {
+ return jid1.bare_jid.to_string() == jid2.bare_jid.to_string();
+ }
+
+ public static bool equals_func(Jid jid1, Jid jid2) {
+ return jid1.to_string() == jid2.to_string();
+ }
+
+ public static new uint hash_bare_func(Jid jid) {
+ return jid.bare_jid.to_string().hash();
+ }
+
+ public static new uint hash_func(Jid jid) {
+ return jid.to_string().hash();
+ }
+}