rubjs 2.7.4 → 2.7.6

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": "rubjs",
3
- "version": "2.7.4",
3
+ "version": "2.7.6",
4
4
  "main": "rubjs/index.js",
5
5
  "types": "rubjs/index.d.ts",
6
6
  "keywords": [
@@ -1,4 +1,37 @@
1
1
  "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
2
35
  var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
36
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
37
  return new (P || (P = Promise))(function (resolve, reject) {
@@ -16,7 +49,13 @@ const fluent_ffmpeg_1 = __importDefault(require("fluent-ffmpeg"));
16
49
  const promises_1 = __importDefault(require("fs/promises"));
17
50
  const path_1 = __importDefault(require("path"));
18
51
  const os_1 = __importDefault(require("os"));
19
- const sharp_1 = __importDefault(require("sharp"));
52
+ let sharp;
53
+ try {
54
+ sharp = Promise.resolve().then(() => __importStar(require("sharp")));
55
+ }
56
+ catch (err) {
57
+ console.log("⚠️ Sharp module could not be loaded:", err.message);
58
+ }
20
59
  class ThumbnailGenerator {
21
60
  static getTime(videoPath) {
22
61
  return __awaiter(this, void 0, void 0, function* () {
@@ -62,7 +101,7 @@ class ThumbnailGenerator {
62
101
  static fromImage(imagePath_1) {
63
102
  return __awaiter(this, arguments, void 0, function* (imagePath, width = 320) {
64
103
  try {
65
- const buffer = yield (0, sharp_1.default)(imagePath).resize(width).toBuffer();
104
+ const buffer = yield sharp(imagePath).resize(width).toBuffer();
66
105
  return buffer.toString("base64");
67
106
  }
68
107
  catch (error) {
@@ -15,11 +15,12 @@ declare class VoiceChatClient {
15
15
  private lastPosition;
16
16
  private intervalId?;
17
17
  private isManualSkip;
18
- constructor();
18
+ private getAnyMusicCallback;
19
+ constructor(getAnyMusicCallback?: () => Promise<string>);
19
20
  play(filePath?: string): Promise<void>;
20
21
  stop(): void;
21
22
  resume(): void;
22
- next(): void;
23
+ next(): Promise<void>;
23
24
  previous(): void;
24
25
  addToPlaylist(filePath: string): void;
25
26
  removeFromPlaylist(filePath: string): void;
@@ -12,7 +12,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
12
12
  const child_process_1 = require("child_process");
13
13
  const wrtc_1 = require("wrtc");
14
14
  class VoiceChatClient {
15
- constructor() {
15
+ constructor(getAnyMusicCallback) {
16
16
  this.buffer = Buffer.alloc(0);
17
17
  this.frameSize = 960;
18
18
  this.playlist = [];
@@ -24,14 +24,20 @@ class VoiceChatClient {
24
24
  this.source = new wrtc_1.nonstandard.RTCAudioSource();
25
25
  this.track = this.source.createTrack();
26
26
  this.pc.addTrack(this.track);
27
+ this.getAnyMusicCallback = getAnyMusicCallback;
27
28
  }
28
29
  play(filePath) {
29
30
  return __awaiter(this, void 0, void 0, function* () {
30
31
  if (this.ffmpeg)
31
32
  this.stop();
32
33
  if (!filePath) {
33
- if (this.playlist.length === 0)
34
- return;
34
+ if (this.playlist.length === 0) {
35
+ if (this.getAnyMusicCallback) {
36
+ this.playlist = [yield this.getAnyMusicCallback()];
37
+ }
38
+ else
39
+ return;
40
+ }
35
41
  filePath = this.playlist[this.currentIndex];
36
42
  }
37
43
  if (!this.chatGuid || !this.voiceChatId || !this.client) {
@@ -75,12 +81,27 @@ class VoiceChatClient {
75
81
  this.lastPosition += 0.02;
76
82
  }
77
83
  });
78
- this.ffmpeg.on("close", (code) => {
84
+ this.ffmpeg.on("close", (code) => __awaiter(this, void 0, void 0, function* () {
79
85
  if (!this.isManualSkip && code !== null && !this.isPaused) {
80
- this.next();
86
+ yield this.next();
81
87
  }
82
88
  this.isManualSkip = false;
83
- });
89
+ }));
90
+ this.clearIntervals();
91
+ this.intervalId = setInterval(() => __awaiter(this, void 0, void 0, function* () {
92
+ try {
93
+ yield this.client.getGroupVoiceChatUpdates(this.chatGuid, this.voiceChatId);
94
+ }
95
+ catch (_a) { }
96
+ }), 10 * 1000);
97
+ this.intervalId = setInterval(() => __awaiter(this, void 0, void 0, function* () {
98
+ try {
99
+ if (this.isPaused)
100
+ return;
101
+ yield this.client.sendVoiceChatActivity(this.chatGuid, this.voiceChatId, this.client.userGuid);
102
+ }
103
+ catch (_a) { }
104
+ }), 2 * 1000);
84
105
  });
85
106
  }
86
107
  stop() {
@@ -96,14 +117,22 @@ class VoiceChatClient {
96
117
  this.play();
97
118
  }
98
119
  next() {
99
- if (this.playlist.length > this.currentIndex + 1) {
100
- this.isManualSkip = true;
101
- this.stop();
102
- this.currentIndex += 1;
103
- this.lastPosition = 0;
104
- this.isPaused = true;
105
- this.play(this.playlist[this.currentIndex]);
106
- }
120
+ return __awaiter(this, void 0, void 0, function* () {
121
+ if (this.playlist.length > this.currentIndex + 1) {
122
+ this.isManualSkip = true;
123
+ this.stop();
124
+ this.currentIndex += 1;
125
+ this.lastPosition = 0;
126
+ this.isPaused = true;
127
+ this.play(this.playlist[this.currentIndex]);
128
+ }
129
+ else {
130
+ if (this.getAnyMusicCallback) {
131
+ this.playlist = [...this.playlist, yield this.getAnyMusicCallback()];
132
+ yield this.next();
133
+ }
134
+ }
135
+ });
107
136
  }
108
137
  previous() {
109
138
  if (this.currentIndex > 0) {
@@ -138,19 +167,6 @@ class VoiceChatClient {
138
167
  const sdpAnswer = connect.sdp_answer_data;
139
168
  yield this.pc.setRemoteDescription(new wrtc_1.RTCSessionDescription({ type: "answer", sdp: sdpAnswer }));
140
169
  yield client.setVoiceChatState(chatGuid, voiceChatId);
141
- this.clearIntervals();
142
- this.intervalId = setInterval(() => __awaiter(this, void 0, void 0, function* () {
143
- try {
144
- yield client.getGroupVoiceChatUpdates(chatGuid, voiceChatId);
145
- }
146
- catch (_a) { }
147
- }), 10 * 1000);
148
- this.intervalId = setInterval(() => __awaiter(this, void 0, void 0, function* () {
149
- try {
150
- yield client.sendVoiceChatActivity(chatGuid, voiceChatId, client.userGuid);
151
- }
152
- catch (_a) { }
153
- }), 2 * 1000);
154
170
  });
155
171
  }
156
172
  clearIntervals() {