var LoginApp = angular.module('LoginApp', ['ngMaterial', 'ui.bootstrap', 'ui.select']).config(configure); /* @ngInject */ function configure($compileProvider, $mdIconProvider, $mdThemingProvider) { // disable debug info // Perfomance enhancement for production environment (see: http://blog.thoughtram.io/angularjs/2014/12/22/exploring-angular-1.3-disabling-debug-info.html) $compileProvider.debugInfoEnabled(false); // Material svg icon sets $mdIconProvider .iconSet('action', 'assets/icons/action-icons.svg', 24) .iconSet('alert', 'assets/icons/alert-icons.svg', 24) .iconSet('av', 'assets/icons/av-icons.svg', 24) .iconSet('communication', 'assets/icons/communication-icons.svg', 24) .iconSet('content', 'assets/icons/content-icons.svg', 24) .iconSet('device', 'assets/icons/device-icons.svg', 24) .iconSet('editor', 'assets/icons/editor-icons.svg', 24) .iconSet('file', 'assets/icons/file-icons.svg', 24) .iconSet('hardware', 'assets/icons/hardware-icons.svg', 24) .iconSet('icons', 'assets/icons/icons-icons.svg', 24) .iconSet('image', 'assets/icons/image-icons.svg', 24) .iconSet('maps', 'assets/icons/maps-icons.svg', 24) .iconSet('navigation', 'assets/icons/navigation-icons.svg', 24) .iconSet('notification', 'assets/icons/notification-icons.svg', 24) .iconSet('social', 'assets/icons/social-icons.svg', 24) .iconSet('toggle', 'assets/icons/toggle-icons.svg', 24) .icon('google-plus', 'assets/icons/google.svg'); /* var indigoMap = $mdThemingProvider.extendPalette('indigo', { '500': '9e9e9e', '800': '9e9e9e' }); $mdThemingProvider.definePalette('indigo', indigoMap); $mdThemingProvider.theme('default') .primaryPalette('indigo', { 'default': '500', 'hue-1': '300', 'hue-2': '800', 'hue-3': 'A100' });*/ } LoginApp.controller('LoginCtrl', ['$scope', '$http','$timeout', function ($scope, $http, $timeout) { $scope.account = {}; $scope.account.email = ""; $scope.account.password = ""; $scope.account.AppID = 0; $scope.account.PartnerID = 0; $scope.account.error = ""; $scope.account.redirect = ""; $scope.account.AppAccess = false; $scope.Loading = false; $scope.app = {}; $scope.app.name = ""; $scope.app.about = ""; $scope.app.url = ""; $scope.app.AccessLevel = {}; $scope.app.fullAccess = true; $scope.newUser = {}; $scope.newUser.firstName = ""; $scope.newUser.lastName = ""; $scope.newUser.organization = ""; $scope.newUser.email = ""; $scope.newUser.password = ""; $scope.newUser.retypePassword = ""; $scope.newUser.tos = false; $scope.newUser.registerDone = false; $scope.reset = {}; $scope.reset.email = ""; $scope.reset.done = false; $scope.save = {}; $scope.save.email = ""; $scope.save.key = ""; $scope.save.password = ""; $scope.save.retypepassword = ""; $scope.disableTimer = true; $scope.app.AccessLevelAllow = ""; $scope.app.AccessLevel = angular.fromJson('[{"name":"Account","selected":false,"rights":[{"name":"Update","selected":false},{"name":"UpdatePassword","selected":false},{"name":"Info","selected":false},{"name":"List","selected":false},{"name":"UpdateSettings","selected":false},{"name":"Settings","selected":false},{"name":"SaveGlobalSettings","selected":false},{"name":"GetGlobalSettings","selected":false}]},{"name":"Applications","selected":false,"rights":[{"name":"New","selected":false},{"name":"Update","selected":false},{"name":"Remove","selected":false},{"name":"List","selected":false},{"name":"DevList","selected":false},{"name":"SetGroup","selected":false},{"name":"RevokeAccess","selected":false}]},{"name":"Domains","selected":false,"rights":[{"name":"List","selected":false},{"name":"New","selected":false},{"name":"Remove","selected":false},{"name":"AddUserToDomain","selected":false},{"name":"RemoveUserFromDomain","selected":false}]},{"name":"Groups","selected":false,"rights":[{"name":"List","selected":false},{"name":"New","selected":false},{"name":"Remove","selected":false},{"name":"AddUserToGroup","selected":false},{"name":"RemoveUserFromGroup","selected":false},{"name":"UpdateItem","selected":false}]},{"name":"Rights","selected":false,"rights":[{"name":"Save","selected":false},{"name":"List","selected":false},{"name":"Values","selected":false}]},{"name":"SubUsers","selected":false,"rights":[{"name":"List","selected":false},{"name":"New","selected":false},{"name":"Update","selected":false},{"name":"Remove","selected":false},{"name":"Info","selected":false},{"name":"UpdatePassword","selected":false}]},{"name":"Files","selected":false,"rights":[{"name":"UploadURL","selected":false},{"name":"Download","selected":false},{"name":"List","selected":false},{"name":"Remove","selected":false},{"name":"Update","selected":false}]},{"name":"FilesFolders","selected":false,"rights":[{"name":"New","selected":false},{"name":"Update","selected":false},{"name":"List","selected":false},{"name":"Remove","selected":false}]},{"name":"Devices","selected":false,"rights":[{"name":"List","selected":false},{"name":"New","selected":false},{"name":"Remove","selected":false},{"name":"Info","selected":false},{"name":"Update","selected":false},{"name":"SetFolder","selected":false},{"name":"RebootReset","selected":false},{"name":"UpdateGlobalSettings","selected":false},{"name":"GlobalSettings","selected":false}]},{"name":"DeviceFolders","selected":false,"rights":[{"name":"List","selected":false},{"name":"New","selected":false},{"name":"Remove","selected":false},{"name":"Update","selected":false}]},{"name":"Playlist","selected":false,"rights":[{"name":"List","selected":false},{"name":"ListByDevice","selected":false},{"name":"New","selected":false},{"name":"Remove","selected":false},{"name":"Update","selected":false},{"name":"Info","selected":false},{"name":"Link","selected":false},{"name":"UnLink","selected":false}]},{"name":"Slide","selected":false,"rights":[{"name":"List","selected":false},{"name":"New","selected":false},{"name":"Remove","selected":false},{"name":"Update","selected":false},{"name":"Get","selected":false},{"name":"Resolutions","selected":false},{"name":"SetDir","selected":false},{"name":"SendTheme","selected":false},{"name":"GetSentThemes","selected":false},{"name":"RemoveSentTheme","selected":false},{"name":"ImportSentTheme","selected":false}]},{"name":"SlideFolders","selected":false,"rights":[{"name":"New","selected":false},{"name":"Update","selected":false},{"name":"List","selected":false},{"name":"Remove","selected":false}]},{"name":"Log","selected":false,"rights":[{"name":"List","selected":false},{"name":"Login","selected":false}]},{"name":"Tag","selected":false,"rights":[{"name":"New","selected":false},{"name":"Update","selected":false},{"name":"List","selected":false}]},{"name":"Feed","selected":false,"rights":[{"name":"New","selected":false},{"name":"Update","selected":false},{"name":"List","selected":false},{"name":"Info","selected":false}]},{"name":"Campaigns","selected":false,"rights":[{"name":"New","selected":false},{"name":"Update","selected":false},{"name":"Remove","selected":false},{"name":"List","selected":false},{"name":"Copy","selected":false}]},{"name":"Questions","selected":false,"rights":[{"name":"New","selected":false},{"name":"Update","selected":false},{"name":"Remove","selected":false},{"name":"List","selected":false}]},{"name":"POPCampaign","selected":false,"rights":[{"name":"New","selected":false},{"name":"Update","selected":false},{"name":"Remove","selected":false},{"name":"List","selected":false},{"name":"Stats","selected":false}]},{"name":"WADS","selected":false,"rights":[{"name":"Update","selected":false},{"name":"Remove","selected":false},{"name":"List","selected":false}]}]'); $timeout(function(){ $scope.disableTimer = false; },1500); if(navigator.userAgent.toLowerCase().indexOf('windows') > 0) { document.querySelector('.login-box').classList.add('windows'); } $scope.savePassword = function(){ $scope.Loading = true; $http({method: 'POST', url: "reset-password.html", transformRequest: function (obj) { var str = []; for (var p in obj) if (obj.hasOwnProperty(p)) { str.push(encodeURIComponent(p) + "=" + encodeURIComponent(obj[p])); } return str.join("&"); }, data: { email: $scope.save.email, key: $scope.save.key, password:$scope.save.password, retypepassword: $scope.save.retypepassword,do: "reset"}, headers: {'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'} }).success(function (data, status, headers, config) { $scope.Loading = false; if (data.code == "200") { window.location = "/login?AppID=DEVCMS&CurrentSession="+data.sessionID; } else { $scope.account.error = data.error; } }).error(function (data, status, headers, config) { $scope.Loading = false; }); }; $scope.getAccessLevel = function(){ $scope.Loading = true; $http({method: 'POST', url: "/login", transformRequest: function (obj) { var str = []; for (var p in obj) if (obj.hasOwnProperty(p)) { str.push(encodeURIComponent(p) + "=" + encodeURIComponent(obj[p])); } return str.join("&"); }, data: { AccessLevel: true }, headers: {'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'} }).success(function (data, status, headers, config) { var AccessLevelList = []; $scope.Loading = false; if (data.code == "200") { $scope.app.fullAccess = false; if(data.AccessLevel.length == 0){ $scope.app.fullAccess = true; } for (i = 0; i < data.AccessLevel.length; i++) { for (i2 = 0; i2 < data.AccessLevel[i].rights.length; i2++) { if(data.AccessLevel[i].rights[i2].selected){ AccessLevelList.push({ "class": data.AccessLevel[i].name, "function": data.AccessLevel[i].rights[i2].name }); } } } $scope.app.AccessLevelAllow = AccessLevelList; } }).error(function (data, status, headers, config) { $scope.Loading = false; }); }; $scope.resetPassword = function(){ $scope.Loading = true; $http({method: 'POST', url: "lost-password.html", transformRequest: function (obj) { var str = []; for (var p in obj) if (obj.hasOwnProperty(p)) { str.push(encodeURIComponent(p) + "=" + encodeURIComponent(obj[p])); } return str.join("&"); }, data: { email: $scope.reset.email,do: "lostpassword"}, headers: {'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'} }).success(function (data, status, headers, config) { $scope.Loading = false; if (data.code == "200") { $scope.reset.done = true; } else { $scope.account.error = data.error; } }).error(function (data, status, headers, config) { $scope.Loading = false; }); }; $scope.register = function () { if ($scope.newUser.tos) { $scope.Loading = true; $http({method: 'POST', url: "register.html", transformRequest: function (obj) { var str = []; for (var p in obj) if (obj.hasOwnProperty(p)) { str.push(encodeURIComponent(p) + "=" + encodeURIComponent(obj[p])); } return str.join("&"); }, data: {tos: "on", grecaptcharesponse: $("#g-recaptcha-response").val(), password: $scope.newUser.password, retypepassword: $scope.newUser.retypePassword, Organization: $scope.newUser.organization, email: $scope.newUser.email, FirstName: $scope.newUser.firstName, LastName: $scope.newUser.lastName, do: "register", r_noemail:$scope.noemail}, headers: {'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'} }).success(function (data, status, headers, config) { if (data.code == "200") { $scope.newUser.registerDone = true; window.location = "/login?AppID=DEVCMS&CurrentSession="+data.sessionID; } else { grecaptcha.reset(); $scope.account.error = data.error; } $scope.Loading = false; }).error(function (data, status, headers, config) { $scope.Loading = false; }); } else { $scope.Loading = false; $scope.account.error = "To use this service you will need to agree to the terms of service."; } }; $scope.login = function () { $scope.Loading = true; var password = md5($scope.account.password); var email = $scope.account.email; $http({method: 'POST', url: "/login", transformRequest: function (obj) { var str = []; for (var p in obj) if (obj.hasOwnProperty(p)) { str.push(encodeURIComponent(p) + "=" + encodeURIComponent(obj[p])); } return str.join("&"); }, data: {username: email, password: password, do: "login"}, headers: {'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'} }).success(function (data, status, headers, config) { $scope.Loading = false; if (data.code == "200") { location.reload(); } else { $scope.account.error = data.error; } }).error(function (data, status, headers, config) { $scope.Loading = false; }); }; $scope.newApp = function () { $scope.Loading = true; var AccessLevel = []; if (!$scope.app.fullAccess) { AccessLevel = angular.toJson($scope.app.AccessLevel); } $http({method: 'POST', url: "login", transformRequest: function (obj) { var str = []; for (var p in obj) if (obj.hasOwnProperty(p)) { str.push(encodeURIComponent(p) + "=" + encodeURIComponent(obj[p])); } return str.join("&"); }, data: { Name: $scope.app.name, About: $scope.app.about, RedirectURL: $scope.app.url, AccessLevel: AccessLevel, do: "newapp" }, headers: {'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'} }).success(function (data, status, headers, config) { $scope.Loading = false; if (data.code == "200") { window.location = "/login?AppID=" + data.AppID; } else { $scope.account.error = data.error; } }).error(function (data, status, headers, config) { $scope.Loading = false; }); }; function md5cycle(x, k) { var a = x[0], b = x[1], c = x[2], d = x[3]; a = ff(a, b, c, d, k[0], 7, -680876936); d = ff(d, a, b, c, k[1], 12, -389564586); c = ff(c, d, a, b, k[2], 17, 606105819); b = ff(b, c, d, a, k[3], 22, -1044525330); a = ff(a, b, c, d, k[4], 7, -176418897); d = ff(d, a, b, c, k[5], 12, 1200080426); c = ff(c, d, a, b, k[6], 17, -1473231341); b = ff(b, c, d, a, k[7], 22, -45705983); a = ff(a, b, c, d, k[8], 7, 1770035416); d = ff(d, a, b, c, k[9], 12, -1958414417); c = ff(c, d, a, b, k[10], 17, -42063); b = ff(b, c, d, a, k[11], 22, -1990404162); a = ff(a, b, c, d, k[12], 7, 1804603682); d = ff(d, a, b, c, k[13], 12, -40341101); c = ff(c, d, a, b, k[14], 17, -1502002290); b = ff(b, c, d, a, k[15], 22, 1236535329); a = gg(a, b, c, d, k[1], 5, -165796510); d = gg(d, a, b, c, k[6], 9, -1069501632); c = gg(c, d, a, b, k[11], 14, 643717713); b = gg(b, c, d, a, k[0], 20, -373897302); a = gg(a, b, c, d, k[5], 5, -701558691); d = gg(d, a, b, c, k[10], 9, 38016083); c = gg(c, d, a, b, k[15], 14, -660478335); b = gg(b, c, d, a, k[4], 20, -405537848); a = gg(a, b, c, d, k[9], 5, 568446438); d = gg(d, a, b, c, k[14], 9, -1019803690); c = gg(c, d, a, b, k[3], 14, -187363961); b = gg(b, c, d, a, k[8], 20, 1163531501); a = gg(a, b, c, d, k[13], 5, -1444681467); d = gg(d, a, b, c, k[2], 9, -51403784); c = gg(c, d, a, b, k[7], 14, 1735328473); b = gg(b, c, d, a, k[12], 20, -1926607734); a = hh(a, b, c, d, k[5], 4, -378558); d = hh(d, a, b, c, k[8], 11, -2022574463); c = hh(c, d, a, b, k[11], 16, 1839030562); b = hh(b, c, d, a, k[14], 23, -35309556); a = hh(a, b, c, d, k[1], 4, -1530992060); d = hh(d, a, b, c, k[4], 11, 1272893353); c = hh(c, d, a, b, k[7], 16, -155497632); b = hh(b, c, d, a, k[10], 23, -1094730640); a = hh(a, b, c, d, k[13], 4, 681279174); d = hh(d, a, b, c, k[0], 11, -358537222); c = hh(c, d, a, b, k[3], 16, -722521979); b = hh(b, c, d, a, k[6], 23, 76029189); a = hh(a, b, c, d, k[9], 4, -640364487); d = hh(d, a, b, c, k[12], 11, -421815835); c = hh(c, d, a, b, k[15], 16, 530742520); b = hh(b, c, d, a, k[2], 23, -995338651); a = ii(a, b, c, d, k[0], 6, -198630844); d = ii(d, a, b, c, k[7], 10, 1126891415); c = ii(c, d, a, b, k[14], 15, -1416354905); b = ii(b, c, d, a, k[5], 21, -57434055); a = ii(a, b, c, d, k[12], 6, 1700485571); d = ii(d, a, b, c, k[3], 10, -1894986606); c = ii(c, d, a, b, k[10], 15, -1051523); b = ii(b, c, d, a, k[1], 21, -2054922799); a = ii(a, b, c, d, k[8], 6, 1873313359); d = ii(d, a, b, c, k[15], 10, -30611744); c = ii(c, d, a, b, k[6], 15, -1560198380); b = ii(b, c, d, a, k[13], 21, 1309151649); a = ii(a, b, c, d, k[4], 6, -145523070); d = ii(d, a, b, c, k[11], 10, -1120210379); c = ii(c, d, a, b, k[2], 15, 718787259); b = ii(b, c, d, a, k[9], 21, -343485551); x[0] = add32(a, x[0]); x[1] = add32(b, x[1]); x[2] = add32(c, x[2]); x[3] = add32(d, x[3]); } function cmn(q, a, b, x, s, t) { a = add32(add32(a, q), add32(x, t)); return add32((a << s) | (a >>> (32 - s)), b); } function ff(a, b, c, d, x, s, t) { return cmn((b & c) | ((~b) & d), a, b, x, s, t); } function gg(a, b, c, d, x, s, t) { return cmn((b & d) | (c & (~d)), a, b, x, s, t); } function hh(a, b, c, d, x, s, t) { return cmn(b ^ c ^ d, a, b, x, s, t); } function ii(a, b, c, d, x, s, t) { return cmn(c ^ (b | (~d)), a, b, x, s, t); } function md51(s) { txt = ''; var n = s.length, state = [1732584193, -271733879, -1732584194, 271733878], i; for (i = 64; i <= s.length; i += 64) { md5cycle(state, md5blk(s.substring(i - 64, i))); } s = s.substring(i - 64); var tail = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]; for (i = 0; i < s.length; i++) tail[i >> 2] |= s.charCodeAt(i) << ((i % 4) << 3); tail[i >> 2] |= 0x80 << ((i % 4) << 3); if (i > 55) { md5cycle(state, tail); for (i = 0; i < 16; i++) tail[i] = 0; } tail[14] = n * 8; md5cycle(state, tail); return state; } /* there needs to be support for Unicode here, * unless we pretend that we can redefine the MD-5 * algorithm for multi-byte characters (perhaps * by adding every four 16-bit characters and * shortening the sum to 32 bits). Otherwise * I suggest performing MD-5 as if every character * was two bytes--e.g., 0040 0025 = @%--but then * how will an ordinary MD-5 sum be matched? * There is no way to standardize text to something * like UTF-8 before transformation; speed cost is * utterly prohibitive. The JavaScript standard * itself needs to look at this: it should start * providing access to strings as preformed UTF-8 * 8-bit unsigned value arrays. */ function md5blk(s) { /* I figured global was faster. */ var md5blks = [], i; /* Andy King said do it this way. */ for (i = 0; i < 64; i += 4) { md5blks[i >> 2] = s.charCodeAt(i) + (s.charCodeAt(i + 1) << 8) + (s.charCodeAt(i + 2) << 16) + (s.charCodeAt(i + 3) << 24); } return md5blks; } var hex_chr = '0123456789abcdef'.split(''); function rhex(n) { var s = '', j = 0; for (; j < 4; j++) s += hex_chr[(n >> (j * 8 + 4)) & 0x0F] + hex_chr[(n >> (j * 8)) & 0x0F]; return s; } function hex(x) { for (var i = 0; i < x.length; i++) x[i] = rhex(x[i]); return x.join(''); } function md5(s) { return hex(md51(s)); } /* this function is much faster, so if possible we use it. Some IEs are the only ones I know of that need the idiotic second function, generated by an if clause. */ function add32(a, b) { return (a + b) & 0xFFFFFFFF; } if (md5('hello') != '5d41402abc4b2a76b9719d911017c592') { function add32(x, y) { var lsw = (x & 0xFFFF) + (y & 0xFFFF), msw = (x >> 16) + (y >> 16) + (lsw >> 16); return (msw << 16) | (lsw & 0xFFFF); } } function SetPasswd() { $('#passwd').val(md5($('#passwdin').val())); return true; } $scope.getAccessLevel(); }]);