當前位置: 首頁>>代碼示例>>Java>>正文


Java TokenPair類代碼示例

本文整理匯總了Java中com.microsoft.alm.secret.TokenPair的典型用法代碼示例。如果您正苦於以下問題:Java TokenPair類的具體用法?Java TokenPair怎麽用?Java TokenPair使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


TokenPair類屬於com.microsoft.alm.secret包,在下文中一共展示了TokenPair類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: removeOAuth2Token

import com.microsoft.alm.secret.TokenPair; //導入依賴的package包/類
public static void removeOAuth2Token(final boolean force) {
    final Authenticator authenticator =
        OAuth2Authenticator.getAuthenticator(CLIENT_ID, REDIRECT_URL, accessTokenStore);

    final String tokenKey =
        authenticator.getUriToKeyConversion().convert(URIUtils.VSTS_ROOT_URL, authenticator.getAuthType());
    final TokenPair oauth2TokenPair = accessTokenStore.get(tokenKey);

    if (oauth2TokenPair != null && oauth2TokenPair.AccessToken != null) {
        final String token = oauth2TokenPair.AccessToken.Value;

        if (force || !isOAuth2TokenValid(token)) {
            accessTokenStore.delete(tokenKey);
        }
    }
}
 
開發者ID:Microsoft,項目名稱:team-explorer-everywhere,代碼行數:17,代碼來源:CredentialsHelper.java

示例2: completeSignIn

import com.microsoft.alm.secret.TokenPair; //導入依賴的package包/類
/**
 * Generates a new server context with session token information for VSO and saves it as the active context
 *
 * @param context
 * @return
 */
public ServerContext completeSignIn(final ServerContext context) {
    if (context.getType() == ServerContext.Type.TFS) {
        //get authenticated user for the collection since user Id is different when authenticated to server vs collection
        return ServerContextManager.getInstance().validateServerConnection(context);
    } else {
        final ServerContext effectiveContext;

        final AuthenticationInfo authenticationInfo = context.getAuthenticationInfo();
        if (AuthenticationInfo.CredsType.AccessToken.equals(authenticationInfo.getType())) {
            final TokenPair tokenPair
                    = new TokenPair(authenticationInfo.getPassword(), authenticationInfo.getRefreshToken());

            final AuthenticationInfo patBackedAuthenticationInfo
                    = VsoAuthInfoProvider.getProvider().getAuthenticationInfo(context.getServerUri(), tokenPair);

            effectiveContext = new ServerContextBuilder(context).authentication(patBackedAuthenticationInfo).build();
        } else {
            effectiveContext = context;
        }

        ServerContextManager.getInstance().add(effectiveContext);
        return effectiveContext;
    }
}
 
開發者ID:Microsoft,項目名稱:vso-intellij,代碼行數:31,代碼來源:LoginPageModelImpl.java

示例3: interactiveLogon

import com.microsoft.alm.secret.TokenPair; //導入依賴的package包/類
/**
 * Opens an interactive logon prompt to acquire acquire an authentication token from the
 * Microsoft Live authentication and identity service.
 *
 * @param targetUri
 * The uniform resource indicator of the resource access tokens are being requested for.
 * 
 * @param requireCompactToken
 * True if a compact access token is required; false if a standard token is acceptable.
 * 
 * @return True if successful; otherwise false.
 */
@Override public boolean interactiveLogon(URI targetUri, boolean requireCompactToken)
{
    final String QueryParameters = "domain_hint=live.com&display=popup&site_id=501454&nux=1";

    BaseSecureStore.validateTargetUri(targetUri);

    Trace.writeLine("VsoMsaAuthentication::InteractiveLogon");

    TokenPair tokens;
    if ((tokens = this.VsoAuthority.acquireToken(targetUri, this.ClientId, this.Resource, RedirectUri, QueryParameters)) != null)
    {
        Trace.writeLine("   token successfully acquired.");

        this.storeRefreshToken(targetUri, tokens.RefreshToken);

        return this.generatePersonalAccessToken(targetUri, tokens.AccessToken, requireCompactToken);
    }

    Trace.writeLine("   failed to acquire token.");
    return false;
}
 
開發者ID:Microsoft,項目名稱:Git-Credential-Manager-for-Mac-and-Linux,代碼行數:34,代碼來源:VsoMsaAuthentication.java

示例4: deviceLogon

import com.microsoft.alm.secret.TokenPair; //導入依賴的package包/類
public boolean deviceLogon(final URI targetUri, final boolean requestCompactToken, final Action<DeviceFlowResponse> callback)
{
    BaseSecureStore.validateTargetUri(targetUri);

    Trace.writeLine("VsoMsaAuthentication::deviceLogon");

    TokenPair tokens;
    if ((tokens = this.VsoAuthority.acquireToken(targetUri, this.ClientId, this.Resource, RedirectUri, callback)) != null)
    {
        Trace.writeLine("   token successfully acquired.");

        this.storeRefreshToken(targetUri, tokens.RefreshToken);

        return this.generatePersonalAccessToken(targetUri, tokens.AccessToken, requestCompactToken);
    }

    Trace.writeLine("   failed to acquire token.");
    return false;
}
 
開發者ID:Microsoft,項目名稱:Git-Credential-Manager-for-Mac-and-Linux,代碼行數:20,代碼來源:VsoMsaAuthentication.java

示例5: interactiveLogon

import com.microsoft.alm.secret.TokenPair; //導入依賴的package包/類
/**
 * <p>Creates an interactive logon session, using ADAL secure browser GUI, which
 * enables users to authenticate with the Azure tenant and acquire the necessary access
 * tokens to exchange for a VSO personal access token.</p>
 * <p>Tokens acquired are stored in the secure secret stores provided during
 * initialization.</p>
 *
 * @param targetUri           The unique identifier for the resource for which access is to
 *                            be acquired.
 * @param requestCompactToken <p>Requests a compact format personal access token; otherwise requests a standard
 *                            personal access token.</p>
 *                            <p>Compact tokens are necessary for clients which have restrictions on the size of
 *                            the basic authentication header which they can create (example: Git).</p>
 * @return                    True if a authentication and personal access token acquisition was successful; otherwise false.
 */
public boolean interactiveLogon(final URI targetUri, final boolean requestCompactToken)
{
    BaseSecureStore.validateTargetUri(targetUri);

    Trace.writeLine("VsoAadAuthentication::interactiveLogon");

    TokenPair tokens;
    if ((tokens = this.VsoAuthority.acquireToken(targetUri, this.ClientId, this.Resource, RedirectUri, (String) null)) != null)
    {
        Trace.writeLine("   token acquisition succeeded.");

        this.storeRefreshToken(targetUri, tokens.RefreshToken);

        return this.generatePersonalAccessToken(targetUri, tokens.AccessToken,  requestCompactToken);
    }

    Trace.writeLine("   interactive logon failed");
    return false;
}
 
開發者ID:Microsoft,項目名稱:Git-Credential-Manager-for-Mac-and-Linux,代碼行數:35,代碼來源:VsoAadAuthentication.java

示例6: deviceLogon

import com.microsoft.alm.secret.TokenPair; //導入依賴的package包/類
public boolean deviceLogon(final URI targetUri, final boolean requestCompactToken, final Action<DeviceFlowResponse> callback)
{
    BaseSecureStore.validateTargetUri(targetUri);

    Trace.writeLine("VsoAadAuthentication::deviceLogon");

    TokenPair tokens;
    if ((tokens = this.VsoAuthority.acquireToken(targetUri, this.ClientId, this.Resource, RedirectUri, callback)) != null)
    {
        Trace.writeLine("   token successfully acquired.");

        this.storeRefreshToken(targetUri, tokens.RefreshToken);

        return this.generatePersonalAccessToken(targetUri, tokens.AccessToken, requestCompactToken);
    }

    Trace.writeLine("   failed to acquire token.");
    return false;
}
 
開發者ID:Microsoft,項目名稱:Git-Credential-Manager-for-Mac-and-Linux,代碼行數:20,代碼來源:VsoAadAuthentication.java

示例7: VsoAuthInfoProvider

import com.microsoft.alm.secret.TokenPair; //導入依賴的package包/類
private VsoAuthInfoProvider() {
    accessTokenStore = new InsecureInMemoryStore<TokenPair>();
    tokenStore = new InsecureInMemoryStore<Token>();

    deviceFlowResponsePrompt = PluginServiceProvider.getInstance().getDeviceFlowResponsePrompt();

    vstsPatAuthenticator = new VstsPatAuthenticator(CLIENT_ID, REDIRECT_URL, accessTokenStore, tokenStore);
}
 
開發者ID:Microsoft,項目名稱:vso-intellij,代碼行數:9,代碼來源:VsoAuthInfoProvider.java

示例8: acquireToken

import com.microsoft.alm.secret.TokenPair; //導入依賴的package包/類
public TokenPair acquireToken(final URI targetUri, final String clientId, final String resource, final URI redirectUri, final Action<DeviceFlowResponse> callback)
{
    Debug.Assert(targetUri != null && targetUri.isAbsolute(), "The targetUri parameter is null or invalid");
    Debug.Assert(!StringHelper.isNullOrWhiteSpace(clientId), "The clientId parameter is null or empty");
    Debug.Assert(!StringHelper.isNullOrWhiteSpace(resource), "The resource parameter is null or empty");
    Debug.Assert(callback != null, "The callback parameter is null");

    Trace.writeLine("AzureAuthority::acquireToken");

    _azureDeviceFlow.setResource(resource);
    _azureDeviceFlow.setRedirectUri(redirectUri);
    final StringBuilder sb = new StringBuilder(authorityHostUrl);
    sb.append("/oauth2/devicecode");
    final URI deviceEndpoint = URI.create(sb.toString());
    final DeviceFlowResponse response = _azureDeviceFlow.requestAuthorization(deviceEndpoint, clientId, null);

    callback.call(response);

    TokenPair tokens = null;
    final URI tokenEndpoint = createTokenEndpointUri(authorityHostUrl);
    try
    {
        tokens = _azureDeviceFlow.requestToken(tokenEndpoint, clientId, response);

        Trace.writeLine("   token acquisition succeeded.");
    }
    catch (final AuthorizationException e)
    {
        Trace.writeLine("   token acquisition failed: ", e);
    }
    return tokens;
}
 
開發者ID:Microsoft,項目名稱:Git-Credential-Manager-for-Mac-and-Linux,代碼行數:33,代碼來源:AzureAuthority.java

示例9: getAuthenticationInfoAsync

import com.microsoft.alm.secret.TokenPair; //導入依賴的package包/類
@Override
public void getAuthenticationInfoAsync(String serverUri, final AuthenticationInfoCallback callback) {
    final SettableFuture<AuthenticationInfo> authenticationInfoFuture = SettableFuture.<AuthenticationInfo>create();

    // Callback for the Device Flow dialog to cancel the current authenticating process.
    // Normally this is hooked up to the cancel button so if user cancels, we do not wait forever in
    // a polling loop.
    final Action<String> cancellationCallback = new Action<String>() {
        @Override
        public void call(final String reasonForCancel) {
            authenticationInfoFuture.setException(new AuthorizationException(reasonForCancel));
        }
    };

    // Must share the same accessTokenStore with the member variable vstsPatAuthenticator to avoid prompt the user
    // when we generate PersonalAccessToken
    final OAuth2Authenticator.OAuth2AuthenticatorBuilder oAuth2AuthenticatorBuilder = new OAuth2Authenticator.OAuth2AuthenticatorBuilder()
            .withClientId(CLIENT_ID)
            .redirectTo(REDIRECT_URL)
            .backedBy(accessTokenStore)
            .manage(OAuth2Authenticator.MANAGEMENT_CORE_RESOURCE)
            .withDeviceFlowCallback(deviceFlowResponsePrompt.getCallback(cancellationCallback));
    final OAuth2Authenticator oAuth2Authenticator = oAuth2AuthenticatorBuilder.build();

    final URI encodedServerUri = UrlHelper.createUri(serverUri);
    final TokenPair tokenPair = oAuth2Authenticator.getOAuth2TokenPair(encodedServerUri, PromptBehavior.AUTO);

    try {
        final AuthenticationInfo authenticationInfo = getAuthenticationInfo(encodedServerUri, tokenPair);

        if (authenticationInfo != null) {
            authenticationInfoFuture.set(authenticationInfo);
        } else {
            authenticationInfoFuture.setException(new TeamServicesException(TeamServicesException.KEY_VSO_AUTH_FAILED));
        }

    } catch (Throwable t) {
        authenticationInfoFuture.setException(t);
    }

    Futures.addCallback(authenticationInfoFuture, callback);
}
 
開發者ID:Microsoft,項目名稱:vso-intellij,代碼行數:43,代碼來源:VsoAuthInfoProvider.java

示例10: getAuthenticationInfo

import com.microsoft.alm.secret.TokenPair; //導入依賴的package包/類
public AuthenticationInfo getAuthenticationInfo(final URI serverUri, final TokenPair tokenPair) {

        if (tokenPair != null) {
            final Client client = RestClientHelper.getClient(serverUri.toString(), tokenPair.AccessToken.Value);

            if (client != null) {
                //Or we could reconsider the name of the token.  Now we call Profile endpoint just to get the email address
                //which is used in token description, but do we need it?  User can only view PATs after they login, and
                //at that time user knows which account/email they are logged in under already.  So the email provides
                //no additional value.
                final AccountHttpClient accountHttpClient
                        = new MyHttpClient(client, OAuth2Authenticator.APP_VSSPS_VISUALSTUDIO);

                final Profile me = accountHttpClient.getMyProfile();
                final String emailAddress = me.getCoreAttributes().getEmailAddress().getValue();
                final String tokenDescription = AuthHelper.getTokenDescription(emailAddress);

                if (serverUri.equals(OAuth2Authenticator.APP_VSSPS_VISUALSTUDIO)) {
                    logger.debug("Creating authenticationInfo backed by AccessToken for: {}", serverUri);
                    return new AuthenticationInfo(
                            me.getId().toString(),
                            tokenPair.AccessToken.Value,
                            serverUri.toString(),
                            emailAddress,
                            CredsType.AccessToken,
                            tokenPair.RefreshToken.Value);
                } else {
                    logger.debug("Getting a PersonalAccessToken for: {}", serverUri);
                    final Token token = vstsPatAuthenticator.getPersonalAccessToken(
                            serverUri,
                            VsoTokenScope.AllScopes,
                            tokenDescription,
                            PromptBehavior.AUTO,
                            tokenPair);

                    if (token != null) {
                        logger.debug("Creating authenticationInfo backed by PersonalAccessToken for: {}", serverUri);
                        return new AuthenticationInfo(
                                me.getId().toString(),
                                token.Value,
                                serverUri.toString(),
                                emailAddress,
                                CredsType.PersonalAccessToken,
                                null);
                    } else {
                        logger.warn("Failed to get a Personal Access Token");
                    }
                }
            } else {
                logger.warn("Failed to get authenticated jaxrs client.");
            }
        } else {
            logger.warn("Failed to get AuthenticationInfo because AccessToken is null.");
        }

        return null;
    }
 
開發者ID:Microsoft,項目名稱:vso-intellij,代碼行數:58,代碼來源:VsoAuthInfoProvider.java

示例11: refreshCredentials

import com.microsoft.alm.secret.TokenPair; //導入依賴的package包/類
/**
 * Attempts to generate a new personal access token (credentials) via use of a stored
 * Azure refresh token, identified by the target resource.
 *
 * @param targetUri           The 'key' by which to identify the refresh token.
 * @param requireCompactToken Generates a compact token if true; generates a self
 *                            describing token if false.
 * @return True if successful; false otherwise.
 */
public boolean refreshCredentials(final URI targetUri, final boolean requireCompactToken)
{
    BaseSecureStore.validateTargetUri(targetUri);

    Trace.writeLine("BaseVsoAuthentication::refreshCredentials");

    try
    {
        TokenPair tokens = null;

        AtomicReference<Token> refreshToken = new AtomicReference<Token>();
        // attempt to read from the local store
        if (this.AdaRefreshTokenStore.readToken(targetUri, refreshToken))
        {
            if ((tokens = this.VsoAuthority.acquireTokenByRefreshToken(targetUri, this.ClientId, this.Resource, refreshToken.get())) !=
                    null)
            {
                Trace.writeLine("   Azure token found in primary cache.");

                this.TenantId = tokens.AccessToken.getTargetIdentity();

                return this.generatePersonalAccessToken(targetUri, tokens.AccessToken, requireCompactToken);
            }
        }

        AtomicReference<Token> federatedAuthToken = new AtomicReference<Token>();
        // attempt to utilize any fedauth tokens captured by the IDE
        if (this.VsoIdeTokenCache.readToken(targetUri, federatedAuthToken))
        {
            Trace.writeLine("   federated auth token found in IDE cache.");

            return this.generatePersonalAccessToken(targetUri, federatedAuthToken.get(), requireCompactToken);
        }
    }
    catch (final Exception exception)
    {
        Debug.Assert(false, exception.getMessage());
    }

    Trace.writeLine("   failed to refresh credentials.");
    return false;
}
 
開發者ID:Microsoft,項目名稱:Git-Credential-Manager-for-Mac-and-Linux,代碼行數:52,代碼來源:BaseVsoAuthentication.java

示例12: acquireTokenByRefreshToken

import com.microsoft.alm.secret.TokenPair; //導入依賴的package包/類
/**
 * Acquires an access token from the authority using a previously acquired refresh token.
 *
 * @param targetUri    The uniform resource indicator of the resource access tokens are being requested for.
 * @param clientId     Identifier of the client requesting the token.
 * @param resource     Identifier of the target resource that is the recipient of the requested token.
 * @param refreshToken The {@link Token} of type {@link TokenType#Refresh}.
 * @return If successful, a {@link TokenPair}; otherwise null.
 */
public TokenPair acquireTokenByRefreshToken(final URI targetUri, final String clientId, final String resource, final Token refreshToken)
{
    throw new NotImplementedException(449243);
}
 
開發者ID:Microsoft,項目名稱:Git-Credential-Manager-for-Mac-and-Linux,代碼行數:14,代碼來源:AzureAuthority.java

示例13: buildTokenPair

import com.microsoft.alm.secret.TokenPair; //導入依賴的package包/類
/**
 * Allows subclasses to construct a subclass of {@link TokenPair} with extra metadata, etc.
 *
 * @param responseText the JSON response received from the token endpoint.
 *
 * @return             a {@link TokenPair} (or subclass thereof).
 */
protected TokenPair buildTokenPair(final String responseText) {
    final TokenPair tokenPair = new TokenPair(responseText);
    return tokenPair;
}
 
開發者ID:Microsoft,項目名稱:Git-Credential-Manager-for-Mac-and-Linux,代碼行數:12,代碼來源:DeviceFlowImpl.java

示例14: requestToken

import com.microsoft.alm.secret.TokenPair; //導入依賴的package包/類
/**
 * The client polls the authorization server's token endpoint repeatedly
 * until the end-user grants or denies the request, or the verification
 * code expires.
 *
 * @param tokenEndpoint           the authorization server's
 *                                token endpoint as described in Section 4.1.1 of RFC6749.
 * @param clientId                the client identifier as described in Section 2.2 of RFC6749.
 * @param deviceFlowResponse      the response obtained from
 *                                {@link #requestAuthorization(URI, String, String)}.
 * @return                        a pair of tokens.
 * @throws AuthorizationException the end-user denied the request,
 *                                or the verification code expired.
 *
 * @see                           "steps (E) and (F) of the Device Flow"
 */
TokenPair requestToken(final URI tokenEndpoint, String clientId, final DeviceFlowResponse deviceFlowResponse) throws AuthorizationException;
 
開發者ID:Microsoft,項目名稱:Git-Credential-Manager-for-Mac-and-Linux,代碼行數:18,代碼來源:DeviceFlow.java

示例15: acquireToken

import com.microsoft.alm.secret.TokenPair; //導入依賴的package包/類
TokenPair acquireToken(final URI targetUri, final String clientId, final String resource, final URI redirectUri, final String queryParameters); 
開發者ID:Microsoft,項目名稱:Git-Credential-Manager-for-Mac-and-Linux,代碼行數:2,代碼來源:IAzureAuthority.java


注:本文中的com.microsoft.alm.secret.TokenPair類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。