Building on @Reinmar's answer, if you are looking to apply cerain disallowed rules & optionally react to a paste event.
CKEDITOR.on('instanceReady', function(ev) {
ev.editor.on('paste', function(evt) {
// Standalone filter based off the existing filter.
// If the editor is removed, so it our custom filter object.
// We don't need to pass an editor however.
// @see https://ckeditor.com/docs/ckeditor4/latest/api/CKEDITOR_filter.html
var filter = new CKEDITOR.filter(evt.editor);
// Allow all content.
// @see https://ckeditor.com/docs/ckeditor4/latest/guide/dev_allowed_content_rules.html#special-features
// Don't set filter.allowedContent property directly, doesn't work.
var allowed = filter.allow({
'$1': {
// Use the ability to specify elements as an object.
elements: CKEDITOR.dtd,
attributes: true,
styles: true,
classes: true
}
});
if (allowed === false) {
console.warn('An error occured setting the custom rules.');
return;
}
// Now disllow color attribute & colour background-color, text-decoration styles.
// Format "elements [attributes, attr2]{styles}(classes)"."
// Default is '*[color]; *{color, background-color, text-decoration}'.
filter.disallow('*[color]; *{color, background-color, text-decoration}');
// Filter it now.
var fragment = CKEDITOR.htmlParser.fragment.fromHtml(evt.data.dataValue);
var writer = new CKEDITOR.htmlParser.basicWriter();
filter.applyTo(fragment);
fragment.writeHtml(writer);
var processed_html = writer.getHtml();
// Set the value of what will be pasted.
evt.data.dataValue = processed_html;
console.log('Content filtered.');
// Clean up - free up memory.
filter.destroy();
});
});