Add Support for Firefox OSD

v1.18.x
RoiEX 8 years ago committed by Julian Lam
parent 2086a64a5e
commit 1fd160a4e6

@ -77,8 +77,9 @@
var type = tag.type ? 'type="' + tag.type + '" ' : ''; var type = tag.type ? 'type="' + tag.type + '" ' : '';
var href = tag.href ? 'href="' + tag.href + '" ' : ''; var href = tag.href ? 'href="' + tag.href + '" ' : '';
var sizes = tag.sizes ? 'sizes="' + tag.sizes + '" ' : ''; var sizes = tag.sizes ? 'sizes="' + tag.sizes + '" ' : '';
var title = tag.title ? 'title="' + tag.title + '" ' : '';
return '<link ' + link + rel + type + sizes + href + '/>\n\t'; return '<link ' + link + rel + type + sizes + title + href + '/>\n\t';
} }
function stringify(obj) { function stringify(obj) {

@ -8,7 +8,7 @@ var meta = require('../meta');
module.exports.handle = function (req, res, next) { module.exports.handle = function (req, res, next) {
if (plugins.hasListeners('filter:search.query')) { if (plugins.hasListeners('filter:search.query')) {
res.type('application/xml').send(generateXML()); res.type('application/opensearchdescription+xml').send(generateXML());
} else { } else {
next(); next();
} }
@ -17,9 +17,21 @@ module.exports.handle = function (req, res, next) {
function generateXML() { function generateXML() {
return xml([{ return xml([{
OpenSearchDescription: [ OpenSearchDescription: [
{ _attr: { xmlns: 'http://a9.com/-/spec/opensearch/1.1/' } }, { _attr: {
{ ShortName: String(meta.config.title || meta.config.browserTitle || 'NodeBB') }, xmlns: 'http://a9.com/-/spec/opensearch/1.1/',
{ Description: String(meta.config.description || '') }, 'xmlns:moz': 'http://www.mozilla.org/2006/browser/search/',
} },
{ ShortName: trimToLength(String(meta.config.title || meta.config.browserTitle || 'NodeBB'), 16) },
{ Description: trimToLength(String(meta.config.description || ''), 1024) },
{ InputEncoding: 'UTF-8' },
{ Image: [
{ _attr: {
width: '16',
height: '16',
type: 'image/x-icon',
} },
nconf.get('url') + '/favicon.ico',
] },
{ Url: { { Url: {
_attr: { _attr: {
type: 'text/html', type: 'text/html',
@ -27,6 +39,11 @@ function generateXML() {
template: nconf.get('url') + '/search?term={searchTerms}&in=titlesposts', template: nconf.get('url') + '/search?term={searchTerms}&in=titlesposts',
}, },
} }, } },
{ 'moz:SearchForm': nconf.get('url') + '/search' },
], ],
}], { declaration: true, indent: '\t' }); }], { declaration: true, indent: '\t' });
} }
function trimToLength(string, length) {
return string.trim().substring(0, length).trim();
}

@ -66,6 +66,7 @@ Tags.parse = function (req, data, meta, link, callback) {
defaultLinks.push({ defaultLinks.push({
rel: 'search', rel: 'search',
type: 'application/opensearchdescription+xml', type: 'application/opensearchdescription+xml',
title: validator.escape(String(Meta.config.title || Meta.config.browserTitle || 'NodeBB')),
href: nconf.get('relative_path') + '/osd.xml', href: nconf.get('relative_path') + '/osd.xml',
}); });
} }

Loading…
Cancel
Save