@pisell/core 1.0.41 → 1.0.43
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/es/app/app.d.ts +99 -0
- package/es/applicationManager/application.d.ts +197 -0
- package/es/applicationManager/index.d.ts +19 -0
- package/es/history/index.d.ts +23 -0
- package/es/index.d.ts +7 -0
- package/es/indexDB/index.js +48 -68
- package/es/logger/index.d.ts +1 -1
- package/es/logger/index.js +199 -165
- package/es/menuManager/index.d.ts +28 -0
- package/es/request/cache.d.ts +46 -0
- package/es/request/index.d.ts +24 -0
- package/es/request/type.d.ts +52 -0
- package/es/request/utils.d.ts +46 -0
- package/es/tasks/index.d.ts +127 -0
- package/es/tasks/scheduledTasksExample.d.ts +61 -0
- package/es/tasks/type.d.ts +100 -0
- package/es/utils/adaptiveThrottle/index.d.ts +36 -0
- package/es/utils/adaptiveThrottle/index.js +136 -0
- package/lib/app/app.d.ts +99 -0
- package/lib/applicationManager/application.d.ts +197 -0
- package/lib/applicationManager/index.d.ts +19 -0
- package/lib/history/index.d.ts +23 -0
- package/lib/index.d.ts +7 -0
- package/lib/indexDB/index.js +2 -48
- package/lib/logger/index.d.ts +1 -1
- package/lib/logger/index.js +21 -6
- package/lib/menuManager/index.d.ts +28 -0
- package/lib/request/cache.d.ts +46 -0
- package/lib/request/index.d.ts +24 -0
- package/lib/request/type.d.ts +52 -0
- package/lib/request/utils.d.ts +46 -0
- package/lib/tasks/index.d.ts +127 -0
- package/lib/tasks/scheduledTasksExample.d.ts +61 -0
- package/lib/tasks/type.d.ts +100 -0
- package/lib/utils/adaptiveThrottle/index.d.ts +36 -0
- package/lib/utils/adaptiveThrottle/index.js +121 -0
- package/package.json +1 -1
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { InternalAxiosRequestConfig } from "axios";
|
|
2
|
+
import { RequestSetting, RequestConfig, RequestWrapperProps } from "./type";
|
|
3
|
+
export declare const getRequestHeaders: (config: InternalAxiosRequestConfig<RequestSetting> & Record<string, any>) => Record<string, string | null>;
|
|
4
|
+
/**
|
|
5
|
+
* @title: 请求前拦截
|
|
6
|
+
* @description:
|
|
7
|
+
* @param {any} config
|
|
8
|
+
* @return {*}
|
|
9
|
+
* @Author: zhiwei.Wang
|
|
10
|
+
* @Date: 2024-07-04 10:51
|
|
11
|
+
*/
|
|
12
|
+
export declare const interceptorsRequest: (config: InternalAxiosRequestConfig<RequestSetting> & Record<string, any>) => Promise<InternalAxiosRequestConfig<RequestSetting> & Record<string, any>>;
|
|
13
|
+
/**
|
|
14
|
+
* @title: 请求前error
|
|
15
|
+
* @description:
|
|
16
|
+
* @param {any} err
|
|
17
|
+
* @return {*}
|
|
18
|
+
* @Author: zhiwei.Wang
|
|
19
|
+
* @Date: 2024-07-04 10:51
|
|
20
|
+
*/
|
|
21
|
+
export declare const interceptorsRequestError: (err: RequestConfig["interceptorsRequestError"]) => any;
|
|
22
|
+
/**
|
|
23
|
+
* @title: 请求后拦截
|
|
24
|
+
* @description:
|
|
25
|
+
* @param {any} response
|
|
26
|
+
* @return {*}
|
|
27
|
+
* @Author: zhiwei.Wang
|
|
28
|
+
* @Date: 2024-07-04 10:51
|
|
29
|
+
*/
|
|
30
|
+
export declare const interceptorsResponse: (response: RequestConfig["interceptorsResponse"]) => any;
|
|
31
|
+
/**
|
|
32
|
+
* @title: 请求后错误拦截
|
|
33
|
+
* @description:
|
|
34
|
+
* @param {any} response
|
|
35
|
+
* @return {*}
|
|
36
|
+
* @Author: zhiwei.Wang
|
|
37
|
+
* @Date: 2024-07-04 10:51
|
|
38
|
+
*/
|
|
39
|
+
export declare const interceptorsResponseError: (response: RequestConfig["interceptorsResponseError"]) => any;
|
|
40
|
+
export declare const requestCallback: (resData: {
|
|
41
|
+
res?: any;
|
|
42
|
+
props: RequestWrapperProps;
|
|
43
|
+
resolve: (value: unknown) => void;
|
|
44
|
+
reject: () => void;
|
|
45
|
+
err?: any;
|
|
46
|
+
}) => void;
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { Task, TasksModule, RunTaskParams, AddTaskParams, DeleteTaskParams } from "./type";
|
|
2
|
+
import App from "../app";
|
|
3
|
+
export declare class TasksManager {
|
|
4
|
+
private static instance;
|
|
5
|
+
private taskFunctions;
|
|
6
|
+
private tasks;
|
|
7
|
+
private app;
|
|
8
|
+
private db;
|
|
9
|
+
useTasks: () => {
|
|
10
|
+
tasks: TasksModule;
|
|
11
|
+
};
|
|
12
|
+
watchTaskCallback: (taskModule: TasksModule) => void;
|
|
13
|
+
private timerIds;
|
|
14
|
+
constructor(app: App);
|
|
15
|
+
static getInstance(app?: App): TasksManager;
|
|
16
|
+
addTaskFunction<T>(name: string, fun: T): void;
|
|
17
|
+
addTaskFunctions<T>(tasks: {
|
|
18
|
+
name: string;
|
|
19
|
+
fun: T;
|
|
20
|
+
}[]): void;
|
|
21
|
+
getTasks(): TasksModule;
|
|
22
|
+
getTaskFunction(name: string): any;
|
|
23
|
+
init(): Promise<void>;
|
|
24
|
+
private saveTaskQueueToLocal;
|
|
25
|
+
private loadTaskQueueFromLocal;
|
|
26
|
+
/**
|
|
27
|
+
* @title: 执行任务
|
|
28
|
+
* @description:
|
|
29
|
+
* @param {Task} task
|
|
30
|
+
* @return {*}
|
|
31
|
+
* @Author: zhiwei.Wang
|
|
32
|
+
* @Date: 2024-09-26 13:53
|
|
33
|
+
*/
|
|
34
|
+
private runTask;
|
|
35
|
+
/**
|
|
36
|
+
* @title: 清除任务定时器
|
|
37
|
+
*/
|
|
38
|
+
private clearTaskTimer;
|
|
39
|
+
/**
|
|
40
|
+
* @title: 计算下一次执行时间
|
|
41
|
+
* @description: 根据定时任务配置计算下一次执行时间
|
|
42
|
+
* @param {Task} task
|
|
43
|
+
* @return {string | null} 下一次执行时间
|
|
44
|
+
*/
|
|
45
|
+
private calculateNextExecuteTime;
|
|
46
|
+
/**
|
|
47
|
+
* @title: 启动定时任务
|
|
48
|
+
* @description: 在特定时间点执行任务(仅在 scheduledTasks 模块中生效)
|
|
49
|
+
* @param {Task} task
|
|
50
|
+
* @return {*}
|
|
51
|
+
*/
|
|
52
|
+
private startScheduledTask;
|
|
53
|
+
/**
|
|
54
|
+
* @title: 启动轮询
|
|
55
|
+
* @description: 根据轮询间隔定期执行任务
|
|
56
|
+
* @param {Task} task
|
|
57
|
+
* @return {*}
|
|
58
|
+
*/
|
|
59
|
+
private startPolling;
|
|
60
|
+
/**
|
|
61
|
+
* @title: 创建任务数据
|
|
62
|
+
* @description:
|
|
63
|
+
* @param {Partial} payload
|
|
64
|
+
* @return {*}
|
|
65
|
+
* @Author: zhiwei.Wang
|
|
66
|
+
* @Date: 2024-09-26 13:54
|
|
67
|
+
*/
|
|
68
|
+
private createTaskData;
|
|
69
|
+
private getTaskQueue;
|
|
70
|
+
private timeout;
|
|
71
|
+
/**
|
|
72
|
+
* @title: 执行任务队列
|
|
73
|
+
* @description:
|
|
74
|
+
* @return {*}
|
|
75
|
+
* @Author: zhiwei.Wang
|
|
76
|
+
* @Date: 2024-09-26 13:52
|
|
77
|
+
*/
|
|
78
|
+
run(payload: RunTaskParams): Promise<void>;
|
|
79
|
+
deleteTask(payload: DeleteTaskParams): void;
|
|
80
|
+
/**
|
|
81
|
+
* @title: 重试任务
|
|
82
|
+
* @description:
|
|
83
|
+
* @return {*}
|
|
84
|
+
* @Author: zhiwei.Wang
|
|
85
|
+
* @Date: 2024-09-26 13:53
|
|
86
|
+
*/
|
|
87
|
+
retryTask(payload: RunTaskParams): void;
|
|
88
|
+
addTask(payload: AddTaskParams): void;
|
|
89
|
+
private updateTask;
|
|
90
|
+
private updateQueueStatus;
|
|
91
|
+
/**
|
|
92
|
+
* @title: 更新队列运行状态
|
|
93
|
+
* @description: 标记队列是否正在执行
|
|
94
|
+
*/
|
|
95
|
+
private updateQueueRunningState;
|
|
96
|
+
private setTasksData;
|
|
97
|
+
private setTasks;
|
|
98
|
+
clearAllTaskTimer(tasks: Task[]): void;
|
|
99
|
+
clearTasks(payload: RunTaskParams): void;
|
|
100
|
+
clearAllTasks(): void;
|
|
101
|
+
watchTask(callback: (taskModule: TasksModule) => void): void;
|
|
102
|
+
/**
|
|
103
|
+
* @title: 获取队列执行状态
|
|
104
|
+
* @description: 获取指定队列的执行状态和进度信息
|
|
105
|
+
* @param {string} module - 模块名
|
|
106
|
+
* @param {string} queueId - 队列ID
|
|
107
|
+
* @return {object} 队列状态信息
|
|
108
|
+
*/
|
|
109
|
+
getQueueStatus(module: string, queueId: string): {
|
|
110
|
+
isRunning: boolean;
|
|
111
|
+
status: "uncompleted" | "completed";
|
|
112
|
+
progress: {
|
|
113
|
+
total: number;
|
|
114
|
+
completed: number;
|
|
115
|
+
failed: number;
|
|
116
|
+
inProgress: number;
|
|
117
|
+
};
|
|
118
|
+
lastRunAt: string | null;
|
|
119
|
+
tasksCount: number;
|
|
120
|
+
} | null;
|
|
121
|
+
/**
|
|
122
|
+
* @title: 获取所有队列状态
|
|
123
|
+
* @description: 获取所有任务队列的执行状态概览
|
|
124
|
+
* @return {object} 所有队列的状态信息
|
|
125
|
+
*/
|
|
126
|
+
getAllQueuesStatus(): any;
|
|
127
|
+
}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 定时任务示例代码
|
|
3
|
+
* 本文件展示了如何使用定时任务功能
|
|
4
|
+
*
|
|
5
|
+
* 重要提示:
|
|
6
|
+
* - 定时任务必须添加到 'scheduledTasks' 模块才能生效
|
|
7
|
+
* - 在其他模块中,scheduled 配置会被忽略,任务将作为普通任务立即执行
|
|
8
|
+
* - 这是为了性能优化,避免在所有模块中检查定时任务配置
|
|
9
|
+
*/
|
|
10
|
+
import { TasksManager } from './index';
|
|
11
|
+
/**
|
|
12
|
+
* 示例1:创建一次性定时任务
|
|
13
|
+
* 在特定时间点执行一次
|
|
14
|
+
*
|
|
15
|
+
* 注意:定时任务必须添加到 'scheduledTasks' 模块才能生效
|
|
16
|
+
*/
|
|
17
|
+
export declare function createOnceScheduledTask(tasksManager: TasksManager): void;
|
|
18
|
+
/**
|
|
19
|
+
* 示例2:创建每日重复的定时任务
|
|
20
|
+
* 每天在固定时间执行
|
|
21
|
+
*/
|
|
22
|
+
export declare function createDailyScheduledTask(tasksManager: TasksManager): void;
|
|
23
|
+
/**
|
|
24
|
+
* 示例3:创建带结束时间的重复任务
|
|
25
|
+
* 在特定时间段内重复执行
|
|
26
|
+
*/
|
|
27
|
+
export declare function createLimitedRepeatTask(tasksManager: TasksManager): void;
|
|
28
|
+
/**
|
|
29
|
+
* 示例4:创建多个时间点的任务
|
|
30
|
+
* 在一天中的多个时间点分别执行
|
|
31
|
+
*/
|
|
32
|
+
export declare function createMultiTimeTask(tasksManager: TasksManager): void;
|
|
33
|
+
/**
|
|
34
|
+
* 示例5:创建每周重复任务
|
|
35
|
+
* 每周一早上9点执行周报
|
|
36
|
+
*/
|
|
37
|
+
export declare function createWeeklyTask(tasksManager: TasksManager): void;
|
|
38
|
+
/**
|
|
39
|
+
* 示例6:创建每月重复任务
|
|
40
|
+
* 每月1号生成月报
|
|
41
|
+
*/
|
|
42
|
+
export declare function createMonthlyTask(tasksManager: TasksManager): void;
|
|
43
|
+
/**
|
|
44
|
+
* 示例7:查询和管理定时任务
|
|
45
|
+
*/
|
|
46
|
+
export declare function manageScheduledTasks(tasksManager: TasksManager): void;
|
|
47
|
+
/**
|
|
48
|
+
* 完整使用示例
|
|
49
|
+
*/
|
|
50
|
+
export declare function fullExample(app: any): void;
|
|
51
|
+
declare const _default: {
|
|
52
|
+
createOnceScheduledTask: typeof createOnceScheduledTask;
|
|
53
|
+
createDailyScheduledTask: typeof createDailyScheduledTask;
|
|
54
|
+
createLimitedRepeatTask: typeof createLimitedRepeatTask;
|
|
55
|
+
createMultiTimeTask: typeof createMultiTimeTask;
|
|
56
|
+
createWeeklyTask: typeof createWeeklyTask;
|
|
57
|
+
createMonthlyTask: typeof createMonthlyTask;
|
|
58
|
+
manageScheduledTasks: typeof manageScheduledTasks;
|
|
59
|
+
fullExample: typeof fullExample;
|
|
60
|
+
};
|
|
61
|
+
export default _default;
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
export declare type TaskRunStatus = "pending" | "in-progress" | "success" | "failure";
|
|
2
|
+
export interface Task {
|
|
3
|
+
id?: string;
|
|
4
|
+
type?: "local" | "cloud";
|
|
5
|
+
retries?: number;
|
|
6
|
+
maxRetries?: number;
|
|
7
|
+
status?: TaskRunStatus;
|
|
8
|
+
action: string;
|
|
9
|
+
payload: any;
|
|
10
|
+
beforeAction?: string;
|
|
11
|
+
beforePayload?: any;
|
|
12
|
+
afterAction?: string;
|
|
13
|
+
afterPayload?: any;
|
|
14
|
+
polling?: {
|
|
15
|
+
interval?: number;
|
|
16
|
+
};
|
|
17
|
+
pollingResult?: {
|
|
18
|
+
count: number;
|
|
19
|
+
timerId?: any;
|
|
20
|
+
};
|
|
21
|
+
scheduled?: {
|
|
22
|
+
executeAt: string | string[];
|
|
23
|
+
repeat?: boolean;
|
|
24
|
+
repeatType?: 'daily' | 'weekly' | 'monthly' | 'yearly';
|
|
25
|
+
repeatInterval?: number;
|
|
26
|
+
endAt?: string;
|
|
27
|
+
};
|
|
28
|
+
scheduledResult?: {
|
|
29
|
+
count: number;
|
|
30
|
+
timerId?: any;
|
|
31
|
+
nextExecuteTime?: string;
|
|
32
|
+
};
|
|
33
|
+
manual?: boolean;
|
|
34
|
+
destroy?: boolean;
|
|
35
|
+
[key: string]: any;
|
|
36
|
+
}
|
|
37
|
+
export interface TaskConfig {
|
|
38
|
+
tasks: Task[];
|
|
39
|
+
}
|
|
40
|
+
declare type TaskModuleName = string;
|
|
41
|
+
declare type TaskQueueName = string;
|
|
42
|
+
declare type TaskStatus = "uncompleted" | "completed";
|
|
43
|
+
export interface TaskQueue {
|
|
44
|
+
status: TaskStatus;
|
|
45
|
+
tasks: Task[];
|
|
46
|
+
isRunning?: boolean;
|
|
47
|
+
progress?: {
|
|
48
|
+
total: number;
|
|
49
|
+
completed: number;
|
|
50
|
+
failed: number;
|
|
51
|
+
inProgress: number;
|
|
52
|
+
};
|
|
53
|
+
lastRunAt?: string;
|
|
54
|
+
}
|
|
55
|
+
export interface RunTaskParams {
|
|
56
|
+
module: TaskModuleName;
|
|
57
|
+
queueId: TaskQueueName;
|
|
58
|
+
callback?: () => void;
|
|
59
|
+
}
|
|
60
|
+
export interface DeleteTaskParams {
|
|
61
|
+
module: TaskModuleName;
|
|
62
|
+
queueId: TaskQueueName;
|
|
63
|
+
taskId: string;
|
|
64
|
+
}
|
|
65
|
+
export interface AddTaskParams {
|
|
66
|
+
module: TaskModuleName;
|
|
67
|
+
queueId: TaskQueueName;
|
|
68
|
+
tasks: Task[];
|
|
69
|
+
}
|
|
70
|
+
export interface AddTaskDataParams {
|
|
71
|
+
module: TaskModuleName;
|
|
72
|
+
queueId: TaskQueueName;
|
|
73
|
+
[key: string]: any;
|
|
74
|
+
}
|
|
75
|
+
export interface TaskRunResult {
|
|
76
|
+
status: TaskRunStatus;
|
|
77
|
+
[key: string]: any;
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* 任务模块
|
|
81
|
+
* 注意:'scheduledTasks' 是保留的模块名,专门用于定时任务
|
|
82
|
+
* 在其他模块中,scheduled 配置会被忽略,任务将作为普通任务执行
|
|
83
|
+
*/
|
|
84
|
+
export interface TasksModule {
|
|
85
|
+
[key: TaskModuleName]: {
|
|
86
|
+
[key: TaskQueueName]: {
|
|
87
|
+
status: TaskStatus;
|
|
88
|
+
tasks: Task[];
|
|
89
|
+
isRunning?: boolean;
|
|
90
|
+
progress?: {
|
|
91
|
+
total: number;
|
|
92
|
+
completed: number;
|
|
93
|
+
failed: number;
|
|
94
|
+
inProgress: number;
|
|
95
|
+
};
|
|
96
|
+
lastRunAt?: string;
|
|
97
|
+
};
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
export {};
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
export declare type ThrottleLevel = number;
|
|
2
|
+
export interface ThrottleExecuteContext {
|
|
3
|
+
/** 事务唯一 key */
|
|
4
|
+
key: string;
|
|
5
|
+
/** 当前节流窗口内的触发次数 */
|
|
6
|
+
count: number;
|
|
7
|
+
/** 是否首次立即执行 */
|
|
8
|
+
isFirst: boolean;
|
|
9
|
+
/** 当前节流等级 */
|
|
10
|
+
level: ThrottleLevel;
|
|
11
|
+
/** 上一次执行时间 */
|
|
12
|
+
lastExecuteTime: number;
|
|
13
|
+
}
|
|
14
|
+
export declare type ThrottleHandler = (ctx: ThrottleExecuteContext) => void | Promise<void>;
|
|
15
|
+
export declare const DEFAULT_THROTTLE_INTERVALS: number[];
|
|
16
|
+
export declare class AdaptiveThrottle {
|
|
17
|
+
private store;
|
|
18
|
+
private intervals;
|
|
19
|
+
constructor(intervals?: number[]);
|
|
20
|
+
/**
|
|
21
|
+
* 触发事务
|
|
22
|
+
*/
|
|
23
|
+
trigger(key: string, handler: ThrottleHandler): void;
|
|
24
|
+
/**
|
|
25
|
+
* 调度下一次节流执行
|
|
26
|
+
*/
|
|
27
|
+
private schedule;
|
|
28
|
+
/**
|
|
29
|
+
* 主动清理某个事务
|
|
30
|
+
*/
|
|
31
|
+
clear(key: string): void;
|
|
32
|
+
/**
|
|
33
|
+
* 清空所有事务
|
|
34
|
+
*/
|
|
35
|
+
clearAll(): void;
|
|
36
|
+
}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __export = (target, all) => {
|
|
6
|
+
for (var name in all)
|
|
7
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
8
|
+
};
|
|
9
|
+
var __copyProps = (to, from, except, desc) => {
|
|
10
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
11
|
+
for (let key of __getOwnPropNames(from))
|
|
12
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
13
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
14
|
+
}
|
|
15
|
+
return to;
|
|
16
|
+
};
|
|
17
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
18
|
+
|
|
19
|
+
// src/utils/adaptiveThrottle/index.ts
|
|
20
|
+
var adaptiveThrottle_exports = {};
|
|
21
|
+
__export(adaptiveThrottle_exports, {
|
|
22
|
+
AdaptiveThrottle: () => AdaptiveThrottle,
|
|
23
|
+
DEFAULT_THROTTLE_INTERVALS: () => DEFAULT_THROTTLE_INTERVALS
|
|
24
|
+
});
|
|
25
|
+
module.exports = __toCommonJS(adaptiveThrottle_exports);
|
|
26
|
+
var DEFAULT_THROTTLE_INTERVALS = [
|
|
27
|
+
5 * 60 * 1e3,
|
|
28
|
+
// 5分钟
|
|
29
|
+
30 * 60 * 1e3,
|
|
30
|
+
// 30分钟
|
|
31
|
+
60 * 60 * 1e3,
|
|
32
|
+
// 1小时
|
|
33
|
+
6 * 60 * 60 * 1e3,
|
|
34
|
+
// 6小时
|
|
35
|
+
24 * 60 * 60 * 1e3
|
|
36
|
+
// 1天
|
|
37
|
+
];
|
|
38
|
+
var AdaptiveThrottle = class {
|
|
39
|
+
store = /* @__PURE__ */ new Map();
|
|
40
|
+
intervals;
|
|
41
|
+
constructor(intervals = DEFAULT_THROTTLE_INTERVALS) {
|
|
42
|
+
this.intervals = intervals;
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* 触发事务
|
|
46
|
+
*/
|
|
47
|
+
trigger(key, handler) {
|
|
48
|
+
const now = Date.now();
|
|
49
|
+
let record = this.store.get(key);
|
|
50
|
+
if (!record) {
|
|
51
|
+
handler({
|
|
52
|
+
key,
|
|
53
|
+
count: 1,
|
|
54
|
+
isFirst: true,
|
|
55
|
+
level: 0,
|
|
56
|
+
lastExecuteTime: now
|
|
57
|
+
});
|
|
58
|
+
record = {
|
|
59
|
+
key,
|
|
60
|
+
count: 0,
|
|
61
|
+
level: 0,
|
|
62
|
+
lastExecuteTime: now
|
|
63
|
+
};
|
|
64
|
+
this.store.set(key, record);
|
|
65
|
+
this.schedule(key, handler, record);
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
record.count++;
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* 调度下一次节流执行
|
|
72
|
+
*/
|
|
73
|
+
schedule(key, handler, record) {
|
|
74
|
+
const interval = this.intervals[record.level];
|
|
75
|
+
record.timer = setTimeout(async () => {
|
|
76
|
+
const count = record.count;
|
|
77
|
+
if (count > 0) {
|
|
78
|
+
await handler({
|
|
79
|
+
key,
|
|
80
|
+
count,
|
|
81
|
+
isFirst: false,
|
|
82
|
+
level: record.level,
|
|
83
|
+
lastExecuteTime: record.lastExecuteTime
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
if (count > 0 && record.level < this.intervals.length - 1) {
|
|
87
|
+
record.level++;
|
|
88
|
+
}
|
|
89
|
+
record.count = 0;
|
|
90
|
+
record.lastExecuteTime = Date.now();
|
|
91
|
+
this.schedule(key, handler, record);
|
|
92
|
+
}, interval);
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* 主动清理某个事务
|
|
96
|
+
*/
|
|
97
|
+
clear(key) {
|
|
98
|
+
const record = this.store.get(key);
|
|
99
|
+
if (!record) return;
|
|
100
|
+
if (record.timer) {
|
|
101
|
+
clearTimeout(record.timer);
|
|
102
|
+
}
|
|
103
|
+
this.store.delete(key);
|
|
104
|
+
}
|
|
105
|
+
/**
|
|
106
|
+
* 清空所有事务
|
|
107
|
+
*/
|
|
108
|
+
clearAll() {
|
|
109
|
+
this.store.forEach((record) => {
|
|
110
|
+
if (record.timer) {
|
|
111
|
+
clearTimeout(record.timer);
|
|
112
|
+
}
|
|
113
|
+
});
|
|
114
|
+
this.store.clear();
|
|
115
|
+
}
|
|
116
|
+
};
|
|
117
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
118
|
+
0 && (module.exports = {
|
|
119
|
+
AdaptiveThrottle,
|
|
120
|
+
DEFAULT_THROTTLE_INTERVALS
|
|
121
|
+
});
|