@andrey4emk/npm-app-back-b24 0.5.17 → 0.5.19

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@andrey4emk/npm-app-back-b24",
3
- "version": "0.5.17",
3
+ "version": "0.5.19",
4
4
  "description": "Bitrix24 OAuth helpers for Node.js projects",
5
5
  "main": "index.js",
6
6
  "type": "module",
@@ -79,6 +79,60 @@ export class ChatApp {
79
79
  }
80
80
  }
81
81
 
82
+ async sendFileChatApp(messangerType, messageData) {
83
+ // Проверяем что верно указан messangerType и в messageData есть phone и message
84
+ if (!["whatsApp"].includes(messangerType) && !["telegram"].includes(messangerType)) {
85
+ return { error: true, message: "Неверный тип мессенджера", data: null };
86
+ }
87
+ if (!messageData.phone || !messageData.message) {
88
+ return { error: true, message: "Отсутствует phone или message", data: null };
89
+ }
90
+ let check = await this.checkTokenChatApp();
91
+ if (check.error) {
92
+ return { error: true, message: `Ошибка с токеном ChatApp в функции sendMessageChatApp класса ChatApp\n${check.message}`, data: null };
93
+ }
94
+ let phone = messageData.phone;
95
+ let caption = messageData.message;
96
+ let file = messageData.fileUrl;
97
+ let fileName = messageData.fileName;
98
+
99
+ let url;
100
+ if (messangerType === "whatsApp") {
101
+ url = `https://api.chatapp.online/v1/licenses/${this.type.whatsApp.licenseId}/messengers/${this.type.whatsApp.messenger[0].type}/chats/${phone}/messages/file`;
102
+ }
103
+ if (messangerType === "telegram") {
104
+ url = `https://api.chatapp.online/v1/licenses/${this.type.telegram.licenseId}/messengers/${this.type.telegram.messenger[0].type}/chats/${phone}/messages/file`;
105
+ }
106
+ let res = await fetch(url, {
107
+ method: "POST",
108
+ headers: {
109
+ Lang: "en",
110
+ "Content-Type": "application/json",
111
+ Accept: "application/json",
112
+ Authorization: this.auth.accessToken,
113
+ },
114
+ body: JSON.stringify({
115
+ file: file,
116
+ fileName: fileName,
117
+ caption: caption,
118
+ }),
119
+ });
120
+ let data = await res.json();
121
+
122
+ if (!data.success) {
123
+ return { error: true, message: `Ошибка при отправке сообщения в ChatApp через ${messangerType}`, data: data };
124
+ } else {
125
+ // Если в процессе запроса обновили токен, то возвращаем информацию об этом.
126
+ let newAuth = null;
127
+ if (this.updateToken) {
128
+ newAuth = this.auth;
129
+ // Сбрасываем флаг обновления токена
130
+ this.updateToken = false;
131
+ }
132
+ return { error: false, message: `Сообщение успешно отправлено в ChatApp через ${messangerType}`, data: data, auth: newAuth };
133
+ }
134
+ }
135
+
82
136
  async phoneCheckChatApp(messangerType, phone) {
83
137
  if (!["whatsApp"].includes(messangerType) && !["telegram"].includes(messangerType)) {
84
138
  return { error: true, message: "Неверный тип мессенджера", data: null };
@@ -3,9 +3,10 @@ import dotEnv from "dotenv";
3
3
  dotEnv.config();
4
4
 
5
5
  export class Smsgold {
6
- constructor(authParam) {
6
+ constructor(authParam, b24 = null) {
7
7
  this.user = authParam.user;
8
8
  this.pass = authParam.pass;
9
+ this.b24 = b24;
9
10
  }
10
11
 
11
12
  async sendSms(messageData) {
@@ -17,12 +18,40 @@ export class Smsgold {
17
18
  if (!phone || !message) {
18
19
  return { error: true, message: "Отсутствуют номер телефона или текст сообщения", result: null };
19
20
  }
21
+ // Проверяем нужно ли отправить файл
22
+ let publicLink = "";
23
+ if (messageData.fileUrl && messageData.fileName) {
24
+ let fileUrl = messageData.fileUrl;
25
+ let fileName = messageData.fileName;
26
+ // Скачиваем файл по ссылке
27
+ let resDownloadFile = await this.downloadFileToUrl(fileUrl);
28
+ if (resDownloadFile.error) {
29
+ return { error: true, message: `Не получилось скачать файл: ${resDownloadFile.message}` };
30
+ }
31
+ // Копируем файл на диск проекта битрикс24. Где автоматически запускается БП на автоматическое удаление файла через 14 дней
32
+ let resUploadFileInFolderB24 = await this.uploadFileInFolderB24(resDownloadFile.buffer, fileName);
33
+ if (resUploadFileInFolderB24.error) {
34
+ return { error: true, message: resUploadFileInFolderB24.message };
35
+ }
36
+ let idFileContract = resUploadFileInFolderB24.data.ID;
37
+ // Получаем публичную ссылку на файл для вставки в сообщение
38
+
39
+ try {
40
+ publicLink = await this.b24.callMethod("disk.file.getExternalLink", {
41
+ id: idFileContract,
42
+ });
43
+ publicLink = publicLink.getData().result;
44
+ } catch (error) {
45
+ logs.add(`Ошибка при получении публичной ссылки на файл: ${error.message}`, "error");
46
+ return { error: true, message: `Ошибка при получении публичной ссылки на файл: ${error.message}` };
47
+ }
48
+ }
20
49
  try {
21
50
  let body = new URLSearchParams({
22
51
  user: this.user,
23
52
  pass: this.pass,
24
53
  action: "send",
25
- text: message,
54
+ text: message + (publicLink ? `\n${publicLink}` : ""),
26
55
  number: phone,
27
56
  sender: "potolkiRepa",
28
57
  }).toString();
@@ -59,4 +88,41 @@ export class Smsgold {
59
88
  return { error: true, message: error.message, result: null };
60
89
  }
61
90
  }
91
+
92
+ // Функция для закачивания файла в папку битрикс24. Используем метод disk.folder.uploadfile
93
+ async uploadFileInFolderB24(fileBuffer, fileName) {
94
+ console.log(`Запустили uploadFileInFolderB24()`);
95
+ try {
96
+ let base64File = await fileBuffer.toString("base64");
97
+ // Используем метод disk.folder.uploadfile
98
+ let res = await b24.callMethod("disk.folder.uploadfile", {
99
+ id: 2792881, // Id папки "contract_company" из проекта "Документы и договора" https://repacheb.bitrix24.ru/workgroups/group/193/disk/path/
100
+ data: {
101
+ NAME: fileName,
102
+ },
103
+ fileContent: [fileName, base64File],
104
+ });
105
+ const data = await res.getData().result;
106
+ return { error: false, data: data };
107
+ } catch (error) {
108
+ logs.add(`Ошибка при загрузке файла в папку битрикс24: ${error.message}`, "error");
109
+ return { error: true, message: `Ошибка при загрузке файла в папку битрикс24: ${error.message}` };
110
+ }
111
+ }
112
+
113
+ async downloadFileToUrl(fileUrl) {
114
+ try {
115
+ const response = await fetch(fileUrl);
116
+ if (!response.ok) {
117
+ throw new Error(`HTTP error! status: ${response.status}`);
118
+ }
119
+ const arrayBuffer = await response.arrayBuffer();
120
+ const buffer = Buffer.from(arrayBuffer);
121
+
122
+ // Возвращаем буфер
123
+ return { error: false, buffer: buffer };
124
+ } catch (error) {
125
+ return { error: true, message: `Ошибка при скачивании файла по fileUrl: ${error.message}` };
126
+ }
127
+ }
62
128
  }