diff options
author | Sem <sembrestels@riseup.net> | 2013-11-09 16:15:20 +0100 |
---|---|---|
committer | Sem <sembrestels@riseup.net> | 2013-11-09 16:15:20 +0100 |
commit | 293fe873dcbedf45571807b722ce859e00a5a3a5 (patch) | |
tree | 4ce7adf3dbeed0a4ac2fbefd55f8844f504db499 /mod/opensearch/views/xml | |
parent | ba0d506ade08ae46ba665474a8b9c81e838f2eee (diff) | |
parent | 853cb44b625cbe0e1cae3dff197d54645a1291a1 (diff) | |
download | elgg-293fe873dcbedf45571807b722ce859e00a5a3a5.tar.gz elgg-293fe873dcbedf45571807b722ce859e00a5a3a5.tar.bz2 |
Add 'mod/opensearch/' from commit '853cb44b625cbe0e1cae3dff197d54645a1291a1'
git-subtree-dir: mod/opensearch
git-subtree-mainline: ba0d506ade08ae46ba665474a8b9c81e838f2eee
git-subtree-split: 853cb44b625cbe0e1cae3dff197d54645a1291a1
Diffstat (limited to 'mod/opensearch/views/xml')
-rw-r--r-- | mod/opensearch/views/xml/opensearch/description.php | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/mod/opensearch/views/xml/opensearch/description.php b/mod/opensearch/views/xml/opensearch/description.php new file mode 100644 index 000000000..586cadf83 --- /dev/null +++ b/mod/opensearch/views/xml/opensearch/description.php @@ -0,0 +1,75 @@ +<?php +/** + * Creates an OpenSearch description document from plugin settings + * http://www.opensearch.org/Specifications/OpenSearch/1.1 + */ + +// reset cache headers because IE8 is stupid +header('Pragma: public', true); +header('Cache-Control: public', true); + +$site = elgg_get_site_entity(); +$email = $site->email; + +$shortname = elgg_get_plugin_setting('shortname', 'opensearch'); +$description = elgg_get_plugin_setting('desc', 'opensearch'); +$longname = elgg_get_plugin_setting('longname', 'opensearch'); +$icon = elgg_get_plugin_setting('icon', 'opensearch'); +$tags = elgg_get_plugin_setting('tags', 'opensearch'); +$lang = string_to_tag_array(elgg_get_plugin_setting('lang', 'opensearch')); +$query = elgg_get_plugin_setting('query', 'opensearch'); + +if (empty($shortname)) { + $shortname = $site->name; +} +if (empty($description)) { + $description = elgg_echo('opensearch:engine', array(elgg_get_site_entity()->name)); +} +if (empty($icon)) { + $icon = '_graphics/favicon.ico'; +} +if (empty($lang)) { + $lang = 'en-us'; +} + + +$rss_url = elgg_normalize_url('search/?q={searchTerms}&view=opensearch_rss'); +$rss_url = elgg_format_url($rss_url); +$html_url = elgg_normalize_url('search/?q={searchTerms}'); +$site_url = elgg_get_site_url(); + +?> +<OpenSearchDescription xmlns="http://a9.com/-/spec/opensearch/1.1/"> + <ShortName><?php echo $shortname; ?></ShortName> + <Description><?php echo $description; ?></Description> +<?php if (isset($longname)): ?> + <LongName><?php echo $longname; ?></LongName> +<?php endif; ?> + <Contact><?php echo $site->email; ?></Contact> + <Url type="text/html" template="<?php echo $html_url; ?>"/> + <Url type="application/rss+xml" template="<?php echo $rss_url; ?>"/> +<?php if (preg_match("/.ico$/", $icon)): ?> + <Image height="16" width="16" type="image/vnd.microsoft.icon"><?php echo "{$site_url}$icon"; ?></Image> +<?php elseif (preg_match("/.png$/", $icon)): ?> + <Image height="64" width="64" type="image/png"><?php echo "{$site_url}$icon"; ?></Image> +<?php endif; ?> +<?php if (isset($tags)): ?> + <Tags><?php echo $tags; ?></Tags> +<?php endif; ?> +<?php if (isset($query)): ?> + <Query role="example" searchTerms="<?php echo $query; ?>" /> +<?php endif; ?> +<?php +if (isset($lang)): + foreach ($lang as $language): +?> + <Language><?php echo $language; ?></Language> +<?php + endforeach; +endif; +?> + <SyndicationRight>open</SyndicationRight> + <AdultContent>false</AdultContent> + <OutputEncoding>UTF-8</OutputEncoding> + <InputEncoding>UTF-8</InputEncoding> + </OpenSearchDescription> |