Filter push updates for CRM entries on all linked contacts, not just primary

This commit is contained in:
nathangray 2020-09-04 09:37:07 -06:00
parent e49529f271
commit d6eade2f75
3 changed files with 77 additions and 15 deletions

View File

@ -30,6 +30,7 @@ require("jqueryui");
require("../jsapi/egw_global"); require("../jsapi/egw_global");
require("../etemplate/et2_types"); require("../etemplate/et2_types");
var egw_app_1 = require("../../api/js/jsapi/egw_app"); var egw_app_1 = require("../../api/js/jsapi/egw_app");
var et2_extension_nextmatch_1 = require("../../api/js/etemplate/et2_extension_nextmatch");
/** /**
* UI for Addressbook CRM view * UI for Addressbook CRM view
* *
@ -51,7 +52,7 @@ var CRMView = /** @class */ (function (_super) {
_this.contact_ids = []; _this.contact_ids = [];
// Private js for the list // Private js for the list
_this.app_obj = null; _this.app_obj = null;
// Push data key(s) to check for our contact ID // Push data key(s) to check for our contact ID in the entry's ACL data
_this.push_contact_ids = ["contact_id"]; _this.push_contact_ids = ["contact_id"];
return _this; return _this;
} }
@ -144,25 +145,46 @@ var CRMView = /** @class */ (function (_super) {
* @param {number} pushData.account_id User that caused the notification * @param {number} pushData.account_id User that caused the notification
*/ */
CRMView.prototype.push = function (pushData) { CRMView.prototype.push = function (pushData) {
var _this = this;
if (pushData.app !== this.app_obj.appname || !this.nm) if (pushData.app !== this.app_obj.appname || !this.nm)
return; return;
// If we know about it and it's an update, just update. // If we know about it and it's an update, just update.
// This must be before all ACL checks, as contact might have changed and entry needs to be removed // This must be before all ACL checks, as contact might have changed and entry needs to be removed
// (server responds then with null / no entry causing the entry to disapear) // (server responds then with null / no entry causing the entry to disappear)
if (pushData.type !== "add" && this.egw.dataHasUID(this.uid(pushData))) { if (pushData.type !== "add" && this.egw.dataHasUID(this.uid(pushData))) {
return this.nm.refresh(pushData.id, pushData.type); // Check to see if it's in OUR nextmatch
var uid_1 = this.uid(pushData);
var known = Object.values(this.nm.controller._indexMap).filter(function (row) { return row.uid == uid_1; });
var type = pushData.type;
if (known && known.length > 0) {
if (!this.id_check(pushData.acl)) {
// Was ours, not anymore, and we know this now - no server needed. Just remove from nm.
type = et2_extension_nextmatch_1.et2_nextmatch.DELETE;
}
return this.nm.refresh(pushData.id, type);
}
} }
if (this.id_check(pushData.acl)) {
return this._app_obj_push(pushData);
}
};
/**
* Check to see if the given entry is "ours"
*
* @param entry
*/
CRMView.prototype.id_check = function (entry) {
var _this = this;
// Check if it's for one of our contacts // Check if it's for one of our contacts
for (var _i = 0, _a = this.push_contact_ids; _i < _a.length; _i++) { for (var _i = 0, _a = this.push_contact_ids; _i < _a.length; _i++) {
var field = _a[_i]; var field = _a[_i];
if (pushData.acl && pushData.acl[field]) { if (entry && entry[field]) {
var val = typeof pushData.acl[field] == "string" ? [pushData.acl[field]] : pushData.acl[field]; var val = typeof entry[field] == "string" ? [entry[field]] : entry[field];
if (val.filter(function (v) { return _this.contact_ids.indexOf(v) >= 0; }).length > 0) { if (val.filter(function (v) { return _this.contact_ids.indexOf(v) >= 0; }).length > 0) {
return this._app_obj_push(pushData); return true;
} }
} }
} }
return false;
}; };
/** /**
* Override the list's push handler to do nothing, we'll call it if we want it. * Override the list's push handler to do nothing, we'll call it if we want it.

View File

@ -39,7 +39,7 @@ export class CRMView extends EgwApp
// Hold on to the original push handler // Hold on to the original push handler
private _app_obj_push: (pushData: PushData) => void; private _app_obj_push: (pushData: PushData) => void;
// Push data key(s) to check for our contact ID // Push data key(s) to check for our contact ID in the entry's ACL data
private push_contact_ids = ["contact_id"]; private push_contact_ids = ["contact_id"];
/** /**
@ -172,24 +172,51 @@ export class CRMView extends EgwApp
// If we know about it and it's an update, just update. // If we know about it and it's an update, just update.
// This must be before all ACL checks, as contact might have changed and entry needs to be removed // This must be before all ACL checks, as contact might have changed and entry needs to be removed
// (server responds then with null / no entry causing the entry to disapear) // (server responds then with null / no entry causing the entry to disappear)
if (pushData.type !== "add" && this.egw.dataHasUID(this.uid(pushData))) if (pushData.type !== "add" && this.egw.dataHasUID(this.uid(pushData)))
{ {
return this.nm.refresh(pushData.id, pushData.type); // Check to see if it's in OUR nextmatch
let uid = this.uid(pushData);
let known = Object.values(this.nm.controller._indexMap).filter(function(row) {return row.uid ==uid;});
let type = pushData.type;
if(known && known.length > 0)
{
if(!this.id_check(pushData.acl))
{
// Was ours, not anymore, and we know this now - no server needed. Just remove from nm.
type = et2_nextmatch.DELETE;
}
return this.nm.refresh(pushData.id, type);
}
} }
if(this.id_check(pushData.acl))
{
return this._app_obj_push(pushData);
}
}
/**
* Check to see if the given entry is "ours"
*
* @param entry
*/
id_check(entry) : boolean
{
// Check if it's for one of our contacts // Check if it's for one of our contacts
for(let field of this.push_contact_ids) for(let field of this.push_contact_ids)
{ {
if(pushData.acl && pushData.acl[field]) if(entry && entry[field])
{ {
let val = typeof pushData.acl[field] == "string" ? [pushData.acl[field]] : pushData.acl[field]; let val = typeof entry[field] == "string" ? [entry[field]] : entry[field];
if(val.filter(v => this.contact_ids.indexOf(v) >= 0).length > 0) if(val.filter(v => this.contact_ids.indexOf(v) >= 0).length > 0)
{ {
return this._app_obj_push(pushData); return true;
} }
} }
} }
return false;
} }
/** /**

View File

@ -89,10 +89,23 @@ class infolog_hooks
{ {
$info = array_intersect_key($entry, array_flip(['info_type', 'info_owner','info_responsible', 'info_modified'])); $info = array_intersect_key($entry, array_flip(['info_type', 'info_owner','info_responsible', 'info_modified']));
// Add in contact ID for CRM view // Add in contact IDs for CRM view
if($entry['info_contact'] && $entry['info_contact']['app'] == 'addressbook') if($entry['info_contact'] && $entry['info_contact']['app'] == 'addressbook')
{ {
$info['contact_id'] = $entry['info_contact']['id']; $info['contact_id'] = [$entry['info_contact']['id']];
}
foreach(Api\Link::get_links('infolog',$entry['info_id'],'addressbook') as $link)
{
if(!is_array($info['contact_id']))
{
$info['contact_id'] = [];
}
// Skip if already there
if(in_array($link,$info['contact_id']))
{
continue;
}
$info['contact_id'][] = $link;
} }
return $info; return $info;
} }