@edgenets/utils 0.1.19 → 0.2.2
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/README.md +107 -13
- package/dist/config/product.config.d.ts +7 -0
- package/dist/config/product.config.d.ts.map +1 -0
- package/dist/config/product.config.js +65 -0
- package/dist/config/product.config.js.map +1 -0
- package/dist/index.d.ts +7 -7
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +7 -7
- package/dist/index.js.map +1 -1
- package/dist/{utils/logger → logger}/default.d.ts +1 -1
- package/dist/logger/default.d.ts.map +1 -0
- package/dist/logger/default.js.map +1 -0
- package/dist/models/broadcast.d.ts.map +1 -0
- package/dist/models/broadcast.js.map +1 -0
- package/dist/models/logger.d.ts.map +1 -0
- package/dist/{types → models}/logger.js.map +1 -1
- package/dist/models/order.d.ts.map +1 -0
- package/dist/models/order.js.map +1 -0
- package/dist/models/product.d.ts.map +1 -0
- package/dist/{types → models}/product.js.map +1 -1
- package/dist/models/user.d.ts.map +1 -0
- package/dist/{types → models}/user.js.map +1 -1
- package/dist/{utils/queue → queue}/index.d.ts.map +1 -1
- package/dist/queue/index.js +15 -0
- package/dist/queue/index.js.map +1 -0
- package/dist/{utils/queue → queue}/queue.d.ts +1 -0
- package/dist/queue/queue.d.ts.map +1 -0
- package/dist/{utils/queue → queue}/queue.js +14 -11
- package/dist/queue/queue.js.map +1 -0
- package/dist/utils/statemachine.util.js +1 -1
- package/dist/utils/statemachine.util.js.map +1 -1
- package/package.json +3 -18
- package/dist/array/unique.d.ts +0 -2
- package/dist/array/unique.d.ts.map +0 -1
- package/dist/array/unique.js +0 -4
- package/dist/array/unique.js.map +0 -1
- package/dist/types/broadcast.d.ts.map +0 -1
- package/dist/types/broadcast.js.map +0 -1
- package/dist/types/logger.d.ts.map +0 -1
- package/dist/types/notification.d.ts +0 -44
- package/dist/types/notification.d.ts.map +0 -1
- package/dist/types/notification.js +0 -10
- package/dist/types/notification.js.map +0 -1
- package/dist/types/order.d.ts.map +0 -1
- package/dist/types/order.js.map +0 -1
- package/dist/types/product.d.ts.map +0 -1
- package/dist/types/user.d.ts.map +0 -1
- package/dist/utils/logger/default.d.ts.map +0 -1
- package/dist/utils/logger/default.js.map +0 -1
- package/dist/utils/logger.util.d.ts +0 -8
- package/dist/utils/logger.util.d.ts.map +0 -1
- package/dist/utils/logger.util.js +0 -15
- package/dist/utils/logger.util.js.map +0 -1
- package/dist/utils/queue/index.js +0 -35
- package/dist/utils/queue/index.js.map +0 -1
- package/dist/utils/queue/queue.d.ts.map +0 -1
- package/dist/utils/queue/queue.js.map +0 -1
- package/dist/utils/scheduler.util.d.ts +0 -23
- package/dist/utils/scheduler.util.d.ts.map +0 -1
- package/dist/utils/scheduler.util.js +0 -81
- package/dist/utils/scheduler.util.js.map +0 -1
- package/dist/utils/tasks/queue.d.ts +0 -23
- package/dist/utils/tasks/queue.d.ts.map +0 -1
- package/dist/utils/tasks/queue.js +0 -72
- package/dist/utils/tasks/queue.js.map +0 -1
- package/dist/utils/tasks/scheduler.d.ts +0 -24
- package/dist/utils/tasks/scheduler.d.ts.map +0 -1
- package/dist/utils/tasks/scheduler.js +0 -98
- package/dist/utils/tasks/scheduler.js.map +0 -1
- /package/dist/{utils/logger → logger}/default.js +0 -0
- /package/dist/{types → models}/broadcast.d.ts +0 -0
- /package/dist/{types → models}/broadcast.js +0 -0
- /package/dist/{types → models}/logger.d.ts +0 -0
- /package/dist/{types → models}/logger.js +0 -0
- /package/dist/{types → models}/order.d.ts +0 -0
- /package/dist/{types → models}/order.js +0 -0
- /package/dist/{types → models}/product.d.ts +0 -0
- /package/dist/{types → models}/product.js +0 -0
- /package/dist/{types → models}/user.d.ts +0 -0
- /package/dist/{types → models}/user.js +0 -0
- /package/dist/{utils/queue → queue}/index.d.ts +0 -0
package/README.md
CHANGED
@@ -2,6 +2,16 @@
|
|
2
2
|
|
3
3
|
Edgenets utilities package containing common types and utilities.
|
4
4
|
|
5
|
+
## Features
|
6
|
+
|
7
|
+
- Logger
|
8
|
+
- Queue
|
9
|
+
- Config
|
10
|
+
- Services
|
11
|
+
- Repositories
|
12
|
+
- Utilities
|
13
|
+
- Models
|
14
|
+
|
5
15
|
## Installation
|
6
16
|
|
7
17
|
```bash
|
@@ -10,22 +20,106 @@ npm install @edgenets/utils
|
|
10
20
|
|
11
21
|
## Usage
|
12
22
|
|
13
|
-
###
|
23
|
+
### Importing Modules
|
14
24
|
|
15
25
|
```typescript
|
16
|
-
import {
|
17
|
-
|
18
|
-
//
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
26
|
+
import { ConsoleLogger, Queue, defaultConfig, ExampleService, ExampleRepository, Utils, User, Order } from '@edgenets/utils';
|
27
|
+
|
28
|
+
// Logger
|
29
|
+
const logger = ConsoleLogger.getInstance();
|
30
|
+
logger.info('Library initialized');
|
31
|
+
|
32
|
+
// Queue
|
33
|
+
const queue = new Queue(defaultConfig.maxConcurrent, defaultConfig.requestRate);
|
34
|
+
queue.addTask(async () => {
|
35
|
+
// Your task here
|
36
|
+
});
|
37
|
+
|
38
|
+
// Service
|
39
|
+
const service = new ExampleService();
|
40
|
+
service.execute();
|
41
|
+
|
42
|
+
// Repository
|
43
|
+
const repository = new ExampleRepository();
|
44
|
+
repository.save({ id: '1', name: 'Example' });
|
45
|
+
|
46
|
+
// Utilities
|
47
|
+
console.log(Utils.formatDate(new Date(), 'yyyy-MM-dd'));
|
48
|
+
|
49
|
+
// Models
|
50
|
+
const newUser: User = {
|
51
|
+
id: '1',
|
52
|
+
name: 'John Doe',
|
53
|
+
email: 'john.doe@example.com',
|
54
|
+
password: 'securepassword',
|
55
|
+
createdAt: new Date(),
|
56
|
+
updatedAt: new Date(),
|
57
|
+
};
|
58
|
+
|
59
|
+
const newOrder: Order = {
|
60
|
+
id: '1',
|
61
|
+
userId: '1',
|
62
|
+
productIds: ['100001', '100002'],
|
63
|
+
totalAmount: 450,
|
64
|
+
status: 'pending',
|
28
65
|
createdAt: new Date(),
|
29
66
|
updatedAt: new Date(),
|
30
67
|
};
|
31
68
|
```
|
69
|
+
|
70
|
+
### Project Structure
|
71
|
+
|
72
|
+
```
|
73
|
+
enterprise-node-lib
|
74
|
+
├── src
|
75
|
+
│ ├── index.ts
|
76
|
+
│ ├── config
|
77
|
+
│ │ ├── default.ts
|
78
|
+
│ │ ├── product.config.ts
|
79
|
+
│ │ └── index.ts
|
80
|
+
│ ├── interfaces
|
81
|
+
│ │ ├── service.ts
|
82
|
+
│ │ ├── repository.ts
|
83
|
+
│ │ └── index.ts
|
84
|
+
│ ├── logger
|
85
|
+
│ │ ├── default.ts
|
86
|
+
│ │ └── index.ts
|
87
|
+
│ ├── models
|
88
|
+
│ │ ├── user.ts
|
89
|
+
│ │ ├── order.ts
|
90
|
+
│ │ └── index.ts
|
91
|
+
│ ├── queue
|
92
|
+
│ │ ├── queue.ts
|
93
|
+
│ │ └── index.ts
|
94
|
+
│ ├── services
|
95
|
+
│ │ ├── exampleService.ts
|
96
|
+
│ │ └── index.ts
|
97
|
+
│ ├── repositories
|
98
|
+
│ │ ├── exampleRepository.ts
|
99
|
+
│ │ └── index.ts
|
100
|
+
│ ├── utils
|
101
|
+
│ │ └── index.ts
|
102
|
+
├── tests
|
103
|
+
│ ├── logger.test.ts
|
104
|
+
│ ├── queue.test.ts
|
105
|
+
│ ├── config.test.ts
|
106
|
+
│ ├── service.test.ts
|
107
|
+
│ ├── repository.test.ts
|
108
|
+
│ ├── user.test.ts
|
109
|
+
│ └── order.test.ts
|
110
|
+
├── package.json
|
111
|
+
├── tsconfig.json
|
112
|
+
└── README.md
|
113
|
+
```
|
114
|
+
|
115
|
+
### Running Tests
|
116
|
+
|
117
|
+
To run the tests, use the following command:
|
118
|
+
|
119
|
+
```bash
|
120
|
+
npm test
|
121
|
+
```
|
122
|
+
|
123
|
+
### License
|
124
|
+
|
125
|
+
This project is licensed under the MIT License.
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"product.config.d.ts","sourceRoot":"","sources":["../../src/config/product.config.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,cAAc;;;;;GAgE1B,CAAC"}
|
@@ -0,0 +1,65 @@
|
|
1
|
+
export const productConfigs = [
|
2
|
+
{
|
3
|
+
id: "100001",
|
4
|
+
name: "Test Product",
|
5
|
+
price: 1,
|
6
|
+
description: "This is test red apple",
|
7
|
+
},
|
8
|
+
{
|
9
|
+
id: "100002",
|
10
|
+
name: "Aria Premium Pass",
|
11
|
+
price: 400,
|
12
|
+
description: "The Aria Passcard is a virtual card designed for convenient and " +
|
13
|
+
"seamless access to specific services, facilities, or promotional " +
|
14
|
+
"programs within the Aira Metaverse.",
|
15
|
+
},
|
16
|
+
{
|
17
|
+
id: "210001",
|
18
|
+
name: "100 Gems",
|
19
|
+
price: 50,
|
20
|
+
description: "Gems",
|
21
|
+
},
|
22
|
+
{
|
23
|
+
id: "210002",
|
24
|
+
name: "500 Gems",
|
25
|
+
price: 250,
|
26
|
+
description: "Gems",
|
27
|
+
},
|
28
|
+
{
|
29
|
+
id: "210003",
|
30
|
+
name: "2k Gems",
|
31
|
+
price: 1000,
|
32
|
+
description: "Gems",
|
33
|
+
},
|
34
|
+
{
|
35
|
+
id: "220001",
|
36
|
+
name: "diamond: 100",
|
37
|
+
price: 60,
|
38
|
+
description: "Earn 100 Diamonds",
|
39
|
+
},
|
40
|
+
{
|
41
|
+
id: "220002",
|
42
|
+
name: "diamond: 500",
|
43
|
+
price: 288,
|
44
|
+
description: "Earn 500 Diamonds",
|
45
|
+
},
|
46
|
+
{
|
47
|
+
id: "220003",
|
48
|
+
name: "diamond: 1500",
|
49
|
+
price: 798,
|
50
|
+
description: "Earn 1500 Diamonds",
|
51
|
+
},
|
52
|
+
{
|
53
|
+
id: "220004",
|
54
|
+
name: "Adcard",
|
55
|
+
price: 300,
|
56
|
+
description: "Gain one month of ad-free access",
|
57
|
+
},
|
58
|
+
{
|
59
|
+
id: "220005",
|
60
|
+
name: "Hero Gilberta",
|
61
|
+
price: 300,
|
62
|
+
description: "Unlock hero Gilberta",
|
63
|
+
},
|
64
|
+
];
|
65
|
+
//# sourceMappingURL=product.config.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"product.config.js","sourceRoot":"","sources":["../../src/config/product.config.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,cAAc,GAAG;IAC5B;QACE,EAAE,EAAE,QAAQ;QACZ,IAAI,EAAE,cAAc;QACpB,KAAK,EAAE,CAAC;QACR,WAAW,EAAE,wBAAwB;KACtC;IACD;QACE,EAAE,EAAE,QAAQ;QACZ,IAAI,EAAE,mBAAmB;QACzB,KAAK,EAAE,GAAG;QACV,WAAW,EACT,kEAAkE;YAClE,mEAAmE;YACnE,qCAAqC;KACxC;IACD;QACE,EAAE,EAAE,QAAQ;QACZ,IAAI,EAAE,UAAU;QAChB,KAAK,EAAE,EAAE;QACT,WAAW,EAAE,MAAM;KACpB;IACD;QACE,EAAE,EAAE,QAAQ;QACZ,IAAI,EAAE,UAAU;QAChB,KAAK,EAAE,GAAG;QACV,WAAW,EAAE,MAAM;KACpB;IACD;QACE,EAAE,EAAE,QAAQ;QACZ,IAAI,EAAE,SAAS;QACf,KAAK,EAAE,IAAI;QACX,WAAW,EAAE,MAAM;KACpB;IACD;QACE,EAAE,EAAE,QAAQ;QACZ,IAAI,EAAE,cAAc;QACpB,KAAK,EAAE,EAAE;QACT,WAAW,EAAE,mBAAmB;KACjC;IACD;QACE,EAAE,EAAE,QAAQ;QACZ,IAAI,EAAE,cAAc;QACpB,KAAK,EAAE,GAAG;QACV,WAAW,EAAE,mBAAmB;KACjC;IACD;QACE,EAAE,EAAE,QAAQ;QACZ,IAAI,EAAE,eAAe;QACrB,KAAK,EAAE,GAAG;QACV,WAAW,EAAE,oBAAoB;KAClC;IACD;QACE,EAAE,EAAE,QAAQ;QACZ,IAAI,EAAE,QAAQ;QACd,KAAK,EAAE,GAAG;QACV,WAAW,EAAE,kCAAkC;KAChD;IACD;QACE,EAAE,EAAE,QAAQ;QACZ,IAAI,EAAE,eAAe;QACrB,KAAK,EAAE,GAAG;QACV,WAAW,EAAE,sBAAsB;KACpC;CACF,CAAC"}
|
package/dist/index.d.ts
CHANGED
@@ -1,12 +1,12 @@
|
|
1
|
-
export * from "./
|
2
|
-
export * from "./
|
3
|
-
export * from "./
|
4
|
-
export * from "./
|
5
|
-
export * from "./
|
1
|
+
export * from "./models/user.js";
|
2
|
+
export * from "./models/product.js";
|
3
|
+
export * from "./models/logger.js";
|
4
|
+
export * from "./models/order.js";
|
5
|
+
export * from "./models/broadcast.js";
|
6
6
|
export { StringUtils } from "./utils/string.util.js";
|
7
7
|
export { SimpleStateMachine, OrderStateMachine, } from "./utils/statemachine.util.js";
|
8
8
|
export { SignatureUtils } from "./utils/signature.util.js";
|
9
|
-
export * from "./
|
9
|
+
export * from "./queue/queue.js";
|
10
10
|
export * from "./utils/generate.util.js";
|
11
|
-
export * from "./
|
11
|
+
export * from "./logger/default.js";
|
12
12
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,cAAc,
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,cAAc,kBAAkB,CAAC;AACjC,cAAc,qBAAqB,CAAC;AACpC,cAAc,oBAAoB,CAAC;AACnC,cAAc,mBAAmB,CAAC;AAClC,cAAc,uBAAuB,CAAC;AAGtC,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAGrD,OAAO,EACL,kBAAkB,EAClB,iBAAiB,GAClB,MAAM,8BAA8B,CAAC;AAGtC,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAG3D,cAAc,kBAAkB,CAAC;AAGjC,cAAc,0BAA0B,CAAC;AAGzC,cAAc,qBAAqB,CAAC"}
|
package/dist/index.js
CHANGED
@@ -1,9 +1,9 @@
|
|
1
1
|
// 导出类型定义
|
2
|
-
export * from "./
|
3
|
-
export * from "./
|
4
|
-
export * from "./
|
5
|
-
export * from "./
|
6
|
-
export * from "./
|
2
|
+
export * from "./models/user.js";
|
3
|
+
export * from "./models/product.js";
|
4
|
+
export * from "./models/logger.js";
|
5
|
+
export * from "./models/order.js";
|
6
|
+
export * from "./models/broadcast.js";
|
7
7
|
// 导出字符串处理函数
|
8
8
|
export { StringUtils } from "./utils/string.util.js";
|
9
9
|
// 导出状态机函数
|
@@ -11,9 +11,9 @@ export { SimpleStateMachine, OrderStateMachine, } from "./utils/statemachine.uti
|
|
11
11
|
// 导出签名处理函数
|
12
12
|
export { SignatureUtils } from "./utils/signature.util.js";
|
13
13
|
// 导出任务队列函数
|
14
|
-
export * from "./
|
14
|
+
export * from "./queue/queue.js";
|
15
15
|
// 导出字符串处理函数
|
16
16
|
export * from "./utils/generate.util.js";
|
17
17
|
// 导出字符串处理函数
|
18
|
-
export * from "./
|
18
|
+
export * from "./logger/default.js";
|
19
19
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,SAAS;AACT,cAAc,
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,SAAS;AACT,cAAc,kBAAkB,CAAC;AACjC,cAAc,qBAAqB,CAAC;AACpC,cAAc,oBAAoB,CAAC;AACnC,cAAc,mBAAmB,CAAC;AAClC,cAAc,uBAAuB,CAAC;AAEtC,YAAY;AACZ,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAErD,UAAU;AACV,OAAO,EACL,kBAAkB,EAClB,iBAAiB,GAClB,MAAM,8BAA8B,CAAC;AAEtC,WAAW;AACX,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAE3D,WAAW;AACX,cAAc,kBAAkB,CAAC;AAEjC,YAAY;AACZ,cAAc,0BAA0B,CAAC;AAEzC,YAAY;AACZ,cAAc,qBAAqB,CAAC"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"default.d.ts","sourceRoot":"","sources":["../../src/logger/default.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAElD,cAAM,aAAc,YAAW,MAAM;IACnC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAA8B;IAErD,OAAO;WAEO,WAAW,IAAI,aAAa;IAO1C,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAG5B,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAG3B,IAAI,CAAC,OAAO,EAAE,MAAM;IAGpB,KAAK,CAAC,OAAO,EAAE,MAAM;CAGtB;AAGD,eAAO,MAAM,aAAa,eAA8B,CAAC"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"default.js","sourceRoot":"","sources":["../../src/logger/default.ts"],"names":[],"mappings":"AAEA,MAAM,aAAa;IACT,MAAM,CAAC,QAAQ,GAAyB,IAAI,CAAC;IACrD,iBAAiB;IACjB,gBAAuB,CAAC;IACxB,cAAc;IACP,MAAM,CAAC,WAAW;QACvB,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;YAC5B,aAAa,CAAC,QAAQ,GAAG,IAAI,aAAa,EAAE,CAAC;QAC/C,CAAC;QACD,OAAO,aAAa,CAAC,QAAQ,CAAC;IAChC,CAAC;IAED,KAAK,CAAC,OAAe;QACnB,OAAO,CAAC,KAAK,CAAC,WAAW,OAAO,EAAE,CAAC,CAAC;IACtC,CAAC;IACD,IAAI,CAAC,OAAe;QAClB,OAAO,CAAC,IAAI,CAAC,UAAU,OAAO,EAAE,CAAC,CAAC;IACpC,CAAC;IACD,IAAI,CAAC,OAAe;QAClB,OAAO,CAAC,GAAG,CAAC,UAAU,OAAO,EAAE,CAAC,CAAC;IACnC,CAAC;IACD,KAAK,CAAC,OAAe;QACnB,OAAO,CAAC,KAAK,CAAC,WAAW,OAAO,EAAE,CAAC,CAAC;IACtC,CAAC;;AAGH,gBAAgB;AAChB,MAAM,CAAC,MAAM,aAAa,GAAG,aAAa,CAAC,WAAW,EAAE,CAAC"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"broadcast.d.ts","sourceRoot":"","sources":["../../src/models/broadcast.ts"],"names":[],"mappings":"AACA,oBAAY,KAAK;IACf,QAAQ,aAAa;IACrB,QAAQ,aAAa;IACrB,QAAQ,aAAa;IACrB,QAAQ,aAAa;IACrB,OAAO,aAAa;CACrB;AAED;;;;;;;;;;;;;;;GAeG;AACH,MAAM,WAAW,YAAY;IAC3B,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,KAAK,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,OAAO,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;IACpB,aAAa,EAAE,MAAM,GAAG,UAAU,GAAG,YAAY,CAAC;IAClD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,OAAO,GAAG,OAAO,GAAG,SAAS,CAAC;IACzC,QAAQ,CAAC,EAAE;QACT,IAAI,EAAE,MAAM,CAAC;QACb,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,GAAG,CAAC,EAAE,MAAM,CAAC;KACd,EAAE,CAAC;IAEJ,QAAQ,EAAE,MAAM,CAAC;IAEjB,SAAS,EAAE,IAAI,CAAC;IAChB,SAAS,EAAE,IAAI,CAAC;IAChB,SAAS,CAAC,EAAE,IAAI,CAAC;CAClB"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"broadcast.js","sourceRoot":"","sources":["../../src/models/broadcast.ts"],"names":[],"mappings":"AAAA,kBAAkB;AAClB,MAAM,CAAN,IAAY,KAMX;AAND,WAAY,KAAK;IACf,kDAAqB,CAAA;IACrB,kDAAqB,CAAA;IACrB,kDAAqB,CAAA;IACrB,kDAAqB,CAAA;IACrB,gDAAoB,CAAA;AACtB,CAAC,EANW,KAAK,KAAL,KAAK,QAMhB"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/models/logger.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,MAAM;IACrB,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;CAE9B"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/models/logger.ts"],"names":[],"mappings":"AAAA,2BAA2B"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"order.d.ts","sourceRoot":"","sources":["../../src/models/order.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"order.js","sourceRoot":"","sources":["../../src/models/order.ts"],"names":[],"mappings":"AAAA,6BAA6B;AAC7B,0BAA0B;AAC1B,4BAA4B;AAE5B;;;;;;GAMG;AAEH,kFAAkF;AAClF,4DAA4D;AAC5D,kEAAkE;AAClE,gEAAgE;AAEhE,yBAAyB;AACzB,eAAe;AACf,yBAAyB;AAEzB,MAAM,CAAN,IAAY,WAOX;AAPD,WAAY,WAAW;IACrB,8BAAe,CAAA;IACf,kCAAmB,CAAA;IACnB,sCAAuB,CAAA;IACvB,sCAAuB,CAAA;IACvB,oCAAqB,CAAA;IACrB,oCAAqB,CAAA;AACvB,CAAC,EAPW,WAAW,KAAX,WAAW,QAOtB;AAED,MAAM,CAAN,IAAY,aAKX;AALD,WAAY,aAAa;IACvB,oCAAmB,CAAA;IACnB,kCAAiB,CAAA;IACjB,kCAAiB,CAAA;IACjB,kCAAiB,CAAA;AACnB,CAAC,EALW,aAAa,KAAb,aAAa,QAKxB;AAED,MAAM,CAAN,IAAY,aAKX;AALD,WAAY,aAAa;IACvB,oCAAmB,CAAA;IACnB,wCAAuB,CAAA;IACvB,kCAAiB,CAAA;IACjB,sCAAqB,CAAA;AACvB,CAAC,EALW,aAAa,KAAb,aAAa,QAKxB;AAED,MAAM,CAAN,IAAY,YAKX;AALD,WAAY,YAAY;IACtB,uCAAuB,CAAA;IACvB,yCAAyB,CAAA;IACzB,uCAAuB,CAAA;IACvB,qCAAqB,CAAA;AACvB,CAAC,EALW,YAAY,KAAZ,YAAY,QAKvB;AAED,MAAM,CAAN,IAAY,cAKX;AALD,WAAY,cAAc;IACxB,uCAAqB,CAAA;IACrB,qCAAmB,CAAA;IACnB,mCAAiB,CAAA;IACjB,mCAAiB,CAAA;AACnB,CAAC,EALW,cAAc,KAAd,cAAc,QAKzB;AAED,MAAM,CAAN,IAAY,cAKX;AALD,WAAY,cAAc;IACxB,4CAA0B,CAAA;IAC1B,qCAAmB,CAAA;IACnB,yCAAuB,CAAA;IACvB,mCAAiB,CAAA;AACnB,CAAC,EALW,cAAc,KAAd,cAAc,QAKzB"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"product.d.ts","sourceRoot":"","sources":["../../src/models/product.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,OAAO;IACtB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACpC"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"product.js","sourceRoot":"","sources":["../../src/
|
1
|
+
{"version":3,"file":"product.js","sourceRoot":"","sources":["../../src/models/product.ts"],"names":[],"mappings":""}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"user.d.ts","sourceRoot":"","sources":["../../src/models/user.ts"],"names":[],"mappings":"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"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"user.js","sourceRoot":"","sources":["../../src/
|
1
|
+
{"version":3,"file":"user.js","sourceRoot":"","sources":["../../src/models/user.ts"],"names":[],"mappings":""}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/queue/index.ts"],"names":[],"mappings":""}
|
@@ -0,0 +1,15 @@
|
|
1
|
+
import { queue } from "./queue.js";
|
2
|
+
// 生成1万条不同等待时间的任务
|
3
|
+
for (let i = 0; i < 10000; i++) {
|
4
|
+
const waitTime = Math.floor(Math.random() * 5000 + 3000); // 随机等待时间,3000到8000毫秒
|
5
|
+
queue.addTask(async () => {
|
6
|
+
await new Promise((resolve) => setTimeout(resolve, waitTime));
|
7
|
+
// console.log(`Task ${i + 1} completed after ${waitTime} ms`);
|
8
|
+
});
|
9
|
+
}
|
10
|
+
// 每秒显示队列状态
|
11
|
+
setInterval(() => {
|
12
|
+
const status = queue.getStatus();
|
13
|
+
console.log(`[Queue][Length: ${status.queueLength}][Active: ${status.activeTasks}][Completed: ${status.completedTasksSinceLastOutput}][Total completed: ${status.totalCompletedTasks}][Execution: ${status.totalExecutionTime.toFixed(2)} seconds]`);
|
14
|
+
}, 1000);
|
15
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/queue/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AAEnC,iBAAiB;AACjB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC;IAC/B,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,qBAAqB;IAC/E,KAAK,CAAC,OAAO,CAAC,KAAK,IAAI,EAAE;QACvB,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC,CAAC;QAC9D,+DAA+D;IACjE,CAAC,CAAC,CAAC;AACL,CAAC;AAED,WAAW;AACX,WAAW,CAAC,GAAG,EAAE;IACf,MAAM,MAAM,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC;IACjC,OAAO,CAAC,GAAG,CACT,mBAAmB,MAAM,CAAC,WAAW,aAAa,MAAM,CAAC,WAAW,gBAAgB,MAAM,CAAC,6BAA6B,sBAAsB,MAAM,CAAC,mBAAmB,gBAAgB,MAAM,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,CAAC,WAAW,CACxO,CAAC;AACJ,CAAC,EAAE,IAAI,CAAC,CAAC"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"queue.d.ts","sourceRoot":"","sources":["../../src/queue/queue.ts"],"names":[],"mappings":"AAAA,qBAAa,KAAK;IAChB,OAAO,CAAC,YAAY,CAAkB;IACtC,OAAO,CAAC,WAAW,CAAa;IAChC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAS;IACvC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAS;IACrC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAA+B;IACrD,OAAO,CAAC,cAAc,CAA+B;IACrD,OAAO,CAAC,6BAA6B,CAAa;IAClD,OAAO,CAAC,mBAAmB,CAAa;IACxC,OAAO,CAAC,SAAS,CAAa;gBAElB,aAAa,GAAE,MAAa,EAAE,WAAW,GAAE,MAAW;IAK3D,OAAO,CAAC,IAAI,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI;IAOlC,eAAe,IAAI,OAAO,CAAC,IAAI,CAAC;IA6B7C,OAAO,CAAC,KAAK;IAIb,OAAO,CAAC,iBAAiB;IAMzB,OAAO,CAAC,mBAAmB;IAM3B,OAAO,CAAC,kBAAkB;IAOnB,SAAS,IAAI;QAClB,WAAW,EAAE,MAAM,CAAC;QACpB,WAAW,EAAE,MAAM,CAAC;QACpB,6BAA6B,EAAE,MAAM,CAAC;QACtC,mBAAmB,EAAE,MAAM,CAAC;QAC5B,kBAAkB,EAAE,MAAM,CAAC;KAC5B;CAWF;AAGD,eAAO,MAAM,KAAK,OAAc,CAAC"}
|
@@ -23,49 +23,52 @@ export class Queue {
|
|
23
23
|
this.startTime = Date.now();
|
24
24
|
this.startStatusInterval();
|
25
25
|
while (this.tasks.length > 0 || this.activeTasks > 0) {
|
26
|
-
const
|
27
|
-
const
|
28
|
-
|
29
|
-
|
30
|
-
|
26
|
+
const tasksToStart = Math.min(this.requestRate, this.tasks.length, this.maxConcurrent - this.activeTasks);
|
27
|
+
const tasksBatch = this.tasks.splice(0, tasksToStart);
|
28
|
+
tasksBatch.forEach((task) => {
|
29
|
+
this.activeTasks++;
|
30
|
+
task().finally(() => {
|
31
|
+
this.activeTasks--;
|
32
|
+
this.completedTasksSinceLastOutput++;
|
33
|
+
this.totalCompletedTasks++;
|
34
|
+
});
|
35
|
+
});
|
36
|
+
await new Promise((resolve) => setTimeout(resolve, 1000)); // 等待1秒
|
31
37
|
}
|
32
38
|
this.stopStatusInterval();
|
33
39
|
this.isProcessing = false;
|
34
40
|
}
|
35
|
-
// 延迟执行
|
36
41
|
delay(ms) {
|
37
42
|
return new Promise((resolve) => setTimeout(resolve, ms));
|
38
43
|
}
|
39
|
-
// 更新活动任务计数
|
40
44
|
updateActiveTasks() {
|
41
45
|
this.activeTasks--;
|
42
46
|
this.completedTasksSinceLastOutput++;
|
43
47
|
this.totalCompletedTasks++;
|
44
48
|
}
|
45
|
-
// 开始状态间隔
|
46
49
|
startStatusInterval() {
|
47
50
|
this.statusInterval = setInterval(() => {
|
48
51
|
// 状态输出由使用类处理
|
49
52
|
}, 1000);
|
50
53
|
}
|
51
|
-
// 停止状态间隔
|
52
54
|
stopStatusInterval() {
|
53
55
|
if (this.statusInterval) {
|
54
56
|
clearInterval(this.statusInterval);
|
55
57
|
this.statusInterval = null;
|
56
58
|
}
|
57
59
|
}
|
58
|
-
// 获取当前状态
|
59
60
|
getStatus() {
|
60
61
|
const status = {
|
61
62
|
queueLength: this.tasks.length,
|
62
63
|
activeTasks: this.activeTasks,
|
63
64
|
completedTasksSinceLastOutput: this.completedTasksSinceLastOutput,
|
64
65
|
totalCompletedTasks: this.totalCompletedTasks,
|
65
|
-
totalExecutionTime: (Date.now() - this.startTime) / 1000 // 总执行时间(秒)
|
66
|
+
totalExecutionTime: (Date.now() - this.startTime) / 1000, // 总执行时间(秒)
|
66
67
|
};
|
67
68
|
this.completedTasksSinceLastOutput = 0; // 重置计数
|
68
69
|
return status;
|
69
70
|
}
|
70
71
|
}
|
72
|
+
// 使用单例模式导出队列实例
|
73
|
+
export const queue = new Queue();
|
71
74
|
//# sourceMappingURL=queue.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"queue.js","sourceRoot":"","sources":["../../src/queue/queue.ts"],"names":[],"mappings":"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"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"statemachine.util.js","sourceRoot":"","sources":["../../src/utils/statemachine.util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,
|
1
|
+
{"version":3,"file":"statemachine.util.js","sourceRoot":"","sources":["../../src/utils/statemachine.util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAEjD,MAAM,OAAO,kBAAkB;IACrB,WAAW,CAA2B;IAE9C,YAAY,WAAqC;QAC/C,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;IACjC,CAAC;IAED;;;;;OAKG;IACH,aAAa,CAAC,aAAqB,EAAE,YAAoB;QACvD,MAAM,kBAAkB,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;QACjE,OAAO,kBAAkB,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;IACnD,CAAC;CACF;AAED,MAAM,gBAAgB,GAAuC;IAC3D,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,CAAC,WAAW,CAAC,OAAO,EAAE,WAAW,CAAC,QAAQ,CAAC;IAChE,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,CAAC,WAAW,CAAC,SAAS,EAAE,WAAW,CAAC,QAAQ,CAAC;IACpE,CAAC,WAAW,CAAC,SAAS,CAAC,EAAE,CAAC,WAAW,CAAC,SAAS,EAAE,WAAW,CAAC,QAAQ,CAAC;IACtE,CAAC,WAAW,CAAC,SAAS,CAAC,EAAE,CAAC,WAAW,CAAC,QAAQ,CAAC;IAC/C,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,EAAE,EAAE,UAAU;IACtC,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,EAAE,EAAE,UAAU;CACvC,CAAC;AAEF,MAAM,CAAC,MAAM,iBAAiB,GAAG,IAAI,kBAAkB,CAAC,gBAAgB,CAAC,CAAC"}
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@edgenets/utils",
|
3
|
-
"version": "0.
|
3
|
+
"version": "0.2.2",
|
4
4
|
"description": "Edgenets utilities package containing common types and utilities.",
|
5
5
|
"type": "module",
|
6
6
|
"main": "dist/index.js",
|
@@ -17,21 +17,6 @@
|
|
17
17
|
"test": "echo 'Skip Tests'",
|
18
18
|
"public": "pnpm build && npm version patch && npm publish --access public"
|
19
19
|
},
|
20
|
-
"
|
21
|
-
|
22
|
-
},
|
23
|
-
"directories": {
|
24
|
-
"test": "test"
|
25
|
-
},
|
26
|
-
"repository": {
|
27
|
-
"type": "git",
|
28
|
-
"url": "git+https://github.com/rocket3labs/edgenets-services.git"
|
29
|
-
},
|
30
|
-
"keywords": [
|
31
|
-
"utils"
|
32
|
-
],
|
33
|
-
"bugs": {
|
34
|
-
"url": "https://github.com/rocket3labs/edgenets-services/issues"
|
35
|
-
},
|
36
|
-
"homepage": "https://github.com/rocket3labs/edgenets-services#readme"
|
20
|
+
"dependencies": {},
|
21
|
+
"devDependencies": {}
|
37
22
|
}
|
package/dist/array/unique.d.ts
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"unique.d.ts","sourceRoot":"","sources":["../../src/array/unique.ts"],"names":[],"mappings":"AAAA,wBAAgB,MAAM,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,CAAC,EAAE,CAEvC"}
|
package/dist/array/unique.js
DELETED
package/dist/array/unique.js.map
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"unique.js","sourceRoot":"","sources":["../../src/array/unique.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,MAAM,CAAI,GAAQ;IAChC,OAAO,CAAC,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;AAC3B,CAAC"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"broadcast.d.ts","sourceRoot":"","sources":["../../src/types/broadcast.ts"],"names":[],"mappings":"AACA,oBAAY,KAAK;IACf,QAAQ,aAAa;IACrB,QAAQ,aAAa;IACrB,QAAQ,aAAa;IACrB,QAAQ,aAAa;IACrB,OAAO,aAAa;CACrB;AAED;;;;;;;;;;;;;;;GAeG;AACH,MAAM,WAAW,YAAY;IAC3B,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,KAAK,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,OAAO,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;IACpB,aAAa,EAAE,MAAM,GAAG,UAAU,GAAG,YAAY,CAAC;IAClD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,OAAO,GAAG,OAAO,GAAG,SAAS,CAAC;IACzC,QAAQ,CAAC,EAAE;QACT,IAAI,EAAE,MAAM,CAAC;QACb,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,GAAG,CAAC,EAAE,MAAM,CAAC;KACd,EAAE,CAAC;IAEJ,QAAQ,EAAE,MAAM,CAAC;IAEjB,SAAS,EAAE,IAAI,CAAC;IAChB,SAAS,EAAE,IAAI,CAAC;IAChB,SAAS,CAAC,EAAE,IAAI,CAAC;CAClB"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"broadcast.js","sourceRoot":"","sources":["../../src/types/broadcast.ts"],"names":[],"mappings":"AAAA,kBAAkB;AAClB,MAAM,CAAN,IAAY,KAMX;AAND,WAAY,KAAK;IACf,kDAAqB,CAAA;IACrB,kDAAqB,CAAA;IACrB,kDAAqB,CAAA;IACrB,kDAAqB,CAAA;IACrB,gDAAoB,CAAA;AACtB,CAAC,EANW,KAAK,KAAL,KAAK,QAMhB"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/types/logger.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,MAAM;IACrB,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;CAE9B"}
|
@@ -1,44 +0,0 @@
|
|
1
|
-
export declare enum BotId {
|
2
|
-
edgenets = 7001972098,
|
3
|
-
ariagame = 6725302634,
|
4
|
-
zoomania = 7076105558,
|
5
|
-
playaria = 7075595472,
|
6
|
-
playgam = 7171779056
|
7
|
-
}
|
8
|
-
/** 样例说明
|
9
|
-
{
|
10
|
-
"chatId": "123456789",
|
11
|
-
"sendStatus": false,
|
12
|
-
"messageText": "Hello, this is your scheduled message!",
|
13
|
-
"mediaUrl": "https://example.com/media.mp4",
|
14
|
-
"keyboard": [
|
15
|
-
{
|
16
|
-
"text": "Visit Website",
|
17
|
-
"url": "https://example.com"
|
18
|
-
}
|
19
|
-
],
|
20
|
-
"messageFormat": "markdown",
|
21
|
-
"botId": 7171779056
|
22
|
-
}
|
23
|
-
*/
|
24
|
-
export interface Notification {
|
25
|
-
id: string;
|
26
|
-
jobId: string;
|
27
|
-
botId: BotId;
|
28
|
-
chatId: string;
|
29
|
-
sendStatus: boolean;
|
30
|
-
messageText: string;
|
31
|
-
messageFormat: "HTML" | "Markdown" | "MarkdownV2";
|
32
|
-
mediaUrl?: string;
|
33
|
-
mediaType: "Image" | "Video" | undefined;
|
34
|
-
keyboard?: {
|
35
|
-
text: string;
|
36
|
-
callback_data?: string;
|
37
|
-
url?: string;
|
38
|
-
}[];
|
39
|
-
errCount: number;
|
40
|
-
createdAt: Date;
|
41
|
-
alertedAt: Date;
|
42
|
-
updatedAt?: Date;
|
43
|
-
}
|
44
|
-
//# sourceMappingURL=notification.d.ts.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"notification.d.ts","sourceRoot":"","sources":["../../src/types/notification.ts"],"names":[],"mappings":"AACA,oBAAY,KAAK;IACf,QAAQ,aAAa;IACrB,QAAQ,aAAa;IACrB,QAAQ,aAAa;IACrB,QAAQ,aAAa;IACrB,OAAO,aAAa;CACrB;AAED;;;;;;;;;;;;;;;GAeG;AACH,MAAM,WAAW,YAAY;IAC3B,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,KAAK,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,OAAO,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;IACpB,aAAa,EAAE,MAAM,GAAG,UAAU,GAAG,YAAY,CAAC;IAClD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,OAAO,GAAG,OAAO,GAAG,SAAS,CAAC;IACzC,QAAQ,CAAC,EAAE;QACT,IAAI,EAAE,MAAM,CAAC;QACb,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,GAAG,CAAC,EAAE,MAAM,CAAC;KACd,EAAE,CAAC;IAEJ,QAAQ,EAAE,MAAM,CAAC;IAEjB,SAAS,EAAE,IAAI,CAAC;IAChB,SAAS,EAAE,IAAI,CAAC;IAChB,SAAS,CAAC,EAAE,IAAI,CAAC;CAClB"}
|
@@ -1,10 +0,0 @@
|
|
1
|
-
// ## Notification
|
2
|
-
export var BotId;
|
3
|
-
(function (BotId) {
|
4
|
-
BotId[BotId["edgenets"] = 7001972098] = "edgenets";
|
5
|
-
BotId[BotId["ariagame"] = 6725302634] = "ariagame";
|
6
|
-
BotId[BotId["zoomania"] = 7076105558] = "zoomania";
|
7
|
-
BotId[BotId["playaria"] = 7075595472] = "playaria";
|
8
|
-
BotId[BotId["playgam"] = 7171779056] = "playgam";
|
9
|
-
})(BotId || (BotId = {}));
|
10
|
-
//# sourceMappingURL=notification.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"notification.js","sourceRoot":"","sources":["../../src/types/notification.ts"],"names":[],"mappings":"AAAA,kBAAkB;AAClB,MAAM,CAAN,IAAY,KAMX;AAND,WAAY,KAAK;IACf,kDAAqB,CAAA;IACrB,kDAAqB,CAAA;IACrB,kDAAqB,CAAA;IACrB,kDAAqB,CAAA;IACrB,gDAAoB,CAAA;AACtB,CAAC,EANW,KAAK,KAAL,KAAK,QAMhB"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"order.d.ts","sourceRoot":"","sources":["../../src/types/order.ts"],"names":[],"mappings":"AAIA;;;;;;GAMG;AAWH,oBAAY,WAAW;IACrB,KAAK,UAAU,CAAE,YAAY;IAC7B,OAAO,YAAY,CAAE,kBAAkB;IACvC,SAAS,cAAc,CAAE,iBAAiB;IAC1C,SAAS,cAAc,CAAE,gBAAgB;IACzC,QAAQ,aAAa,CAAE,MAAM;IAC7B,QAAQ,aAAa;CACtB;AAED,oBAAY,aAAa;IACvB,OAAO,YAAY,CAAE,yBAAyB;IAC9C,MAAM,WAAW,CAAE,QAAQ;IAC3B,MAAM,WAAW,CAAE,aAAa;IAChC,MAAM,WAAW;CAClB;AAED,oBAAY,aAAa;IACvB,OAAO,YAAY;IACnB,SAAS,cAAc;IACvB,MAAM,WAAW;IACjB,QAAQ,aAAa;CACtB;AAED,oBAAY,YAAY;IACtB,SAAS,cAAc,CAAE,QAAQ;IACjC,UAAU,eAAe,CAAE,QAAQ;IACnC,SAAS,cAAc,CAAE,QAAQ;IACjC,QAAQ,aAAa;CACtB;AAED,oBAAY,cAAc;IACxB,QAAQ,aAAa;IACrB,OAAO,YAAY;IACnB,MAAM,WAAW;IACjB,MAAM,WAAW;CAClB;AAED,oBAAY,cAAc;IACxB,UAAU,gBAAgB;IAC1B,OAAO,YAAY;IACnB,SAAS,cAAc;IACvB,MAAM,WAAW;CAClB;AAMD,MAAM,WAAW,aAAa;IAC5B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE;QACT,QAAQ,CAAC,EAAE;YACT,EAAE,EAAE,MAAM,CAAC;SACZ,CAAC;QACF,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;KACxB,CAAC;CACH;AAED,MAAM,WAAW,SAAS;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,YAAY;IAC3B,MAAM,EAAE,aAAa,CAAC;IACtB,MAAM,EAAE,aAAa,CAAC;IACtB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACpC;AAED,MAAM,WAAW,WAAW;IAC1B,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,YAAY,EAAE,YAAY,CAAC;IAC3B,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,eAAe;IAC9B,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,aAAa;IAC5B,MAAM,EAAE,cAAc,CAAC;IACvB,MAAM,EAAE,cAAc,CAAC;IACvB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,eAAe,CAAC;IAC1B,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,YAAY,EAAE,OAAO,CAAC;CACvB;AAMD,MAAM,WAAW,KAAK;IACpB,QAAQ,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC;IAE7B,MAAM,EAAE,WAAW,CAAC;IACpB,KAAK,EAAE,SAAS,EAAE,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;IAErB,QAAQ,EAAE,aAAa,CAAC;IACxB,OAAO,EAAE,YAAY,CAAC;IAEtB,MAAM,CAAC,EAAE,WAAW,CAAC;IACrB,QAAQ,CAAC,EAAE,aAAa,CAAC;IACzB,QAAQ,CAAC,EAAE,aAAa,CAAC;IAEzB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAEnC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB"}
|
package/dist/types/order.js.map
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"order.js","sourceRoot":"","sources":["../../src/types/order.ts"],"names":[],"mappings":"AAAA,6BAA6B;AAC7B,0BAA0B;AAC1B,4BAA4B;AAE5B;;;;;;GAMG;AAEH,kFAAkF;AAClF,4DAA4D;AAC5D,kEAAkE;AAClE,gEAAgE;AAEhE,yBAAyB;AACzB,eAAe;AACf,yBAAyB;AAEzB,MAAM,CAAN,IAAY,WAOX;AAPD,WAAY,WAAW;IACrB,8BAAe,CAAA;IACf,kCAAmB,CAAA;IACnB,sCAAuB,CAAA;IACvB,sCAAuB,CAAA;IACvB,oCAAqB,CAAA;IACrB,oCAAqB,CAAA;AACvB,CAAC,EAPW,WAAW,KAAX,WAAW,QAOtB;AAED,MAAM,CAAN,IAAY,aAKX;AALD,WAAY,aAAa;IACvB,oCAAmB,CAAA;IACnB,kCAAiB,CAAA;IACjB,kCAAiB,CAAA;IACjB,kCAAiB,CAAA;AACnB,CAAC,EALW,aAAa,KAAb,aAAa,QAKxB;AAED,MAAM,CAAN,IAAY,aAKX;AALD,WAAY,aAAa;IACvB,oCAAmB,CAAA;IACnB,wCAAuB,CAAA;IACvB,kCAAiB,CAAA;IACjB,sCAAqB,CAAA;AACvB,CAAC,EALW,aAAa,KAAb,aAAa,QAKxB;AAED,MAAM,CAAN,IAAY,YAKX;AALD,WAAY,YAAY;IACtB,uCAAuB,CAAA;IACvB,yCAAyB,CAAA;IACzB,uCAAuB,CAAA;IACvB,qCAAqB,CAAA;AACvB,CAAC,EALW,YAAY,KAAZ,YAAY,QAKvB;AAED,MAAM,CAAN,IAAY,cAKX;AALD,WAAY,cAAc;IACxB,uCAAqB,CAAA;IACrB,qCAAmB,CAAA;IACnB,mCAAiB,CAAA;IACjB,mCAAiB,CAAA;AACnB,CAAC,EALW,cAAc,KAAd,cAAc,QAKzB;AAED,MAAM,CAAN,IAAY,cAKX;AALD,WAAY,cAAc;IACxB,4CAA0B,CAAA;IAC1B,qCAAmB,CAAA;IACnB,yCAAuB,CAAA;IACvB,mCAAiB,CAAA;AACnB,CAAC,EALW,cAAc,KAAd,cAAc,QAKzB"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"product.d.ts","sourceRoot":"","sources":["../../src/types/product.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,OAAO;IACtB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACpC"}
|
package/dist/types/user.d.ts.map
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"user.d.ts","sourceRoot":"","sources":["../../src/types/user.ts"],"names":[],"mappings":"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"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"default.d.ts","sourceRoot":"","sources":["../../../src/utils/logger/default.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAEpD,cAAM,aAAc,YAAW,MAAM;IACnC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAA8B;IAErD,OAAO;WAEO,WAAW,IAAI,aAAa;IAO1C,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAG5B,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAG3B,IAAI,CAAC,OAAO,EAAE,MAAM;IAGpB,KAAK,CAAC,OAAO,EAAE,MAAM;CAGtB;AAGD,eAAO,MAAM,aAAa,eAA8B,CAAC"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"default.js","sourceRoot":"","sources":["../../../src/utils/logger/default.ts"],"names":[],"mappings":"AAEA,MAAM,aAAa;IACT,MAAM,CAAC,QAAQ,GAAyB,IAAI,CAAC;IACrD,iBAAiB;IACjB,gBAAuB,CAAC;IACxB,cAAc;IACP,MAAM,CAAC,WAAW;QACvB,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;YAC5B,aAAa,CAAC,QAAQ,GAAG,IAAI,aAAa,EAAE,CAAC;QAC/C,CAAC;QACD,OAAO,aAAa,CAAC,QAAQ,CAAC;IAChC,CAAC;IAED,KAAK,CAAC,OAAe;QACnB,OAAO,CAAC,KAAK,CAAC,WAAW,OAAO,EAAE,CAAC,CAAC;IACtC,CAAC;IACD,IAAI,CAAC,OAAe;QAClB,OAAO,CAAC,IAAI,CAAC,UAAU,OAAO,EAAE,CAAC,CAAC;IACpC,CAAC;IACD,IAAI,CAAC,OAAe;QAClB,OAAO,CAAC,GAAG,CAAC,UAAU,OAAO,EAAE,CAAC,CAAC;IACnC,CAAC;IACD,KAAK,CAAC,OAAe;QACnB,OAAO,CAAC,KAAK,CAAC,WAAW,OAAO,EAAE,CAAC,CAAC;IACtC,CAAC;;AAGH,gBAAgB;AAChB,MAAM,CAAC,MAAM,aAAa,GAAG,aAAa,CAAC,WAAW,EAAE,CAAC"}
|
@@ -1,8 +0,0 @@
|
|
1
|
-
import type { Logger } from "../types/logger.js";
|
2
|
-
export declare class ConsoleLogger implements Logger {
|
3
|
-
debug(message: string): void;
|
4
|
-
warn(message: string): void;
|
5
|
-
info(message: string): void;
|
6
|
-
error(message: string): void;
|
7
|
-
}
|
8
|
-
//# sourceMappingURL=logger.util.d.ts.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"logger.util.d.ts","sourceRoot":"","sources":["../../src/utils/logger.util.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAEjD,qBAAa,aAAc,YAAW,MAAM;IAC1C,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAG5B,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAG3B,IAAI,CAAC,OAAO,EAAE,MAAM;IAGpB,KAAK,CAAC,OAAO,EAAE,MAAM;CAGtB"}
|
@@ -1,15 +0,0 @@
|
|
1
|
-
export class ConsoleLogger {
|
2
|
-
debug(message) {
|
3
|
-
console.debug(`[DEBUG] ${message}`);
|
4
|
-
}
|
5
|
-
warn(message) {
|
6
|
-
console.warn(`[WARN] ${message}`);
|
7
|
-
}
|
8
|
-
info(message) {
|
9
|
-
console.log(`[INFO] ${message}`);
|
10
|
-
}
|
11
|
-
error(message) {
|
12
|
-
console.error(`[ERROR] ${message}`);
|
13
|
-
}
|
14
|
-
}
|
15
|
-
//# sourceMappingURL=logger.util.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"logger.util.js","sourceRoot":"","sources":["../../src/utils/logger.util.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,aAAa;IACxB,KAAK,CAAC,OAAe;QACnB,OAAO,CAAC,KAAK,CAAC,WAAW,OAAO,EAAE,CAAC,CAAC;IACtC,CAAC;IACD,IAAI,CAAC,OAAe;QAClB,OAAO,CAAC,IAAI,CAAC,UAAU,OAAO,EAAE,CAAC,CAAC;IACpC,CAAC;IACD,IAAI,CAAC,OAAe;QAClB,OAAO,CAAC,GAAG,CAAC,UAAU,OAAO,EAAE,CAAC,CAAC;IACnC,CAAC;IACD,KAAK,CAAC,OAAe;QACnB,OAAO,CAAC,KAAK,CAAC,WAAW,OAAO,EAAE,CAAC,CAAC;IACtC,CAAC;CACF"}
|
@@ -1,35 +0,0 @@
|
|
1
|
-
// import { Queue } from "./queue";
|
2
|
-
import { Queue } from "./queue.js";
|
3
|
-
const MAX_CONCURRENT_REQUESTS = 1000;
|
4
|
-
const REQUESTS_PER_SECOND = 30;
|
5
|
-
const TOTAL_REQUESTS = 1000000;
|
6
|
-
const queue = new Queue(MAX_CONCURRENT_REQUESTS, REQUESTS_PER_SECOND);
|
7
|
-
const apiRequest = async (id) => {
|
8
|
-
console.log(`[API] Request ${id} started...`);
|
9
|
-
// 模拟API请求
|
10
|
-
await new Promise((resolve) => setTimeout(resolve, Math.random() * 10000)); // 模拟延迟
|
11
|
-
};
|
12
|
-
const startRequests = () => {
|
13
|
-
let requestCount = 0;
|
14
|
-
const interval = setInterval(() => {
|
15
|
-
if (requestCount < TOTAL_REQUESTS) {
|
16
|
-
for (let i = 0; i < REQUESTS_PER_SECOND; i++) {
|
17
|
-
if (requestCount < TOTAL_REQUESTS) {
|
18
|
-
queue.addTask(() => apiRequest(requestCount++));
|
19
|
-
}
|
20
|
-
}
|
21
|
-
}
|
22
|
-
else {
|
23
|
-
clearInterval(interval);
|
24
|
-
}
|
25
|
-
}, 1000);
|
26
|
-
const statusInterval = setInterval(() => {
|
27
|
-
const status = queue.getStatus();
|
28
|
-
console.log(`[Queue][Length: ${status.queueLength}][Active: ${status.activeTasks}][Completed: ${status.completedTasksSinceLastOutput}][Total completed: ${status.totalCompletedTasks}][Execution: ${status.totalExecutionTime.toFixed(2)} seconds]`);
|
29
|
-
if (status.totalCompletedTasks >= TOTAL_REQUESTS) {
|
30
|
-
clearInterval(statusInterval);
|
31
|
-
}
|
32
|
-
}, 1000);
|
33
|
-
};
|
34
|
-
startRequests();
|
35
|
-
//# sourceMappingURL=index.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utils/queue/index.ts"],"names":[],"mappings":"AAAA,mCAAmC;AAEnC,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AAEnC,MAAM,uBAAuB,GAAG,IAAI,CAAC;AACrC,MAAM,mBAAmB,GAAG,EAAE,CAAC;AAC/B,MAAM,cAAc,GAAG,OAAO,CAAC;AAE/B,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC,uBAAuB,EAAE,mBAAmB,CAAC,CAAC;AAEtE,MAAM,UAAU,GAAG,KAAK,EAAE,EAAU,EAAiB,EAAE;IACrD,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAAE,aAAa,CAAC,CAAC;IAC9C,UAAU;IACV,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO;AACrF,CAAC,CAAC;AAEF,MAAM,aAAa,GAAG,GAAG,EAAE;IACzB,IAAI,YAAY,GAAG,CAAC,CAAC;IAErB,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,EAAE;QAChC,IAAI,YAAY,GAAG,cAAc,EAAE,CAAC;YAClC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,mBAAmB,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC7C,IAAI,YAAY,GAAG,cAAc,EAAE,CAAC;oBAClC,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;gBAClD,CAAC;YACH,CAAC;QACH,CAAC;aAAM,CAAC;YACN,aAAa,CAAC,QAAQ,CAAC,CAAC;QAC1B,CAAC;IACH,CAAC,EAAE,IAAI,CAAC,CAAC;IAET,MAAM,cAAc,GAAG,WAAW,CAAC,GAAG,EAAE;QACtC,MAAM,MAAM,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC;QACjC,OAAO,CAAC,GAAG,CACT,mBAAmB,MAAM,CAAC,WAAW,aAAa,MAAM,CAAC,WAAW,gBAAgB,MAAM,CAAC,6BAA6B,sBAAsB,MAAM,CAAC,mBAAmB,gBAAgB,MAAM,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,CAAC,WAAW,CACxO,CAAC;QACF,IAAI,MAAM,CAAC,mBAAmB,IAAI,cAAc,EAAE,CAAC;YACjD,aAAa,CAAC,cAAc,CAAC,CAAC;QAChC,CAAC;IACH,CAAC,EAAE,IAAI,CAAC,CAAC;AACX,CAAC,CAAC;AAEF,aAAa,EAAE,CAAC"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"queue.d.ts","sourceRoot":"","sources":["../../../src/utils/queue/queue.ts"],"names":[],"mappings":"AAAA,qBAAa,KAAK;IAChB,OAAO,CAAC,YAAY,CAAkB;IACtC,OAAO,CAAC,WAAW,CAAa;IAChC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAS;IACvC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAS;IACrC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAA+B;IACrD,OAAO,CAAC,cAAc,CAA+B;IACrD,OAAO,CAAC,6BAA6B,CAAa;IAClD,OAAO,CAAC,mBAAmB,CAAa;IACxC,OAAO,CAAC,SAAS,CAAa;gBAElB,aAAa,GAAE,MAAa,EAAE,WAAW,GAAE,MAAW;IAK3D,OAAO,CAAC,IAAI,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI;IAOlC,eAAe,IAAI,OAAO,CAAC,IAAI,CAAC;IAmB7C,OAAO,CAAC,KAAK;IAKb,OAAO,CAAC,iBAAiB;IAOzB,OAAO,CAAC,mBAAmB;IAO3B,OAAO,CAAC,kBAAkB;IAQnB,SAAS,IAAI;QAAE,WAAW,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAC;QAAC,6BAA6B,EAAE,MAAM,CAAC;QAAC,mBAAmB,EAAE,MAAM,CAAC;QAAC,kBAAkB,EAAE,MAAM,CAAA;KAAE;CAWjK"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"queue.js","sourceRoot":"","sources":["../../../src/utils/queue/queue.ts"],"names":[],"mappings":"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"}
|
@@ -1,23 +0,0 @@
|
|
1
|
-
type Task = () => Promise<boolean>;
|
2
|
-
export interface SchedulerOptions {
|
3
|
-
interval?: number;
|
4
|
-
taskTimeout?: number;
|
5
|
-
logInterval?: number;
|
6
|
-
maxRecursions: number;
|
7
|
-
maxRetries?: number;
|
8
|
-
maxTotalTime?: number;
|
9
|
-
}
|
10
|
-
declare class SchedulerUtils {
|
11
|
-
private static instance;
|
12
|
-
private tasks;
|
13
|
-
private constructor();
|
14
|
-
static getInstance(): SchedulerUtils;
|
15
|
-
run(task: Task, options: SchedulerOptions): void;
|
16
|
-
private handleTaskError;
|
17
|
-
private timeout;
|
18
|
-
private delay;
|
19
|
-
cancelAll(): void;
|
20
|
-
}
|
21
|
-
export declare const schedule: SchedulerUtils;
|
22
|
-
export {};
|
23
|
-
//# sourceMappingURL=scheduler.util.d.ts.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"scheduler.util.d.ts","sourceRoot":"","sources":["../../src/utils/scheduler.util.ts"],"names":[],"mappings":"AAAA,KAAK,IAAI,GAAG,MAAM,OAAO,CAAC,OAAO,CAAC,CAAC;AAEnC,MAAM,WAAW,gBAAgB;IAC/B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,cAAM,cAAc;IAClB,OAAO,CAAC,MAAM,CAAC,QAAQ,CAA+B;IACtD,OAAO,CAAC,KAAK,CAA2D;IAGxE,OAAO;WAGO,WAAW,IAAI,cAAc;IAOpC,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,gBAAgB,GAAG,IAAI;YA0DzC,eAAe;IAmB7B,OAAO,CAAC,OAAO;IAMf,OAAO,CAAC,KAAK;IAIN,SAAS,IAAI,IAAI;CAMzB;AAGD,eAAO,MAAM,QAAQ,gBAA+B,CAAC"}
|
@@ -1,81 +0,0 @@
|
|
1
|
-
class SchedulerUtils {
|
2
|
-
static instance = null;
|
3
|
-
tasks = new Map();
|
4
|
-
// 私有构造函数,防止外部实例化
|
5
|
-
constructor() { }
|
6
|
-
// 获取单例实例的静态方法
|
7
|
-
static getInstance() {
|
8
|
-
if (!SchedulerUtils.instance) {
|
9
|
-
SchedulerUtils.instance = new SchedulerUtils();
|
10
|
-
}
|
11
|
-
return SchedulerUtils.instance;
|
12
|
-
}
|
13
|
-
run(task, options) {
|
14
|
-
const { interval = 1000, // 默认 1000 毫秒
|
15
|
-
maxRecursions = 0, // 默认不迭代
|
16
|
-
maxRetries = 0, // 默认不重试
|
17
|
-
logInterval = 1, // 默认每次递归都打印日志
|
18
|
-
taskTimeout = 30000, // 默认单次执行时间30秒
|
19
|
-
maxTotalTime = 60000, // 默认最大执行时间60秒
|
20
|
-
} = options || {};
|
21
|
-
let counter = 0;
|
22
|
-
let retries = 0;
|
23
|
-
const startTime = Date.now();
|
24
|
-
const executeTask = async () => {
|
25
|
-
try {
|
26
|
-
if (maxTotalTime && Date.now() - startTime > maxTotalTime) {
|
27
|
-
console.log("达到总的最大执行时间,停止任务。");
|
28
|
-
this.cancelAll();
|
29
|
-
return;
|
30
|
-
}
|
31
|
-
const shouldContinue = await Promise.race([
|
32
|
-
task(),
|
33
|
-
this.timeout(taskTimeout),
|
34
|
-
]);
|
35
|
-
counter++;
|
36
|
-
if (shouldContinue && counter < maxRecursions) {
|
37
|
-
if (counter % logInterval === 0) {
|
38
|
-
console.log(`递归执行, 第 ${counter} 次, 已执行 ${(Date.now() - startTime) / 1000} 秒`);
|
39
|
-
}
|
40
|
-
this.tasks.set(setTimeout(async () => {
|
41
|
-
await executeTask();
|
42
|
-
}, interval), setTimeout(() => { }, interval));
|
43
|
-
}
|
44
|
-
else {
|
45
|
-
this.cancelAll();
|
46
|
-
}
|
47
|
-
}
|
48
|
-
catch (error) {
|
49
|
-
await this.handleTaskError(error, retries, maxRetries, executeTask, interval);
|
50
|
-
retries++;
|
51
|
-
}
|
52
|
-
};
|
53
|
-
executeTask();
|
54
|
-
}
|
55
|
-
async handleTaskError(error, retries, maxRetries, retryTask, interval) {
|
56
|
-
if (retries < maxRetries) {
|
57
|
-
console.error(`Retry attempt ${retries + 1} due to error: ${error}`);
|
58
|
-
await this.delay(interval * (retries + 1)); // 指数退避
|
59
|
-
await retryTask(); // 重新执行任务
|
60
|
-
}
|
61
|
-
else {
|
62
|
-
console.error("Max retries reached. Task execution stopped due to persistent errors.");
|
63
|
-
this.cancelAll();
|
64
|
-
}
|
65
|
-
}
|
66
|
-
timeout(ms) {
|
67
|
-
return new Promise((_, reject) => setTimeout(() => reject("Task timed out"), ms));
|
68
|
-
}
|
69
|
-
delay(ms) {
|
70
|
-
return new Promise((resolve) => setTimeout(resolve, ms));
|
71
|
-
}
|
72
|
-
cancelAll() {
|
73
|
-
this.tasks.forEach((_, taskId) => {
|
74
|
-
clearTimeout(taskId);
|
75
|
-
});
|
76
|
-
this.tasks.clear();
|
77
|
-
}
|
78
|
-
}
|
79
|
-
// 导出 BotService 的单一实例,保证全局唯一
|
80
|
-
export const schedule = SchedulerUtils.getInstance();
|
81
|
-
//# sourceMappingURL=scheduler.util.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"scheduler.util.js","sourceRoot":"","sources":["../../src/utils/scheduler.util.ts"],"names":[],"mappings":"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"}
|
@@ -1,23 +0,0 @@
|
|
1
|
-
export type QueueTask<T> = () => Promise<T>;
|
2
|
-
export interface QueueOptions {
|
3
|
-
concurrency?: number;
|
4
|
-
interval?: number;
|
5
|
-
}
|
6
|
-
export declare class Queue<T> {
|
7
|
-
private options;
|
8
|
-
private queue;
|
9
|
-
private activeTasks;
|
10
|
-
private isProcessing;
|
11
|
-
constructor(options?: QueueOptions);
|
12
|
-
enqueue(task: QueueTask<T>): void;
|
13
|
-
trigger(): Promise<void>;
|
14
|
-
getStatus(): {
|
15
|
-
activeTasks: number;
|
16
|
-
pendingTasks: number;
|
17
|
-
isProcessing: boolean;
|
18
|
-
};
|
19
|
-
private processQueue;
|
20
|
-
private delay;
|
21
|
-
private updateActiveTasks;
|
22
|
-
}
|
23
|
-
//# sourceMappingURL=queue.d.ts.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"queue.d.ts","sourceRoot":"","sources":["../../../src/utils/tasks/queue.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,SAAS,CAAC,CAAC,IAAI,MAAM,OAAO,CAAC,CAAC,CAAC,CAAC;AAE5C,MAAM,WAAW,YAAY;IAC3B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,qBAAa,KAAK,CAAC,CAAC;IAMhB,OAAO,CAAC,OAAO;IALjB,OAAO,CAAC,KAAK,CAAsB;IACnC,OAAO,CAAC,WAAW,CAAK;IACxB,OAAO,CAAC,YAAY,CAAS;gBAGnB,OAAO,GAAE,YAAiD;IAI7D,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI;IAS3B,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAU9B,SAAS,IAAI;QAClB,WAAW,EAAE,MAAM,CAAC;QACpB,YAAY,EAAE,MAAM,CAAC;QACrB,YAAY,EAAE,OAAO,CAAC;KACvB;YASa,YAAY;IAiC1B,OAAO,CAAC,KAAK;IAKb,OAAO,CAAC,iBAAiB;CAI1B"}
|
@@ -1,72 +0,0 @@
|
|
1
|
-
export class Queue {
|
2
|
-
options;
|
3
|
-
queue = [];
|
4
|
-
activeTasks = 0;
|
5
|
-
isProcessing = false;
|
6
|
-
constructor(options = { concurrency: 1, interval: 1000 }) {
|
7
|
-
this.options = options;
|
8
|
-
}
|
9
|
-
// 添加任务到队列
|
10
|
-
enqueue(task) {
|
11
|
-
this.queue.push(task);
|
12
|
-
if (!this.isProcessing) {
|
13
|
-
console.log("[Queue] Automatically starting processQueue...");
|
14
|
-
this.processQueue();
|
15
|
-
}
|
16
|
-
}
|
17
|
-
// 手动触发队列处理
|
18
|
-
async trigger() {
|
19
|
-
console.log("[Queue] Manually triggered processQueue...");
|
20
|
-
if (!this.isProcessing) {
|
21
|
-
await this.processQueue();
|
22
|
-
}
|
23
|
-
else {
|
24
|
-
console.log("[Queue] Already processing.");
|
25
|
-
}
|
26
|
-
}
|
27
|
-
// 获取队列状态
|
28
|
-
getStatus() {
|
29
|
-
return {
|
30
|
-
activeTasks: this.activeTasks,
|
31
|
-
pendingTasks: this.queue.length,
|
32
|
-
isProcessing: this.isProcessing,
|
33
|
-
};
|
34
|
-
}
|
35
|
-
// 队列处理逻辑
|
36
|
-
async processQueue() {
|
37
|
-
this.isProcessing = true;
|
38
|
-
while (this.queue.length > 0) {
|
39
|
-
const batch = this.queue.splice(0, this.options.concurrency || 1);
|
40
|
-
this.activeTasks += batch.length; // 增加活动任务计数
|
41
|
-
console.log(`[Queue] Processing batch of ${batch.length} tasks...`);
|
42
|
-
// 批次并行执行
|
43
|
-
await Promise.all(batch.map(async (task) => {
|
44
|
-
try {
|
45
|
-
await task();
|
46
|
-
}
|
47
|
-
catch (err) {
|
48
|
-
console.error(`[Queue][TaskFailed]: ${err}`);
|
49
|
-
}
|
50
|
-
finally {
|
51
|
-
this.updateActiveTasks();
|
52
|
-
}
|
53
|
-
}));
|
54
|
-
if (this.queue.length > 0) {
|
55
|
-
console.log(`[Queue] Delaying for ${this.options.interval || 0}ms...`);
|
56
|
-
await this.delay(this.options.interval || 0);
|
57
|
-
}
|
58
|
-
}
|
59
|
-
this.isProcessing = false;
|
60
|
-
console.log("[Queue] All tasks processed.");
|
61
|
-
}
|
62
|
-
// 延迟执行
|
63
|
-
delay(ms) {
|
64
|
-
return new Promise((resolve) => setTimeout(resolve, ms));
|
65
|
-
}
|
66
|
-
// 更新活动任务计数
|
67
|
-
updateActiveTasks() {
|
68
|
-
this.activeTasks--;
|
69
|
-
console.log(`[Queue] Active tasks: ${this.activeTasks}`);
|
70
|
-
}
|
71
|
-
}
|
72
|
-
//# sourceMappingURL=queue.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"queue.js","sourceRoot":"","sources":["../../../src/utils/tasks/queue.ts"],"names":[],"mappings":"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"}
|
@@ -1,24 +0,0 @@
|
|
1
|
-
import type { Logger } from "../../types/logger.js";
|
2
|
-
export type SchedulerTask = () => Promise<boolean>;
|
3
|
-
export interface SchedulerOptions {
|
4
|
-
interval?: number;
|
5
|
-
taskTimeout?: number;
|
6
|
-
logInterval?: number;
|
7
|
-
maxRecursions: number;
|
8
|
-
maxRetries?: number;
|
9
|
-
maxTotalTime?: number;
|
10
|
-
}
|
11
|
-
declare class Scheduler {
|
12
|
-
private static instance;
|
13
|
-
private tasks;
|
14
|
-
private constructor();
|
15
|
-
static getInstance(): Scheduler;
|
16
|
-
run(task: SchedulerTask, options: SchedulerOptions, logger?: Logger): void;
|
17
|
-
private handleTaskError;
|
18
|
-
private timeout;
|
19
|
-
private delay;
|
20
|
-
cancelAll(): void;
|
21
|
-
}
|
22
|
-
export declare const scheduler: Scheduler;
|
23
|
-
export {};
|
24
|
-
//# sourceMappingURL=scheduler.d.ts.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"scheduler.d.ts","sourceRoot":"","sources":["../../../src/utils/tasks/scheduler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAGpD,MAAM,MAAM,aAAa,GAAG,MAAM,OAAO,CAAC,OAAO,CAAC,CAAC;AAEnD,MAAM,WAAW,gBAAgB;IAC/B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,cAAM,SAAS;IACb,OAAO,CAAC,MAAM,CAAC,QAAQ,CAA0B;IACjD,OAAO,CAAC,KAAK,CAA2D;IAExE,OAAO;WAEO,WAAW,IAAI,SAAS;IAO/B,GAAG,CACR,IAAI,EAAE,aAAa,EACnB,OAAO,EAAE,gBAAgB,EACzB,MAAM,GAAE,MAAsB,GAC7B,IAAI;YAuDO,eAAe;IAmB7B,OAAO,CAAC,OAAO;IAMf,OAAO,CAAC,KAAK;IAIN,SAAS,IAAI,IAAI;CAMzB;AAGD,eAAO,MAAM,SAAS,WAA0B,CAAC"}
|
@@ -1,98 +0,0 @@
|
|
1
|
-
import { consoleLogger } from "../logger/default.js";
|
2
|
-
class Scheduler {
|
3
|
-
static instance = null;
|
4
|
-
tasks = new Map();
|
5
|
-
// 私有构造函数,防止外部实例化
|
6
|
-
constructor() { }
|
7
|
-
// 获取单例实例的静态方法
|
8
|
-
static getInstance() {
|
9
|
-
if (!Scheduler.instance) {
|
10
|
-
Scheduler.instance = new Scheduler();
|
11
|
-
}
|
12
|
-
return Scheduler.instance;
|
13
|
-
}
|
14
|
-
run(task, options, logger = consoleLogger) {
|
15
|
-
const { interval = 1000, // 默认 1000 毫秒
|
16
|
-
maxRecursions = 0, // 默认不迭代
|
17
|
-
maxRetries = 0, // 默认不重试
|
18
|
-
logInterval = 1, // 默认每次递归都打印日志
|
19
|
-
taskTimeout = 30000, // 默认单次执行时间30秒
|
20
|
-
maxTotalTime = 60000, // 默认最大执行时间60秒
|
21
|
-
} = options || {};
|
22
|
-
let counter = 0;
|
23
|
-
let retries = 0;
|
24
|
-
const startTime = Date.now();
|
25
|
-
const executeTask = async () => {
|
26
|
-
try {
|
27
|
-
if (maxTotalTime && Date.now() - startTime > maxTotalTime) {
|
28
|
-
logger.info("达到总的最大执行时间,停止任务。");
|
29
|
-
this.cancelAll();
|
30
|
-
return;
|
31
|
-
}
|
32
|
-
const shouldContinue = await Promise.race([
|
33
|
-
task(),
|
34
|
-
this.timeout(taskTimeout),
|
35
|
-
]);
|
36
|
-
counter++;
|
37
|
-
if (shouldContinue && counter < maxRecursions) {
|
38
|
-
if (counter % logInterval === 0) {
|
39
|
-
logger.info(`递归执行, 第 ${counter} 次, 已执行 ${(Date.now() - startTime) / 1000} 秒`);
|
40
|
-
}
|
41
|
-
this.tasks.set(setTimeout(async () => {
|
42
|
-
await executeTask();
|
43
|
-
}, interval), setTimeout(() => { }, interval));
|
44
|
-
}
|
45
|
-
else {
|
46
|
-
this.cancelAll();
|
47
|
-
}
|
48
|
-
}
|
49
|
-
catch (error) {
|
50
|
-
await this.handleTaskError(error, retries, maxRetries, executeTask, interval);
|
51
|
-
retries++;
|
52
|
-
}
|
53
|
-
};
|
54
|
-
executeTask();
|
55
|
-
}
|
56
|
-
async handleTaskError(error, retries, maxRetries, retryTask, interval) {
|
57
|
-
if (retries < maxRetries) {
|
58
|
-
console.error(`Retry attempt ${retries + 1} due to error: ${error}`);
|
59
|
-
await this.delay(interval * (retries + 1)); // 指数退避
|
60
|
-
await retryTask(); // 重新执行任务
|
61
|
-
}
|
62
|
-
else {
|
63
|
-
console.error("Max retries reached. Task execution stopped due to persistent errors.");
|
64
|
-
this.cancelAll();
|
65
|
-
}
|
66
|
-
}
|
67
|
-
timeout(ms) {
|
68
|
-
return new Promise((_, reject) => setTimeout(() => reject("Task timed out"), ms));
|
69
|
-
}
|
70
|
-
delay(ms) {
|
71
|
-
return new Promise((resolve) => setTimeout(resolve, ms));
|
72
|
-
}
|
73
|
-
cancelAll() {
|
74
|
-
this.tasks.forEach((_, taskId) => {
|
75
|
-
clearTimeout(taskId);
|
76
|
-
});
|
77
|
-
this.tasks.clear();
|
78
|
-
}
|
79
|
-
}
|
80
|
-
// 导出单一实例,保证全局唯一
|
81
|
-
export const scheduler = Scheduler.getInstance();
|
82
|
-
///////////////
|
83
|
-
// 使用示例
|
84
|
-
// 使用 Scheduler 调度任务
|
85
|
-
//
|
86
|
-
// import { schedule } from "@edgenets/utils";
|
87
|
-
// const exampleTask: Task = async () => {
|
88
|
-
// console.log("Executing task...");
|
89
|
-
// return Math.random() < 0.8; // 80% 概率继续执行
|
90
|
-
// };
|
91
|
-
// scheduler.run(exampleTask, {
|
92
|
-
// interval: 2000, // 每 2 秒执行一次
|
93
|
-
// maxRecursions: 10, // 最多递归 10 次
|
94
|
-
// logInterval: 2, // 每 2 次打印一次日志
|
95
|
-
// taskTimeout: 3000, // 单次任务最多执行 3 秒
|
96
|
-
// maxRetries: 3, // 每次失败最多重试 3 次
|
97
|
-
// });
|
98
|
-
//# sourceMappingURL=scheduler.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"scheduler.js","sourceRoot":"","sources":["../../../src/utils/tasks/scheduler.ts"],"names":[],"mappings":"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"}
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|