-
Notifications
You must be signed in to change notification settings - Fork 4.9k
/
Copy pathwebChatAdapter.ts
102 lines (90 loc) · 3.98 KB
/
webChatAdapter.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
import { ConnectionStatus } from 'botframework-directlinejs';
import { BotAdapter, TurnContext } from 'botbuilder-core';
import { BOT_PROFILE, USER_PROFILE } from './app';
import Observable from 'core-js/features/observable';
/**
* Custom BotAdapter used for deploying a bot in a browser.
*/
export class WebChatAdapter extends BotAdapter {
constructor() {
super();
this.botConnection = {
connectionStatus$: new Observable(observer => {
observer.next(ConnectionStatus.Uninitialized);
observer.next(ConnectionStatus.Connecting);
observer.next(ConnectionStatus.Online);
}),
activity$: new Observable(observer => {
this.activityObserver = observer;
}),
end() {
// The React component was called to unmount:
// https://github.com/Microsoft/BotFramework-WebChat/blob/57360e4df92e041d5b0fd4810c1abf96621b5283/src/Chat.tsx#L237-L247
// Developers will need to decide what behavior the component should implement.
// For this sample, this.botConnection.componentWillUnmount() and this.botConnection.end()
// is never called.
console.log('this.botConnection.componentWillUnmount() called.');
},
getSessionId: () => new Observable(observer => observer.complete()),
postActivity: activity => {
const id = Date.now().toString();
return new Observable(observer => {
const serverActivity = {
...activity,
id,
conversation: { id: 'bot' },
channelId: 'WebChat',
recipient: BOT_PROFILE,
timestamp: new Date().toISOString()
};
this.onReceive(serverActivity).then(() => {
observer.next(id);
observer.complete();
this.activityObserver.next(serverActivity);
});
});
}
};
}
/**
* This WebChatAdapter implements the sendActivities method which is called by the TurnContext class.
* It's also possible to write a custom TurnContext with different methods of accessing an adapter.
* @param {TurnContext} context
* @param {Activity[]} activities
*/
sendActivities(context, activities) {
const sentActivities = activities.map(activity => Object.assign({}, activity, {
id: Date.now().toString(),
channelId: 'WebChat',
conversation: { id: 'bot' },
from: BOT_PROFILE,
recipient: USER_PROFILE,
timestamp: new Date().toISOString()
}));
sentActivities.forEach(activity => this.activityObserver.next(activity));
return Promise.resolve(sentActivities.map(activity => {
return { id: activity.id };
}));
}
/**
* Registers the business logic for the adapter, it takes a handler that takes a TurnContext object as a parameter.
* @param {function} logic The driver code of the developer's bot application. This code receives and responds to user messages.
*/
processActivity(logic) {
this.logic = logic;
return this;
}
/**
* Runs the bot's middleware pipeline in addition to any business logic, if `this.logic` is found.
* @param {Activity} activity
*/
onReceive(activity) {
const context = new TurnContext(this, activity);
// Runs the middleware pipeline followed by any registered business logic.
// If no business logic has been registered via processActivity, a default
// value is provided as to not break the bot.
return this.runMiddleware(context, this.logic || function() { });
}
}