Показать сообщение отдельно
  #3 (permalink)  
Старый 24.09.2013, 22:47
Профессор
Отправить личное сообщение для DjDiablo Посмотреть профиль Найти все сообщения от DjDiablo
 
Регистрация: 04.02.2011
Сообщений: 1,815

Я любопытства ради попробывал сделать авторизацию в VK.
Идея в том что хитрый метод access (в котором был кэлбек логикой доступной только авторизованных) вызывал кэлбек если пользователь уже авторизован, либо вызывал окно авторизации и вызывал кэлбек после авторизации.

Собственно это идея сквозного функционала, теперь в любой директиве или контролере можно делать защищенные участки кода которые выполнятся только для авторизованных пользователей.

<!DOCTYPE HTML>
  <html ng-app="project">
    <head>         
      <script src="//vk.com/js/api/openapi.js"></script>
      <script src="http://code.angularjs.org/angular-1.0.1.js"></script>    
    </head>
    <body >      
    <script>      
      
  var projectModule = angular.module('project',[]);  
  projectModule.factory('user', function() {      
   var vk = {
     data: {}, 
     appID: 3896712, // как веб сайт
     appPermissions: 16,

     //инициализация
     init: function(){      
       VK.init({apiId: vk.appID});                      
     },

     //метод входа
     login:function(callback){                    
       
        function authInfo(response){     
             if(response.session){ // Авторизация успешна
               vk.data.user = response.session.user;
               callback(vk.data.user);                            
             }else {
               alert("Авторизоваться не удалось!");
             }     
        }                       
    
        VK.Auth.login(authInfo, vk.appPermissions);
     },

     //метод проверки доступа
     access:function(callback){
       VK.Auth.getLoginStatus(function(response) { 
         if(response.session){ // Пользователь авторизован
           callback(vk.data.user);
         }else { // Пользователь не авторизован
           vk.login(callback);         
         }                    
       })     
     },

     logout:function(){
       VK.Auth.logout();
       this.data.user={};
       alert('вы вышли');
     }
   
  }
  
   vk.init();       
   return vk;     
    
  });
  
      
  function FirstCtrl($scope, user) {	    
    $scope.logout=function(){
       user.logout();
    }

    user.access(function(usr){
       alert('Этот код исполнится только для авторизованных');
       console.log(usr);      
    });
    
  }         
      </script>
  
      <div ng-controller="FirstCtrl">
        <button ng-click="logout()">Разлогинится</button>		   		
      </div>
  
    </body>
  </html>
__________________
Лучше калымить в гандурасе чем гандурасить на колыме

Последний раз редактировалось DjDiablo, 25.09.2013 в 02:33.
Ответить с цитированием