Authentification dans Direct Line API 1.1
Important
Cet article décrit l’authentification dans l’API Direct Line 1.1. Si vous créez une connexion entre votre application cliente et votre bot, utilisez plutôt Direct Line’API 3.0.
Un client peut authentifier les requêtes destinées à l’API Direct Line 1.1 soit à l’aide d’un secret que vous obtenez dans la page de configuration du canal Direct Line sur le portail Bot Framework, soit à l’aide d’un jeton que vous obtenez au moment de l’exécution.
Le secret ou le jeton doit être spécifié dans l’en-tête Authorization
de chaque requête à l’aide du schéma « Bearer » ou du schéma « BotConnector ».
Schéma Bearer :
Authorization: Bearer SECRET_OR_TOKEN
Schéma BotConnector :
Authorization: BotConnector SECRET_OR_TOKEN
Secrets et jetons
Un secret Direct Line est une clé principale qui peut être utilisée pour accéder à toute conversation appartenant au robot associé. Un secret peut également être utilisé pour obtenir un jeton. Les secrets n’expirent pas.
Un jeton Direct Line est une clé qui peut être utilisée pour accéder à une seule conversation. Un jeton expire, mais peut être actualisé.
Si vous créez une application de service à service, l’approche la plus simple peut consister à spécifier le secret dans l’en-tête Authorization
des demandes d’API Direct Line. Si vous écrivez une application où le client s’exécute dans un navigateur web ou une application mobile, vous souhaiterez peut-être échanger votre secret contre un jeton (qui fonctionne uniquement pour une conversation et expire sauf s’il est actualisé) et spécifier le jeton dans l’en-tête Authorization
des demandes d’API Direct Line. Choisissez le modèle de sécurité qui vous convient le mieux.
Notes
Les informations d’identification de votre client Direct Line sont différentes de celles de votre robot. Cela vous permet de réviser vos clés de manière indépendante et de partager des jetons de client sans révéler le mot de passe de votre robot.
Obtenir un secret Direct Line
Vous pouvez obtenir un secret Direct Line via la page de configuration du canal Direct Line pour votre bot dans le Portail Azure :
Générer un jeton Direct Line
Pour générer un jeton Direct Line qui peut être utilisé pour accéder à une seule conversation, commencez par obtenir le secret Direct Line à partir de la page de configuration du canal Direct Line dans la Portail Azure. Ensuite, émettez la demande suivante pour échanger votre secret Direct Line contre un jeton Direct Line :
POST https://directline.botframework.com/api/tokens/conversation
Authorization: Bearer SECRET
Dans l’en-tête Authorization
de cette demande, remplacez SECRET par la valeur de votre secret Direct Line.
Les extraits de code suivants illustrent la demande et la réponse dans le cadre de la génération de jeton.
Requête
POST https://directline.botframework.com/api/tokens/conversation
Authorization: Bearer RCurR_XV9ZA.cwA.BKA.iaJrC8xpy8qbOF5xnR2vtCX7CZj0LdjAPGfiCpg4Fv0
response
Si la requête aboutit, la réponse contient un jeton valide pour une conversation. Le jeton expire au bout de 30 minutes. Pour que le jeton reste valide, vous devez l’actualiser avant son expiration.
HTTP/1.1 200 OK
[other headers]
"RCurR_XV9ZA.cwA.BKA.iaJrC8xpy8qbOF5xnR2vtCX7CZj0LdjAPGfiCpg4Fv0y8qbOF5xPGfiCpg4Fv0y8qqbOF5x8qbOF5xn"
Générer un jeton ou démarrer une conversation
L’opération de génération de jeton (POST /api/tokens/conversation
) est similaire à l’opération de démarrage de conversation (POST /api/conversations
) dans la mesure où les deux opérations retournent un token
qui peut être utilisé pour accéder à une seule conversation. Toutefois, contrairement à l’opération Démarrer la conversation, l’opération Générer un jeton ne démarre pas la conversation ou ne contacte pas le bot.
Si vous envisagez de distribuer le jeton aux clients et souhaitez qu’ils initialisent la conversation, utilisez l’opération de génération de jeton. Si vous envisagez de démarrer la conversation immédiatement, utilisez plutôt l’opération de démarrage de conversation.
Actualiser un jeton Direct Line
Un jeton Direct Line est valide pendant 30 minutes à partir du moment où il est généré et peut être actualisé un nombre illimité de fois, tant qu’il n’a pas expiré. Un jeton expiré ne peut pas être actualisé. Pour actualiser un jeton Direct Line, émettez la demande suivante :
POST https://directline.botframework.com/api/tokens/{conversationId}/renew
Authorization: Bearer TOKEN_TO_BE_REFRESHED
Dans l’URI de cette requête, remplacez {conversationId} par l’ID de la conversation pour lequel le jeton est valide et, dans l’en-tête Authorization
de cette requête, remplacez TOKEN_TO_BE_REFRESHED par le jeton Direct Line que vous souhaitez actualiser.
Les extraits de code suivants illustrent la demande et la réponse dans le cadre de l’actualisation du jeton.
Requête
POST https://directline.botframework.com/api/tokens/abc123/renew
Authorization: Bearer CurR_XV9ZA.cwA.BKA.iaJrC8xpy8qbOF5xnR2vtCX7CZj0LdjAPGfiCpg4Fv0y8qbOF5xPGfiCpg4Fv0y8qqbOF5x8qbOF5xn
response
Si la requête aboutit, la réponse contient un nouveau jeton valide pour la même conversation que le jeton précédent. Le nouveau jeton expire au bout de 30 minutes. Pour que le nouveau jeton reste valide, vous devez l’actualiser avant son expiration.
HTTP/1.1 200 OK
[other headers]
"RCurR_XV9ZA.cwA.BKA.y8qbOF5xPGfiCpg4Fv0y8qqbOF5x8qbOF5xniaJrC8xpy8qbOF5xnR2vtCX7CZj0LdjAPGfiCpg4Fv0"