##// END OF EJS Templates
fix(service-api): rely on urljoin for constructing the call url
fix(service-api): rely on urljoin for constructing the call url

File last commit:

r4339:de17b181 default
r5319:cc68847e default
Show More
users.js
96 lines | 3.3 KiB | application/javascript | JavascriptLexer
// # Copyright (C) 2010-2020 RhodeCode GmbH
// #
// # This program is free software: you can redistribute it and/or modify
// # it under the terms of the GNU Affero General Public License, version 3
// # (only), as published by the Free Software Foundation.
// #
// # This program is distributed in the hope that it will be useful,
// # but WITHOUT ANY WARRANTY; without even the implied warranty of
// # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// # GNU General Public License for more details.
// #
// # You should have received a copy of the GNU Affero General Public License
// # along with this program. If not, see <http://www.gnu.org/licenses/>.
// #
// # This program is dual-licensed. If you wish to learn more about the
// # RhodeCode Enterprise Edition, including its added features, Support services,
// # and proprietary license terms, please see https://rhodecode.com/licenses/
var generatePassword = function(length) {
if (length === undefined){
length = 8
}
var charset = "abcdefghijklnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
var gen_pass = "";
for (var i = 0, n = charset.length; i < length; ++i) {
gen_pass += charset.charAt(Math.floor(Math.random() * n));
}
return gen_pass;
};
/**
* User autocomplete
*/
var UsersAutoComplete = function(input_id, user_id) {
$('#'+input_id).autocomplete({
serviceUrl: pyroutes.url('user_autocomplete_data'),
minChars:2,
maxHeight:400,
deferRequestBy: 300, //miliseconds
showNoSuggestionNotice: true,
tabDisabled: true,
autoSelectFirst: true,
params: { user_id: user_id },
formatResult: autocompleteFormatResult,
lookupFilter: autocompleteFilterResult
});
};
var _showAuthToken = function (authTokenId, showUrl) {
SwalNoAnimation.fire({
title: _gettext('Show this authentication token?'),
showCancelButton: true,
confirmButtonText: _gettext('Show'),
showLoaderOnConfirm: true,
allowOutsideClick: function () {
!Swal.isLoading()
},
preConfirm: function () {
var postData = {
'auth_token_id': authTokenId,
'csrf_token': CSRF_TOKEN
};
return new Promise(function (resolve, reject) {
$.ajax({
type: 'POST',
data: postData,
url: showUrl,
headers: {'X-PARTIAL-XHR': true}
})
.done(function (data) {
resolve(data);
})
.fail(function (jqXHR, textStatus, errorThrown) {
//reject("Failed to fetch Authentication Token")
var message = formatErrorMessage(jqXHR, textStatus, errorThrown);
ajaxErrorSwal(message);
});
})
}
})
.then(function (result) {
if (result.value) {
var tmpl = ('<code>{0}</code>' +
'<i class="tooltip icon-clipboard clipboard-action" data-clipboard-text="{1}" title="Copy Token"></i>');
SwalNoAnimation.fire({
title: _gettext('Authentication Token'),
html: tmpl.format(result.value.auth_token, result.value.auth_token),
})
}
})
}