2015-06-01 6 views
0

Как я могу сделать, чтобы отменить токен для пользователя?Как отменить токен для пользователя

Это мой код аутентификации, и я хочу сбросить (отменить) доступ для одного пользователя. Это связано с тем, что я использую GMail API, и я хочу, чтобы мой пользователь мог изменить их электронную почту, если это необходимо.

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

Dim datafolder As String = Server.MapPath("App_Data/GoogleService.api.auth.store") 
     Dim scopes As IList(Of String) = New List(Of String)() 
     Dim UserId As String = Context.User.Identity.Name.ToString 

     scopes.Add(DriveService.Scope.Drive) 
     scopes.Add(GmailService.Scope.MailGoogleCom) 
     Dim myclientsecret As New ClientSecrets() With { _ 
      .ClientId = CLIENT_ID, _ 
      .ClientSecret = CLIENT_SECRET _ 
     } 

     Dim flow As GoogleAuthorizationCodeFlow 

     flow = New GoogleAuthorizationCodeFlow(New GoogleAuthorizationCodeFlow.Initializer() With { _ 
      .DataStore = New FileDataStore(datafolder), _ 
      .ClientSecrets = myclientsecret, _ 
      .Scopes = scopes _ 
     }) 

     Dim uri As String = Request.Url.ToString() 

     Dim code = Request("code") 

     If code IsNot Nothing Then 
      Dim token = flow.ExchangeCodeForTokenAsync(UserId, code, uri.Substring(0, uri.IndexOf("?")), CancellationToken.None).Result 

      ' Extract the right state. 
      Dim oauthState = AuthWebUtility.ExtracRedirectFromState(flow.DataStore, UserId, Request("state")).Result 
      Response.Redirect(oauthState) 
     Else 
      Dim result = New AuthorizationCodeWebApp(flow, uri, uri).AuthorizeAsync(UserId, CancellationToken.None).Result 
      If result.RedirectUri IsNot Nothing Then 
       ' Redirect the user to the authorization server. 
       Response.Redirect(result.RedirectUri) 
      Else 
       ' The data store contains the user credential, so the user has been already authenticated. 
       myDriveService = New DriveService(New BaseClientService.Initializer() With { _ 
        .ApplicationName = "Liens Google SyGED", _ 
        .HttpClientInitializer = result.Credential _ 
       }) 

       myGMailService = New GmailService(New BaseClientService.Initializer() With { _ 
       .ApplicationName = "Liens Google SyGED", _ 
       .HttpClientInitializer = result.Credential _ 
      }) 

      End If 
     End If 
+1

Вы пробовали просто удалить файл для идентификатора пользователя? – DaImTo

+0

Не найден файл на моем сервере –

+1

Filedatastore хранит файл в% appdata% вы проверили там? – DaImTo

ответ

Смежные вопросы