forked from extern/egroupware
WIP SpamTitan integration:
- Take acc_spam_api into account for showing spam actions
This commit is contained in:
parent
a9e750c8b2
commit
b099ba8a5e
@ -877,6 +877,70 @@ class mail_ui
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Method to execute spam actions
|
||||||
|
*
|
||||||
|
* @param type $_action action id
|
||||||
|
* @param type $_params
|
||||||
|
*/
|
||||||
|
public function ajax_spamAction($_action, $_params)
|
||||||
|
{
|
||||||
|
$msg = array();
|
||||||
|
$response = Api\Json\Response::get();
|
||||||
|
if ($GLOBALS['egw_info']['apps']['stylite'])
|
||||||
|
{
|
||||||
|
$data = array_merge($_params, array(
|
||||||
|
'userpwd' => $this->mail_bo->icServer['params']['acc_imap_password'],
|
||||||
|
'user' => $this->mail_bo->icServer['params']['acc_imap_username'],
|
||||||
|
'api_url' => $this->mail_bo->icServer['params']['acc_spam_api']
|
||||||
|
));
|
||||||
|
$msg[] = stylite_mail_spamtitan::execSpamTitanAction($_action, $_params, $data);
|
||||||
|
}
|
||||||
|
switch ($_action)
|
||||||
|
{
|
||||||
|
case 'spam':
|
||||||
|
// Move to spam from Inbox
|
||||||
|
break;
|
||||||
|
case 'ham':
|
||||||
|
// copy to Ham and move from Spam to Inbox
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
$response->apply('egw.message',[implode('\n',$msg)]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Build spam actions
|
||||||
|
*
|
||||||
|
* @return array actions
|
||||||
|
*/
|
||||||
|
public function getSpamActions ()
|
||||||
|
{
|
||||||
|
$actions = array (
|
||||||
|
'spamfilter' => array (
|
||||||
|
'caption' => 'spam',
|
||||||
|
'icon' => 'dhtmlxtree/MailFolderJunk',
|
||||||
|
'children' => array (
|
||||||
|
'spam' => array (
|
||||||
|
'caption' => 'Report as Spam',
|
||||||
|
'icon' => 'dhtmlxtree/MailFolderJunk',
|
||||||
|
'onExecute' => 'javaScript:app.mail.spam_actions',
|
||||||
|
),
|
||||||
|
'ham' => array (
|
||||||
|
'caption' => 'Not a Spam',
|
||||||
|
'icon' => 'ham',
|
||||||
|
'onExecute' => 'javaScript:app.mail.spam_actions',
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
$account = Mail\Account::read($this->mail_bo->profileID);
|
||||||
|
// spamTitan actions
|
||||||
|
if ($GLOBALS['egw_info']['apps']['stylite'] && $account['params']['acc_spam_api'])
|
||||||
|
{
|
||||||
|
$actions['spamfilter']['children'] = array_merge($actions['spamfilter']['children'], stylite_mail_spamtitan::getActions());
|
||||||
|
}
|
||||||
|
return $actions;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get actions / context menu for index
|
* Get actions / context menu for index
|
||||||
@ -1305,17 +1369,14 @@ class mail_ui
|
|||||||
{
|
{
|
||||||
unset($actions['save']['children']['save2filemanager']);
|
unset($actions['save']['children']['save2filemanager']);
|
||||||
}
|
}
|
||||||
if ($GLOBALS['egw_info']['apps']['stylite'])
|
|
||||||
|
$spam_actions = $this->getSpamActions();
|
||||||
|
$group++;
|
||||||
|
foreach ($spam_actions as &$action)
|
||||||
{
|
{
|
||||||
$spamtitan_actions = stylite_mail_spamtitan::getActions();
|
$action['group'] = $group;
|
||||||
$group++;
|
|
||||||
foreach ($spamtitan_actions as &$action)
|
|
||||||
{
|
|
||||||
$action['group'] = $group;
|
|
||||||
}
|
|
||||||
$actions = array_merge($actions, $spamtitan_actions);
|
|
||||||
}
|
}
|
||||||
return $actions;
|
return array_merge($actions, $spam_actions);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -5479,16 +5479,16 @@ app.classes.mail = AppJS.extend(
|
|||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Actions handler
|
* Spam Actions handler
|
||||||
*
|
*
|
||||||
* @param {object} _action egw action
|
* @param {object} _action egw action
|
||||||
* @param {object} _sender nm row
|
* @param {object} _sender nm row
|
||||||
*/
|
*/
|
||||||
spamtitan_actions: function (_action, _sender)
|
spam_actions: function (_action, _sender)
|
||||||
{
|
{
|
||||||
var id = _sender[0].id;
|
var id = _sender[0].id;
|
||||||
var data = egw.dataGetUIDdata(id);
|
var data = egw.dataGetUIDdata(id);
|
||||||
this.egw.json('stylite.stylite_mail_spamtitan.ajax_action', [_action.id, {}]).sendRequest(true);
|
this.egw.json('mail.mail_ui.ajax_spamAction', [_action.id, {'acc_id':id.split('::')[2], data:data.data}]).sendRequest(true);
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user