External Libraries: zxcvbn library.

This reverts [44354] for more investigation into inconsistent password strength values that passed locally prior to commit.

Unprops omarreiss, netweb, desrosj.
See #43749.

git-svn-id: https://develop.svn.wordpress.org/trunk@44356 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Jonathan Desrosiers 2018-12-20 21:02:16 +00:00
parent 54debcd452
commit 30dcae9e2d
3 changed files with 7 additions and 173 deletions

View File

@ -5,10 +5,6 @@ var webpackConfig = require( './webpack.config' );
module.exports = function(grunt) {
var path = require('path'),
fs = require( 'fs' ),
rot = require( 'rot' );
esprima = require( 'esprima' );
estraverse = require( 'estraverse' );
escodegen = require( 'escodegen' );
spawn = require( 'child_process' ).spawnSync,
SOURCE_DIR = 'src/',
BUILD_DIR = 'build/',
@ -684,10 +680,7 @@ module.exports = function(grunt) {
'!wp-admin/js/custom-header.js', // Why? We should minify this.
'!wp-admin/js/farbtastic.js',
'!wp-includes/js/swfobject.js',
'!wp-includes/js/wp-embed.js', // We have extra options for this, see uglify:embed
// .min files that still need to be minified.
'wp-includes/js/zxcvbn.min.js'
'!wp-includes/js/wp-embed.js' // We have extra options for this, see uglify:embed
]
},
embed: {
@ -1075,12 +1068,6 @@ module.exports = function(grunt) {
]
}
},
rot13: {
zxcvbn: {
src: './node_modules/zxcvbn/dist/zxcvbn.js',
dest: 'build/wp-includes/js/zxcvbn.min.js'
},
},
_watch: {
options: {
interval: 2000
@ -1359,7 +1346,6 @@ module.exports = function(grunt) {
'clean:js',
'webpack:dev',
'copy:js',
'rot13:zxcvbn',
'file_append',
'uglify:all',
'build:tinymce',
@ -1378,7 +1364,6 @@ module.exports = function(grunt) {
grunt.registerTask( 'build', [
'clean:all',
'copy:all',
'rot13:zxcvbn',
'file_append',
'cssmin:core',
'colors',
@ -1451,59 +1436,6 @@ module.exports = function(grunt) {
// Default task.
grunt.registerTask('default', ['build']);
grunt.registerMultiTask('rot13', 'ROT-13 zxcvbn passwords for PG-ness.', function() {
this.files.forEach(function(f) {
// Build AST from source code
var code = grunt.file.read(f.src);
var ast = esprima.parse(code);
ast = estraverse.replace(ast, {
enter: function(node) {
// Filter string
let key_names = [
'passwords',
'english_wikipedia',
'female_names',
'surnames',
'us_tv_and_film',
'male_names'
];
if( node.type === 'Property' && key_names.includes( node.key.name ) ) {
// Wrap encrypted string with decrypt function.
var value = {
type: 'CallExpression',
callee: {
type: 'Identifier',
name: 'rot'
},
arguments: [{
type: 'Literal',
value: rot(node.value.callee.object.value, 13),
raw: rot(node.value.callee.object.raw, 13)
}, {
type: 'Literal',
value: 13,
raw: 13
}]
};
node.value = value;
return node;
}
}
});
// ROT-13 decode function
var prependCode = 'var lowercase="abcdefghijklmnopqrstuvwxyz",uppercase="ABCDEFGHIJKLMNOPQRSTUVWXYZ",regexLowercase=/[a-z]/,regexUppercase=/[A-Z]/,rot=function(e,r){if(null==r&&(r=13),r=Number(r),e=String(e),0==r)return e;0>r&&(r+=26);for(var a,c,t,s=e.length,p=-1,n="";++p<s;)a=e.charAt(p),regexLowercase.test(a)?(c=lowercase.indexOf(a),t=(c+r)%26,n+=lowercase.charAt(t)):regexUppercase.test(a)?(c=uppercase.indexOf(a),t=(c+r)%26,n+=uppercase.charAt(t)):n+=a;return n};\n';
// Generate new file from modified AST
var modifiedCode = prependCode + escodegen.generate(ast);
grunt.file.write(f.dest, modifiedCode);
grunt.log.writeln('File "' + f.dest + '" encrypted.');
});
});
/*
* Automatically updates the `:dynamic` configurations
* so that only the changed files are updated.

105
package-lock.json generated
View File

@ -4428,11 +4428,6 @@
"lodash.isplainobject": "^4.0.6"
}
},
"deep-is": {
"version": "0.1.3",
"resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz",
"integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ="
},
"deepmerge": {
"version": "1.5.2",
"resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-1.5.2.tgz",
@ -4993,31 +4988,6 @@
"resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
"integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ="
},
"escodegen": {
"version": "1.10.0",
"resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.10.0.tgz",
"integrity": "sha512-fjUOf8johsv23WuIKdNQU4P9t9jhQ4Qzx6pC2uW890OloK3Zs1ZAoCNpg/2larNF501jLl3UNy0kIRcF6VI22g==",
"requires": {
"esprima": "^3.1.3",
"estraverse": "^4.2.0",
"esutils": "^2.0.2",
"optionator": "^0.8.1",
"source-map": "~0.6.1"
},
"dependencies": {
"esprima": {
"version": "3.1.3",
"resolved": "https://registry.npmjs.org/esprima/-/esprima-3.1.3.tgz",
"integrity": "sha1-/cpRzuYTOJXjyI1TXOSdv/YqRjM="
},
"source-map": {
"version": "0.6.1",
"resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
"integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
"optional": true
}
}
},
"eslint-scope": {
"version": "4.0.0",
"resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.0.tgz",
@ -5029,9 +4999,10 @@
}
},
"esprima": {
"version": "4.0.0",
"resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.0.tgz",
"integrity": "sha512-oftTcaMu/EGrEIu904mWteKIv8vMuOgGYo7EhVJJN00R/EED9DCua/xxHRdYnKtcECzVg7xOWhflvJMnqcFZjw=="
"version": "1.0.4",
"resolved": "https://registry.npmjs.org/esprima/-/esprima-1.0.4.tgz",
"integrity": "sha1-n1V+CPw7TSbs6d00+Pv0drYlha0=",
"dev": true
},
"esrecurse": {
"version": "4.2.1",
@ -5045,7 +5016,8 @@
"estraverse": {
"version": "4.2.0",
"resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz",
"integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM="
"integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=",
"dev": true
},
"esutils": {
"version": "2.0.2",
@ -5411,11 +5383,6 @@
"integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=",
"dev": true
},
"fast-levenshtein": {
"version": "2.0.6",
"resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz",
"integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc="
},
"faye-websocket": {
"version": "0.10.0",
"resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.10.0.tgz",
@ -7112,14 +7079,6 @@
"dev": true,
"requires": {
"esprima": "~1.0.0"
},
"dependencies": {
"esprima": {
"version": "1.0.4",
"resolved": "https://registry.npmjs.org/esprima/-/esprima-1.0.4.tgz",
"integrity": "sha1-n1V+CPw7TSbs6d00+Pv0drYlha0=",
"dev": true
}
}
},
"grunt-known-options": {
@ -9315,15 +9274,6 @@
"invert-kv": "^1.0.0"
}
},
"levn": {
"version": "0.3.0",
"resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz",
"integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=",
"requires": {
"prelude-ls": "~1.1.2",
"type-check": "~0.3.2"
}
},
"line-height": {
"version": "0.3.1",
"resolved": "https://registry.npmjs.org/line-height/-/line-height-0.3.1.tgz",
@ -11199,26 +11149,6 @@
}
}
},
"optionator": {
"version": "0.8.2",
"resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz",
"integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=",
"requires": {
"deep-is": "~0.1.3",
"fast-levenshtein": "~2.0.4",
"levn": "~0.3.0",
"prelude-ls": "~1.1.2",
"type-check": "~0.3.2",
"wordwrap": "~1.0.0"
},
"dependencies": {
"wordwrap": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz",
"integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus="
}
}
},
"optipng-bin": {
"version": "3.1.4",
"resolved": "https://registry.npmjs.org/optipng-bin/-/optipng-bin-3.1.4.tgz",
@ -12216,11 +12146,6 @@
}
}
},
"prelude-ls": {
"version": "1.1.2",
"resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz",
"integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ="
},
"prepend-http": {
"version": "1.0.4",
"resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-1.0.4.tgz",
@ -13317,11 +13242,6 @@
"inherits": "^2.0.1"
}
},
"rot": {
"version": "0.1.0",
"resolved": "https://registry.npmjs.org/rot/-/rot-0.1.0.tgz",
"integrity": "sha1-rPQEhNIAhC6LxIRDgmFuSGNdSN4="
},
"rtlcss": {
"version": "2.2.1",
"resolved": "https://registry.npmjs.org/rtlcss/-/rtlcss-2.2.1.tgz",
@ -15383,14 +15303,6 @@
"resolved": "https://registry.npmjs.org/twemoji/-/twemoji-11.0.0.tgz",
"integrity": "sha1-fuxX0Sv9H//o1efwXaC2QipgeQ8="
},
"type-check": {
"version": "0.3.2",
"resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz",
"integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=",
"requires": {
"prelude-ls": "~1.1.2"
}
},
"type-is": {
"version": "1.6.16",
"resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.16.tgz",
@ -16873,11 +16785,6 @@
"lodash": "^4.8.0",
"readable-stream": "^2.0.0"
}
},
"zxcvbn": {
"version": "4.4.2",
"resolved": "https://registry.npmjs.org/zxcvbn/-/zxcvbn-4.4.2.tgz",
"integrity": "sha1-KOwXzwl0PtyrBW3dixsGJizHPDA="
}
}
}

View File

@ -94,9 +94,6 @@
"@wordpress/wordcount": "^2.0.3",
"backbone": "1.3.3",
"element-closest": "^2.0.2",
"escodegen": "1.10.0",
"esprima": "4.0.0",
"estraverse": "4.2.0",
"formdata-polyfill": "^3.0.12",
"imagesloaded": "3.2.0",
"jquery": "1.12.4",
@ -110,10 +107,8 @@
"polyfill-library": "^3.26.0-0",
"react": "^16.6.3",
"react-dom": "^16.6.3",
"rot": "0.1.0",
"twemoji": "11.0.0",
"underscore": "1.8.3",
"zxcvbn": "4.4.2",
"whatwg-fetch": "^3.0.0"
},
"scripts": {