parent
d5e036596b
commit
b72ea08d03
|
@ -413,7 +413,7 @@ public class TrustManager {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (our_nodes.size == 0) {
|
if (our_nodes.size == 0 && module.store.local_registration_id != sid) {
|
||||||
db.identity_meta.update_last_message_undecryptable(identity_id, sid, message.time);
|
db.identity_meta.update_last_message_undecryptable(identity_id, sid, message.time);
|
||||||
trust_manager.bad_message_state_updated(conversation.account, message.from, sid);
|
trust_manager.bad_message_state_updated(conversation.account, message.from, sid);
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,22 +38,47 @@ public class BadMessagesPopulator : Plugins.ConversationItemPopulator, Plugins.C
|
||||||
|
|
||||||
private void init_state() {
|
private void init_state() {
|
||||||
var qry = db.identity_meta.select()
|
var qry = db.identity_meta.select()
|
||||||
.join_with(db.identity, db.identity.id, db.identity_meta.identity_id)
|
.join_with(db.identity, db.identity.id, db.identity_meta.identity_id)
|
||||||
.with(db.identity.account_id, "=", current_conversation.account.id)
|
.with(db.identity.account_id, "=", current_conversation.account.id)
|
||||||
.with(db.identity_meta.address_name, "=", current_conversation.counterpart.to_string())
|
.where("last_message_untrusted is not NULL OR last_message_undecryptable is not NULL");
|
||||||
.where("last_message_untrusted is not NULL OR last_message_undecryptable is not NULL");
|
|
||||||
|
switch (current_conversation.type_) {
|
||||||
|
case Conversation.Type.CHAT:
|
||||||
|
qry.with(db.identity_meta.address_name, "=", current_conversation.counterpart.to_string());
|
||||||
|
break;
|
||||||
|
case Conversation.Type.GROUPCHAT:
|
||||||
|
bool is_private = stream_interactor.get_module(MucManager.IDENTITY).is_private_room(current_conversation.account, current_conversation.counterpart);
|
||||||
|
if (!is_private) return;
|
||||||
|
|
||||||
|
var list = stream_interactor.get_module(MucManager.IDENTITY).get_offline_members(current_conversation.counterpart, current_conversation.account);
|
||||||
|
if (list == null || list.is_empty) return;
|
||||||
|
|
||||||
|
var selection = new StringBuilder();
|
||||||
|
string[] selection_args = {};
|
||||||
|
foreach (Jid jid in list) {
|
||||||
|
if (selection.len == 0) {
|
||||||
|
selection.append(@" ($(db.identity_meta.address_name) = ?");
|
||||||
|
} else {
|
||||||
|
selection.append(@" OR $(db.identity_meta.address_name) = ?");
|
||||||
|
}
|
||||||
|
selection_args += jid.to_string();
|
||||||
|
}
|
||||||
|
selection.append(")");
|
||||||
|
qry.where(selection.str, selection_args);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
foreach (Row row in qry) {
|
foreach (Row row in qry) {
|
||||||
Jid jid = new Jid(row[db.identity_meta.address_name]);
|
Jid jid = new Jid(row[db.identity_meta.address_name]);
|
||||||
if (!db.identity_meta.last_message_untrusted.is_null(row)) {
|
if (!db.identity_meta.last_message_untrusted.is_null(row)) {
|
||||||
DateTime time = new DateTime.from_unix_utc(row[db.identity_meta.last_message_untrusted]);
|
DateTime time = new DateTime.from_unix_utc(row[db.identity_meta.last_message_untrusted]);
|
||||||
var item = new BadMessageItem(plugin, current_conversation.account, jid, time, BadnessType.UNTRUSTED);
|
var item = new BadMessageItem(plugin, current_conversation, jid, time, BadnessType.UNTRUSTED);
|
||||||
bad_items.add(item);
|
bad_items.add(item);
|
||||||
item_collection.insert_item(item);
|
item_collection.insert_item(item);
|
||||||
}
|
}
|
||||||
if (!db.identity_meta.last_message_undecryptable.is_null(row)) {
|
if (!db.identity_meta.last_message_undecryptable.is_null(row)) {
|
||||||
DateTime time = new DateTime.from_unix_utc(row[db.identity_meta.last_message_undecryptable]);
|
DateTime time = new DateTime.from_unix_utc(row[db.identity_meta.last_message_undecryptable]);
|
||||||
var item = new BadMessageItem(plugin, current_conversation.account, jid, time, BadnessType.UNDECRYPTABLE);
|
var item = new BadMessageItem(plugin, current_conversation, jid, time, BadnessType.UNDECRYPTABLE);
|
||||||
bad_items.add(item);
|
bad_items.add(item);
|
||||||
item_collection.insert_item(item);
|
item_collection.insert_item(item);
|
||||||
}
|
}
|
||||||
|
@ -81,14 +106,14 @@ public class BadMessagesPopulator : Plugins.ConversationItemPopulator, Plugins.C
|
||||||
public class BadMessageItem : Plugins.MetaConversationItem {
|
public class BadMessageItem : Plugins.MetaConversationItem {
|
||||||
|
|
||||||
private Plugin plugin;
|
private Plugin plugin;
|
||||||
private Account account;
|
private Conversation conversation;
|
||||||
private DateTime date;
|
private DateTime date;
|
||||||
private Jid problem_jid;
|
private Jid problem_jid;
|
||||||
private BadnessType badness_type;
|
private BadnessType badness_type;
|
||||||
|
|
||||||
public BadMessageItem(Plugin plugin, Account account, Jid jid, DateTime date, BadnessType badness_type) {
|
public BadMessageItem(Plugin plugin, Conversation conversation, Jid jid, DateTime date, BadnessType badness_type) {
|
||||||
this.plugin = plugin;
|
this.plugin = plugin;
|
||||||
this.account = account;
|
this.conversation = conversation;
|
||||||
this.problem_jid = jid;
|
this.problem_jid = jid;
|
||||||
this.date = date;
|
this.date = date;
|
||||||
this.sort_time = date;
|
this.sort_time = date;
|
||||||
|
@ -96,25 +121,35 @@ public class BadMessageItem : Plugins.MetaConversationItem {
|
||||||
}
|
}
|
||||||
|
|
||||||
public override Object? get_widget(Plugins.WidgetType widget_type) {
|
public override Object? get_widget(Plugins.WidgetType widget_type) {
|
||||||
return new BadMessagesWidget(plugin, account, problem_jid, badness_type);
|
return new BadMessagesWidget(plugin, conversation, problem_jid, badness_type);
|
||||||
}
|
}
|
||||||
|
|
||||||
public override Gee.List<Plugins.MessageAction>? get_item_actions(Plugins.WidgetType type) { return null; }
|
public override Gee.List<Plugins.MessageAction>? get_item_actions(Plugins.WidgetType type) { return null; }
|
||||||
}
|
}
|
||||||
|
|
||||||
public class BadMessagesWidget : Box {
|
public class BadMessagesWidget : Box {
|
||||||
public BadMessagesWidget(Plugin plugin, Account account, Jid jid, BadnessType badness_type) {
|
public BadMessagesWidget(Plugin plugin, Conversation conversation, Jid jid, BadnessType badness_type) {
|
||||||
Object(orientation:Orientation.HORIZONTAL, spacing:5);
|
Object(orientation:Orientation.HORIZONTAL, spacing:5);
|
||||||
|
|
||||||
this.halign = Align.CENTER;
|
this.halign = Align.CENTER;
|
||||||
this.visible = true;
|
this.visible = true;
|
||||||
|
|
||||||
var sb = new StringBuilder();
|
var sb = new StringBuilder();
|
||||||
|
string who = "Your contact";
|
||||||
|
if (conversation.type_ == Conversation.Type.GROUPCHAT) {
|
||||||
|
var occupants = plugin.app.stream_interactor.get_module(MucManager.IDENTITY).get_occupants(conversation.counterpart, conversation.account);
|
||||||
|
if (occupants == null) return;
|
||||||
|
foreach (Jid occupant in occupants) {
|
||||||
|
if (jid.equals_bare(plugin.app.stream_interactor.get_module(MucManager.IDENTITY).get_real_jid(occupant, conversation.account))) {
|
||||||
|
who = occupant.resourcepart;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
if (badness_type == BadnessType.UNTRUSTED) {
|
if (badness_type == BadnessType.UNTRUSTED) {
|
||||||
sb.append("Your contact has been using an untrusted device. You won't see messages from devices that you do not trust.");
|
sb.append("%s has been using an untrusted device. You won't see messages from devices that you do not trust.".printf(who));
|
||||||
sb.append(" <a href=\"\">%s</a>".printf("Manage devices"));
|
sb.append(" <a href=\"\">%s</a>".printf("Manage devices"));
|
||||||
} else {
|
} else {
|
||||||
sb.append("Your contact does not trust this device. That means, you might be missing messages.");
|
sb.append("%s does not trust this device. That means, you might be missing messages.".printf(who));
|
||||||
}
|
}
|
||||||
Label label = new Label(sb.str) { margin_start=70, margin_end=70, justify=Justification.CENTER, use_markup=true, selectable=true, wrap=true, wrap_mode=Pango.WrapMode.WORD_CHAR, hexpand=true, visible=true };
|
Label label = new Label(sb.str) { margin_start=70, margin_end=70, justify=Justification.CENTER, use_markup=true, selectable=true, wrap=true, wrap_mode=Pango.WrapMode.WORD_CHAR, hexpand=true, visible=true };
|
||||||
label.get_style_context().add_class("dim-label");
|
label.get_style_context().add_class("dim-label");
|
||||||
|
@ -122,7 +157,7 @@ public class BadMessagesWidget : Box {
|
||||||
|
|
||||||
label.activate_link.connect(() => {
|
label.activate_link.connect(() => {
|
||||||
if (badness_type == BadnessType.UNTRUSTED) {
|
if (badness_type == BadnessType.UNTRUSTED) {
|
||||||
ContactDetailsDialog dialog = new ContactDetailsDialog(plugin, account, jid);
|
ContactDetailsDialog dialog = new ContactDetailsDialog(plugin, conversation.account, jid);
|
||||||
dialog.set_transient_for((Window) get_toplevel());
|
dialog.set_transient_for((Window) get_toplevel());
|
||||||
dialog.present();
|
dialog.present();
|
||||||
}
|
}
|
||||||
|
|
|
@ -139,7 +139,7 @@ public class Database {
|
||||||
ensure_init();
|
ensure_init();
|
||||||
Sqlite.Statement statement;
|
Sqlite.Statement statement;
|
||||||
if (db.prepare_v2(sql, sql.length, out statement) != OK) {
|
if (db.prepare_v2(sql, sql.length, out statement) != OK) {
|
||||||
error("SQLite error: %d - %s", db.errcode(), db.errmsg());
|
error("SQLite error: %d - %s: %s", db.errcode(), db.errmsg(), sql);
|
||||||
}
|
}
|
||||||
return statement;
|
return statement;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue