Compare commits
20 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
687dfa84e9 | ||
|
|
b7da515969 | ||
|
|
e2c291c040 | ||
|
|
87f2c5290f | ||
|
|
4fdddc8c92 | ||
|
|
d53a5c5e26 | ||
|
|
9772b3b1fd | ||
|
|
84fe91adbb | ||
|
|
b6cd85eab0 | ||
|
|
209b3aaa45 | ||
|
|
4912ce6f61 | ||
|
|
013ffa318f | ||
|
|
ac2f953b90 | ||
|
|
a25c71a04a | ||
|
|
836d4751ad | ||
|
|
2983a14038 | ||
|
|
6e71ba4b5b | ||
|
|
5dc6aa5660 | ||
|
|
6d4b6b1609 | ||
|
|
1e3b63fe5b |
@@ -1,5 +1,10 @@
|
||||
FROM node:10-alpine
|
||||
|
||||
RUN apk add g++ make python
|
||||
RUN apk add tzdata
|
||||
|
||||
ENV TZ America/Montreal
|
||||
|
||||
RUN mkdir -p /home/node/app/node_modules && chown -R node:node /home/node/app
|
||||
|
||||
WORKDIR /home/node/app
|
||||
|
||||
@@ -157,6 +157,10 @@ export const mockGetGroupUsers = jest.fn(() => {
|
||||
|
||||
export const mockGetUser = jest.fn().mockReturnValue({ presence: 'online'});
|
||||
|
||||
export const mockSendStateEvent = jest.fn(() => {
|
||||
return Promise.resolve();
|
||||
});
|
||||
|
||||
export const mockClient = {
|
||||
registerRequest: mockRegisterRequest,
|
||||
initCrypto: mockInitCrypto,
|
||||
@@ -186,6 +190,7 @@ export const mockClient = {
|
||||
getJoinedRoomMembers: mockGetJoinedRoomMembers,
|
||||
getUser: mockGetUser,
|
||||
getGroupUsers: mockGetGroupUsers,
|
||||
sendStateEvent: mockSendStateEvent,
|
||||
}
|
||||
|
||||
export const WebStorageSessionStore = jest.fn()
|
||||
|
||||
336
dist/bot.js
vendored
336
dist/bot.js
vendored
File diff suppressed because it is too large
Load Diff
14
dist/bot.test.js
vendored
14
dist/bot.test.js
vendored
@@ -103,6 +103,8 @@ describe('OcrccBot', () => {
|
||||
mockAppendFileSync.mockClear();
|
||||
|
||||
_matrixJsSdk.mockGetGroupUsers.mockClear();
|
||||
|
||||
_matrixJsSdk.mockSendStateEvent.mockClear();
|
||||
});
|
||||
test('constructor should inititialize class variables', () => {
|
||||
const bot = new _bot.default(botConfig);
|
||||
@@ -276,4 +278,16 @@ describe('OcrccBot', () => {
|
||||
expect(_matrixJsSdk.mockStartClient).toHaveBeenCalled();
|
||||
});
|
||||
});
|
||||
test('#sendBotSignal should send custom state event', () => {
|
||||
const bot = new _bot.default(botConfig);
|
||||
bot.start();
|
||||
const test_room_id = 'test_room_id';
|
||||
const signal = 'END_CHAT';
|
||||
bot.sendBotSignal(test_room_id, signal);
|
||||
(0, _waitForExpect.default)(() => {
|
||||
expect(_matrixJsSdk.mockSendStateEvent).toHaveBeenCalledWith(test_room_id, 'm.bot.signal', {
|
||||
signal
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
17
dist/index.js
vendored
17
dist/index.js
vendored
@@ -19,7 +19,10 @@ const {
|
||||
BOT_PASSWORD,
|
||||
BOT_DISPLAY_NAME,
|
||||
FACILITATOR_ROOM_ID,
|
||||
CAPTURE_TRANSCRIPTS
|
||||
CAPTURE_TRANSCRIPTS,
|
||||
CHAT_NOT_AVAILABLE_MESSAGE,
|
||||
MAX_WAIT_TIME,
|
||||
MAX_INACTIVE
|
||||
} = process.env;
|
||||
const botConfig = {
|
||||
ENCRYPTION_CONFIG,
|
||||
@@ -32,7 +35,15 @@ const botConfig = {
|
||||
BOT_PASSWORD,
|
||||
BOT_DISPLAY_NAME,
|
||||
FACILITATOR_ROOM_ID,
|
||||
CAPTURE_TRANSCRIPTS
|
||||
CAPTURE_TRANSCRIPTS,
|
||||
CHAT_NOT_AVAILABLE_MESSAGE,
|
||||
MAX_WAIT_TIME,
|
||||
MAX_INACTIVE
|
||||
};
|
||||
const bot = new _bot.default(botConfig);
|
||||
bot.start();
|
||||
|
||||
try {
|
||||
bot.start();
|
||||
} catch (err) {
|
||||
console.log("AAAAAAAAAAAAA", err);
|
||||
}
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "private-safesupport-bot",
|
||||
"version": "1.2.0",
|
||||
"version": "2.0.2",
|
||||
"description": "Chatbot to manage interactions on Safe Support Chat",
|
||||
"main": "dist/index.js",
|
||||
"scripts": {
|
||||
|
||||
375
src/bot.js
375
src/bot.js
File diff suppressed because it is too large
Load Diff
@@ -32,7 +32,8 @@ import {
|
||||
mockKick,
|
||||
mockGetJoinedRoomMembers,
|
||||
mockGetUser,
|
||||
mockGetGroupUsers
|
||||
mockGetGroupUsers,
|
||||
mockSendStateEvent,
|
||||
} from "matrix-js-sdk";
|
||||
|
||||
import OcrccBot from './bot'
|
||||
@@ -100,6 +101,7 @@ describe('OcrccBot', () => {
|
||||
mockSendTextMessage.mockClear()
|
||||
mockAppendFileSync.mockClear()
|
||||
mockGetGroupUsers.mockClear()
|
||||
mockSendStateEvent.mockClear()
|
||||
})
|
||||
|
||||
|
||||
@@ -325,4 +327,17 @@ describe('OcrccBot', () => {
|
||||
expect(mockStartClient).toHaveBeenCalled()
|
||||
})
|
||||
})
|
||||
|
||||
test('#sendBotSignal should send custom state event', () => {
|
||||
const bot = new OcrccBot(botConfig)
|
||||
bot.start()
|
||||
const test_room_id = 'test_room_id'
|
||||
const signal = 'END_CHAT'
|
||||
|
||||
bot.sendBotSignal(test_room_id, signal)
|
||||
|
||||
waitForExpect(() => {
|
||||
expect(mockSendStateEvent).toHaveBeenCalledWith(test_room_id, 'm.bot.signal', { signal })
|
||||
})
|
||||
})
|
||||
})
|
||||
13
src/index.js
13
src/index.js
@@ -5,6 +5,7 @@ const KICK_REASON = "A facilitator has already joined this chat.";
|
||||
const BOT_ERROR_MESSAGE =
|
||||
"Something went wrong on our end, please restart the chat and try again.";
|
||||
const MAX_RETRIES = 3;
|
||||
|
||||
const {
|
||||
MATRIX_SERVER_URL,
|
||||
BOT_USERNAME,
|
||||
@@ -13,6 +14,9 @@ const {
|
||||
BOT_DISPLAY_NAME,
|
||||
FACILITATOR_ROOM_ID,
|
||||
CAPTURE_TRANSCRIPTS,
|
||||
CHAT_NOT_AVAILABLE_MESSAGE,
|
||||
MAX_WAIT_TIME,
|
||||
MAX_INACTIVE,
|
||||
} = process.env;
|
||||
|
||||
const botConfig = {
|
||||
@@ -27,9 +31,16 @@ const botConfig = {
|
||||
BOT_DISPLAY_NAME,
|
||||
FACILITATOR_ROOM_ID,
|
||||
CAPTURE_TRANSCRIPTS,
|
||||
CHAT_NOT_AVAILABLE_MESSAGE,
|
||||
MAX_WAIT_TIME,
|
||||
MAX_INACTIVE,
|
||||
}
|
||||
|
||||
import OcrccBot from './bot'
|
||||
|
||||
const bot = new OcrccBot(botConfig);
|
||||
bot.start();
|
||||
try {
|
||||
bot.start();
|
||||
} catch(err) {
|
||||
console.log("AAAAAAAAAAAAA", err)
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user