Ghost/ghost/admin/lib/koenig-editor/addon/helpers/sanitize-html.js
Kevin Ansfield 359fcb0756 Koenig - Pass html card content through sanitiser
refs https://github.com/TryGhost/Ghost/issues/9724
- extract html sanitisation into a Koenig helper `{{sanitise-html}}` (all markdown handling will eventually move into Koenig too)
- render sanitised html in the html card
2018-08-09 14:59:03 +01:00

28 lines
964 B
JavaScript

/* global html_sanitize */
import cajaSanitizers from 'ghost-admin/utils/caja-sanitizers';
import {assign} from '@ember/polyfills';
import {helper} from '@ember/component/helper';
import {htmlSafe} from '@ember/string';
import {isArray} from '@ember/array';
export function sanitizeHtml(params, options = {}) {
let html = isArray(params) ? params[0] : params;
options = assign({replaceJS: true}, options);
// replace script and iFrame
if (options.replaceJS) {
html = html.replace(/<script\b[^<]*(?:(?!<\/script>)<[^<]*)*<\/script>/gi,
'<pre class="js-embed-placeholder">Embedded JavaScript</pre>');
html = html.replace(/<iframe\b[^<]*(?:(?!<\/iframe>)<[^<]*)*<\/iframe>/gi,
'<pre class="iframe-embed-placeholder">Embedded iFrame</pre>');
}
// sanitize html
html = html_sanitize(html, cajaSanitizers.url, cajaSanitizers.id);
return htmlSafe(html);
}
export default helper(sanitizeHtml);