私のアプリには2つのページがあります:main.html
とlogin.html
。認証されていないユーザーがアクセスする/main
場合は、にリダイレクトする必要があります/login
。
問題は、main.html
最初にレンダリングされ、1秒ほど後に、ユーザー認証が失敗したときにlogin.html
レンダリングされることです。
main.html
認証が成功するまでレンダリングされないようにするにはどうすればよいですか?
関連するコード(CoffeeScript)は次のとおりです。
angular.module('myApp', [...])
.config(['$routeProvider', ($routeProvider) ->
$routeProvider.when '/login',
templateUrl: 'html/login.html'
controller: LoginController
$routeProvider.otherwise
templateUrl: 'html/main.html'
controller: MainController
])
.run(['$rootScope', '$location', 'appService', ($rootScope, $location, app) ->
$rootScope.$on '$locationChangeStart', (event, newValue, oldValue) ->
return if newValue == '/login'
$.when(app.authenticate()).fail ->
$location.path '/login'
$rootScope.$apply()
])
angular.module('myApp.services').factory 'appService' , () ->
rootRef = new Firebase('https://myapp.firebaseio.com')
user: null
authenticate: ->
deferred = $.Deferred()
authClient = new FirebaseAuthClient rootRef, (error, user) =>
if error
# An error occurred while attempting login
@user = null
deferred.reject()
else if user
# User authenticated with Firebase
@user = user
deferred.resolve()
else
# User is logged out
@user = null
deferred.reject()
deferred.promise()