Editor: Prevent adding `javascript:` and `data:` URLs through the inline link dialog.

git-svn-id: https://develop.svn.wordpress.org/trunk@41393 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Dominik Schilling (ocean90) 2017-09-19 08:00:40 +00:00
parent ce69e660bd
commit 1f0d51dbd2
2 changed files with 23 additions and 2 deletions

View File

@ -4,7 +4,7 @@
renderHtml: function() { renderHtml: function() {
return ( return (
'<div id="' + this._id + '" class="wp-link-preview">' + '<div id="' + this._id + '" class="wp-link-preview">' +
'<a href="' + this.url + '" target="_blank" tabindex="-1">' + this.url + '</a>' + '<a href="' + this.url + '" target="_blank" rel="noopener" tabindex="-1">' + this.url + '</a>' +
'</div>' '</div>'
); );
}, },
@ -249,6 +249,13 @@
text = inputInstance.getLinkText(); text = inputInstance.getLinkText();
editor.focus(); editor.focus();
var parser = document.createElement( 'a' );
parser.href = href;
if ( 'javascript:' === parser.protocol || 'data:' === parser.protocol ) { // jshint ignore:line
href = '';
}
if ( ! href ) { if ( ! href ) {
editor.dom.remove( linkNode, true ); editor.dom.remove( linkNode, true );
return; return;

View File

@ -312,7 +312,7 @@ var wpLink;
var html = '<a href="' + attrs.href + '"'; var html = '<a href="' + attrs.href + '"';
if ( attrs.target ) { if ( attrs.target ) {
html += ' target="' + attrs.target + '"'; html += ' rel="noopener" target="' + attrs.target + '"';
} }
return html + '>'; return html + '>';
@ -337,6 +337,13 @@ var wpLink;
attrs = wpLink.getAttrs(); attrs = wpLink.getAttrs();
text = inputs.text.val(); text = inputs.text.val();
var parser = document.createElement( 'a' );
parser.href = attrs.href;
if ( 'javascript:' === parser.protocol || 'data:' === parser.protocol ) { // jshint ignore:line
attrs.href = '';
}
// If there's no href, return. // If there's no href, return.
if ( ! attrs.href ) { if ( ! attrs.href ) {
return; return;
@ -390,6 +397,13 @@ var wpLink;
var attrs = wpLink.getAttrs(), var attrs = wpLink.getAttrs(),
$link, text, hasText, $mceCaret; $link, text, hasText, $mceCaret;
var parser = document.createElement( 'a' );
parser.href = attrs.href;
if ( 'javascript:' === parser.protocol || 'data:' === parser.protocol ) { // jshint ignore:line
attrs.href = '';
}
if ( ! attrs.href ) { if ( ! attrs.href ) {
editor.execCommand( 'unlink' ); editor.execCommand( 'unlink' );
wpLink.close(); wpLink.close();