X-Git-Url: http://git.indexdata.com/?p=mkws-moved-to-github.git;a=blobdiff_plain;f=src%2Fmkws-core.js;h=2b258073e28781efebf914a04e91f18a10cf3f99;hp=6b0ab488939a8a7484b452409c09d8aa85e20fde;hb=7b6b1d731e85c96c95101e444364eca4ab03782c;hpb=fb18432fbe8d0c62265dd61be7027af0201c2fb9 diff --git a/src/mkws-core.js b/src/mkws-core.js index 6b0ab48..2b25807 100644 --- a/src/mkws-core.js +++ b/src/mkws-core.js @@ -3,7 +3,7 @@ * See the file LICENSE for details */ -"use strict"; // HTML5: disable for log_level >= 2 +"use strict"; // Set up global mkws object. Contains truly global state such as SP @@ -17,8 +17,7 @@ window.mkws = { authenticating: false, active: false, logger: undefined, - log_level: 1, // Will be overridden from mkws.config, but - // initial value allows jQuery popup to use logging. + log_level: "info", teams: {}, widgetType2function: {}, defaultTemplates: {}, @@ -91,9 +90,29 @@ if (typeof(mkws_jQuery) !== "undefined") { mkws.$ = jQuery; } +// It's ridiculous that JSNLog doesn't provide this +mkws.stringToLevel = function(s) { + if (s === 'trace') { + return JL.getTraceLevel(); + } else if (s === 'debug') { + return JL.getDebugLevel(); + } else if (s === 'info') { + return JL.getInfoLevel(); + } else if (s === 'warn') { + return JL.getWarnLevel(); + } else if (s === 'error') { + return JL.getErrorLevel(); + } else if (s === 'fatal') { + return JL.getFatalLevel(); + } else { + throw "bad log-level '" + s + "'"; + } +} + mkws.logger = JL('mkws'); var consoleAppender = JL.createConsoleAppender('consoleAppender'); -mkws.logger.setOptions({ "appenders": [consoleAppender]} ); +mkws.logger.setOptions({ "appenders": [consoleAppender], + "level": mkws.stringToLevel(mkws.log_level) }); function _log(fn, string) { @@ -111,17 +130,12 @@ function _log(fn, string) { }; -// \\\ transitional placeholder function until we have promoted all invocations -mkws.log = function(x) { _log(mkws.logger.debug, "LEGACY LOG: " + x) }; -/* -trace("message with severity trace"); -debug("message with severity debug"); -info("message with severity info"); -warn("message with severity warn"); -error("message with severity error"); -fatal("message with severity fatal"); -*/ - +mkws.trace = function(x) { _log(mkws.logger.trace, x) }; +mkws.debug = function(x) { _log(mkws.logger.debug, x) }; +mkws.info = function(x) { _log(mkws.logger.info, x) }; +mkws.warn = function(x) { _log(mkws.logger.warn, x) }; +mkws.error = function(x) { _log(mkws.logger.error, x) }; +mkws.fatal = function(x) { _log(mkws.logger.fatal, x) }; // Translation function. @@ -148,12 +162,12 @@ mkws.getParameterByName = function(name, url) { mkws.registerWidgetType = function(name, fn) { if(mkws._old2new.hasOwnProperty(name)) { - mkws.log("Warning: registerWidgetType old widget name: " + name + " => " + mkws._old2new[name]); + mkws.warn("registerWidgetType old widget name: " + name + " => " + mkws._old2new[name]); name = mkws._old2new[name]; } mkws.widgetType2function[name] = fn; - mkws.log("registered widget-type '" + name + "'"); + mkws.info("registered widget-type '" + name + "'"); }; mkws.promotionFunction = function(name) { @@ -162,7 +176,7 @@ mkws.promotionFunction = function(name) { mkws.setMkwsConfig = function(overrides) { - // Set global log_level flag early so that mkws.log() works + // Set global log_level flag early so that _log() works var tmp = overrides.log_level; if (typeof(tmp) !== 'undefined') mkws.log_level = tmp; @@ -258,11 +272,11 @@ mkws.pagerNext = function(tname) { mkws.pazpar2_url = function() { if (mkws.config.pazpar2_url) { - mkws.log("using pre-baked pazpar2_url '" + mkws.config.pazpar2_url + "'"); + mkws.info("using pre-baked pazpar2_url '" + mkws.config.pazpar2_url + "'"); return mkws.config.pazpar2_url; } else { var s = document.location.protocol + "//" + mkws.config.pp2_hostname + "/" + mkws.config.pp2_path; - mkws.log("generated pazpar2_url '" + s + "'"); + mkws.info("generated pazpar2_url '" + s + "'"); return s; } }; @@ -282,7 +296,7 @@ mkws.pazpar2_url = function() { var token; if (window.name) { token = window.name.replace(/.*\//, ''); - mkws.log("Reusing existing window token '" + token + "'"); + mkws.debug("Reusing existing window token '" + token + "'"); } else { // Incredible that the standard JavaScript runtime doesn't define a // unique windowId. Instead, we have to make one up. And since there's @@ -293,16 +307,15 @@ if (window.name) { // Ten chars from 26 alpha-numerics = 36^10 = 3.65e15 combinations. // At one per second, it will take 116 million years to duplicate a token token = Math.random().toString(36).slice(2, 12); - mkws.log("Generated new window token '" + token + "'"); + mkws.debug("Generated new window token '" + token + "'"); } window.name = window.location.hostname + window.location.pathname + '/' + token; -mkws.log("Using window.name '" + window.name + "'"); +mkws.info("Using window.name '" + window.name + "'"); // wrapper to provide local copy of the jQuery object. (function($) { - var log = mkws.log; var _old2new = { // Maps old-style widget names to new-style 'Authname': 'auth-name', 'ConsoleBuilder': 'console-builder', @@ -333,7 +346,7 @@ mkws.log("Using window.name '" + window.name + "'"); // undefined, we don't get an error message, but this // function and its callers, up several stack level, // silently return. What a crock. - log("handleNodeWithTeam() called on node with no classes"); + mkws.fatal("handleNodeWithTeam() called on node with no classes"); return; } var list = classes.split(/\s+/) @@ -365,7 +378,7 @@ mkws.log("Using window.name '" + window.name + "'"); if (node.getAttribute("autosearch")) { if (mkws.autoHasAuto || mkws.teams["AUTO"] && mkws.teams["AUTO"].config["query"]) { - log("AUTO team already has a query, using unique team"); + mkws.warn("AUTO team already has a query, using unique team"); teamName = "UNIQUE"; } mkws.autoHasAuto = true; @@ -396,7 +409,7 @@ mkws.log("Using window.name '" + window.name + "'"); mkws.width = width; if (from) { - log("changing from " + from + " to " + to + ": " + width); + mkws.info("changing from " + from + " to " + to + ": " + width); for (var tname in mkws.teams) { var team = mkws.teams[tname]; team.visitWidgets(function(t, w) { @@ -423,11 +436,11 @@ mkws.log("Using window.name '" + window.name + "'"); */ function authenticateSession(auth_url, auth_domain, pp2_url) { mkws.authenticating = true; - log("service proxy authentication on URL: " + auth_url); + mkws.info("service proxy authentication on URL: " + auth_url); if (!auth_domain) { auth_domain = pp2_url.replace(/^(https?:)?\/\/(.*?)\/.*/, '$2'); - log("guessed auth_domain '" + auth_domain + "' from pp2_url '" + pp2_url + "'"); + mkws.info("guessed auth_domain '" + auth_domain + "' from pp2_url '" + pp2_url + "'"); } var request = new pzHttpRequest(auth_url, function(err) { @@ -448,7 +461,7 @@ mkws.log("Using window.name '" + window.name + "'"); return; } - log("service proxy authentication successful"); + mkws.info("service proxy authentication successful"); mkws.authenticated = true; var authName = $(data).find("displayName").text(); // You'd think there would be a better way to do this: @@ -463,7 +476,7 @@ mkws.log("Using window.name '" + window.name + "'"); function runAutoSearches() { - log("running auto searches"); + mkws.info("running auto searches"); for (var teamName in mkws.teams) { mkws.teams[teamName].queue("ready").publish(); @@ -521,7 +534,7 @@ mkws.log("Using window.name '" + window.name + "'"); myTeam.addWidget(myWidget); var newHTML = this.innerHTML; if (newHTML !== oldHTML) { - myTeam.log("widget " + type + " HTML changed: reparsing"); + myTeam.info("widget " + type + " HTML changed: reparsing"); makeWidgetsWithin(level+1, $(this)); } }); @@ -546,14 +559,14 @@ mkws.log("Using window.name '" + window.name + "'"); var greet = "MKWS initialised"; if (rootsel) greet += " (limited to " + rootsel + ")" if (message) greet += " :: " + message; - mkws.log(greet); + mkws.info(greet); // MKWS is not active until init() has been run against an object with widget nodes. // We only set initial configuration when MKWS is first activated. if (!mkws.isActive) { var widgetSelector = selectorForAllWidgets(); if ($(widgetSelector).length < 1) { - mkws.log("no widgets found"); + mkws.warn("no widgets found"); return; } @@ -561,10 +574,10 @@ mkws.log("Using window.name '" + window.name + "'"); mkws.autoHasAuto = false; var saved_config; if (typeof mkws_config === 'undefined') { - log("setting empty config"); + mkws.info("setting empty config"); saved_config = {}; } else { - log("using config: " + $.toJSON(mkws_config)); + mkws.info("using config: " + $.toJSON(mkws_config)); saved_config = mkws_config; } mkws.setMkwsConfig(saved_config); @@ -575,7 +588,7 @@ mkws.log("Using window.name '" + window.name + "'"); var lang = key.replace(/^language_/, ""); // Copy custom languages into list mkws.locale_lang[lang] = mkws.config[key]; - log("added locally configured language '" + lang + "'"); + mkws.info("added locally configured language '" + lang + "'"); } } } @@ -587,12 +600,12 @@ mkws.log("Using window.name '" + window.name + "'"); mkws.config.lang = lang; } - log("using language: " + (mkws.config.lang ? mkws.config.lang : "none")); + mkws.info("using language: " + (mkws.config.lang ? mkws.config.lang : "none")); // protocol independent link for pazpar2: "//mkws/sp" -> "https://mkws/sp" if (mkws.pazpar2_url().match(/^\/\//)) { mkws.config.pazpar2_url = document.location.protocol + mkws.config.pazpar2_url; - log("adjusted protocol independent link to " + mkws.pazpar2_url()); + mkws.info("adjusted protocol independent link to " + mkws.pazpar2_url()); } if (mkws.config.responsive_design_width) { @@ -612,21 +625,21 @@ mkws.log("Using window.name '" + window.name + "'"); } var now = $.now(); - log("walking MKWS nodes took " + (now-then) + " ms"); + mkws.info("walking MKWS nodes took " + (now-then) + " ms"); for (var tName in mkws.teams) { var myTeam = mkws.teams[tName] myTeam.makePz2(); - myTeam.log("made PZ2 object"); + myTeam.info("made PZ2 object"); /* myTeam.visitWidgets(function(t, w) { - log(" has widget of type '" + t + "': " + w); + mkws.debug(" has widget of type '" + t + "': " + w); }); */ } function sp_auth_url(config) { if (config.service_proxy_auth) { - mkws.log("using pre-baked sp_auth_url '" + config.service_proxy_auth + "'"); + mkws.info("using pre-baked sp_auth_url '" + config.service_proxy_auth + "'"); return config.service_proxy_auth; } else { var s = '//'; @@ -642,7 +655,7 @@ mkws.log("Using window.name '" + window.name + "'"); s += ('&username=' + c.substr(0, c.indexOf('/')) + '&password=' + c.substr(c.indexOf('/')+1)); } - mkws.log("generated sp_auth_url '" + s + "'"); + mkws.info("generated sp_auth_url '" + s + "'"); return s; } }