Files
roundcubemail/plugins/show_additional_headers/show_additional_headers.php
Michael Voříšek ca8b17d191 Modernize more basic CS (#9258)
* fix "yoda_style"

* fix "is_null"

* rm useless rule ignores

* add full "PhpCsFixer:risky" ruleset

* fix "implode_call"

* fix "no_alias_functions"

* fix "array_push"

* fix "long_to_shorthand_operator"

* fix "ternary_to_elvis_operator"

* fix "logical_operators"

* fix "fopen_flags"

* rename "returns" phpdoc tags to "return"

* fix "php_unit_construct"

* fix "function_to_constant"

* fix "php_unit_data_provider_return_type"

* fix "php_unit_set_up_tear_down_visibility"

* some safe "string_length_to_empty"

* fix "phpdoc_align"

* fix "phpdoc_no_alias_tag"

* fix "trailing_comma_in_multiline"

---------

Co-authored-by: Aleksander Machniak <alec@alec.pl>
2023-12-17 09:51:11 +01:00

91 lines
2.6 KiB
PHP

<?php
/**
* Show additional message headers
*
* Proof-of-concept plugin which will fetch additional headers
* and display them in the message view.
*
* Enable the plugin in config.inc.php and add your desired headers:
* $config['show_additional_headers'] = ['User-Agent'];
*
* @author Thomas Bruederli
* @license GNU GPLv3+
*/
class show_additional_headers extends rcube_plugin
{
public $task = 'mail';
/**
* Plugin initialization
*/
function init()
{
$rcmail = rcmail::get_instance();
if ($rcmail->action == 'show' || $rcmail->action == 'preview') {
$this->add_hook('storage_init', [$this, 'storage_init']);
$this->add_hook('message_headers_output', [$this, 'message_headers']);
}
else if ($rcmail->action == '') {
// with enabled_caching we're fetching additional headers before show/preview
$this->add_hook('storage_init', [$this, 'storage_init']);
}
}
/**
* Handler for 'storage_init' hook, where we tell the core to
* fetch specified additional headers from IMAP.
*
* @params array $p Hook parameters
*
* @return array Modified hook parameters
*/
function storage_init($p)
{
$rcmail = rcmail::get_instance();
$add_headers = $rcmail->config->get('show_additional_headers', []);
if (!empty($add_headers)) {
$add_headers = strtoupper(implode(' ', (array) $add_headers));
if (isset($p['fetch_headers'])) {
$p['fetch_headers'] .= ' ' . $add_headers;
}
else {
$p['fetch_headers'] = $add_headers;
}
}
return $p;
}
/**
* Handler for 'message_headers_output' hook, where we add the additional
* headers to the output.
*
* @params array $p Hook parameters
*
* @return array Modified hook parameters
*/
function message_headers($p)
{
$rcmail = rcmail::get_instance();
$add_headers = $rcmail->config->get('show_additional_headers', []);
foreach ((array) $add_headers as $header) {
if ($value = $p['headers']->get($header)) {
if (is_array($value)) {
foreach ($value as $idx => $v) {
$p['output']["$header:$idx"] = ['title' => $header, 'value' => $v];
}
}
else {
$p['output'][$header] = ['title' => $header, 'value' => $value];
}
}
}
return $p;
}
}