From: Mike Taylor Date: Mon, 11 Aug 2014 09:19:43 +0000 (+0100) Subject: Merge branch 'master' into mike X-Git-Tag: 1.0.0~39^2~7^2~4^2~46 X-Git-Url: http://sru.miketaylor.org.uk/?a=commitdiff_plain;h=694f4b8e3a4a60e0792c83a80578f373606b5406;hp=879ad99f16e7f8927da7c1936f39b9f017339202;p=mkws-moved-to-github.git Merge branch 'master' into mike --- diff --git a/examples/htdocs/mike.html b/examples/htdocs/mike.html index 90caf92..934fd6e 100644 --- a/examples/htdocs/mike.html +++ b/examples/htdocs/mike.html @@ -7,8 +7,11 @@ var mkws_config = { pazpar2_url: "//sp-mkws.indexdata.com/service-proxy/", // For now, we have to provide known-bad credentials to skip user/pw login: see bug MKSP-125 - service_proxy_auth: "//sp-mkws.indexdata.com/service-proxy/?command=auth&action=perconfig&username=XXX&password=XXX" - // For explicit credential-based authentication, add: &username=orex&password=orexmkc + service_proxy_auth: undefined, + // Was: //sp-mkws.indexdata.com/service-proxy/?command=auth&action=perconfig&username=XXX&password=XXX +// pp2_hostname: "sp-mkws.indexdata.com", +// sp_path: "service-proxy/", +// credentials: "XXX/XXX", }; diff --git a/src/mkws-core.js b/src/mkws-core.js index a3a1ac9..3c2ff2a 100644 --- a/src/mkws-core.js +++ b/src/mkws-core.js @@ -166,7 +166,11 @@ mkws.setMkwsConfig = function(overrides) { var config_default = { use_service_proxy: true, pazpar2_url: "//mkws.indexdata.com/service-proxy/", - service_proxy_auth: "//mkws.indexdata.com/service-proxy-auth", + service_proxy_auth: undefined, // generally rolled from the next three properties + // Was: //mkws.indexdata.com/service-proxy-auth + pp2_hostname: "mkws.indexdata.com", + sp_path: "service-proxy-auth", + credentials: undefined, lang: "", sort_options: [["relevance"], ["title:1", "title"], ["date:0", "newest"], ["date:1", "oldest"]], perpage_options: [10, 20, 30, 50], @@ -623,8 +627,28 @@ mkws.pagerNext = function(tname) { } */ + function sp_auth_url(config) { + if (config.service_proxy_auth) { + mkws.log("using pre-baked sp_auth_url '" + config.service_proxy_auth + "'"); + return config.service_proxy_auth; + } else { + var s = '//'; + s += config.auth_hostname ? config.auth_hostname : config.pp2_hostname; + s += '/' + config.sp_path + '?command=auth&action=perconfig'; + var c = config.credentials; + if (c) { + if (c) { + s += ('&username=' + c.substr(0, c.indexOf('/')) + + '&password=' + c.substr(c.indexOf('/')+1)); + } + } + mkws.log("generated sp_auth_url '" + s + "'"); + return s; + } + } + if (mkws.config.use_service_proxy) { - authenticateSession(mkws.config.service_proxy_auth, + authenticateSession(sp_auth_url(mkws.config), mkws.config.service_proxy_auth_domain, mkws.config.pazpar2_url); } else {