From: Olivier Lamy Date: Fri, 26 Oct 2012 12:58:50 +0000 (+0000) Subject: [MRM-1705] Feature to add custom parameters and/or headers when requesting an externa... X-Git-Tag: archiva-1.4-M4~703 X-Git-Url: https://source.dussan.org/?a=commitdiff_plain;h=30ffd9ee14cad99bb72590f18b168cda44d5c02e;p=archiva.git [MRM-1705] Feature to add custom parameters and/or headers when requesting an external repositories. implements ui for extra headers. git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@1402495 13f79535-47bb-0310-9956-ffa450edef68 --- diff --git a/archiva-modules/archiva-web/archiva-web-common/src/main/resources/org/apache/archiva/i18n/default.properties b/archiva-modules/archiva-web/archiva-web-common/src/main/resources/org/apache/archiva/i18n/default.properties index bdf72b627..ac9059a0d 100644 --- a/archiva-modules/archiva-web/archiva-web-common/src/main/resources/org/apache/archiva/i18n/default.properties +++ b/archiva-modules/archiva-web/archiva-web-common/src/main/resources/org/apache/archiva/i18n/default.properties @@ -37,6 +37,9 @@ url=Url directory=Directory save.all=Save all common.loading=Loading... +key=Key +value=Value +key.empty.error.message=Key cannot be empty authz.karma.needed=You need to be authenticated for this action or have more privileges. error.500=An error has happened you must contact the administrator to check the logs. @@ -160,6 +163,8 @@ remoterepository.download.remote.full=Full download ? remoterepository.download.remote.scheduled=Download Remote Index of repository {0} scheduled. remoterepository.delete.confirm=Are you sure to delete Remote Repository {0} ? remoterepository.deleted=Remote repository {0} deleted. +remoteRepository.extraParametersEntries=Additionnal url parameters +remoteRepository.extraHeadersEntries=Additionnal Http Headers #network proxy diff --git a/archiva-modules/archiva-web/archiva-webapp-js/src/main/webapp/js/archiva/repositories.js b/archiva-modules/archiva-web/archiva-webapp-js/src/main/webapp/js/archiva/repositories.js index 4d605a8e9..0b961f8fe 100644 --- a/archiva-modules/archiva-web/archiva-webapp-js/src/main/webapp/js/archiva/repositories.js +++ b/archiva-modules/archiva-web/archiva-webapp-js/src/main/webapp/js/archiva/repositories.js @@ -877,7 +877,12 @@ function(jquery,i18n,jqueryTmpl,bootstrap,jqueryValidate,ko) { addExtraParameter=function(){ var mainContent=$("#main-content"); + mainContent.find("#extra-parameters-error" ).html(""); var key=mainContent.find("#extraParameter-key").val(); + if($.trim(key).length<1){ + displayErrorMessage( $.i18n.prop("key.empty.error.message"),"extra-parameters-error"); + return; + } var value=mainContent.find("#extraParameter-value").val(); $.log("addExtraParameter="+key+":"+value); var oldTab = self.remoteRepository.extraParametersEntries(); @@ -898,6 +903,37 @@ function(jquery,i18n,jqueryTmpl,bootstrap,jqueryValidate,ko) { } } + addExtraHeader=function(){ + + var mainContent=$("#main-content"); + mainContent.find("#extra-headers-error" ).html(""); + var key=mainContent.find("#extraHeader-key").val(); + if( $.trim(key).length<1){ + if($.trim(key).length<1){ + displayErrorMessage( $.i18n.prop("key.empty.error.message"),"extra-headers-error"); + return; + } + } + var value=mainContent.find("#extraHeader-value").val(); + $.log("addExtraParameter="+key+":"+value); + var oldTab = self.remoteRepository.extraHeadersEntries(); + oldTab.push(new Entry(key,value)); + self.remoteRepository.extraHeadersEntries(oldTab); + mainContent.find("#extraHeader-key").val(""); + mainContent.find("#extraHeader-value").val(""); + self.remoteRepository.modified(true); + } + + deleteExtraHeader=function(key){ + for(var i=0;i

${$.i18n.prop('remoteRepository.extraParametersEntries')}

+
- - + + @@ -648,6 +649,29 @@ +
+
+

${$.i18n.prop('remoteRepository.extraHeadersEntries')}

+
+
${$.i18n.prop('key')}:${$.i18n.prop('value')}: ${$.i18n.prop('add')}
+ + + + + + + {{each(i, extraHeaderEntry) remoteRepository.extraHeadersEntries}} + + + + + + {{/each}} + +
${$.i18n.prop('key')}:${$.i18n.prop('value')}:${$.i18n.prop('add')}
${extraHeaderEntry.key}${extraHeaderEntry.value}${$.i18n.prop('delete')}
+
+ +