From 9ca91d02c5252cb66d600005f05a6bf13cfee1fe Mon Sep 17 00:00:00 2001 From: Igor Zhukov Date: Wed, 22 Jan 2014 10:42:43 +0400 Subject: [PATCH] Fixed baseDcId update for authorization --- app/index.html | 4 ++-- app/js/controllers.js | 10 +++++----- app/js/lib/mtproto.js | 6 +++++- 3 files changed, 12 insertions(+), 8 deletions(-) diff --git a/app/index.html b/app/index.html index 7d25d4a8..7a43a856 100644 --- a/app/index.html +++ b/app/index.html @@ -33,12 +33,12 @@ - + - + diff --git a/app/js/controllers.js b/app/js/controllers.js index 52f4a483..6161e3c7 100644 --- a/app/js/controllers.js +++ b/app/js/controllers.js @@ -22,13 +22,13 @@ angular.module('myApp.controllers', []) }) .controller('AppLoginController', function ($scope, $location, MtpApiManager, ErrorService) { - var dcID = 1; + var options = {dcID: 1}; $scope.credentials = {}; $scope.progress = {}; function saveAuth (result) { - MtpApiManager.setUserAuth(dcID, { + MtpApiManager.setUserAuth(options.dcID, { expires: result.expires, id: result.user.id }); @@ -40,7 +40,7 @@ angular.module('myApp.controllers', []) $scope.progress.enabled = true; MtpApiManager.invokeApi('auth.checkPhone', { phone_number: $scope.credentials.phone_number - }, {dcID: dcID}).then(function (result) { + }, options).then(function (result) { $scope.progress.enabled = false; if (!result.phone_registered) { ErrorService.showSimpleError('No account', 'Sorry, there is no Telegram account for ' + $scope.credentials.phone_number + '. Please sign up using our mobile apps.'); @@ -53,7 +53,7 @@ angular.module('myApp.controllers', []) sms_type: 0, api_id: 2496, api_hash: '8da85b0d5bfe62527e5b244c209159c3' - }, {dcID: dcID}).then(function (sentCode) { + }, options).then(function (sentCode) { $scope.progress.enabled = false; $scope.credentials.phone_code_hash = sentCode.phone_code_hash; @@ -98,7 +98,7 @@ angular.module('myApp.controllers', []) } $scope.progress.enabled = true; - MtpApiManager.invokeApi(method, params, {dcID: dcID}).then(saveAuth, function (error) { + MtpApiManager.invokeApi(method, params, options).then(saveAuth, function (error) { $scope.progress.enabled = false; if (error.code == 400 && error.type == 'PHONE_NUMBER_UNOCCUPIED') { return $scope.logIn(true); diff --git a/app/js/lib/mtproto.js b/app/js/lib/mtproto.js index 826e3fc9..f6694ff4 100644 --- a/app/js/lib/mtproto.js +++ b/app/js/lib/mtproto.js @@ -2244,7 +2244,11 @@ factory('MtpApiManager', function (AppConfigManager, MtpAuthorizer, MtpNetworker else if (error.code == 303) { var newDcID = error.type.match(/^(PHONE_MIGRATE_|NETWORK_MIGRATE_)(\d+)/)[2]; if (newDcID != dcID) { - AppConfigManager.set({dc: baseDcID = dcID}); + if (options.dcID) { + options.dcID = newDcID; + } else { + AppConfigManager.set({dc: baseDcID = newDcID}); + } mtpGetNetworker(newDcID).then(function (networker) { networker.wrapApiCall(method, params, options).then(function (result) {