From c70de6f5940d2d7e593b788c95d7665b17f33d56 Mon Sep 17 00:00:00 2001 From: Kload Date: Tue, 4 Feb 2014 21:41:53 +0100 Subject: [PATCH] Serve JSON with revelant informations for the panel --- access.lua | 28 +++++++++++++++++------- portal/assets/js/ynhpanel.js | 39 ++++++++++++++++++++++++++++++++++ portal/assets/js/ynhpanel.json | 1 + 3 files changed, 60 insertions(+), 8 deletions(-) create mode 100644 portal/assets/js/ynhpanel.js create mode 100644 portal/assets/js/ynhpanel.json diff --git a/access.lua b/access.lua index b5630d2..9495b0f 100644 --- a/access.lua +++ b/access.lua @@ -254,7 +254,8 @@ function serve(uri) png = "image/png", svg = "image/svg+xml", ico = "image/vnd.microsoft.icon", - woff = "application/x-font-woff" + woff = "application/x-font-woff", + json = "application/json" } -- Set Content-Type @@ -273,6 +274,9 @@ function serve(uri) elseif ext == "ms" then local data = get_data_for(file) content = hige.render(content, data) + elseif ext == "json" then + local data = get_data_for(file) + content = json.encode(data) end -- Reset flash messages @@ -339,6 +343,15 @@ function get_data_for(view) for url, name in pairs(conf["users"][user]) do table.insert(data["app"], { url = url, name = name }) end + elseif view == "ynhpanel.json" then + data = { + app = {}, + user = user, + portal_url = portal_url + } + for url, name in pairs(conf["users"][user]) do + table.insert(data["app"], { url = url, name = name }) + end end data['flash_fail'] = {flashs["fail"]} @@ -570,13 +583,6 @@ then end --- Serve the panel JS - -if string.match(ngx.var.uri, "^/ynhpanel.js$") then - serve("/ynhsso/assets/js/ynhpanel.js") -end - - -- Skipped urls -- i.e. http://mydomain.org/no_protection/ @@ -604,6 +610,12 @@ end -- if is_logged_in() then + if string.match(ngx.var.uri, "^/ynhpanel.js$") then + serve("/ynhsso/assets/js/ynhpanel.js") + end + if string.match(ngx.var.uri, "^/ynhpanel.json$") then + serve("/ynhsso/assets/js/ynhpanel.json") + end if not has_access() then return redirect(portal_url) end diff --git a/portal/assets/js/ynhpanel.js b/portal/assets/js/ynhpanel.js new file mode 100644 index 0000000..9c1b53f --- /dev/null +++ b/portal/assets/js/ynhpanel.js @@ -0,0 +1,39 @@ +// Smallest DOMReady +// http://dustindiaz.com/smallest-domready-ever +function domReady(cb) { + /in/.test(document.readyState) // in = loadINg + ? setTimeout('domReady('+cb+')', 9) + : cb(); +} + +domReady(function(){ + //console.log('DOM is ready !'); + //alert("YNH Portal"); + + var portal = document.createElement('a'); + + portal.id = 'ynhportal'; + portal.href = '/ynhsso/'; + + portal.style.display="block"; + portal.style.position="fixed"; + portal.style.zIndex="1000"; + portal.style.bottom="5%"; + portal.style.right="30px"; + + portal.style.width="60px"; + portal.style.height="52px"; + portal.style.padding="10px"; + portal.style.borderRadius="5px"; + portal.style.background="#000"; + portal.style.backgroundImage = "url()"; + portal.style.backgroundPosition = "center center"; + portal.style.backgroundRepeat = "no-repeat"; + + portal.style.opacity = "0.35"; + portal.addEventListener('mouseover', function(){portal.style.opacity="1";}); + portal.addEventListener('mouseout', function(){portal.style.opacity="0.5";}); + + document.body.insertBefore(portal); +}); + diff --git a/portal/assets/js/ynhpanel.json b/portal/assets/js/ynhpanel.json new file mode 100644 index 0000000..0967ef4 --- /dev/null +++ b/portal/assets/js/ynhpanel.json @@ -0,0 +1 @@ +{}