Change from manual URL construction to using a lib
Makes the code cleaner to read and more resilient to changes Fixes https://jira.coreos.com/browse/QUAY-940
This commit is contained in:
parent
e33760fcd2
commit
648590c356
13 changed files with 85 additions and 56 deletions
|
@ -84,7 +84,7 @@ angular.module('quay').directive('entitySearch', function () {
|
|||
$scope.checkLazyLoad = function() {
|
||||
if (!$scope.namespace || !$scope.thisUser || !$scope.requiresLazyLoading ||
|
||||
$scope.isLazyLoading || !$scope.userRequestedLazyLoading) {
|
||||
return;
|
||||
return;
|
||||
}
|
||||
|
||||
$scope.isLazyLoading = true;
|
||||
|
@ -229,15 +229,20 @@ angular.module('quay').directive('entitySearch', function () {
|
|||
name: 'entities' + $rootScope.__entity_search_counter,
|
||||
remote: {
|
||||
url: '/api/v1/entities/%QUERY',
|
||||
replace: function (url, uriEncodedQuery) {
|
||||
replace: function (query_url, uriEncodedQuery) {
|
||||
$scope.lazyLoad();
|
||||
|
||||
var namespace = $scope.namespace || '';
|
||||
url = url.replace('%QUERY', uriEncodedQuery);
|
||||
url += '?namespace=' + encodeURIComponent(namespace);
|
||||
|
||||
var url = UtilService.getRestUrl(query_url.replace('%QUERY', uriEncodedQuery));
|
||||
url.setQueryParameter('namespace', namespace);
|
||||
|
||||
if ($scope.isOrganization && isSupported('team')) {
|
||||
url += '&includeTeams=true'
|
||||
url.setQueryParameter('includeTeams', true);
|
||||
}
|
||||
|
||||
if (isSupported('org')) {
|
||||
url += '&includeOrgs=true'
|
||||
url.setQueryParameter('includeOrgs', true);
|
||||
}
|
||||
return url;
|
||||
},
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
import { LogUsageChart } from '../../graphing';
|
||||
|
||||
import { parse } from 'path';
|
||||
|
||||
/**
|
||||
* Element which displays usage logs for the given entity.
|
||||
|
@ -383,8 +383,8 @@ angular.module('quay').directive('logsView', function () {
|
|||
url = UtilService.getRestUrl('superuser', suffix)
|
||||
}
|
||||
|
||||
url += '?starttime=' + encodeURIComponent(getDateString($scope.options.logStartDate));
|
||||
url += '&endtime=' + encodeURIComponent(getDateString($scope.options.logEndDate));
|
||||
url.setQueryParameter('starttime', getDateString($scope.options.logStartDate));
|
||||
url.setQueryParameter('endtime', getDateString($scope.options.logEndDate));
|
||||
return url;
|
||||
};
|
||||
|
||||
|
@ -405,7 +405,7 @@ angular.module('quay').directive('logsView', function () {
|
|||
|
||||
$scope.chartLoading = true;
|
||||
|
||||
var aggregateUrl = getUrl('aggregatelogs')
|
||||
var aggregateUrl = getUrl('aggregatelogs').toString();
|
||||
var loadAggregate = Restangular.one(aggregateUrl);
|
||||
loadAggregate.customGET().then(function(resp) {
|
||||
$scope.chart = new LogUsageChart(logKinds);
|
||||
|
@ -430,12 +430,10 @@ angular.module('quay').directive('logsView', function () {
|
|||
|
||||
$scope.loading = true;
|
||||
|
||||
var logsUrl = getUrl('logs');
|
||||
if ($scope.nextPageToken) {
|
||||
logsUrl = logsUrl + '&next_page=' + encodeURIComponent($scope.nextPageToken);
|
||||
}
|
||||
var url = getUrl('logs');
|
||||
url.setQueryParameter('next_page', $scope.nextPageToken);
|
||||
|
||||
var loadLogs = Restangular.one(logsUrl);
|
||||
var loadLogs = Restangular.one(url.toString());
|
||||
loadLogs.customGET().then(function(resp) {
|
||||
resp.logs.forEach(function(log) {
|
||||
$scope.logs.push(log);
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
var urlParseURL = require('url-parse');
|
||||
|
||||
/**
|
||||
* Service which exposes the server-defined API as a nice set of helper methods and automatic
|
||||
* callbacks. Any method defined on the server is exposed here as an equivalent method. Also
|
||||
|
@ -44,7 +46,7 @@ angular.module('quay').factory('ApiService', ['Restangular', '$q', 'UtilService'
|
|||
|
||||
// Build the path, adjusted with the inline parameters.
|
||||
var used = {};
|
||||
var url = '';
|
||||
var urlPath = '';
|
||||
for (var i = 0; i < path.length; ++i) {
|
||||
var c = path[i];
|
||||
if (c == '{') {
|
||||
|
@ -56,29 +58,29 @@ angular.module('quay').factory('ApiService', ['Restangular', '$q', 'UtilService'
|
|||
}
|
||||
|
||||
used[varName] = true;
|
||||
url += parameters[varName];
|
||||
urlPath += encodeURI(parameters[varName]);
|
||||
i = end;
|
||||
continue;
|
||||
}
|
||||
|
||||
url += c;
|
||||
urlPath += c;
|
||||
}
|
||||
|
||||
// Append any query parameters.
|
||||
var isFirst = true;
|
||||
var url = new urlParseURL(urlPath, '/');
|
||||
url.query = {};
|
||||
|
||||
for (var paramName in parameters) {
|
||||
if (!parameters.hasOwnProperty(paramName)) { continue; }
|
||||
if (used[paramName]) { continue; }
|
||||
|
||||
var value = parameters[paramName];
|
||||
if (value != null) {
|
||||
url += isFirst ? '?' : '&';
|
||||
url += paramName + '=' + encodeURIComponent(value)
|
||||
isFirst = false;
|
||||
url.query[paramName] = value
|
||||
}
|
||||
}
|
||||
|
||||
return url;
|
||||
return url.toString();
|
||||
};
|
||||
|
||||
var getGenericOperationName = function(userOperationName) {
|
||||
|
|
|
@ -29,7 +29,7 @@ angular.module('quay').factory('RolesService', ['UtilService', 'Restangular', 'A
|
|||
var namespace = repository.namespace;
|
||||
var name = repository.name;
|
||||
var url = UtilService.getRestUrl('repository', namespace, name, 'permissions', entityKind, entityName);
|
||||
return Restangular.one(url);
|
||||
return Restangular.one(url.toString());
|
||||
};
|
||||
|
||||
roleService.deleteRepositoryRole = function(repository, entityKind, entityName, callback) {
|
||||
|
|
|
@ -23,11 +23,13 @@ angular.module('quay').factory('TriggerService', ['UtilService', '$sanitize', 'K
|
|||
var redirect_uri = KeyService['githubRedirectUri'] + '/trigger/' +
|
||||
namespace + '/' + repository;
|
||||
|
||||
var authorize_url = KeyService['githubTriggerAuthorizeUrl'];
|
||||
var client_id = KeyService['githubTriggerClientId'];
|
||||
|
||||
return authorize_url + 'client_id=' + client_id +
|
||||
'&scope=repo,user:email&redirect_uri=' + redirect_uri;
|
||||
var authorize_url = new UtilService.UrlBuilder(KeyService['githubTriggerAuthorizeUrl']);
|
||||
authorize_url.setQueryParameter('client_id', client_id);
|
||||
authorize_url.setQueryParameter('scope', 'repo,user:email');
|
||||
authorize_url.setQueryParameter('redirect_uri', redirect_uri);
|
||||
return authorize_url.toString();
|
||||
},
|
||||
'is_external': true,
|
||||
'is_enabled': function() {
|
||||
|
@ -81,10 +83,14 @@ angular.module('quay').factory('TriggerService', ['UtilService', '$sanitize', 'K
|
|||
'run_parameters': [branch_tag],
|
||||
'get_redirect_url': function(namespace, repository) {
|
||||
var redirect_uri = KeyService['gitlabRedirectUri'] + '/trigger';
|
||||
var authorize_url = KeyService['gitlabTriggerAuthorizeUrl'];
|
||||
var client_id = KeyService['gitlabTriggerClientId'];
|
||||
|
||||
return authorize_url + 'client_id=' + client_id + '&redirect_uri=' + redirect_uri + '&response_type=code&state=repo:' + namespace + '/' + repository;
|
||||
var authorize_url = new UtilService.UrlBuilder(KeyService['gitlabTriggerAuthorizeUrl']);
|
||||
authorize_url.setQueryParameter('client_id', client_id);
|
||||
authorize_url.setQueryParameter('state', 'repo:' + namespace + '/' + repository);
|
||||
authorize_url.setQueryParameter('redirect_uri', redirect_uri);
|
||||
authorize_url.setQueryParameter('response_type', 'code');
|
||||
return authorize_url.toString();
|
||||
},
|
||||
'is_external': false,
|
||||
'is_enabled': function() {
|
||||
|
|
|
@ -1,3 +1,23 @@
|
|||
var urlParseURL = require('url-parse');
|
||||
|
||||
var UrlBuilder = function(initial_url) {
|
||||
this.url = urlParseURL(initial_url || '', '/');
|
||||
};
|
||||
|
||||
UrlBuilder.prototype.setQueryParameter = function(paramName, paramValue) {
|
||||
if (paramValue == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
this.url.query = this.url.query || {};
|
||||
this.url.query[paramName] = paramValue;
|
||||
};
|
||||
|
||||
UrlBuilder.prototype.toString = function() {
|
||||
return this.url.toString();
|
||||
};
|
||||
|
||||
|
||||
/**
|
||||
* Service which exposes various utility methods.
|
||||
*/
|
||||
|
@ -98,19 +118,23 @@ angular.module('quay').factory('UtilService', ['$sanitize', 'markdownConverter',
|
|||
};
|
||||
|
||||
utilService.getRestUrl = function(args) {
|
||||
var url = '';
|
||||
var path = '';
|
||||
|
||||
for (var i = 0; i < arguments.length; ++i) {
|
||||
if (i > 0) {
|
||||
url += '/';
|
||||
path += '/';
|
||||
}
|
||||
url += encodeURI(arguments[i])
|
||||
path += encodeURI(arguments[i])
|
||||
}
|
||||
return url;
|
||||
|
||||
return new UrlBuilder(path);
|
||||
};
|
||||
|
||||
utilService.textToSafeHtml = function(text) {
|
||||
return $sanitize(utilService.escapeHtmlString(text));
|
||||
};
|
||||
|
||||
utilService.UrlBuilder = UrlBuilder;
|
||||
|
||||
return utilService;
|
||||
}]);
|
||||
|
|
Reference in a new issue