mirror of
https://github.com/zulip/zulip.git
synced 2025-11-01 12:33:40 +00:00
This module was exposing its functions as globals. This PR fixes it use the IIFE module style that we use in our other modules.
72 lines
2.1 KiB
JavaScript
72 lines
2.1 KiB
JavaScript
var common = (function () {
|
|
|
|
var exports = {};
|
|
|
|
exports.status_classes = 'alert-error alert-success alert-info';
|
|
|
|
exports.autofocus = function (selector) {
|
|
$(function () {
|
|
$(selector)[0].focus();
|
|
});
|
|
};
|
|
|
|
// Return a boolean indicating whether the password is acceptable.
|
|
// Also updates a Bootstrap progress bar control (a jQuery object)
|
|
// if provided.
|
|
//
|
|
// Assumes that zxcvbn.js has been loaded.
|
|
//
|
|
// This is in common.js because we want to use it from the signup page
|
|
// and also from the in-app password change interface.
|
|
exports.password_quality = function (password, bar, password_field) {
|
|
// We load zxcvbn.js asynchronously, so the variable might not be set.
|
|
if (typeof zxcvbn === 'undefined') {
|
|
return undefined;
|
|
}
|
|
|
|
var min_length = 6;
|
|
var min_quality = 0;
|
|
|
|
if (password_field) {
|
|
min_length = password_field.data('minLength') || min_length;
|
|
min_quality = password_field.data('minQuality') || min_quality;
|
|
}
|
|
|
|
// Consider the password acceptable if it's at least 6 characters.
|
|
var acceptable = password.length >= min_length;
|
|
|
|
// Compute a quality score in [0,1].
|
|
var result = zxcvbn(password);
|
|
var quality = Math.min(1,Math.log(1 + result.crack_times_seconds.
|
|
offline_slow_hashing_1e4_per_second) / 22);
|
|
|
|
// Even if zxcvbn loves your short password, the bar should be filled
|
|
// at most 1/3 of the way, because we won't accept it.
|
|
if (!acceptable) {
|
|
quality = Math.min(quality, 0.33);
|
|
|
|
// In case the quality is below the minimum, we should not accept the password
|
|
} else if (quality < min_quality) {
|
|
acceptable = false;
|
|
}
|
|
|
|
if (bar !== undefined) {
|
|
// Display the password quality score on a progress bar
|
|
// which bottoms out at 10% so there's always something
|
|
// for the user to see.
|
|
bar.width(((90 * quality) + 10) + '%')
|
|
.removeClass('bar-success bar-danger')
|
|
.addClass(acceptable ? 'bar-success' : 'bar-danger');
|
|
}
|
|
|
|
return acceptable;
|
|
};
|
|
|
|
return exports;
|
|
|
|
}());
|
|
|
|
if (typeof module !== 'undefined') {
|
|
module.exports = common;
|
|
}
|