com.azure.identity.AuthenticationRecord Maven / Gradle / Ivy
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
package com.azure.identity;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.microsoft.aad.msal4j.IAuthenticationResult;
import reactor.core.publisher.Mono;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
/**
* Authentication Record represents the account information of the authenticated account.
* This is helpful in scenarios where applications require brokered authentication via {@link DeviceCodeCredential}
* or {@link InteractiveBrowserCredential}.
*
* Authentication record is returned when
* {@link DeviceCodeCredential#authenticate()} or {@link InteractiveBrowserCredential#authenticate()} api is invoked.
* The returned auth record can be stored/persisted in the user application. Further, this record can be configured on
* the {@link DeviceCodeCredentialBuilder#authenticationRecord(AuthenticationRecord)} or
* {@link InteractiveBrowserCredentialBuilder#authenticationRecord(AuthenticationRecord)} to proactively indicate
* that a previously authenticated account should be used from the persisted cache instead of authenticating again.
*
* @see DeviceCodeCredential
* @see InteractiveBrowserCredential
*/
public final class AuthenticationRecord {
private static final ObjectMapper OBJECT_MAPPER = new ObjectMapper();
@JsonProperty("authority")
private String authority;
@JsonProperty("homeAccountId")
private String homeAccountId;
@JsonProperty("tenantId")
private String tenantId;
@JsonProperty("username")
private String username;
@JsonProperty("clientId")
private String clientId;
AuthenticationRecord() { }
AuthenticationRecord(IAuthenticationResult authenticationResult, String tenantId, String clientId) {
authority = authenticationResult.account().environment();
homeAccountId = authenticationResult.account().homeAccountId();
username = authenticationResult.account().username();
this.tenantId = tenantId;
this.clientId = clientId;
}
/**
* Get the authority host used to authenticate the account.
*
* @return the authority host.
*/
public String getAuthority() {
return authority;
}
/**
* Get the unique identifier of the account.
*
* @return the account id.
*/
public String getHomeAccountId() {
return homeAccountId;
}
/**
* Get the tenant, which the account authenticated in.
*
* @return the tenant id.
*/
public String getTenantId() {
return tenantId;
}
/**
* Get the client id of the application used for authentication.
*
* @return the client id.
*/
public String getClientId() {
return clientId;
}
/**
* Get the user principal name of the account.
*
* @return the username.
*/
public String getUsername() {
return username;
}
/**
* Serializes the {@link AuthenticationRecord} to the specified {@link OutputStream}
*
* @param outputStream The {@link OutputStream} to which the serialized record will be written to.
* @return A {@link Mono} containing {@link Void}
*/
public Mono serializeAsync(OutputStream outputStream) {
return Mono.defer(() -> {
try {
OBJECT_MAPPER.writeValue(outputStream, this);
} catch (IOException e) {
return Mono.error(e);
}
return Mono.just(outputStream);
});
}
/**
* Serializes the {@link AuthenticationRecord} to the specified {@link OutputStream}
*
* @param outputStream The {@link OutputStream} to which the serialized record will be written to.
*/
public void serialize(OutputStream outputStream) {
serializeAsync(outputStream).block();
}
/**
* Deserializes the {@link AuthenticationRecord} from the specified {@link InputStream}
*
* @param inputStream The {@link InputStream} from which the serialized record will be read.
* @return A {@link Mono} containing the {@link AuthenticationRecord} object.
*/
public static Mono deserializeAsync(InputStream inputStream) {
return Mono.defer(() -> {
AuthenticationRecord authenticationRecord;
try {
authenticationRecord =
OBJECT_MAPPER.readValue(inputStream, AuthenticationRecord.class);
} catch (IOException e) {
return Mono.error(e);
}
return Mono.just(authenticationRecord);
});
}
/**
* Deserializes the {@link AuthenticationRecord} from the specified {@link InputStream}
*
* @param inputStream The {@link InputStream} from which the serialized record will be read.
* @return the {@link AuthenticationRecord} object.
*/
public static AuthenticationRecord deserialize(InputStream inputStream) {
return deserializeAsync(inputStream).block();
}
}