@trebired/logger 1.1.2 → 2.0.0
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/CHANGELOG.md +21 -0
- package/README.md +177 -14
- package/dist/browser/console_transport.d.ts +5 -0
- package/dist/browser/console_transport.d.ts.map +1 -0
- package/dist/browser/console_transport.js +51 -0
- package/dist/browser/console_transport.js.map +1 -0
- package/dist/browser/create_log.d.ts +4 -0
- package/dist/browser/create_log.d.ts.map +1 -0
- package/dist/browser/create_log.js +234 -0
- package/dist/browser/create_log.js.map +1 -0
- package/dist/browser/index.d.ts +4 -0
- package/dist/browser/index.d.ts.map +1 -0
- package/dist/browser/index.js +3 -0
- package/dist/browser/index.js.map +1 -0
- package/dist/browser/react.d.ts +30 -0
- package/dist/browser/react.d.ts.map +1 -0
- package/dist/browser/react.js +44 -0
- package/dist/browser/react.js.map +1 -0
- package/dist/constants.d.ts +2 -1
- package/dist/constants.d.ts.map +1 -1
- package/dist/constants.js +4 -1
- package/dist/constants.js.map +1 -1
- package/dist/core/create_log.d.ts.map +1 -1
- package/dist/core/create_log.js +111 -137
- package/dist/core/create_log.js.map +1 -1
- package/dist/core/shared.d.ts +31 -0
- package/dist/core/shared.d.ts.map +1 -0
- package/dist/core/shared.js +144 -0
- package/dist/core/shared.js.map +1 -0
- package/dist/format/console.d.ts +2 -2
- package/dist/format/console.d.ts.map +1 -1
- package/dist/format/console.js +2 -17
- package/dist/format/console.js.map +1 -1
- package/dist/format/options.d.ts +4 -0
- package/dist/format/options.d.ts.map +1 -0
- package/dist/format/options.js +19 -0
- package/dist/format/options.js.map +1 -0
- package/dist/index.d.ts +4 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -1
- package/dist/index.js.map +1 -1
- package/dist/storage/names.d.ts +10 -3
- package/dist/storage/names.d.ts.map +1 -1
- package/dist/storage/names.js +76 -33
- package/dist/storage/names.js.map +1 -1
- package/dist/storage/options.d.ts.map +1 -1
- package/dist/storage/options.js +3 -1
- package/dist/storage/options.js.map +1 -1
- package/dist/storage/partitions.d.ts +30 -0
- package/dist/storage/partitions.d.ts.map +1 -0
- package/dist/storage/partitions.js +564 -0
- package/dist/storage/partitions.js.map +1 -0
- package/dist/storage/query.d.ts +8 -4
- package/dist/storage/query.d.ts.map +1 -1
- package/dist/storage/query.js +135 -28
- package/dist/storage/query.js.map +1 -1
- package/dist/storage/retention.d.ts.map +1 -1
- package/dist/storage/retention.js +51 -2
- package/dist/storage/retention.js.map +1 -1
- package/dist/storage/walk.d.ts.map +1 -1
- package/dist/storage/walk.js +65 -9
- package/dist/storage/walk.js.map +1 -1
- package/dist/storage/write.d.ts +1 -0
- package/dist/storage/write.d.ts.map +1 -1
- package/dist/storage/write.js +12 -1
- package/dist/storage/write.js.map +1 -1
- package/dist/stream/index.d.ts +11 -3
- package/dist/stream/index.d.ts.map +1 -1
- package/dist/stream/index.js +40 -4
- package/dist/stream/index.js.map +1 -1
- package/dist/types.d.ts +189 -4
- package/dist/types.d.ts.map +1 -1
- package/package.json +24 -3
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
import { normGroup } from "../groups.js";
|
|
2
|
+
import { minLevelWeight, normalizeLevel } from "../levels/index.js";
|
|
3
|
+
import { prepareMetadata } from "../metadata/process.js";
|
|
4
|
+
import { asObject, toString } from "../utils/values.js";
|
|
5
|
+
const DEFAULT_GROUP = "default";
|
|
6
|
+
function buildOrigin(source, instance = null) {
|
|
7
|
+
const src = toString(source) || "app";
|
|
8
|
+
const inst = instance == null ? null : String(instance);
|
|
9
|
+
return {
|
|
10
|
+
source: src,
|
|
11
|
+
instance: inst || null,
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
function parseCallArguments(argsLike, fallbackGroup) {
|
|
15
|
+
const args = Array.isArray(argsLike) ? argsLike : Array.from(argsLike || []);
|
|
16
|
+
const hasExplicitGroup = typeof args[0] === "string" && typeof args[1] === "string";
|
|
17
|
+
return {
|
|
18
|
+
group: hasExplicitGroup ? args[0] : fallbackGroup,
|
|
19
|
+
message: hasExplicitGroup ? args[1] : String(args[0] ?? ""),
|
|
20
|
+
metadata: hasExplicitGroup ? asObject(args[2]) : asObject(args[1]),
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
function shouldKeepSample(entry, sample) {
|
|
24
|
+
if (sample == null)
|
|
25
|
+
return true;
|
|
26
|
+
if (typeof sample === "number") {
|
|
27
|
+
if (!Number.isFinite(sample))
|
|
28
|
+
return true;
|
|
29
|
+
if (sample <= 0)
|
|
30
|
+
return false;
|
|
31
|
+
if (sample >= 1)
|
|
32
|
+
return true;
|
|
33
|
+
return Math.random() < sample;
|
|
34
|
+
}
|
|
35
|
+
if (typeof sample === "function") {
|
|
36
|
+
try {
|
|
37
|
+
return sample(entry) === true;
|
|
38
|
+
}
|
|
39
|
+
catch {
|
|
40
|
+
return false;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
return true;
|
|
44
|
+
}
|
|
45
|
+
function createCommonLogger(options) {
|
|
46
|
+
const levels = options.levels;
|
|
47
|
+
const threshold = minLevelWeight(options.minLevel, levels);
|
|
48
|
+
const defaultSource = toString(options.defaultSource) || "app";
|
|
49
|
+
const defaultGroup = normGroup(options.defaultGroup || DEFAULT_GROUP).key;
|
|
50
|
+
const defaultMetadata = asObject(options.defaultMetadata);
|
|
51
|
+
let enabled = true;
|
|
52
|
+
let closed = false;
|
|
53
|
+
function emit(levelInput, groupInput, messageInput, metadataInput, originInput) {
|
|
54
|
+
if (!enabled || closed)
|
|
55
|
+
return;
|
|
56
|
+
const level = normalizeLevel(levelInput, levels);
|
|
57
|
+
const levelConfig = levels[level] || levels.info;
|
|
58
|
+
if (levelConfig.weight < threshold)
|
|
59
|
+
return;
|
|
60
|
+
const rawMetadata = {
|
|
61
|
+
...defaultMetadata,
|
|
62
|
+
...asObject(metadataInput),
|
|
63
|
+
};
|
|
64
|
+
const recordedAt = toString(rawMetadata.__recorded_at) || new Date().toISOString();
|
|
65
|
+
const metadata = prepareMetadata(rawMetadata, options.serializers, options.redact);
|
|
66
|
+
const group = normGroup(groupInput || defaultGroup).key;
|
|
67
|
+
const message = typeof messageInput === "string" ? messageInput : String(messageInput ?? "");
|
|
68
|
+
const originSource = originInput && originInput.source ? originInput.source : defaultSource;
|
|
69
|
+
const originInstance = originInput && Object.prototype.hasOwnProperty.call(originInput, "instance") ? originInput.instance : null;
|
|
70
|
+
const entry = {
|
|
71
|
+
recorded_at: recordedAt,
|
|
72
|
+
level,
|
|
73
|
+
group,
|
|
74
|
+
message,
|
|
75
|
+
origin: buildOrigin(originSource, originInstance),
|
|
76
|
+
};
|
|
77
|
+
if (typeof options.getPartition === "function")
|
|
78
|
+
entry.partition = options.getPartition() ?? null;
|
|
79
|
+
if (Object.keys(metadata).length)
|
|
80
|
+
entry.metadata = metadata;
|
|
81
|
+
if (!shouldKeepSample(entry, options.sample))
|
|
82
|
+
return;
|
|
83
|
+
options.writeEntry(entry, levelConfig);
|
|
84
|
+
}
|
|
85
|
+
function bindGroup(groupName, originInput, extraMetadata) {
|
|
86
|
+
const boundGroup = normGroup(groupName || defaultGroup).key;
|
|
87
|
+
const mergedExtraMetadata = asObject(extraMetadata);
|
|
88
|
+
const grouped = {};
|
|
89
|
+
for (const level of Object.keys(levels)) {
|
|
90
|
+
grouped[level] = (message, metadata) => emit(level, boundGroup, message, { ...mergedExtraMetadata, ...asObject(metadata) }, originInput);
|
|
91
|
+
}
|
|
92
|
+
grouped.child = (moreMetadata) => bindGroup(boundGroup, originInput, { ...mergedExtraMetadata, ...asObject(moreMetadata) });
|
|
93
|
+
return grouped;
|
|
94
|
+
}
|
|
95
|
+
const api = {
|
|
96
|
+
group(groupName) {
|
|
97
|
+
return bindGroup(groupName || defaultGroup);
|
|
98
|
+
},
|
|
99
|
+
withScope(source, groupName, instance) {
|
|
100
|
+
const originInput = {
|
|
101
|
+
source: toString(source) || defaultSource,
|
|
102
|
+
instance: instance == null ? null : String(instance),
|
|
103
|
+
};
|
|
104
|
+
return bindGroup(groupName || defaultGroup, originInput);
|
|
105
|
+
},
|
|
106
|
+
setEnabled(flag) {
|
|
107
|
+
enabled = Boolean(flag);
|
|
108
|
+
},
|
|
109
|
+
logError(error, metadata, source) {
|
|
110
|
+
const meta = asObject(metadata);
|
|
111
|
+
const groupName = toString(meta.group) || defaultGroup;
|
|
112
|
+
const originSource = toString(source) || defaultSource;
|
|
113
|
+
if (error instanceof Error) {
|
|
114
|
+
emit("error", groupName, error.message, { ...meta, stack: error.stack }, { source: originSource });
|
|
115
|
+
return;
|
|
116
|
+
}
|
|
117
|
+
emit("error", groupName, String(error), meta, { source: originSource });
|
|
118
|
+
},
|
|
119
|
+
flush() {
|
|
120
|
+
return options.flush();
|
|
121
|
+
},
|
|
122
|
+
async close() {
|
|
123
|
+
if (closed)
|
|
124
|
+
return;
|
|
125
|
+
closed = true;
|
|
126
|
+
await options.close();
|
|
127
|
+
},
|
|
128
|
+
getStats() {
|
|
129
|
+
return options.getStats();
|
|
130
|
+
},
|
|
131
|
+
};
|
|
132
|
+
for (const level of Object.keys(levels)) {
|
|
133
|
+
api[level] = function levelLogger() {
|
|
134
|
+
const parsed = parseCallArguments(arguments, defaultGroup);
|
|
135
|
+
emit(level, parsed.group, parsed.message, parsed.metadata);
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
return {
|
|
139
|
+
api,
|
|
140
|
+
emit,
|
|
141
|
+
};
|
|
142
|
+
}
|
|
143
|
+
export { DEFAULT_GROUP, buildOrigin, createCommonLogger, parseCallArguments, shouldKeepSample };
|
|
144
|
+
//# sourceMappingURL=shared.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shared.js","sourceRoot":"","sources":["../../src/core/shared.ts"],"names":[],"mappings":"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"}
|
package/dist/format/console.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import type {
|
|
2
|
-
|
|
1
|
+
import type { LogEntry, LogLevelConfig, LogStreamName, NormalizedConsoleOptions } from "../types.js";
|
|
2
|
+
import { normalizeConsoleOptions } from "./options.js";
|
|
3
3
|
declare function formatConsole(entry: LogEntry, levelConfig: LogLevelConfig, options: NormalizedConsoleOptions, timeZone: string): string;
|
|
4
4
|
declare function writeConsole(streamName: LogStreamName | undefined, line: string): void;
|
|
5
5
|
export { formatConsole, normalizeConsoleOptions, writeConsole };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"console.d.ts","sourceRoot":"","sources":["../../src/format/console.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"console.d.ts","sourceRoot":"","sources":["../../src/format/console.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,cAAc,EAAE,aAAa,EAAE,wBAAwB,EAAE,MAAM,aAAa,CAAC;AAGrG,OAAO,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AAmBvD,iBAAS,aAAa,CAAC,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,cAAc,EAAE,OAAO,EAAE,wBAAwB,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM,CAoBhI;AAED,iBAAS,YAAY,CAAC,UAAU,EAAE,aAAa,GAAG,SAAS,EAAE,IAAI,EAAE,MAAM,GAAG,IAAI,CAO/E;AAED,OAAO,EAAE,aAAa,EAAE,uBAAuB,EAAE,YAAY,EAAE,CAAC"}
|
package/dist/format/console.js
CHANGED
|
@@ -1,21 +1,6 @@
|
|
|
1
|
-
import { formatDisplayTimestamp
|
|
1
|
+
import { formatDisplayTimestamp } from "../utils/datetime.js";
|
|
2
2
|
import { toString } from "../utils/values.js";
|
|
3
|
-
|
|
4
|
-
if (input === false) {
|
|
5
|
-
return { enabled: false, colors: true, timestamp: true, group: true, metadata: true, locale: normalizeLocale() };
|
|
6
|
-
}
|
|
7
|
-
if (input && typeof input === "object") {
|
|
8
|
-
return {
|
|
9
|
-
enabled: input.enabled !== false,
|
|
10
|
-
colors: input.colors !== false,
|
|
11
|
-
timestamp: input.timestamp !== false,
|
|
12
|
-
group: input.group !== false,
|
|
13
|
-
metadata: input.metadata !== false,
|
|
14
|
-
locale: normalizeLocale(input.locale),
|
|
15
|
-
};
|
|
16
|
-
}
|
|
17
|
-
return { enabled: true, colors: true, timestamp: true, group: true, metadata: true, locale: normalizeLocale() };
|
|
18
|
-
}
|
|
3
|
+
import { normalizeConsoleOptions } from "./options.js";
|
|
19
4
|
function hexToAnsi(hex, bold = false) {
|
|
20
5
|
const raw = toString(hex).replace(/^#/, "");
|
|
21
6
|
const normalized = raw.length >= 6 ? raw.slice(0, 6) : "";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"console.js","sourceRoot":"","sources":["../../src/format/console.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,sBAAsB,EAAE,
|
|
1
|
+
{"version":3,"file":"console.js","sourceRoot":"","sources":["../../src/format/console.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"options.d.ts","sourceRoot":"","sources":["../../src/format/options.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,wBAAwB,EAAE,MAAM,aAAa,CAAC;AAG5E,iBAAS,uBAAuB,CAAC,KAAK,EAAE,OAAO,GAAG,cAAc,GAAG,SAAS,GAAG,wBAAwB,CAiBtG;AAED,OAAO,EAAE,uBAAuB,EAAE,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { normalizeLocale } from "../utils/datetime.js";
|
|
2
|
+
function normalizeConsoleOptions(input) {
|
|
3
|
+
if (input === false) {
|
|
4
|
+
return { enabled: false, colors: true, timestamp: true, group: true, metadata: true, locale: normalizeLocale() };
|
|
5
|
+
}
|
|
6
|
+
if (input && typeof input === "object") {
|
|
7
|
+
return {
|
|
8
|
+
enabled: input.enabled !== false,
|
|
9
|
+
colors: input.colors !== false,
|
|
10
|
+
timestamp: input.timestamp !== false,
|
|
11
|
+
group: input.group !== false,
|
|
12
|
+
metadata: input.metadata !== false,
|
|
13
|
+
locale: normalizeLocale(input.locale),
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
return { enabled: true, colors: true, timestamp: true, group: true, metadata: true, locale: normalizeLocale() };
|
|
17
|
+
}
|
|
18
|
+
export { normalizeConsoleOptions };
|
|
19
|
+
//# sourceMappingURL=options.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"options.js","sourceRoot":"","sources":["../../src/format/options.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAEvD,SAAS,uBAAuB,CAAC,KAA2C;IAC1E,IAAI,KAAK,KAAK,KAAK,EAAE,CAAC;QACpB,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,eAAe,EAAE,EAAE,CAAC;IACnH,CAAC;IAED,IAAI,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QACvC,OAAO;YACL,OAAO,EAAE,KAAK,CAAC,OAAO,KAAK,KAAK;YAChC,MAAM,EAAE,KAAK,CAAC,MAAM,KAAK,KAAK;YAC9B,SAAS,EAAE,KAAK,CAAC,SAAS,KAAK,KAAK;YACpC,KAAK,EAAE,KAAK,CAAC,KAAK,KAAK,KAAK;YAC5B,QAAQ,EAAE,KAAK,CAAC,QAAQ,KAAK,KAAK;YAClC,MAAM,EAAE,eAAe,CAAC,KAAK,CAAC,MAAM,CAAC;SACtC,CAAC;IACJ,CAAC;IAED,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,eAAe,EAAE,EAAE,CAAC;AAClH,CAAC;AAED,OAAO,EAAE,uBAAuB,EAAE,CAAC"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
export { TOP_LEVEL, DEFAULT_LEVELS as defaultLevels } from "./constants.js";
|
|
2
2
|
export { createLog } from "./core/create_log.js";
|
|
3
3
|
export { normalizeLevels } from "./levels/index.js";
|
|
4
|
-
export {
|
|
4
|
+
export { buildPartitionName, buildTemporaryPartitionName, formatPartitionTimePrefix, sanitizePartitionName, } from "./storage/names.js";
|
|
5
|
+
export { copyPartition, createPartition, deleteLogs, deletePartition, deletePartitions, getPartitionInfo, listPartitions, mergePartition, movePartition, renamePartition, } from "./storage/partitions.js";
|
|
6
|
+
export { getLogsForDir } from "./storage/query.js";
|
|
5
7
|
export { logStream } from "./stream/index.js";
|
|
6
|
-
export type { ConsoleOptions, CreateLogOptions, LogEntry, LogInstance, LogLevelConfig, LogOrigin, LogQueryOptions, LogQueryResult, LogStats, LogStreamName, RedactOptions, RedactTransformArgs, RequestLoggerOptions, RetentionOptions, WriteOptions, } from "./types.js";
|
|
8
|
+
export type { BrowserLogStreamContext, ConsoleOptions, CopyPartitionOptions, CreatePartitionOptions, CreateLogOptions, DeleteLogFileSummary, DeleteLogsOptions, DeleteLogsResult, DeletePartitionResult, DeletePartitionsOptions, LogEntry, LogInstance, LogLevelConfig, LogOrigin, LogQueryOptions, LogQueryResult, LogQueryTotals, LogPartitionTotals, LogPartitionSummary, LogStats, LogStreamContext, LogStreamHandler, LogStreamName, MergePartitionOptions, MovePartitionOptions, PartitionInfo, PartitionNameOptions, PartitionSanitizeOptions, PartitionSanitizer, PartitionTimeValue, PartitionTotals, PromotePartitionOptions, RedactOptions, RedactTransformArgs, RenamePartitionOptions, RequestLoggerOptions, RetentionOptions, ServerLogStreamContext, SetPartitionOptions, WriteOptions, } from "./types.js";
|
|
7
9
|
//# 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":"AAAA,OAAO,EAAE,SAAS,EAAE,cAAc,IAAI,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAC5E,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,cAAc,IAAI,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAC5E,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EACL,kBAAkB,EAClB,2BAA2B,EAC3B,yBAAyB,EACzB,qBAAqB,GACtB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EACL,aAAa,EACb,eAAe,EACf,UAAU,EACV,eAAe,EACf,gBAAgB,EAChB,gBAAgB,EAChB,cAAc,EACd,cAAc,EACd,aAAa,EACb,eAAe,GAChB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAE9C,YAAY,EACV,uBAAuB,EACvB,cAAc,EACd,oBAAoB,EACpB,sBAAsB,EACtB,gBAAgB,EAChB,oBAAoB,EACpB,iBAAiB,EACjB,gBAAgB,EAChB,qBAAqB,EACrB,uBAAuB,EACvB,QAAQ,EACR,WAAW,EACX,cAAc,EACd,SAAS,EACT,eAAe,EACf,cAAc,EACd,cAAc,EACd,kBAAkB,EAClB,mBAAmB,EACnB,QAAQ,EACR,gBAAgB,EAChB,gBAAgB,EAChB,aAAa,EACb,qBAAqB,EACrB,oBAAoB,EACpB,aAAa,EACb,oBAAoB,EACpB,wBAAwB,EACxB,kBAAkB,EAClB,kBAAkB,EAClB,eAAe,EACf,uBAAuB,EACvB,aAAa,EACb,mBAAmB,EACnB,sBAAsB,EACtB,oBAAoB,EACpB,gBAAgB,EAChB,sBAAsB,EACtB,mBAAmB,EACnB,YAAY,GACb,MAAM,YAAY,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
export { TOP_LEVEL, DEFAULT_LEVELS as defaultLevels } from "./constants.js";
|
|
2
2
|
export { createLog } from "./core/create_log.js";
|
|
3
3
|
export { normalizeLevels } from "./levels/index.js";
|
|
4
|
-
export {
|
|
4
|
+
export { buildPartitionName, buildTemporaryPartitionName, formatPartitionTimePrefix, sanitizePartitionName, } from "./storage/names.js";
|
|
5
|
+
export { copyPartition, createPartition, deleteLogs, deletePartition, deletePartitions, getPartitionInfo, listPartitions, mergePartition, movePartition, renamePartition, } from "./storage/partitions.js";
|
|
6
|
+
export { getLogsForDir } from "./storage/query.js";
|
|
5
7
|
export { logStream } from "./stream/index.js";
|
|
6
8
|
//# 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,OAAO,EAAE,SAAS,EAAE,cAAc,IAAI,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAC5E,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,cAAc,IAAI,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAC5E,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EACL,kBAAkB,EAClB,2BAA2B,EAC3B,yBAAyB,EACzB,qBAAqB,GACtB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EACL,aAAa,EACb,eAAe,EACf,UAAU,EACV,eAAe,EACf,gBAAgB,EAChB,gBAAgB,EAChB,cAAc,EACd,cAAc,EACd,aAAa,EACb,eAAe,GAChB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC"}
|
package/dist/storage/names.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { LogEntry } from "../types.js";
|
|
1
|
+
import type { LogEntry, PartitionNameOptions, PartitionSanitizeOptions } from "../types.js";
|
|
2
2
|
type ParsedLogFile = {
|
|
3
3
|
day: string;
|
|
4
4
|
hour: string;
|
|
@@ -9,13 +9,20 @@ type ParsedLogFile = {
|
|
|
9
9
|
type WalkedLogFile = ParsedLogFile & {
|
|
10
10
|
absPath: string;
|
|
11
11
|
relDir: string;
|
|
12
|
+
groupDir: string;
|
|
12
13
|
groupKey: string;
|
|
14
|
+
partition: string | null;
|
|
13
15
|
};
|
|
16
|
+
declare function sanitizePartitionName(input: string, options?: PartitionSanitizeOptions): string;
|
|
17
|
+
declare function formatPartitionTimePrefix(options?: PartitionNameOptions): string;
|
|
18
|
+
declare function buildPartitionName(options?: PartitionNameOptions): string;
|
|
19
|
+
declare function buildTemporaryPartitionName(options?: PartitionNameOptions): string;
|
|
20
|
+
declare function normalizePartitionKey(input: unknown): string;
|
|
14
21
|
declare function nowFileStamp(date?: Date, timeZone?: string): string;
|
|
15
22
|
declare function fileStampForEntry(entry: LogEntry, timeZone?: string): string;
|
|
16
23
|
declare function makeLogFileName(stamp: string, sequence: number, level: string): string;
|
|
17
24
|
declare function parseLogFileName(fileName: string): ParsedLogFile | null;
|
|
18
|
-
declare function walkedFileFromPath(baseDir: string, filePath: string): WalkedLogFile | null;
|
|
19
|
-
export { fileStampForEntry, makeLogFileName, nowFileStamp, parseLogFileName, walkedFileFromPath };
|
|
25
|
+
declare function walkedFileFromPath(baseDir: string, filePath: string, partition?: string | null, rootDir?: string): WalkedLogFile | null;
|
|
26
|
+
export { buildPartitionName, buildTemporaryPartitionName, fileStampForEntry, formatPartitionTimePrefix, makeLogFileName, normalizePartitionKey, nowFileStamp, parseLogFileName, sanitizePartitionName, walkedFileFromPath, };
|
|
20
27
|
export type { ParsedLogFile, WalkedLogFile };
|
|
21
28
|
//# sourceMappingURL=names.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"names.d.ts","sourceRoot":"","sources":["../../src/storage/names.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"names.d.ts","sourceRoot":"","sources":["../../src/storage/names.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EACV,QAAQ,EACR,oBAAoB,EACpB,wBAAwB,EAGzB,MAAM,aAAa,CAAC;AAIrB,KAAK,aAAa,GAAG;IACnB,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,OAAO,CAAC;CACrB,CAAC;AAEF,KAAK,aAAa,GAAG,aAAa,GAAG;IACnC,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;CAC1B,CAAC;AAmBF,iBAAS,qBAAqB,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,GAAE,wBAA6B,GAAG,MAAM,CAE5F;AAMD,iBAAS,yBAAyB,CAAC,OAAO,GAAE,oBAAyB,GAAG,MAAM,CAG7E;AAED,iBAAS,kBAAkB,CAAC,OAAO,GAAE,oBAAyB,GAAG,MAAM,CAYtE;AAED,iBAAS,2BAA2B,CAAC,OAAO,GAAE,oBAAyB,GAAG,MAAM,CAa/E;AAED,iBAAS,qBAAqB,CAAC,KAAK,EAAE,OAAO,GAAG,MAAM,CAIrD;AAED,iBAAS,YAAY,CAAC,IAAI,OAAa,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,CAGlE;AAED,iBAAS,iBAAiB,CAAC,KAAK,EAAE,QAAQ,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,CAGrE;AAED,iBAAS,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM,CAG/E;AAED,iBAAS,gBAAgB,CAAC,QAAQ,EAAE,MAAM,GAAG,aAAa,GAAG,IAAI,CAWhE;AAED,iBAAS,kBAAkB,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,GAAE,MAAM,GAAG,IAAW,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,aAAa,GAAG,IAAI,CAetI;AAED,OAAO,EACL,kBAAkB,EAClB,2BAA2B,EAC3B,iBAAiB,EACjB,yBAAyB,EACzB,eAAe,EACf,qBAAqB,EACrB,YAAY,EACZ,gBAAgB,EAChB,qBAAqB,EACrB,kBAAkB,GACnB,CAAC;AACF,YAAY,EAAE,aAAa,EAAE,aAAa,EAAE,CAAC"}
|
package/dist/storage/names.js
CHANGED
|
@@ -1,9 +1,68 @@
|
|
|
1
|
+
import crypto from "node:crypto";
|
|
1
2
|
import path from "node:path";
|
|
2
3
|
import { TOP_LEVEL } from "../constants.js";
|
|
3
4
|
import { groupKeyFromRelDir } from "../groups.js";
|
|
4
5
|
import { getLocalDateTimeParts, normalizeTimeZone } from "../utils/datetime.js";
|
|
6
|
+
import { toString } from "../utils/values.js";
|
|
7
|
+
function sanitizePartitionFragment(input) {
|
|
8
|
+
return toString(input)
|
|
9
|
+
.trim()
|
|
10
|
+
.replace(/[^a-zA-Z0-9_-]+/g, "-")
|
|
11
|
+
.replace(/-+/g, "-")
|
|
12
|
+
.replace(/_+/g, "_")
|
|
13
|
+
.replace(/^[-_]+|[-_]+$/g, "");
|
|
14
|
+
}
|
|
15
|
+
function normalizePartitionValue(input, sanitizer) {
|
|
16
|
+
const raw = toString(input);
|
|
17
|
+
const prepared = typeof sanitizer === "function" ? sanitizer(raw) : raw;
|
|
18
|
+
const normalized = sanitizePartitionFragment(prepared);
|
|
19
|
+
if (!normalized)
|
|
20
|
+
throw new Error("invalid-partition-name");
|
|
21
|
+
return normalized;
|
|
22
|
+
}
|
|
23
|
+
function sanitizePartitionName(input, options = {}) {
|
|
24
|
+
return normalizePartitionValue(input, options.sanitizer);
|
|
25
|
+
}
|
|
26
|
+
function partitionTimeParts(at, timeZone) {
|
|
27
|
+
return getLocalDateTimeParts(at, normalizeTimeZone(timeZone));
|
|
28
|
+
}
|
|
29
|
+
function formatPartitionTimePrefix(options = {}) {
|
|
30
|
+
const parts = partitionTimeParts(options.at, options.timeZone);
|
|
31
|
+
return `${parts.year}-${parts.month}-${parts.day}-${parts.hour}-0000`;
|
|
32
|
+
}
|
|
33
|
+
function buildPartitionName(options = {}) {
|
|
34
|
+
const prefix = formatPartitionTimePrefix(options);
|
|
35
|
+
const suffix = toString(options.suffix).trim();
|
|
36
|
+
if (!suffix)
|
|
37
|
+
return prefix;
|
|
38
|
+
const preparedSuffix = options.sanitizeSuffix === false
|
|
39
|
+
? suffix
|
|
40
|
+
: typeof options.sanitizeSuffix === "function"
|
|
41
|
+
? options.sanitizeSuffix(suffix)
|
|
42
|
+
: suffix;
|
|
43
|
+
return sanitizePartitionName(`${prefix}-${preparedSuffix}`);
|
|
44
|
+
}
|
|
45
|
+
function buildTemporaryPartitionName(options = {}) {
|
|
46
|
+
const suffix = toString(options.suffix).trim();
|
|
47
|
+
const random = crypto.randomBytes(4).toString("hex");
|
|
48
|
+
const prefix = formatPartitionTimePrefix(options);
|
|
49
|
+
if (!suffix)
|
|
50
|
+
return sanitizePartitionName(`${prefix}-tmp-${random}`);
|
|
51
|
+
const preparedSuffix = options.sanitizeSuffix === false
|
|
52
|
+
? suffix
|
|
53
|
+
: typeof options.sanitizeSuffix === "function"
|
|
54
|
+
? options.sanitizeSuffix(suffix)
|
|
55
|
+
: suffix;
|
|
56
|
+
return sanitizePartitionName(`${prefix}-${preparedSuffix}-tmp-${random}`);
|
|
57
|
+
}
|
|
58
|
+
function normalizePartitionKey(input) {
|
|
59
|
+
const raw = toString(input).trim();
|
|
60
|
+
if (!raw)
|
|
61
|
+
return "";
|
|
62
|
+
return sanitizePartitionName(raw);
|
|
63
|
+
}
|
|
5
64
|
function nowFileStamp(date = new Date(), timeZone) {
|
|
6
|
-
const parts =
|
|
65
|
+
const parts = partitionTimeParts(date, timeZone);
|
|
7
66
|
return `${parts.year}-${parts.month}-${parts.day}-${parts.hour}`;
|
|
8
67
|
}
|
|
9
68
|
function fileStampForEntry(entry, timeZone) {
|
|
@@ -15,48 +74,32 @@ function makeLogFileName(stamp, sequence, level) {
|
|
|
15
74
|
return `${stamp}-${seq}-${level}.jsonl`;
|
|
16
75
|
}
|
|
17
76
|
function parseLogFileName(fileName) {
|
|
18
|
-
const
|
|
19
|
-
if (
|
|
20
|
-
return {
|
|
21
|
-
day: next[1],
|
|
22
|
-
hour: next[2],
|
|
23
|
-
sequence: Number(next[3]) || 0,
|
|
24
|
-
level: next[4],
|
|
25
|
-
compressed: Boolean(next[5]),
|
|
26
|
-
};
|
|
27
|
-
}
|
|
28
|
-
const legacyWithSequence = /^(\d{2}-\d{2}-\d{4})-(\d{2})-(\d+)-([a-z0-9._-]+)\.log\.json(\.gz)?$/i.exec(fileName);
|
|
29
|
-
if (legacyWithSequence) {
|
|
30
|
-
return {
|
|
31
|
-
day: legacyWithSequence[1],
|
|
32
|
-
hour: legacyWithSequence[2],
|
|
33
|
-
sequence: Number(legacyWithSequence[3]) || 0,
|
|
34
|
-
level: legacyWithSequence[4],
|
|
35
|
-
compressed: Boolean(legacyWithSequence[5]),
|
|
36
|
-
};
|
|
37
|
-
}
|
|
38
|
-
const legacy = /^(\d{2}-\d{2}-\d{4})-(\d{2})-([a-z0-9._-]+)\.log\.json(\.gz)?$/i.exec(fileName);
|
|
39
|
-
if (!legacy)
|
|
77
|
+
const match = /^(\d{4}-\d{2}-\d{2})-(\d{2})-(\d+)-([a-z0-9._-]+)\.jsonl(\.gz)?$/i.exec(fileName);
|
|
78
|
+
if (!match)
|
|
40
79
|
return null;
|
|
41
80
|
return {
|
|
42
|
-
day:
|
|
43
|
-
hour:
|
|
44
|
-
sequence: 0,
|
|
45
|
-
level:
|
|
46
|
-
compressed: Boolean(
|
|
81
|
+
day: match[1],
|
|
82
|
+
hour: match[2],
|
|
83
|
+
sequence: Number(match[3]) || 0,
|
|
84
|
+
level: match[4],
|
|
85
|
+
compressed: Boolean(match[5]),
|
|
47
86
|
};
|
|
48
87
|
}
|
|
49
|
-
function walkedFileFromPath(baseDir, filePath) {
|
|
88
|
+
function walkedFileFromPath(baseDir, filePath, partition = null, rootDir) {
|
|
50
89
|
const parsed = parseLogFileName(path.basename(filePath));
|
|
51
90
|
if (!parsed)
|
|
52
91
|
return null;
|
|
53
|
-
const
|
|
92
|
+
const relativeRoot = rootDir || baseDir;
|
|
93
|
+
const relDir = path.relative(relativeRoot, path.dirname(filePath));
|
|
94
|
+
const groupDir = relDir && relDir !== "." ? relDir : "";
|
|
54
95
|
return {
|
|
55
96
|
...parsed,
|
|
56
97
|
absPath: filePath,
|
|
57
|
-
relDir,
|
|
58
|
-
|
|
98
|
+
relDir: path.relative(baseDir, path.dirname(filePath)),
|
|
99
|
+
groupDir,
|
|
100
|
+
groupKey: groupDir ? groupKeyFromRelDir(groupDir) : TOP_LEVEL,
|
|
101
|
+
partition,
|
|
59
102
|
};
|
|
60
103
|
}
|
|
61
|
-
export { fileStampForEntry, makeLogFileName, nowFileStamp, parseLogFileName, walkedFileFromPath };
|
|
104
|
+
export { buildPartitionName, buildTemporaryPartitionName, fileStampForEntry, formatPartitionTimePrefix, makeLogFileName, normalizePartitionKey, nowFileStamp, parseLogFileName, sanitizePartitionName, walkedFileFromPath, };
|
|
62
105
|
//# sourceMappingURL=names.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"names.js","sourceRoot":"","sources":["../../src/storage/names.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAE7B,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"names.js","sourceRoot":"","sources":["../../src/storage/names.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"options.d.ts","sourceRoot":"","sources":["../../src/storage/options.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,0BAA0B,EAAE,sBAAsB,EAAE,gBAAgB,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAGtH,iBAAS,qBAAqB,CAAC,KAAK,CAAC,EAAE,YAAY,GAAG,sBAAsB,CAY3E;AAED,iBAAS,yBAAyB,CAAC,KAAK,CAAC,EAAE,gBAAgB,GAAG,0BAA0B,
|
|
1
|
+
{"version":3,"file":"options.d.ts","sourceRoot":"","sources":["../../src/storage/options.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,0BAA0B,EAAE,sBAAsB,EAAE,gBAAgB,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAGtH,iBAAS,qBAAqB,CAAC,KAAK,CAAC,EAAE,YAAY,GAAG,sBAAsB,CAY3E;AAED,iBAAS,yBAAyB,CAAC,KAAK,CAAC,EAAE,gBAAgB,GAAG,0BAA0B,CAcvF;AAED,OAAO,EAAE,yBAAyB,EAAE,qBAAqB,EAAE,CAAC"}
|
package/dist/storage/options.js
CHANGED
|
@@ -13,10 +13,12 @@ function normalizeWriteOptions(input) {
|
|
|
13
13
|
function normalizeRetentionOptions(input) {
|
|
14
14
|
const cfg = input || {};
|
|
15
15
|
const days = Number(cfg.maxAgeDays);
|
|
16
|
+
const maxPartitions = Number(cfg.maxPartitions);
|
|
16
17
|
const cleanupIntervalMs = Number(cfg.cleanupIntervalMs);
|
|
17
18
|
return {
|
|
18
19
|
enabled: cfg.enabled !== false,
|
|
19
|
-
maxAgeDays: Number.isFinite(days) && days > 0 ? days :
|
|
20
|
+
maxAgeDays: Number.isFinite(days) && days > 0 ? Math.floor(days) : null,
|
|
21
|
+
maxPartitions: Number.isFinite(maxPartitions) && maxPartitions > 0 ? Math.floor(maxPartitions) : null,
|
|
20
22
|
maxFileSize: parseSize(cfg.maxFileSize, 20 * 1024 * 1024),
|
|
21
23
|
compressOldFiles: cfg.compressOldFiles === true,
|
|
22
24
|
cleanupIntervalMs: Number.isFinite(cleanupIntervalMs) && cleanupIntervalMs > 0 ? cleanupIntervalMs : 60 * 60 * 1000,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"options.js","sourceRoot":"","sources":["../../src/storage/options.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE7C,SAAS,qBAAqB,CAAC,KAAoB;IACjD,MAAM,GAAG,GAAG,KAAK,IAAI,EAAE,CAAC;IACxB,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IAEtC,OAAO;QACL,IAAI,EAAE,GAAG,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO;QAC5C,QAAQ,EAAE,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK;QAClF,QAAQ,EACN,GAAG,CAAC,QAAQ,KAAK,aAAa,IAAI,GAAG,CAAC,QAAQ,KAAK,OAAO,IAAI,GAAG,CAAC,QAAQ,KAAK,aAAa;YAC1F,CAAC,CAAC,GAAG,CAAC,QAAQ;YACd,CAAC,CAAC,aAAa;KACpB,CAAC;AACJ,CAAC;AAED,SAAS,yBAAyB,CAAC,KAAwB;IACzD,MAAM,GAAG,GAAG,KAAK,IAAI,EAAE,CAAC;IACxB,MAAM,IAAI,GAAG,MAAM,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IACpC,MAAM,iBAAiB,GAAG,MAAM,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;IAExD,OAAO;QACL,OAAO,EAAE,GAAG,CAAC,OAAO,KAAK,KAAK;QAC9B,UAAU,EAAE,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"options.js","sourceRoot":"","sources":["../../src/storage/options.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE7C,SAAS,qBAAqB,CAAC,KAAoB;IACjD,MAAM,GAAG,GAAG,KAAK,IAAI,EAAE,CAAC;IACxB,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IAEtC,OAAO;QACL,IAAI,EAAE,GAAG,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO;QAC5C,QAAQ,EAAE,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK;QAClF,QAAQ,EACN,GAAG,CAAC,QAAQ,KAAK,aAAa,IAAI,GAAG,CAAC,QAAQ,KAAK,OAAO,IAAI,GAAG,CAAC,QAAQ,KAAK,aAAa;YAC1F,CAAC,CAAC,GAAG,CAAC,QAAQ;YACd,CAAC,CAAC,aAAa;KACpB,CAAC;AACJ,CAAC;AAED,SAAS,yBAAyB,CAAC,KAAwB;IACzD,MAAM,GAAG,GAAG,KAAK,IAAI,EAAE,CAAC;IACxB,MAAM,IAAI,GAAG,MAAM,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IACpC,MAAM,aAAa,GAAG,MAAM,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;IAChD,MAAM,iBAAiB,GAAG,MAAM,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;IAExD,OAAO;QACL,OAAO,EAAE,GAAG,CAAC,OAAO,KAAK,KAAK;QAC9B,UAAU,EAAE,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI;QACvE,aAAa,EAAE,MAAM,CAAC,QAAQ,CAAC,aAAa,CAAC,IAAI,aAAa,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI;QACrG,WAAW,EAAE,SAAS,CAAC,GAAG,CAAC,WAAW,EAAE,EAAE,GAAG,IAAI,GAAG,IAAI,CAAC;QACzD,gBAAgB,EAAE,GAAG,CAAC,gBAAgB,KAAK,IAAI;QAC/C,iBAAiB,EAAE,MAAM,CAAC,QAAQ,CAAC,iBAAiB,CAAC,IAAI,iBAAiB,GAAG,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,GAAG,IAAI;KACpH,CAAC;AACJ,CAAC;AAED,OAAO,EAAE,yBAAyB,EAAE,qBAAqB,EAAE,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { CopyPartitionOptions, CreatePartitionOptions, DeleteLogsOptions, DeleteLogsResult, DeletePartitionResult, DeletePartitionsOptions, MergePartitionOptions, MovePartitionOptions, PartitionInfo, RenamePartitionOptions } from "../types.js";
|
|
2
|
+
type PartitionMarker = {
|
|
3
|
+
name: string;
|
|
4
|
+
temporary: boolean;
|
|
5
|
+
created_at: string;
|
|
6
|
+
updated_at: string;
|
|
7
|
+
};
|
|
8
|
+
type PartitionWriteOptions = {
|
|
9
|
+
temporary?: boolean;
|
|
10
|
+
preserveTemporary?: boolean;
|
|
11
|
+
createdAt?: string;
|
|
12
|
+
updatedAt?: string;
|
|
13
|
+
preserveCreatedAt?: boolean;
|
|
14
|
+
};
|
|
15
|
+
declare function readPartitionMarkerFromRoot(rootDir: string, expectedName?: string): Promise<PartitionMarker | null>;
|
|
16
|
+
declare function readPartitionMarkerFromRootSync(rootDir: string, expectedName?: string): PartitionMarker | null;
|
|
17
|
+
declare function touchPartitionMarker(dir: string, partition: string, options?: PartitionWriteOptions): Promise<PartitionMarker>;
|
|
18
|
+
declare function touchPartitionMarkerSync(dir: string, partition: string, options?: PartitionWriteOptions): PartitionMarker;
|
|
19
|
+
declare function createPartition(dir: string, partition: string, options?: CreatePartitionOptions): Promise<PartitionInfo>;
|
|
20
|
+
declare function listPartitions(dir: string): Promise<PartitionInfo[]>;
|
|
21
|
+
declare function getPartitionInfo(dir: string, partition: string): Promise<PartitionInfo | null>;
|
|
22
|
+
declare function renamePartition(dir: string, options: RenamePartitionOptions): Promise<PartitionInfo>;
|
|
23
|
+
declare function movePartition(options: MovePartitionOptions): Promise<PartitionInfo>;
|
|
24
|
+
declare function copyPartition(options: CopyPartitionOptions): Promise<PartitionInfo>;
|
|
25
|
+
declare function mergePartition(dir: string, options: MergePartitionOptions): Promise<PartitionInfo>;
|
|
26
|
+
declare function deletePartition(dir: string, partition: string): Promise<DeletePartitionResult>;
|
|
27
|
+
declare function deletePartitions(dir: string, options?: DeletePartitionsOptions): Promise<DeletePartitionResult>;
|
|
28
|
+
declare function deleteLogs(dir: string, options?: DeleteLogsOptions): Promise<DeleteLogsResult>;
|
|
29
|
+
export { createPartition, copyPartition, deleteLogs, deletePartition, deletePartitions, getPartitionInfo, listPartitions, mergePartition, movePartition, readPartitionMarkerFromRoot, readPartitionMarkerFromRootSync, renamePartition, touchPartitionMarker, touchPartitionMarkerSync, };
|
|
30
|
+
//# sourceMappingURL=partitions.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"partitions.d.ts","sourceRoot":"","sources":["../../src/storage/partitions.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EACV,oBAAoB,EACpB,sBAAsB,EACtB,iBAAiB,EACjB,gBAAgB,EAChB,qBAAqB,EACrB,uBAAuB,EAEvB,qBAAqB,EACrB,oBAAoB,EACpB,aAAa,EACb,sBAAsB,EACvB,MAAM,aAAa,CAAC;AAIrB,KAAK,eAAe,GAAG;IACrB,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,OAAO,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;CACpB,CAAC;AASF,KAAK,qBAAqB,GAAG;IAC3B,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,iBAAiB,CAAC,EAAE,OAAO,CAAC;CAC7B,CAAC;AA6CF,iBAAe,2BAA2B,CAAC,OAAO,EAAE,MAAM,EAAE,YAAY,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC,CAQlH;AAED,iBAAS,+BAA+B,CAAC,OAAO,EAAE,MAAM,EAAE,YAAY,CAAC,EAAE,MAAM,GAAG,eAAe,GAAG,IAAI,CAQvG;AA4BD,iBAAe,oBAAoB,CAAC,GAAG,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,GAAE,qBAA0B,GAAG,OAAO,CAAC,eAAe,CAAC,CASjI;AAED,iBAAS,wBAAwB,CAAC,GAAG,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,GAAE,qBAA0B,GAAG,eAAe,CAStH;AAmWD,iBAAe,eAAe,CAAC,GAAG,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,GAAE,sBAA2B,GAAG,OAAO,CAAC,aAAa,CAAC,CAa3H;AAED,iBAAe,cAAc,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC,CAInE;AAED,iBAAe,gBAAgB,CAAC,GAAG,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,GAAG,IAAI,CAAC,CAG7F;AAED,iBAAe,eAAe,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,EAAE,sBAAsB,GAAG,OAAO,CAAC,aAAa,CAAC,CAWnG;AAED,iBAAe,aAAa,CAAC,OAAO,EAAE,oBAAoB,GAAG,OAAO,CAAC,aAAa,CAAC,CAWlF;AAED,iBAAe,aAAa,CAAC,OAAO,EAAE,oBAAoB,GAAG,OAAO,CAAC,aAAa,CAAC,CAalF;AAED,iBAAe,cAAc,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,EAAE,qBAAqB,GAAG,OAAO,CAAC,aAAa,CAAC,CAIjG;AAED,iBAAe,eAAe,CAAC,GAAG,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,qBAAqB,CAAC,CAE7F;AAED,iBAAe,gBAAgB,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,GAAE,uBAA4B,GAAG,OAAO,CAAC,qBAAqB,CAAC,CAoBlH;AAED,iBAAe,UAAU,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,GAAE,iBAAsB,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAqBjG;AAED,OAAO,EACL,eAAe,EACf,aAAa,EACb,UAAU,EACV,eAAe,EACf,gBAAgB,EAChB,gBAAgB,EAChB,cAAc,EACd,cAAc,EACd,aAAa,EACb,2BAA2B,EAC3B,+BAA+B,EAC/B,eAAe,EACf,oBAAoB,EACpB,wBAAwB,GACzB,CAAC"}
|