Fix security issues
This commit is contained in:
@@ -302,7 +302,7 @@ ${message_font_close}
|
|||||||
<td abswidth=5>
|
<td abswidth=5>
|
||||||
<td abswidth=225 maxlines=1>
|
<td abswidth=225 maxlines=1>
|
||||||
${message_font_open}
|
${message_font_open}
|
||||||
${(message.subject) ? message.subject : "(No Subject)"}
|
${(message.subject) ? wtvshared.htmlEntitize(message.subject) : "(No Subject)"}
|
||||||
${message_font_close}
|
${message_font_close}
|
||||||
<td abswidth=5>
|
<td abswidth=5>
|
||||||
<td abswidth=47 maxlines=1>
|
<td abswidth=47 maxlines=1>
|
||||||
|
|||||||
@@ -266,7 +266,7 @@ ${page_start}-${page_end}
|
|||||||
<tr>
|
<tr>
|
||||||
${(has_relation) ? `<td abswidth=20 rowspan=2 valign=top><font size="+2">•` : ''}
|
${(has_relation) ? `<td abswidth=20 rowspan=2 valign=top><font size="+2">•` : ''}
|
||||||
<td abswidth=426 maxlines=1>
|
<td abswidth=426 maxlines=1>
|
||||||
<font color=1bb0f1>${(message.headers.SUBJECT) ? message.headers.SUBJECT : "(No Subject)"}
|
<font color=1bb0f1>${(message.headers.SUBJECT) ? wtvshared.htmlEntitize(message.headers.SUBJECT) : "(No Subject)"}
|
||||||
<tr>
|
<tr>
|
||||||
<td maxlines=1>
|
<td maxlines=1>
|
||||||
<font size="-1" color=544f53><b>
|
<font size="-1" color=544f53><b>
|
||||||
|
|||||||
@@ -193,8 +193,17 @@ class WTVShared {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
var allowedProtocols = allowedSchemes;
|
||||||
|
// allow links to services flagged as "wideopen"
|
||||||
|
Object.keys(this.minisrv_config.services).forEach((k) => {
|
||||||
|
var flag = parseInt(this.minisrv_config.services[k].flags, 16);
|
||||||
|
if (flag === 4 || flag === 7) {
|
||||||
|
allowedProtocols.push(k);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
const clean = this.sanitizeHtml(string, {
|
const clean = this.sanitizeHtml(string, {
|
||||||
allowedTags: ['a', 'audioscope', 'b', 'bgsound', 'big', 'blackface', 'blockquote', 'bq', 'br', 'caption', 'center', 'cite', 'c', 'dd', 'dfn', 'div', 'dl', 'dt', 'fn', 'font', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'html', 'i', 'img', 'label', 'li', 'link', 'listing', 'em', 'marquee', 'nobr', 'note', 'ol', 'p', 'plaintext', 'pre', 's', 'samp', 'small', 'span', 'strike', 'strong', 'style', 'sub', 'sup', 'tbody', 'table', 'td', 'th', 'tr', 'tt', 'u', 'ul'],
|
allowedTags: ['a', 'audioscope', 'b', 'bgsound', 'big', 'blackface', 'blockquote', 'bq', 'br', 'caption', 'center', 'cite', 'c', 'dd', 'dfn', 'div', 'dl', 'dt', 'fn', 'font', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'html', 'i', 'img', 'label', 'li', 'link', 'listing', 'em', 'marquee', 'nobr', 'note', 'ol', 'p', 'plaintext', 'pre', 's', 'samp', 'small', 'span', 'strike', 'strong', 'sub', 'sup', 'tbody', 'table', 'td', 'th', 'tr', 'tt', 'u', 'ul'],
|
||||||
disallowedTagsMode: 'discard',
|
disallowedTagsMode: 'discard',
|
||||||
allowedAttributes: {
|
allowedAttributes: {
|
||||||
a: ['href', 'name', 'target'],
|
a: ['href', 'name', 'target'],
|
||||||
@@ -206,11 +215,25 @@ class WTVShared {
|
|||||||
allowedSchemes: allowedSchemes,
|
allowedSchemes: allowedSchemes,
|
||||||
allowedSchemesByTag: {},
|
allowedSchemesByTag: {},
|
||||||
allowedSchemesAppliedToAttributes: ['href', 'src', 'cite'],
|
allowedSchemesAppliedToAttributes: ['href', 'src', 'cite'],
|
||||||
allowVulnerableTags: true,
|
exclusiveFilter: function (frame) {
|
||||||
|
var allowed = false;
|
||||||
|
Object.keys(frame.attribs).forEach((k) => {
|
||||||
|
if (k == "href" || k == "background" || k == "src") {
|
||||||
|
var value = frame.attribs[k];
|
||||||
|
Object.keys(allowedProtocols).forEach((j) => {
|
||||||
|
if (value.startsWith(allowedProtocols[j])) {
|
||||||
|
allowed = true;
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
});
|
||||||
|
console.log(frame, allowed);
|
||||||
|
return !allowed;
|
||||||
|
},
|
||||||
|
allowVulnerableTags: false,
|
||||||
allowProtocolRelative: false
|
allowProtocolRelative: false
|
||||||
})
|
}, true)
|
||||||
// todo: add missing user open tags (eg </i> if user did not close it) (might be done by sanitize-html?)
|
// todo: add missing user open tags (eg </i> if user did not close it) (might be done by sanitize-html?)
|
||||||
// todo: figure out bgcolor and text color voodoo
|
|
||||||
return clean;
|
return clean;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user