2021-11-17 16:08:17 +05:30
|
|
|
/*
|
|
|
|
Copyright 2020 Bruno Windels <bruno@windels.cloud>
|
|
|
|
Copyright 2021 The Matrix.org Foundation C.I.C.
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
import {LogLevel, LogFilter} from "./LogFilter";
|
|
|
|
import type {BaseLogger} from "./BaseLogger";
|
|
|
|
import type {BlobHandle} from "../platform/web/dom/BlobHandle.js";
|
|
|
|
|
|
|
|
export interface ISerializedItem {
|
|
|
|
s: number;
|
|
|
|
d?: number;
|
|
|
|
v: LogItemValues;
|
|
|
|
l: LogLevel;
|
|
|
|
e?: {
|
|
|
|
stack?: string;
|
|
|
|
name: string;
|
|
|
|
message: string;
|
|
|
|
};
|
|
|
|
f?: boolean;
|
|
|
|
c?: Array<ISerializedItem>;
|
|
|
|
};
|
|
|
|
|
|
|
|
export interface ILogItem {
|
|
|
|
logLevel: LogLevel;
|
|
|
|
error?: Error;
|
2021-11-17 19:03:58 +05:30
|
|
|
readonly logger: ILogger;
|
|
|
|
readonly level: typeof LogLevel;
|
|
|
|
readonly end?: number;
|
|
|
|
readonly start?: number;
|
|
|
|
readonly values: LogItemValues;
|
2021-11-17 16:08:17 +05:30
|
|
|
wrap<T>(labelOrValues: LabelOrValues, callback: LogCallback<T>, logLevel?: LogLevel, filterCreator?: FilterCreator): T;
|
2021-12-09 23:14:44 +05:30
|
|
|
log(labelOrValues: LabelOrValues, logLevel?: LogLevel): ILogItem;
|
2022-02-04 22:19:10 +05:30
|
|
|
set(key: string | object, value: unknown): ILogItem;
|
2021-11-17 16:08:17 +05:30
|
|
|
runDetached(labelOrValues: LabelOrValues, callback: LogCallback<unknown>, logLevel?: LogLevel, filterCreator?: FilterCreator): ILogItem;
|
|
|
|
wrapDetached(labelOrValues: LabelOrValues, callback: LogCallback<unknown>, logLevel?: LogLevel, filterCreator?: FilterCreator): void;
|
|
|
|
refDetached(logItem: ILogItem, logLevel?: LogLevel): void;
|
|
|
|
ensureRefId(): void;
|
|
|
|
catch(err: Error): Error;
|
|
|
|
serialize(filter: LogFilter, parentStartTime: number | undefined, forced: boolean): ISerializedItem | undefined;
|
2021-12-01 16:09:42 +05:30
|
|
|
finish(): void;
|
2021-12-03 11:48:01 +05:30
|
|
|
child(labelOrValues: LabelOrValues, logLevel?: LogLevel, filterCreator?: FilterCreator): ILogItem;
|
2021-11-17 16:08:17 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
export interface ILogger {
|
|
|
|
log(labelOrValues: LabelOrValues, logLevel?: LogLevel): void;
|
|
|
|
wrapOrRun<T>(item: ILogItem | undefined, labelOrValues: LabelOrValues, callback: LogCallback<T>, logLevel?: LogLevel, filterCreator?: FilterCreator): T;
|
|
|
|
runDetached<T>(labelOrValues: LabelOrValues, callback: LogCallback<T>, logLevel?: LogLevel, filterCreator?: FilterCreator): ILogItem;
|
|
|
|
run<T>(labelOrValues: LabelOrValues, callback: LogCallback<T>, logLevel?: LogLevel, filterCreator?: FilterCreator): T;
|
|
|
|
export(): Promise<ILogExport | undefined>;
|
|
|
|
get level(): typeof LogLevel;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface ILogExport {
|
|
|
|
get count(): number;
|
|
|
|
removeFromStore(): Promise<void>;
|
|
|
|
asBlob(): BlobHandle;
|
|
|
|
}
|
|
|
|
|
|
|
|
export type LogItemValues = {
|
|
|
|
l?: string;
|
|
|
|
t?: string;
|
|
|
|
id?: unknown;
|
|
|
|
status?: string | number;
|
|
|
|
refId?: number;
|
|
|
|
ref?: number;
|
|
|
|
[key: string]: any
|
|
|
|
}
|
|
|
|
|
|
|
|
export type LabelOrValues = string | LogItemValues;
|
|
|
|
export type FilterCreator = ((filter: LogFilter, item: ILogItem) => LogFilter);
|
|
|
|
export type LogCallback<T> = (item: ILogItem) => T;
|