Condividi tramite


Informazioni sui tipi di identificatore

Gli SDK dei Servizi di comunicazione e le API REST usano il tipo di identificatore per identificare chi sta comunicando con chi. Ad esempio, gli identificatori specificano chi chiamare o chi ha inviato un messaggio di chat.

A seconda del contesto, gli identificatori vengono incapsulati con proprietà aggiuntive, ad esempio all'interno di ChatParticipant in Chat SDK o all'interno di RemoteParticipant in Calling SDK.

In questo articolo verranno illustrati i diversi tipi di identificatori e il loro aspetto all’interno dei linguaggi di programmazione. Verranno inoltre forniti suggerimenti su come usarli.

Tipi di identificatore di comunicazione

Esistono identità utente, create dall'utente stesso, e identità esterne. Gli utenti e i numeri di telefono di Microsoft Teams sono identità esterne che vengono riprodotte in scenari di interoperabilità. Ognuno di questi diversi tipi di identità ha un identificatore corrispondente che lo rappresenta. Un identificatore è un tipo strutturato che offre sicurezza del tipo e funziona bene con il completamento del codice dell'editor.

Utente di comunicazione

L'interfaccia CommunicationUserIdentifier rappresenta un'identità utente creata usando Identity SDK o API REST. È l'unico identificatore usato se l'applicazione non usa l'interoperabilità di Microsoft Teams o le funzionalità di telefonia.

Utilizzo di base

// at some point you will have created a new user identity in your trusted service
const newUser = await identityClient.createUser();

// and then send newUser.communicationUserId down to your client application
// where you can again create an identifier for the user
const sameUser = { communicationUserId: newUserId };

Informazioni di riferimento sulle API

CommunicationUserIdentifier

Utente di Microsoft Teams

L'interfaccia MicrosoftTeamsUserIdentifier rappresenta un utente di Teams con l'ID oggetto utente di Microsoft Entra. È possibile recuperare l'ID oggetto utente di Microsoft Entra tramite l'endpoint REST API /utente di Microsoft Graph dalla idproprietà nella risposta. Per altre informazioni su come usare Microsoft Graph, provare Graph Explorer ed esaminare Graph SDK. In alternativa, è possibile trovare l'ID come oid attestazione in un token Microsoft Entra o un token di accesso di Microsoft Entra dopo che l'utente ha eseguito l'accesso e acquisito un token.

Utilizzo di base

// get the Teams user's ID from Graph APIs if only the email is known
const user = await graphClient.api("/users/bob@contoso.com").get();

// create an identifier
const teamsUser = { microsoftTeamsUserId: user.id };

// if you're not operating in the public cloud, you must also pass the right Cloud type.
const gcchTeamsUser = { microsoftTeamsUserId: userId, cloud: "gcch" };

Informazioni di riferimento sulle API

MicrosoftTeamsUserIdentifier

Numero di telefono

L'interfaccia PhoneNumberIdentifier rappresenta un numero di telefono. Il servizio presuppone che i numeri di telefono siano formattati in formato E.164.

Utilizzo di base

// create an identifier
const phoneNumber = { phoneNumber: "+112345556789" };

Informazioni di riferimento sulle API

PhoneNumberIdentifier

Applicazione Microsoft Teams

L'interfaccia MicrosoftTeamsAppIdentifier rappresenta un bot delle applicazioni di Teams Voice, come ad esempio Coda delle chiamate e Operatore automatico con l'ID oggetto bot Microsoft Entra. Le applicazioni di Teams devono essere configurate con un account di risorsa. È possibile recuperare l'ID oggetto bot Microsoft Entra tramite l'endpoint REST API /utente di Microsoft Graph dalla idproprietà nella risposta. Per altre informazioni su come usare Microsoft Graph, provare Graph Explorer ed esaminare Graph SDK.

Utilizzo di base

// Get the Microsoft Teams App's ID from Graph APIs
const users = await graphClient.api("/users")
                    .filter(filterConditions)
                    .select('displayName,id')
                    .get();
//Here we assume that you have a function getBotFromUsers that gets the bot from the returned response
const bot = getBotFromUsers(users);
// Create an identifier
const teamsAppIdentifier = { teamsAppId: bot.id };

// If you're not operating in the public cloud, you must also pass the right Cloud type.
const gcchTeamsAppIdentifier = { teamsAppId: id, cloud: "gcch" };

Informazioni di riferimento sulle API

MicrosoftTeamsAppIdentifier

Sconosciuto

L'interfaccia UnknownIdentifier esiste per la correzione futura e potrebbe essere presente in una versione precedente di SDK in cui sia stato recentemente introdotto un nuovo tipo di identificatore. Qualsiasi identificatore sconosciuto dal servizio verrà deserializzato in UnknownIdentifier in SDK.

Utilizzo di base

// create an identifier
const unknownId = { id: "a raw id that originated in the service" };

Informazioni di riferimento sulle API

UnknownIdentifier

Come gestire l'interfaccia CommunicationIdentifier di base

Mentre si costruiscono identificatori per un tipo concreto passato all'SDK, l'SDK restituisce un CommunicationIdentifierKind, che è un'unione discriminata. È facile restringersi a un tipo concreto e si suggerisce un'istruzione switch-case con criteri di ricerca:

switch (communicationIdentifier.kind)
{
    case "communicationUser":
        // TypeScript has narrowed communicationIdentifier to be a CommunicationUserKind
        console.log(`Communication user: ${communicationIdentifier.communicationUserId}`);
        break;
    case "microsoftTeamsUser":
        // narrowed to MicrosoftTeamsUserKind
        console.log(`Teams user: ${communicationIdentifier.microsoftTeamsUserId}`);
        break;
    case "microsoftTeamsApp":
        // narrowed to MicrosoftTeamsAppIdentifier
        console.log(`Teams app: ${communicationIdentifier.teamsAppId}`);
        break;
    case "phoneNumber":
         // narrowed to PhoneNumberKind
        console.log(`Phone number: ${communicationIdentifier.phoneNumber}`);
        break;
    case "unknown":
         // narrowed to UnknownIdentifierKind
        console.log(`Unknown: ${communicationIdentifier.id}`);
        break;
    default:
        // be careful here whether you want to throw because a new SDK version
        // can introduce new identifier types
        break;
}

Le interfacce dell'identificatore sono state progettate in modo da non dover specificare kind per ridurre il livello di dettaglio e l'unione discriminante con la proprietà kind viene usata solo quando viene restituita da SDK. Tuttavia, se si ha la necessità di tradurre un identificatore nel tipo di unione discriminante corrispondente, è possibile usare questo helper:

const identifierKind = getIdentifierKind(identifier); // now you can switch-case on the kind

Rappresentazione dell'ID non elaborato

In alcuni casi è necessario serializzare un identificatore in una stringa flat. Ad esempio, se si vuole archiviare l'identificatore in una tabella di database o se lo si vuole usare come parametro URL.

A tale scopo, gli identificatori hanno un'altra rappresentazione denominata RawId. Un identificatore può sempre essere convertito nell'ID non elaborato corrispondente e un ID non elaborato valido può sempre essere convertito in un identificatore.

Poiché azure-communication-common@2.1.0 l'SDK consente la conversione:

// get an identifier's raw Id
const rawId = getIdentifierRawId(communicationIdentifier);

// create an identifier from a given raw Id
const identifier = createIdentifierFromRawId(rawId);

Un ID non elaborato non valido verrà semplicemente convertito in un UnknownIdentifier nell'SDK e qualsiasi convalida avviene solo sul lato servizio.

Utente di comunicazione

CommunicationUserIdentifier rappresenta un'identità utente creata usando Identity SDK o l'API REST. È l'unico identificatore usato se l'applicazione non usa l'interoperabilità di Microsoft Teams o le funzionalità di telefonia.

Utilizzo di base

// at some point you will have created a new user identity in your trusted service
CommunicationUserIdentifier newUser = await identityClient.CreateUser();

// and then send newUser.Id down to your client application
// where you can again create an identifier for the user
var sameUser = new CommunicationUserIdentifier(newUserId);

Informazioni di riferimento sulle API

CommunicationUserIdentifier

Utente di Microsoft Teams

MicrosoftTeamsUserIdentifier rappresenta un utente di Teams con l'ID oggetto utente di Microsoft Entra. È possibile recuperare l'ID oggetto utente di Microsoft Entra tramite l'endpoint REST API /utente di Microsoft Graph dalla idproprietà nella risposta. Per altre informazioni su come usare Microsoft Graph, provare Graph Explorer ed esaminare Graph SDK. In alternativa, è possibile trovare l'ID come oid attestazione in un token Microsoft Entra o un token di accesso di Microsoft Entra dopo che l'utente ha eseguito l'accesso e acquisito un token.

Utilizzo di base

// get the Teams user's ID from Graph APIs if only the email is known
var user = await graphClient.Users["bob@contoso.com"]
    .Request()
    .GetAsync();

// create an identifier
var teamsUser = new MicrosoftTeamsUserIdentifier(user.Id);

// if you're not operating in the public cloud, you must also pass the right Cloud type.
var gcchTeamsUser = new MicrosoftTeamsUserIdentifier(userId: userId, cloud: CommunicationCloudEnvironment.Gcch);

Informazioni di riferimento sulle API

MicrosoftTeamsUserIdentifier

Numero di telefono

PhoneNumberIdentifier rappresenta un numero di telefono. Il servizio presuppone che i numeri di telefono siano formattati in formato E.164.

Utilizzo di base

// create an identifier
var phoneNumber = new PhoneNumberIdentifier("+112345556789");

Informazioni di riferimento sulle API

PhoneNumberIdentifier

Applicazione Microsoft Teams

L'interfaccia MicrosoftTeamsAppIdentifier rappresenta un bot delle applicazioni di Teams Voice, come ad esempio Coda delle chiamate e Operatore automatico con l'ID oggetto bot Microsoft Entra. Le applicazioni di Teams devono essere configurate con un account di risorsa. È possibile recuperare l'ID oggetto bot Microsoft Entra tramite l'endpoint REST API /utente di Microsoft Graph dalla idproprietà nella risposta. Per altre informazioni su come usare Microsoft Graph, provare Graph Explorer ed esaminare Graph SDK.

Utilizzo di base

// Get the Microsoft Teams App's ID from Graph APIs
var users = await graphClient.Users.GetAsync((requestConfiguration) =>
{
	requestConfiguration.QueryParameters.Select = new string []{ "displayName","id" };
	requestConfiguration.QueryParameters.Filter = filterConditions;
});

// Here we assume that you have a function GetBotFromUsers that gets the bot from the returned response
var bot = GetBotFromUsers(users);

// Create an identifier
var teamsAppIdentifier = new MicrosoftTeamsAppIdentifier(bot.Id);

// If you're not operating in the public cloud, you must also pass the right Cloud type.
var gcchTeamsAppIdentifier = new MicrosoftTeamsAppIdentifier(bot.Id, CommunicationCloudEnvironment.Gcch);

Informazioni di riferimento sulle API

MicrosoftTeamsAppIdentifier

Sconosciuto

UnknownIdentifier esiste per la correzione futura e potrebbe essere presente in una versione precedente di SDK in cui sia stato recentemente introdotto un nuovo tipo di identificatore. Qualsiasi identificatore sconosciuto dal servizio verrà deserializzato in UnknownIdentifier in SDK.

Utilizzo di base

// create an identifier
var unknown = new UnknownIdentifier("a raw id that originated in the service");

Informazioni di riferimento sulle API

UnknownIdentifier

Come gestire la CommunicationIdentifier classe base

Mentre si costruiscono identificatori per un tipo concreto passato all'SDK, l'SDK restituisce un CommunicationIdentifier protocollo. È facile eseguire il down-cast a un tipo concreto e si consiglia un'istruzione switch-case con criteri di ricerca:

switch (communicationIdentifier)
{
    case CommunicationUserIdentifier communicationUser:
        Console.WriteLine($"Communication user: {communicationUser.Id}");
        break;
    case MicrosoftTeamsUserIdentifier teamsUser:
        Console.WriteLine($"Teams user: {teamsUser.UserId}");
        break;
    case MicrosoftTeamsAppIdentifier teamsApp:
        Console.WriteLine($"Teams app: {teamsApp.AppId}");
        break;
    case PhoneNumberIdentifier phoneNumber:
        Console.WriteLine($"Phone number: {phoneNumber.PhoneNumber}");
        break;
    case UnknownIdentifier unknown:
        Console.WriteLine($"Unknown: {unknown.Id}");
        break;
    default:
        // be careful here whether you want to throw because a new SDK version
        // can introduce new identifier types
        break;
}

Rappresentazione dell'ID non elaborato

In alcuni casi è necessario serializzare un identificatore in una stringa flat. Ad esempio, se si vuole archiviare l'identificatore in una tabella di database o se lo si vuole usare come parametro URL.

A tale scopo, gli identificatori hanno un'altra rappresentazione denominata RawId. Un identificatore può sempre essere convertito nell'ID non elaborato corrispondente e un ID non elaborato valido può sempre essere convertito in un identificatore.

Poiché Azure.Communication.Common 1.2.0 l'SDK consente la conversione:

// get an identifier's raw Id
string rawId = communicationIdentifier.RawId;

// create an identifier from a given raw Id
CommunicationIdentifier identifier = CommunicationIdentifier.FromRawId(rawId);

Un ID non elaborato non valido verrà semplicemente convertito in un UnknownIdentifier nell'SDK e qualsiasi convalida avviene solo sul lato servizio.

Utente di comunicazione

CommunicationUserIdentifier rappresenta un'identità utente creata usando Identity SDK o l'API REST. È l'unico identificatore usato se l'applicazione non usa l'interoperabilità di Microsoft Teams o le funzionalità di telefonia.

Utilizzo di base

# at some point you will have created a new user identity in your trusted service
new_user = identity_client.create_user()

# and then send new_user.properties['id'] down to your client application
# where you can again create an identifier for the user
same_user = CommunicationUserIdentifier(new_user_id)

Informazioni di riferimento sulle API

CommunicationUserIdentifier

Utente di Microsoft Teams

MicrosoftTeamsUserIdentifier rappresenta un utente di Teams con l'ID oggetto utente di Microsoft Entra. È possibile recuperare l'ID oggetto utente di Microsoft Entra tramite l'endpoint REST API /utente di Microsoft Graph dalla idproprietà nella risposta. Per altre informazioni su come usare Microsoft Graph, provare Graph Explorer ed esaminare Graph SDK. In alternativa, è possibile trovare l'ID come oid attestazione in un token Microsoft Entra o un token di accesso di Microsoft Entra dopo che l'utente ha eseguito l'accesso e acquisito un token.

Utilizzo di base

# get the Teams user's ID from Graph APIs if only the email is known
user_id = graph_client.get("/users/bob@contoso.com").json().get("id");

# create an identifier
teams_user = MicrosoftTeamsUserIdentifier(user_id)

# if you're not operating in the public cloud, you must also pass the right Cloud type.
gcch_teams_user = MicrosoftTeamsUserIdentifier(user_id, cloud=CommunicationCloudEnvironment.GCCH)

Informazioni di riferimento sulle API

MicrosoftTeamsUserIdentifier

Numero di telefono

PhoneNumberIdentifier rappresenta un numero di telefono. Il servizio presuppone che i numeri di telefono siano formattati in formato E.164.

Utilizzo di base

# create an identifier
phone_number = PhoneNumberIdentifier("+112345556789")

Informazioni di riferimento sulle API

PhoneNumberIdentifier

Applicazione Microsoft Teams

L'interfaccia MicrosoftTeamsAppIdentifier rappresenta un bot delle applicazioni di Teams Voice, come ad esempio Coda delle chiamate e Operatore automatico con l'ID oggetto bot Microsoft Entra. Le applicazioni di Teams devono essere configurate con un account di risorsa. È possibile recuperare l'ID oggetto bot Microsoft Entra tramite l'endpoint REST API /utente di Microsoft Graph dalla idproprietà nella risposta. Per altre informazioni su come usare Microsoft Graph, provare Graph Explorer ed esaminare Graph SDK.

Utilizzo di base

# Get the Microsoft Teams App's ID from Graph APIs
users = graph_client.get("/users").json()

# Here we assume that you have a function get_bot_from_users that gets the bot from the returned response
bot = get_bot_from_users(users);

# Create an identifier
teams_app_identifier = MicrosoftTeamsAppIdentifier(app_id=bot.get("id"))

# If you're not operating in the public cloud, you must also pass the right Cloud type.
gcch_teams_app_identifier = MicrosoftTeamsAppIdentifier(
            app_id=bot.get("id"),
            cloud=CommunicationCloudEnvironment.GCCH
        )

Informazioni di riferimento sulle API

MicrosoftTeamsAppIdentifier

Sconosciuto

UnknownIdentifier esiste per la correzione futura e potrebbe essere presente in una versione precedente di SDK in cui sia stato recentemente introdotto un nuovo tipo di identificatore. Qualsiasi identificatore sconosciuto dal servizio verrà deserializzato in UnknownIdentifier in SDK.

Utilizzo di base

# create an identifier
unknown = UnknownIdentifier("a raw id that originated in the service")

Informazioni di riferimento sulle API

UnknownIdentifier

Come gestire la CommunicationIdentifier classe base

Mentre si costruiscono identificatori per un tipo concreto passato all'SDK, l'SDK restituisce un CommunicationIdentifier protocollo. Le classi di identificatori concreti sono solo il protocollo CommunicationIdentifier insieme a un dizionario tipizzato denominato properties. È quindi possibile usare criteri di ricerca per la variabile di istanza del kind protocollo per eseguire la conversione nel tipo concreto:

match communication_identifier.kind:
    case CommunicationIdentifierKind.COMMUNICATION_USER:
        print(f"Communication user: {communication_identifier.properties['id']}")
    case CommunicationIdentifierKind.MICROSOFT_TEAMS_USER:
        print(f"Teams user: {communication_identifier.properties['user_id']}")
    case CommunicationIdentifierKind.MICROSOFT_TEAMS_APP:
        print(f"Teams app: {communication_identifier.properties['app_id']}")
    case CommunicationIdentifierKind.PHONE_NUMBER:
        print(f"Phone number: {communication_identifier.properties['value']}")
    case CommunicationIdentifierKind.UNKNOWN:
        print(f"Unknown: {communication_identifier.raw_id}")
    case _:
        # be careful here whether you want to throw because a new SDK version
        # can introduce new identifier types

Rappresentazione dell'ID non elaborato

In alcuni casi è necessario serializzare un identificatore in una stringa flat. Ad esempio, se si vuole archiviare l'identificatore in una tabella di database o se lo si vuole usare come parametro URL.

A tale scopo, gli identificatori hanno un'altra rappresentazione denominata RawId. Un identificatore può sempre essere convertito nell'ID non elaborato corrispondente e un ID non elaborato valido può sempre essere convertito in un identificatore.

L'SDK consente la conversione:

# get an identifier's raw Id
raw_id = communication_identifier.raw_id

# create an identifier from a given raw Id
identifier = identifier_from_raw_id(raw_id)

Un ID non elaborato non valido verrà semplicemente convertito in un UnknownIdentifier nell'SDK e qualsiasi convalida avviene solo sul lato servizio.

Utente di comunicazione

CommunicationUserIdentifier rappresenta un'identità utente creata usando Identity SDK o l'API REST. È l'unico identificatore usato se l'applicazione non usa l'interoperabilità di Microsoft Teams o le funzionalità di telefonia.

Utilizzo di base

// at some point you will have created a new user identity in your trusted service
CommunicationUserIdentifier newUser = identityClient.CreateUser();

// and then send newUser.getId() down to your client application
// where you can again create an identifier for the user
var sameUser = new CommunicationUserIdentifier(newUserId);

Informazioni di riferimento sulle API

CommunicationUserIdentifier

Utente di Microsoft Teams

MicrosoftTeamsUserIdentifier rappresenta un utente di Teams con l'ID oggetto utente di Microsoft Entra. È possibile recuperare l'ID oggetto utente di Microsoft Entra tramite l'endpoint REST API /utente di Microsoft Graph dalla idproprietà nella risposta. Per altre informazioni su come usare Microsoft Graph, provare Graph Explorer ed esaminare Graph SDK. In alternativa, è possibile trovare l'ID come oid attestazione in un token Microsoft Entra o un token di accesso di Microsoft Entra dopo che l'utente ha eseguito l'accesso e acquisito un token.

Utilizzo di base

// get the Teams user's ID from Graph APIs if only the email is known
var user = graphClient.users("bob@contoso.com")
    .buildRequest()
    .get();

// create an identifier
var teamsUser = new MicrosoftTeamsUserIdentifier(user.id);

// if you're not operating in the public cloud, you must also set the right Cloud type.
var gcchTeamsUser = new MicrosoftTeamsUserIdentifier(userId).setCloudEnvironment(CommunicationCloudEnvironment.GCCH);

Informazioni di riferimento sulle API

MicrosoftTeamsUserIdentifier

Numero di telefono

PhoneNumberIdentifier rappresenta un numero di telefono. Il servizio presuppone che i numeri di telefono siano formattati in formato E.164.

Utilizzo di base

// create an identifier
var phoneNumber = new PhoneNumberIdentifier("+112345556789");

Informazioni di riferimento sulle API

PhoneNumberIdentifier

Applicazione Microsoft Teams

L'interfaccia MicrosoftTeamsAppIdentifier rappresenta un bot delle applicazioni di Teams Voice, come ad esempio Coda delle chiamate e Operatore automatico con l'ID oggetto bot Microsoft Entra. Le applicazioni di Teams devono essere configurate con un account di risorsa. È possibile recuperare l'ID oggetto bot Microsoft Entra tramite l'endpoint REST API /utente di Microsoft Graph dalla idproprietà nella risposta. Per altre informazioni su come usare Microsoft Graph, provare Graph Explorer ed esaminare Graph SDK.

Utilizzo di base

// Get the Microsoft Teams App's ID from Graph APIs
var user = graphClient.users()
	.buildRequest()
	.filter(filterConditions)
	.select("displayName,id")
	.get();

//Here we assume that you have a function getBotFromUsers that gets the bot from the returned response
var bot = getBotFromUsers(users);

// Create an identifier
var teamsAppIdentifier = new MicrosoftTeamsAppIdentifier(bot.id);

// If you're not operating in the public cloud, you must also pass the right Cloud type.
var gcchTeamsAppIdentifier = new MicrosoftTeamsAppIdentifier(bot.id, CommunicationCloudEnvironment.GCCH);

Informazioni di riferimento sulle API

MicrosoftTeamsAppIdentifier

Sconosciuto

UnknownIdentifier esiste per la correzione futura e potrebbe essere presente in una versione precedente di SDK in cui sia stato recentemente introdotto un nuovo tipo di identificatore. Qualsiasi identificatore sconosciuto dal servizio verrà deserializzato in UnknownIdentifier in SDK.

Utilizzo di base

// create an identifier
var unknown = new UnknownIdentifier("a raw id that originated in the service");

Informazioni di riferimento sulle API

UnknownIdentifier

Come gestire la CommunicationIdentifier classe base

Mentre si costruiscono identificatori per un tipo concreto passato all'SDK, l'SDK restituisce un sunto CommunicationIdentifier. È possibile eseguire nuovamente il down-cast a un tipo concreto:

if (communicationIdentifier instanceof CommunicationUserIdentifier) {
    System.out.println("Communication user: " + ((CommunicationUserIdentifier)communicationIdentifier).getId());
}
else if (communicationIdentifier instanceof MicrosoftTeamsUserIdentifier) {
    System.out.println("Teams user: " + ((MicrosoftTeamsUserIdentifier)communicationIdentifier).getUserId());
}
else if (communicationIdentifier instanceof  MicrosoftTeamsAppIdentifier) {
    Log.i(tag, "Teams app: " + (( MicrosoftTeamsAppIdentifier)communicationIdentifier).getAppId());
}
else if (communicationIdentifier instanceof PhoneNumberIdentifier) {
    System.out.println("Phone number: " + ((PhoneNumberIdentifier)communicationIdentifier).getPhoneNumber());
}
else if (communicationIdentifier instanceof UnknownIdentifier) {
    System.out.println("Unknown user: " + ((UnknownIdentifier)communicationIdentifier).getId());
}
else {
    // be careful here whether you want to throw because a new SDK version
        // can introduce new identifier types
}

Rappresentazione dell'ID non elaborato

In alcuni casi è necessario serializzare un identificatore in una stringa flat. Ad esempio, se si vuole archiviare l'identificatore in una tabella di database o se lo si vuole usare come parametro URL.

A tale scopo, gli identificatori hanno un'altra rappresentazione denominata RawId. Un identificatore può sempre essere convertito nell'ID non elaborato corrispondente e un ID non elaborato valido può sempre essere convertito in un identificatore.

Poiché azure-communication-common 1.2.0 l'SDK consente la conversione:

// get an identifier's raw Id
String rawId = communicationIdentifier.getRawId();

// create an identifier from a given raw Id
CommunicationIdentifier identifier = CommunicationIdentifier.fromRawId(rawId);

Un ID non elaborato non valido verrà semplicemente convertito in un UnknownIdentifier nell'SDK e qualsiasi convalida avviene solo sul lato servizio.

Utente di comunicazione

CommunicationUserIdentifier rappresenta un'identità utente creata usando Identity SDK o l'API REST. È l'unico identificatore usato se l'applicazione non usa l'interoperabilità di Microsoft Teams o le funzionalità di telefonia.

Utilizzo di base

// at some point you will have created a new user identity in your trusted service
// and send the new user id down to your client application
// where you can create an identifier for the user
let user = CommunicationUserIdentifier(newUserId)

Informazioni di riferimento sulle API

CommunicationUserIdentifier

Utente di Microsoft Teams

MicrosoftTeamsUserIdentifier rappresenta un utente di Teams con l'ID oggetto utente di Microsoft Entra. È possibile recuperare l'ID oggetto utente di Microsoft Entra tramite l'endpoint REST API /utente di Microsoft Graph dalla idproprietà nella risposta. Per altre informazioni su come usare Microsoft Graph, provare Graph Explorer ed esaminare Graph SDK. In alternativa, è possibile trovare l'ID come oid attestazione in un ID token o un token di accesso di Microsoft Entra dopo che l'utente ha eseguito l'accesso e acquisito un token.

Utilizzo di base

// get the Teams user's ID if only the email is known, assuming a helper method for the Graph API
let userId = await getUserIdFromGraph("bob@contoso.com")

// create an identifier
let teamsUser = MicrosoftTeamsUserIdentifier(userId: userId)

// if you're not operating in the public cloud, you must also pass the right Cloud type.
let gcchTeamsUser = MicrosoftTeamsUserIdentifier(userId: userId, cloud: CommunicationCloudEnvironment.Gcch)

Informazioni di riferimento sulle API

MicrosoftTeamsUserIdentifier

Numero di telefono

PhoneNumberIdentifier rappresenta un numero di telefono. Il servizio presuppone che i numeri di telefono siano formattati in formato E.164.

Utilizzo di base

// create an identifier
let phoneNumber = PhoneNumberIdentifier(phoneNumber: "+112345556789")

Informazioni di riferimento sulle API

PhoneNumberIdentifier

Applicazione Microsoft Teams

L'interfaccia MicrosoftTeamsAppIdentifier rappresenta un bot delle applicazioni di Teams Voice, come ad esempio Coda delle chiamate e Operatore automatico con l'ID oggetto bot Microsoft Entra. Le applicazioni di Teams devono essere configurate con un account di risorsa. È possibile recuperare l'ID oggetto bot Microsoft Entra tramite l'endpoint REST API /utente di Microsoft Graph dalla idproprietà nella risposta. Per altre informazioni su come usare Microsoft Graph, provare Graph Explorer ed esaminare Graph SDK.

Utilizzo di base

// Get the Microsoft Teams App's ID from Graph APIs, assuming a helper method for the Graph API
let botId = await getBotIdFromGraph()

// Create an identifier
let teamsAppIdentifier = MicrosoftTeamsAppIdentifier(appId: botId)

// If you're not operating in the public cloud, you must also pass the right Cloud type.
let gcchTeamsAppIdentifier = MicrosoftTeamsAppIdentifier(appId: botId, cloudEnvironment: CommunicationCloudEnvironment.Gcch)

Informazioni di riferimento sulle API

MicrosoftTeamsAppIdentifier

Sconosciuto

UnknownIdentifier esiste per la correzione futura e potrebbe essere presente in una versione precedente di SDK in cui sia stato recentemente introdotto un nuovo tipo di identificatore. Qualsiasi identificatore sconosciuto dal servizio verrà deserializzato in UnknownIdentifier in SDK.

Utilizzo di base

// create an identifier
let unknown = UnknownIdentifier("a raw id that originated in the service")

Informazioni di riferimento sulle API

UnknownIdentifier

Come gestire il CommunicationIdentifier protocollo di base

Mentre si costruiscono identificatori per un tipo concreto passato all'SDK, l'SDK restituisce un CommunicationIdentifier protocollo. È facile eseguire nuovamente il down-cast a un tipo concreto ed è consigliabile usare un'istruzione switch-case con criteri di ricerca:

switch (communicationIdentifier)
{
    case let communicationUser as CommunicationUserIdentifier:
        print(#"Communication user: \(communicationUser.id)"#)
    case let teamsUser as MicrosoftTeamsUserIdentifier:
        print(#"Teams user: \(teamsUser.UserId)"#)
    case let teamsApp as MicrosoftTeamsAppIdentifier:
        print(#"Teams app: \(teamsApp.appId)"#)
    case let phoneNumber as PhoneNumberIdentifier:
        print(#"Phone number: \(phoneNumber.PhoneNumber)"#)
    case let unknown as UnknownIdentifier:
        print(#"Unknown: \(unknown.Id)"#)
    @unknown default:
        // be careful here whether you want to throw because a new SDK version
        // can introduce new identifier types
        break;
}

Rappresentazione dell'ID non elaborato

In alcuni casi è necessario serializzare un identificatore in una stringa flat. Ad esempio, se si vuole archiviare l'identificatore in una tabella di database o se lo si vuole usare come parametro URL.

A tale scopo, gli identificatori hanno un'altra rappresentazione denominata RawId. Un identificatore può sempre essere convertito nell'ID non elaborato corrispondente e un ID non elaborato valido può sempre essere convertito in un identificatore.

Poiché Azure.Communication.Common 1.1.0 l'SDK consente la conversione:

Swift

// get an identifier's raw Id
let rawId = communicationIdentifier.rawId;

// create an identifier from a given raw Id
let identifier = createCommunicationIdentifier(fromRawId: rawId);

Un ID non elaborato non valido verrà semplicemente convertito in un UnknownIdentifier nell'SDK e qualsiasi convalida avviene solo sul lato servizio.

Utente di comunicazione

CommunicationUserIdentifier rappresenta un'identità utente creata usando Identity SDK o l'API REST. È l'unico identificatore usato se l'applicazione non usa l'interoperabilità di Microsoft Teams o le funzionalità di telefonia.

Utilizzo di base

// at some point you will have created a new user identity in your trusted service
CommunicationUserIdentifier newUser = identityClient.CreateUser();

// and then send newUser.getId() down to your client application
// where you can again create an identifier for the user
CommunicationUserIdentifier sameUser = new CommunicationUserIdentifier(newUserId);

Informazioni di riferimento sulle API

CommunicationUserIdentifier

Utente di Microsoft Teams

MicrosoftTeamsUserIdentifier rappresenta un utente di Teams con l'ID oggetto utente di Microsoft Entra. È possibile recuperare l'ID oggetto utente di Microsoft Entra tramite l'endpoint REST API /utente di Microsoft Graph dalla idproprietà nella risposta. Per altre informazioni su come usare Microsoft Graph, provare Graph Explorer ed esaminare Graph SDK. In alternativa, è possibile trovare l'ID come oid attestazione in un ID token o un token di accesso di Microsoft Entra dopo che l'utente ha eseguito l'accesso e acquisito un token.

Utilizzo di base

// get the Teams user's ID from Graph APIs if only the email is known
User user = graphClient.users("bob@contoso.com")
    .buildRequest()
    .get();

// create an identifier
MicrosoftTeamsUserIdentifier teamsUser = new MicrosoftTeamsUserIdentifier(user.id);

// if you're not operating in the public cloud, you must also set the right Cloud type.
MicrosoftTeamsUserIdentifier gcchTeamsUser = new MicrosoftTeamsUserIdentifier(userId).setCloudEnvironment(CommunicationCloudEnvironment.GCCH);

Informazioni di riferimento sulle API

MicrosoftTeamsUserIdentifier

Numero di telefono

PhoneNumberIdentifier rappresenta un numero di telefono. Il servizio presuppone che i numeri di telefono siano formattati in formato E.164.

Utilizzo di base

// create an identifier
PhoneNumberIdentifier phoneNumber = new PhoneNumberIdentifier("+112345556789");

Informazioni di riferimento sulle API

PhoneNumberIdentifier

Applicazione Microsoft Teams

L'interfaccia MicrosoftTeamsAppIdentifier rappresenta un bot delle applicazioni di Teams Voice, come ad esempio Coda delle chiamate e Operatore automatico con l'ID oggetto bot Microsoft Entra. Le applicazioni di Teams devono essere configurate con un account di risorsa. È possibile recuperare l'ID oggetto bot Microsoft Entra tramite l'endpoint REST API /utente di Microsoft Graph dalla idproprietà nella risposta. Per altre informazioni su come usare Microsoft Graph, provare Graph Explorer ed esaminare Graph SDK.

Utilizzo di base

// Get the Microsoft Teams App's ID from Graph APIs
UserCollectionPage users = graphClient.users()
	.buildRequest()
	.filter(filterConditions)
	.select("displayName,id")
	.get();

//Here we assume that you have a function getBotFromUsers that gets the bot from the returned response
User bot = getBotFromUsers(users);

// Create an identifier
MicrosoftTeamsAppIdentifier teamsAppIdentifier = new MicrosoftTeamsAppIdentifier(bot.id);

// If you're not operating in the public cloud, you must also pass the right Cloud type.
MicrosoftTeamsAppIdentifier gcchTeamsAppIdentifier = new MicrosoftTeamsAppIdentifier(bot.id, CommunicationCloudEnvironment.GCCH);

Informazioni di riferimento sulle API

MicrosoftTeamsAppIdentifier

Sconosciuto

UnknownIdentifier esiste per la correzione futura e potrebbe essere presente in una versione precedente di SDK in cui sia stato recentemente introdotto un nuovo tipo di identificatore. Qualsiasi identificatore sconosciuto dal servizio verrà deserializzato in UnknownIdentifier in SDK.

Utilizzo di base

// create an identifier
UnknownIdentifier unknown = new UnknownIdentifier("a raw id that originated in the service");

Informazioni di riferimento sulle API

UnknownIdentifier

Come gestire la CommunicationIdentifier classe base

Mentre si costruiscono identificatori per un tipo concreto passato all'SDK, l'SDK restituisce un sunto CommunicationIdentifier. È possibile eseguire nuovamente il down-cast a un tipo concreto:

if (communicationIdentifier instanceof CommunicationUserIdentifier) {
    Log.i(tag, "Communication user: " + ((CommunicationUserIdentifier)communicationIdentifier).getId());
}
else if (communicationIdentifier instanceof MicrosoftTeamsUserIdentifier) {
    Log.i(tag, "Teams user: " + ((MicrosoftTeamsUserIdentifier)communicationIdentifier).getUserId());
}
else if (communicationIdentifier instanceof  MicrosoftTeamsAppIdentifier) {
    Log.i(tag, "Teams app: " + (( MicrosoftTeamsAppIdentifier)communicationIdentifier).getAppId());
}
else if (communicationIdentifier instanceof PhoneNumberIdentifier) {
    Log.i(tag, "Phone number: " + ((PhoneNumberIdentifier)communicationIdentifier).getPhoneNumber());
}
else if (communicationIdentifier instanceof UnknownIdentifier) {
    Log.i(tag, "Unknown user: " + ((UnknownIdentifier)communicationIdentifier).getId());
}
else {
    // be careful here whether you want to throw because a new SDK version
    // can introduce new identifier types
}

Rappresentazione dell'ID non elaborato

In alcuni casi è necessario serializzare un identificatore in una stringa flat. Ad esempio, se si vuole archiviare l'identificatore in una tabella di database o se lo si vuole usare come parametro URL.

A tale scopo, gli identificatori hanno un'altra rappresentazione denominata RawId. Un identificatore può sempre essere convertito nell'ID non elaborato corrispondente e un ID non elaborato valido può sempre essere convertito in un identificatore.

Poiché azure-communication-common 1.1.0 l'SDK consente la conversione:

// get an identifier's raw Id
String rawId = communicationIdentifier.getRawId();

// create an identifier from a given raw Id
CommunicationIdentifier identifier = CommunicationIdentifier.fromRawId(rawId);

Un ID non elaborato non valido verrà semplicemente convertito in un UnknownIdentifier nell'SDK e qualsiasi convalida avviene solo sul lato servizio.

Nelle API REST, l'identificatore è un tipo polimorfico: si costruisce un oggetto JSON e una proprietà che esegue il mapping a un sottotipo di identificatore concreto. Per motivi di praticità e compatibilità con le versioni precedenti, le proprietà kind e rawId sono facoltative nelle richieste, ma vengono popolate nelle risposte del servizio.

Utente di comunicazione

CommunicationUserIdentifierModel rappresenta un'identità utente creata usando Identity SDK o l'API REST. È l'unico identificatore usato se l'applicazione non usa l'interoperabilità di Microsoft Teams o le funzionalità di telefonia.

Utilizzo di base


// at some point you will have created a new user identity in your trusted service
// you can specify an identifier with the id of the new user in a request
{
    "communicationUser": {
        "id": "8:acs:8540c0de-899f-5cce-acb5-3ec493af3800_c94ff260-162d-46d6-94fd-e79f4d213715"
    }
}

// the corresponding serialization in a response
{
    "kind": "communicationUser",
    "rawId": "8:acs:8540c0de-899f-5cce-acb5-3ec493af3800_c94ff260-162d-46d6-94fd-e79f4d213715",
    "communicationUser": {
        "id": "8:acs:8540c0de-899f-5cce-acb5-3ec493af3800_c94ff260-162d-46d6-94fd-e79f4d213715"
    }
}

È possibile trovare un esempio per una richiesta che include un identificatore nell'API REST di Chat per l'aggiunta di un partecipante e un esempio per una risposta con un identificatore in ricevi messaggio di chat.

Informazioni di riferimento sulle API

CommunicationUserIdentifierModel

Utente di Microsoft Teams

MicrosoftTeamsUserIdentifierModel rappresenta un utente di Teams con l'ID oggetto utente di Microsoft Entra. È possibile recuperare l'ID oggetto utente di Microsoft Entra tramite l'endpoint REST API /utente di Microsoft Graph dalla idproprietà nella risposta. Per altre informazioni su come usare Microsoft Graph, provare Graph Explorer ed esaminare Graph SDK. In alternativa, è possibile trovare l'ID come oid attestazione in un token Microsoft Entra o un token di accesso di Microsoft Entra dopo che l'utente ha eseguito l'accesso e acquisito un token.

Utilizzo di base

// request
{
    "microsoftTeamsUser": {
        "userId": "00aa00aa-bb11-cc22-dd33-44ee44ee44ee"
    }
}

// response
{
    "kind": "microsoftTeamsUser",
    "rawId": "8:orgid:00aa00aa-bb11-cc22-dd33-44ee44ee44ee",
    "microsoftTeamsUser": {
        "userId": "00aa00aa-bb11-cc22-dd33-44ee44ee44ee"
    }
}


// if you're not operating in the public cloud, you must also pass the right Cloud type in a request
{
    "microsoftTeamsUser": {
        "userId": "00aa00aa-bb11-cc22-dd33-44ee44ee44ee",
        "cloud": "gcch"
    }
}

// response
{
    "kind": "microsoftTeamsUser",
    "rawId": "8:gcch:00aa00aa-bb11-cc22-dd33-44ee44ee44ee",
    "microsoftTeamsUser": {
        "userId": "00aa00aa-bb11-cc22-dd33-44ee44ee44ee",
        "isAnonymous": false,
        "cloud": "gcch"
    }
}

Informazioni di riferimento sulle API

MicrosoftTeamsUserIdentifierModel

Numero di telefono

PhoneNumberIdentifierModel rappresenta un numero di telefono. Il servizio presuppone che i numeri di telefono siano formattati in formato E.164.

Utilizzo di base

// request
{
    "phoneNumber": {
        "value": "+112345556789"
    }
}

// response
{
    "kind": "phoneNumber",
    "rawId": "4:+112345556789",
    "phoneNumber": {
        "value": "+112345556789"
    }
}

Informazioni di riferimento sulle API

PhoneNumberIdentifierModel

Applicazione Microsoft Teams

MicrosoftTeamsAppIdentifierModel rappresenta un bot delle applicazioni di Teams Voice, come ad esempio Coda delle chiamate e Operatore automatico con l'ID oggetto bot Microsoft Entra. Le applicazioni di Teams devono essere configurate con un account di risorsa. È possibile recuperare l'ID oggetto bot Microsoft Entra tramite l'endpoint REST API /utente di Microsoft Graph dalla idproprietà nella risposta. Per altre informazioni su come usare Microsoft Graph, provare Graph Explorer ed esaminare Graph SDK.

Utilizzo di base

// request
{
    "microsoftTeamsApp": {
        "appId": "00001111-aaaa-2222-bbbb-3333cccc4444"
    }
}

// response
{
    "kind": "microsoftTeamsApp",
    "rawId": "28:orgid:00001111-aaaa-2222-bbbb-3333cccc4444",
    "microsoftTeamsApp": {
        "appId": "00001111-aaaa-2222-bbbb-3333cccc4444"
    }
}


// if you're not operating in the public cloud, you must also pass the right Cloud type in a request
{
    "microsoftTeamsApp": {
        "appId": "00001111-aaaa-2222-bbbb-3333cccc4444",
        "cloud": "gcch"
    }
}

// response
{
    "kind": "microsoftTeamsApp",
    "rawId": "28:gcch:00001111-aaaa-2222-bbbb-3333cccc4444",
    "microsoftTeamsApp": {
        "appId": "00001111-aaaa-2222-bbbb-3333cccc4444",
        "cloud": "gcch"
    }
}

Informazioni di riferimento sulle API

MicrosoftTeamsAppIdentifierModel

Sconosciuto

Se un nuovo identificatore viene introdotto in un servizio, verrà effettuato il downgrade a CommunicationIdentifierModel se si usa una versione precedente dell'API.

Utilizzo di base

// request
{
    "rawId": "a raw id that originated in the service"
}

// response
{
    "kind": "unknown",
    "rawId": "a raw id that originated in the service"
}

Informazioni di riferimento sulle API

CommunicationIdentifierModel

Come gestire l'oggetto CommunicationIdentifierModel nelle risposte

Le versioni recenti dell'API popolano una kind proprietà che è possibile usare per discriminare:

switch (communicationIdentifier.kind)
{
    case "communicationUser":
        console.log(`Communication user: ${communicationIdentifier.communicationUser.id}`);
        break;
    case "microsoftTeamsUser":
        console.log(`Teams user: ${communicationIdentifier.microsoftTeamsUser.userId}`);
        break;
    case "microsoftTeamsApp":
        console.log(`Teams user: ${communicationIdentifier.microsoftTeamsApp.appId}`);
        break;
    case "phoneNumber":
        console.log(`Phone number: ${communicationIdentifier.phoneNumber.value}`);
        break;
    case "unknown":
        console.log(`Unknown: ${communicationIdentifier.rawId}`);
        break;
    default:
        // this case should not be hit because adding a new identifier type requires a new API version
        // if it does get hit, please file an issue on https://github.com/Azure/azure-rest-api-specs/issues 
        break;
}

Nelle versioni precedenti dell'API, la kind proprietà è mancante ed è necessario verificare l'esistenza della sotto-proprietà corretta:

if (communicationIdentifier.communicationUser) {
    console.log(`Communication user: ${communicationIdentifier.communicationUser.id}`);
} else if (communicationIdentifier.microsoftTeamsUser) {
    console.log(`Teams user: ${communicationIdentifier.microsoftTeamsUser.userId}`);
} else if (communicationIdentifier.microsoftTeamsApp) {
    console.log(`Teams app: ${communicationIdentifier.microsoftTeamsApp.appId}`);
} else if (communicationIdentifier.phoneNumber) {
    console.log(`Phone number: ${communicationIdentifier.phoneNumber.value}`);
} else {
    console.log(`Unknown: ${communicationIdentifier.rawId}`);
}

Rappresentazione dell'ID non elaborato

In alcuni casi è necessario serializzare un identificatore in una stringa flat. Ad esempio, se si vuole archiviare l'identificatore in una tabella di database o se lo si vuole usare come parametro URL.

A tale scopo, gli identificatori hanno un'altra rappresentazione denominata RawId. Un identificatore può sempre essere convertito nell'ID non elaborato corrispondente e un ID non elaborato valido può sempre essere convertito in un identificatore.

Se si usa Azure SDK, sarà utile per la conversione. Se si usa direttamente l'API REST, è necessario costruire manualmente l'ID non elaborato, come descritto di seguito.

Utente di comunicazione

Identificatore:

{
    "communicationUser": {
        "id": "[communicationUserId]"
    }
}

ID non elaborato:

[communicationUserId]

L'ID non elaborato è uguale a communicationUser.id.

Utente di Microsoft Teams

Identificatore:

{
    "microsoftTeamsUser": {
        "userId": "[entraUserId]"
    }
}

ID non elaborato:

8:orgid:[entraUserId]

L'ID non elaborato è l'ID oggetto utente di Microsoft Entra preceduto da 8:orgid:.

Identificatore:

{
    "microsoftTeamsUser": {
        "userId": "[entraUserId]",
        "cloud": "gcch"
    }
}

ID non elaborato:

8:gcch:[entraUserId]

L'ID non elaborato è l'ID oggetto utente di Microsoft Entra preceduto da 8:gcch: o 8:dod:, a seconda dell'ambiente cloud.

Identificatore:

{
    "microsoftTeamsUser": {
        "userId": "[visitorUserId]",
        "isAnonymous": true
    }
}

ID non elaborato:

8:teamsvisitor:[visitorUserId]

L'ID non elaborato è l'ID visitatore di Teams preceduto da 8:teamsvisitor:. L'ID visitatore di Teams è un ID temporaneo generato da Teams per abilitare l'accesso alle riunioni.

Numero di telefono

Identificatore:

{
    "phoneNumber": {
        "value": "+1123455567"
    }
}

ID non elaborato:

4:+1123455567

L'ID non elaborato è il numero di telefono formattato E.164 preceduto da 4:.

applicazione Microsoft Teams

Identificatore:

{
    "microsoftTeamsApp": {
        "appId": "[entraUserId]"
    }
}

ID non elaborato:

28:orgid:[entraUserId]

L'ID non elaborato è l'ID oggetto utente Entra dell'applicazione preceduto da 28:orgid:.

Identificatore:

{
    "microsoftTeamsUser": {
        "userId": "[entraUserId]",
        "cloud": "gcch"
    }
}

ID non elaborato:

28:gcch:[entraUserId]

L'ID non elaborato è l'ID oggetto utente Entra dell'applicazione preceduto da 28:gcch: o 28:dod:, a seconda dell'ambiente cloud.

Sconosciuto

Identificatore:

{
    "rawId": "[unknown identifier id]"
}

ID non elaborato:

[unknown identifier id]

Se un ID non elaborato non è valido, il servizio non riuscirà a eseguire la richiesta.

Passaggi successivi