X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?p=src%2Fapp-framework-demo.git;a=blobdiff_plain;f=afb-client%2Fapp%2FFrontend%2Fetc%2FAppConfig.js;fp=afb-client%2Fapp%2FFrontend%2Fetc%2FAppConfig.js;h=c8f1abef85d5bea21b3ee7811b0723463654adea;hp=5c9283ef882ae0db79635224d30116341a8e2741;hb=c8a7784c665e1571400853c0c91b9c47be3ce86f;hpb=7b8fe1b305a36f925fc2757a2c126c88fb0a5137 diff --git a/afb-client/app/Frontend/etc/AppConfig.js b/afb-client/app/Frontend/etc/AppConfig.js index 5c9283e..c8f1abe 100644 --- a/afb-client/app/Frontend/etc/AppConfig.js +++ b/afb-client/app/Frontend/etc/AppConfig.js @@ -16,11 +16,6 @@ }, session: { // Those data are updated by session service - create : '/api/token/create', - refresh : '/api/token/refresh', - check : '/api/token/check', - reset : '/api/token/reset', - ping : '/api/token/check', initial : urlquery.token || '123456789', // typical dev initial token timeout : 3600, // timeout is updated client sessin context creation pingrate: 30, // Ping rate to check if server is still alive @@ -34,24 +29,36 @@ // Factory is a singleton and share its context within all instances. .factory('AppCall', function ($http, AppConfig, $log) { + var myCalls = { get : function(plugin, action, query, cbresponse, cberror) { - if (!query.token) query.token = AppConfig.session.token; // add token to provided query - var handle= $http.get('/api/' + plugin + '/' + action , {params: query}).then (onsuccess, onerror); - handle.onsuccess (function(data, errcode, headers, config) { + var onerror = function(response) { + if (cberror) cberror(response.data, response.status, response.config); + else cbresponse(response.data, response.status, response.config); + }; + + var onsuccess =function(response) { + if (!response.data || !response.data.request) { + onerror (response); + return; + } + + var request=response.data.request; + // if token was updated keep it within application cache - if (data.request.token) AppConfig.session.token = data.request.token; - if (data.request.uuid) AppConfig.session.uuid = data.request.uuid; - if (data.request.timeout) AppConfig.session.timeout = data.request.timeout; + if (request.token) AppConfig.session.token = request.token; + if (request.uuid) AppConfig.session.uuid = request.uuid; + if (request.timeout) AppConfig.session.timeout = request.timeout; - cbresponse(data, errcode, headers, config); - }); + cbresponse(response.data, response.status, response.config); + }; + + + if (!query.token) query.token = AppConfig.session.token; // add token to provided query + if (!query.reqid) query.reqid = action; // use action as default requestID + var handle= $http.get('/api/' + plugin + '/' + action , {params: query}).then(onsuccess, onerror); - handle.onerror (function(data, errcode, headers, config) { - if (cberror) cberror(data, errcode, headers, config); - else cbresponse(data, errcode, headers, config); - }); } }; return myCalls;