2017-03-02 14:37:32 +00:00
|
|
|
using Gee;
|
2020-03-29 18:23:47 +00:00
|
|
|
using Qlite;
|
2017-03-02 14:37:32 +00:00
|
|
|
using Xmpp;
|
2020-03-29 18:23:47 +00:00
|
|
|
using Xmpp.Xep.ServiceDiscovery;
|
2017-03-02 14:37:32 +00:00
|
|
|
|
|
|
|
namespace Dino {
|
|
|
|
|
|
|
|
public class EntityCapabilitiesStorage : Xep.EntityCapabilities.Storage, Object {
|
|
|
|
|
|
|
|
private Database db;
|
2020-03-29 18:23:47 +00:00
|
|
|
private HashMap<string, Gee.List<string>> features_cache = new HashMap<string, Gee.List<string>>();
|
|
|
|
private HashMap<string, Identity> identity_cache = new HashMap<string, Identity>();
|
2017-03-02 14:37:32 +00:00
|
|
|
|
|
|
|
public EntityCapabilitiesStorage(Database db) {
|
|
|
|
this.db = db;
|
|
|
|
}
|
|
|
|
|
2017-08-02 15:29:55 +00:00
|
|
|
public void store_features(string entity, Gee.List<string> features) {
|
2020-04-23 11:53:44 +00:00
|
|
|
if (features_cache.contains(entity)) return;
|
|
|
|
|
2020-03-29 18:23:47 +00:00
|
|
|
foreach (string feature in features) {
|
|
|
|
db.entity_feature.insert()
|
|
|
|
.value(db.entity_feature.entity, entity)
|
|
|
|
.value(db.entity_feature.feature, feature)
|
|
|
|
.perform();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-04-21 14:25:21 +00:00
|
|
|
public void store_identities(string entity, Gee.Set<Identity> identities) {
|
2020-03-29 18:23:47 +00:00
|
|
|
foreach (Identity identity in identities) {
|
|
|
|
if (identity.category == Identity.CATEGORY_CLIENT) {
|
|
|
|
db.entity_identity.insert()
|
|
|
|
.value(db.entity_identity.entity, entity)
|
|
|
|
.value(db.entity_identity.category, identity.category)
|
|
|
|
.value(db.entity_identity.type, identity.type_)
|
|
|
|
.value(db.entity_identity.name, identity.name)
|
|
|
|
.perform();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
2017-03-02 14:37:32 +00:00
|
|
|
}
|
|
|
|
|
2018-01-10 14:12:54 +00:00
|
|
|
public Gee.List<string> get_features(string entity) {
|
2020-03-29 18:23:47 +00:00
|
|
|
Gee.List<string>? features = features_cache[entity];
|
|
|
|
if (features != null) {
|
|
|
|
return features;
|
|
|
|
}
|
|
|
|
|
|
|
|
features = new ArrayList<string>();
|
|
|
|
foreach (Row row in db.entity_feature.select({db.entity_feature.feature}).with(db.entity_feature.entity, "=", entity)) {
|
|
|
|
features.add(row[db.entity_feature.feature]);
|
|
|
|
}
|
|
|
|
features_cache[entity] = features;
|
|
|
|
return features;
|
|
|
|
}
|
|
|
|
|
|
|
|
public Identity? get_identities(string entity) {
|
|
|
|
Identity? identity = identity_cache[entity];
|
|
|
|
if (identity != null) {
|
|
|
|
return identity;
|
|
|
|
}
|
|
|
|
|
|
|
|
RowOption row = db.entity_identity.select().with(db.entity_identity.entity, "=", entity).single().row();
|
|
|
|
if (row.is_present()) {
|
|
|
|
identity = new Identity(row[db.entity_identity.category], row[db.entity_identity.type], row[db.entity_identity.name]);
|
|
|
|
}
|
|
|
|
identity_cache[entity] = identity;
|
|
|
|
return identity;
|
2017-03-02 14:37:32 +00:00
|
|
|
}
|
|
|
|
}
|
2017-08-02 15:29:55 +00:00
|
|
|
}
|