diff --git src/wp-admin/js/password-strength-meter.js src/wp-admin/js/password-strength-meter.js
index 2ac7e86..efd26bb 100644
|
|
|
var passwordStrength; |
| 18 | 18 | if (password1 != password2 && password2 && password2.length > 0) |
| 19 | 19 | return 5; |
| 20 | 20 | |
| | 21 | if ( 'undefined' === typeof window.zxcvbn ) { |
| | 22 | // Password strength unknown. |
| | 23 | return -1; |
| | 24 | } |
| | 25 | |
| 21 | 26 | var result = zxcvbn( password1, blacklist ); |
| 22 | 27 | return result.score; |
| 23 | 28 | }, |
diff --git src/wp-admin/js/user-profile.js src/wp-admin/js/user-profile.js
index 5ec77bc..c5f5db3 100644
|
|
|
|
| 30 | 30 | function generatePassword() { |
| 31 | 31 | if ( typeof zxcvbn !== 'function' ) { |
| 32 | 32 | setTimeout( generatePassword, 50 ); |
| 33 | | } else { |
| | 33 | return; |
| | 34 | } else if ( ! $pass1.val() ) { |
| | 35 | // zxcvbn loaded before user entered password. |
| 34 | 36 | $pass1.val( $pass1.data( 'pw' ) ); |
| 35 | | $pass1.trigger( 'pwupdate' ).trigger( 'wp-check-valid-field' ); |
| 36 | | if ( 1 !== parseInt( $toggleButton.data( 'start-masked' ), 10 ) ) { |
| 37 | | $pass1Wrap.addClass( 'show-password' ); |
| 38 | | } else { |
| 39 | | $toggleButton.trigger( 'click' ); |
| 40 | | } |
| | 37 | $pass1.trigger( 'pwupdate' ); |
| | 38 | showOrHideWeakPasswordCheckbox(); |
| | 39 | } |
| | 40 | else { |
| | 41 | // zxcvbn loaded after the user entered password, check strength. |
| | 42 | check_pass_strength(); |
| | 43 | showOrHideWeakPasswordCheckbox(); |
| 41 | 44 | } |
| | 45 | |
| | 46 | if ( 1 !== parseInt( $toggleButton.data( 'start-masked' ), 10 ) ) { |
| | 47 | $pass1Wrap.addClass( 'show-password' ); |
| | 48 | } else { |
| | 49 | $toggleButton.trigger( 'click' ); |
| | 50 | } |
| | 51 | |
| | 52 | // Once zxcvbn loads, passwords strength is known. |
| | 53 | $( '#pw-weak-text-label' ).html( userProfileL10n.warnWeak ); |
| 42 | 54 | } |
| 43 | 55 | |
| 44 | 56 | function bindPass1() { |
| 45 | | var passStrength = $('#pass-strength-result')[0]; |
| 46 | | |
| 47 | 57 | currentPass = $pass1.val(); |
| 48 | 58 | |
| 49 | 59 | $pass1Wrap = $pass1.parent(); |
| … |
… |
|
| 82 | 92 | $pass1Text.val( currentPass ); |
| 83 | 93 | } |
| 84 | 94 | $pass1.add( $pass1Text ).removeClass( 'short bad good strong' ); |
| 85 | | |
| 86 | | if ( passStrength.className ) { |
| 87 | | $pass1.add( $pass1Text ).addClass( passStrength.className ); |
| 88 | | if ( 'short' === passStrength.className || 'bad' === passStrength.className ) { |
| 89 | | if ( ! $weakCheckbox.prop( 'checked' ) ) { |
| 90 | | $submitButtons.prop( 'disabled', true ); |
| 91 | | } |
| 92 | | $weakRow.show(); |
| 93 | | } else { |
| 94 | | $submitButtons.prop( 'disabled', false ); |
| 95 | | $weakRow.hide(); |
| 96 | | } |
| 97 | | } |
| | 95 | showOrHideWeakPasswordCheckbox(); |
| 98 | 96 | } ); |
| 99 | 97 | } |
| 100 | 98 | |
| … |
… |
|
| 289 | 287 | strength = wp.passwordStrength.meter( pass1, wp.passwordStrength.userInputBlacklist(), pass1 ); |
| 290 | 288 | |
| 291 | 289 | switch ( strength ) { |
| | 290 | case -1: |
| | 291 | $( '#pass-strength-result' ).addClass( 'bad' ).html( pwsL10n.unknown ); |
| | 292 | break; |
| 292 | 293 | case 2: |
| 293 | 294 | $('#pass-strength-result').addClass('bad').html( pwsL10n.bad ); |
| 294 | 295 | break; |
| … |
… |
|
| 306 | 307 | } |
| 307 | 308 | } |
| 308 | 309 | |
| | 310 | function showOrHideWeakPasswordCheckbox() { |
| | 311 | var passStrength = $('#pass-strength-result')[0]; |
| | 312 | |
| | 313 | if ( passStrength.className ) { |
| | 314 | $pass1.add( $pass1Text ).addClass( passStrength.className ); |
| | 315 | if ( 'short' === passStrength.className || 'bad' === passStrength.className ) { |
| | 316 | if ( ! $weakCheckbox.prop( 'checked' ) ) { |
| | 317 | $submitButtons.prop( 'disabled', true ); |
| | 318 | } |
| | 319 | $weakRow.show(); |
| | 320 | } else { |
| | 321 | $submitButtons.prop( 'disabled', false ); |
| | 322 | $weakRow.hide(); |
| | 323 | } |
| | 324 | } |
| | 325 | } |
| | 326 | |
| 309 | 327 | $(document).ready( function() { |
| 310 | 328 | var $colorpicker, $stylesheet, user_id, current_user_id, |
| 311 | 329 | select = $( '#display_name' ); |
diff --git src/wp-admin/user-edit.php src/wp-admin/user-edit.php
index 492617d..aa6ed7f 100644
|
|
|
if ( $show_password_fields = apply_filters( 'show_password_fields', true, $profi |
| 531 | 531 | <td> |
| 532 | 532 | <label> |
| 533 | 533 | <input type="checkbox" name="pw_weak" class="pw-checkbox" /> |
| 534 | | <?php _e( 'Confirm use of weak password' ); ?> |
| | 534 | <span id="pw-weak-text-label"><?php _e( 'Confirm use of potentially weak password' ); ?></span> |
| 535 | 535 | </label> |
| 536 | 536 | </td> |
| 537 | 537 | </tr> |
diff --git src/wp-includes/script-loader.php src/wp-includes/script-loader.php
index 9fff743..3b1e8fa 100644
|
|
|
function wp_default_scripts( &$scripts ) { |
| 380 | 380 | |
| 381 | 381 | $scripts->add( 'password-strength-meter', "/wp-admin/js/password-strength-meter$suffix.js", array( 'jquery', 'zxcvbn-async' ), false, 1 ); |
| 382 | 382 | did_action( 'init' ) && $scripts->localize( 'password-strength-meter', 'pwsL10n', array( |
| | 383 | 'unknown' => _x( 'Password strength unknown', 'password strength' ), |
| 383 | 384 | 'short' => _x( 'Very weak', 'password strength' ), |
| 384 | 385 | 'bad' => _x( 'Weak', 'password strength' ), |
| 385 | 386 | 'good' => _x( 'Medium', 'password strength' ), |
| … |
… |
function wp_default_scripts( &$scripts ) { |
| 390 | 391 | $scripts->add( 'user-profile', "/wp-admin/js/user-profile$suffix.js", array( 'jquery', 'password-strength-meter', 'wp-util' ), false, 1 ); |
| 391 | 392 | did_action( 'init' ) && $scripts->localize( 'user-profile', 'userProfileL10n', array( |
| 392 | 393 | 'warn' => __( 'Your new password has not been saved.' ), |
| | 394 | 'warnWeak' => __( 'Confirm use of weak password.' ), |
| 393 | 395 | 'show' => __( 'Show' ), |
| 394 | 396 | 'hide' => __( 'Hide' ), |
| 395 | 397 | 'cancel' => __( 'Cancel' ), |