@trebired/logger 1.1.3 → 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 +12 -0
- package/README.md +135 -2
- 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/core/create_log.d.ts.map +1 -1
- package/dist/core/create_log.js +105 -145
- 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 +3 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -1
- package/dist/storage/names.d.ts +6 -2
- package/dist/storage/names.d.ts.map +1 -1
- package/dist/storage/names.js +66 -31
- package/dist/storage/names.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 +3 -3
- package/dist/storage/query.d.ts.map +1 -1
- package/dist/storage/query.js +29 -31
- package/dist/storage/query.js.map +1 -1
- package/dist/storage/retention.d.ts.map +1 -1
- package/dist/storage/retention.js +2 -5
- package/dist/storage/retention.js.map +1 -1
- package/dist/storage/walk.d.ts.map +1 -1
- package/dist/storage/walk.js +3 -20
- package/dist/storage/walk.js.map +1 -1
- package/dist/storage/write.d.ts +1 -2
- package/dist/storage/write.d.ts.map +1 -1
- package/dist/storage/write.js +10 -12
- 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 +162 -4
- package/dist/types.d.ts.map +1 -1
- package/package.json +24 -2
|
@@ -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 { buildPartitionName, buildTemporaryPartitionName, formatPartitionTimePrefix, sanitizePartitionName, } from "./storage/names.js";
|
|
5
|
+
export { copyPartition, createPartition, deleteLogs, deletePartition, deletePartitions, getPartitionInfo, listPartitions, mergePartition, movePartition, renamePartition, } from "./storage/partitions.js";
|
|
4
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, LogQueryTotals, LogPartitionTotals, LogPartitionSummary, 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,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAE9C,YAAY,EACV,cAAc,EACd,gBAAgB,EAChB,QAAQ,EACR,WAAW,EACX,cAAc,EACd,SAAS,EACT,eAAe,EACf,cAAc,EACd,cAAc,EACd,kBAAkB,EAClB,mBAAmB,EACnB,QAAQ,EACR,aAAa,EACb,aAAa,EACb,mBAAmB,EACnB,oBAAoB,EACpB,gBAAgB,EAChB,YAAY,GACb,MAAM,YAAY,CAAC"}
|
|
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 { buildPartitionName, buildTemporaryPartitionName, formatPartitionTimePrefix, sanitizePartitionName, } from "./storage/names.js";
|
|
5
|
+
export { copyPartition, createPartition, deleteLogs, deletePartition, deletePartitions, getPartitionInfo, listPartitions, mergePartition, movePartition, renamePartition, } from "./storage/partitions.js";
|
|
4
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,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC"}
|
|
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;
|
|
@@ -13,12 +13,16 @@ type WalkedLogFile = ParsedLogFile & {
|
|
|
13
13
|
groupKey: string;
|
|
14
14
|
partition: string | null;
|
|
15
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;
|
|
16
20
|
declare function normalizePartitionKey(input: unknown): string;
|
|
17
21
|
declare function nowFileStamp(date?: Date, timeZone?: string): string;
|
|
18
22
|
declare function fileStampForEntry(entry: LogEntry, timeZone?: string): string;
|
|
19
23
|
declare function makeLogFileName(stamp: string, sequence: number, level: string): string;
|
|
20
24
|
declare function parseLogFileName(fileName: string): ParsedLogFile | null;
|
|
21
25
|
declare function walkedFileFromPath(baseDir: string, filePath: string, partition?: string | null, rootDir?: string): WalkedLogFile | null;
|
|
22
|
-
export { fileStampForEntry, makeLogFileName, normalizePartitionKey, nowFileStamp, parseLogFileName, walkedFileFromPath };
|
|
26
|
+
export { buildPartitionName, buildTemporaryPartitionName, fileStampForEntry, formatPartitionTimePrefix, makeLogFileName, normalizePartitionKey, nowFileStamp, parseLogFileName, sanitizePartitionName, walkedFileFromPath, };
|
|
23
27
|
export type { ParsedLogFile, WalkedLogFile };
|
|
24
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,13 +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
|
-
import { toString } from "../utils/values.js";
|
|
5
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
|
+
}
|
|
6
58
|
function normalizePartitionKey(input) {
|
|
7
|
-
|
|
59
|
+
const raw = toString(input).trim();
|
|
60
|
+
if (!raw)
|
|
61
|
+
return "";
|
|
62
|
+
return sanitizePartitionName(raw);
|
|
8
63
|
}
|
|
9
64
|
function nowFileStamp(date = new Date(), timeZone) {
|
|
10
|
-
const parts =
|
|
65
|
+
const parts = partitionTimeParts(date, timeZone);
|
|
11
66
|
return `${parts.year}-${parts.month}-${parts.day}-${parts.hour}`;
|
|
12
67
|
}
|
|
13
68
|
function fileStampForEntry(entry, timeZone) {
|
|
@@ -19,35 +74,15 @@ function makeLogFileName(stamp, sequence, level) {
|
|
|
19
74
|
return `${stamp}-${seq}-${level}.jsonl`;
|
|
20
75
|
}
|
|
21
76
|
function parseLogFileName(fileName) {
|
|
22
|
-
const
|
|
23
|
-
if (
|
|
24
|
-
return {
|
|
25
|
-
day: next[1],
|
|
26
|
-
hour: next[2],
|
|
27
|
-
sequence: Number(next[3]) || 0,
|
|
28
|
-
level: next[4],
|
|
29
|
-
compressed: Boolean(next[5]),
|
|
30
|
-
};
|
|
31
|
-
}
|
|
32
|
-
const legacyWithSequence = /^(\d{2}-\d{2}-\d{4})-(\d{2})-(\d+)-([a-z0-9._-]+)\.log\.json(\.gz)?$/i.exec(fileName);
|
|
33
|
-
if (legacyWithSequence) {
|
|
34
|
-
return {
|
|
35
|
-
day: legacyWithSequence[1],
|
|
36
|
-
hour: legacyWithSequence[2],
|
|
37
|
-
sequence: Number(legacyWithSequence[3]) || 0,
|
|
38
|
-
level: legacyWithSequence[4],
|
|
39
|
-
compressed: Boolean(legacyWithSequence[5]),
|
|
40
|
-
};
|
|
41
|
-
}
|
|
42
|
-
const legacy = /^(\d{2}-\d{2}-\d{4})-(\d{2})-([a-z0-9._-]+)\.log\.json(\.gz)?$/i.exec(fileName);
|
|
43
|
-
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)
|
|
44
79
|
return null;
|
|
45
80
|
return {
|
|
46
|
-
day:
|
|
47
|
-
hour:
|
|
48
|
-
sequence: 0,
|
|
49
|
-
level:
|
|
50
|
-
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]),
|
|
51
86
|
};
|
|
52
87
|
}
|
|
53
88
|
function walkedFileFromPath(baseDir, filePath, partition = null, rootDir) {
|
|
@@ -66,5 +101,5 @@ function walkedFileFromPath(baseDir, filePath, partition = null, rootDir) {
|
|
|
66
101
|
partition,
|
|
67
102
|
};
|
|
68
103
|
}
|
|
69
|
-
export { fileStampForEntry, makeLogFileName, normalizePartitionKey, nowFileStamp, parseLogFileName, walkedFileFromPath };
|
|
104
|
+
export { buildPartitionName, buildTemporaryPartitionName, fileStampForEntry, formatPartitionTimePrefix, makeLogFileName, normalizePartitionKey, nowFileStamp, parseLogFileName, sanitizePartitionName, walkedFileFromPath, };
|
|
70
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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"}
|
|
@@ -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"}
|