patreon-dl 1.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/README.md +422 -0
- package/bin/patreon-dl.js +5 -0
- package/dist/cli/CLIOptionValidator.d.ts +9 -0
- package/dist/cli/CLIOptionValidator.d.ts.map +1 -0
- package/dist/cli/CLIOptionValidator.js +85 -0
- package/dist/cli/CLIOptionValidator.js.map +1 -0
- package/dist/cli/CLIOptions.d.ts +20 -0
- package/dist/cli/CLIOptions.d.ts.map +1 -0
- package/dist/cli/CLIOptions.js +75 -0
- package/dist/cli/CLIOptions.js.map +1 -0
- package/dist/cli/CommandLineParser.d.ts +11 -0
- package/dist/cli/CommandLineParser.d.ts.map +1 -0
- package/dist/cli/CommandLineParser.js +212 -0
- package/dist/cli/CommandLineParser.js.map +1 -0
- package/dist/cli/ConfigFileParser.d.ts +9 -0
- package/dist/cli/ConfigFileParser.d.ts.map +1 -0
- package/dist/cli/ConfigFileParser.js +163 -0
- package/dist/cli/ConfigFileParser.js.map +1 -0
- package/dist/cli/index.d.ts +7 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +162 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/downloaders/Bootstrap.d.ts +29 -0
- package/dist/downloaders/Bootstrap.d.ts.map +1 -0
- package/dist/downloaders/Bootstrap.js +51 -0
- package/dist/downloaders/Bootstrap.js.map +1 -0
- package/dist/downloaders/Downloader.d.ts +59 -0
- package/dist/downloaders/Downloader.d.ts.map +1 -0
- package/dist/downloaders/Downloader.js +357 -0
- package/dist/downloaders/Downloader.js.map +1 -0
- package/dist/downloaders/DownloaderEvent.d.ts +47 -0
- package/dist/downloaders/DownloaderEvent.d.ts.map +1 -0
- package/dist/downloaders/DownloaderEvent.js +6 -0
- package/dist/downloaders/DownloaderEvent.js.map +1 -0
- package/dist/downloaders/DownloaderOptions.d.ts +39 -0
- package/dist/downloaders/DownloaderOptions.d.ts.map +1 -0
- package/dist/downloaders/DownloaderOptions.js +69 -0
- package/dist/downloaders/DownloaderOptions.js.map +1 -0
- package/dist/downloaders/PostDownloader.d.ts +8 -0
- package/dist/downloaders/PostDownloader.d.ts.map +1 -0
- package/dist/downloaders/PostDownloader.js +428 -0
- package/dist/downloaders/PostDownloader.js.map +1 -0
- package/dist/downloaders/ProductDownloader.d.ts +8 -0
- package/dist/downloaders/ProductDownloader.d.ts.map +1 -0
- package/dist/downloaders/ProductDownloader.js +171 -0
- package/dist/downloaders/ProductDownloader.js.map +1 -0
- package/dist/downloaders/cache/StatusCache.d.ts +43 -0
- package/dist/downloaders/cache/StatusCache.d.ts.map +1 -0
- package/dist/downloaders/cache/StatusCache.js +206 -0
- package/dist/downloaders/cache/StatusCache.js.map +1 -0
- package/dist/downloaders/index.d.ts +7 -0
- package/dist/downloaders/index.d.ts.map +1 -0
- package/dist/downloaders/index.js +6 -0
- package/dist/downloaders/index.js.map +1 -0
- package/dist/downloaders/task/DownloadTask.d.ts +89 -0
- package/dist/downloaders/task/DownloadTask.d.ts.map +1 -0
- package/dist/downloaders/task/DownloadTask.js +240 -0
- package/dist/downloaders/task/DownloadTask.js.map +1 -0
- package/dist/downloaders/task/DownloadTaskBatch.d.ts +45 -0
- package/dist/downloaders/task/DownloadTaskBatch.d.ts.map +1 -0
- package/dist/downloaders/task/DownloadTaskBatch.js +195 -0
- package/dist/downloaders/task/DownloadTaskBatch.js.map +1 -0
- package/dist/downloaders/task/DownloadTaskBatchEvent.d.ts +32 -0
- package/dist/downloaders/task/DownloadTaskBatchEvent.d.ts.map +1 -0
- package/dist/downloaders/task/DownloadTaskBatchEvent.js +2 -0
- package/dist/downloaders/task/DownloadTaskBatchEvent.js.map +1 -0
- package/dist/downloaders/task/DownloadTaskFactory.d.ts +20 -0
- package/dist/downloaders/task/DownloadTaskFactory.d.ts.map +1 -0
- package/dist/downloaders/task/DownloadTaskFactory.js +177 -0
- package/dist/downloaders/task/DownloadTaskFactory.js.map +1 -0
- package/dist/downloaders/task/FFmpegDownloadTask.d.ts +27 -0
- package/dist/downloaders/task/FFmpegDownloadTask.d.ts.map +1 -0
- package/dist/downloaders/task/FFmpegDownloadTask.js +206 -0
- package/dist/downloaders/task/FFmpegDownloadTask.js.map +1 -0
- package/dist/downloaders/task/FetcherDownloadTask.d.ts +21 -0
- package/dist/downloaders/task/FetcherDownloadTask.d.ts.map +1 -0
- package/dist/downloaders/task/FetcherDownloadTask.js +213 -0
- package/dist/downloaders/task/FetcherDownloadTask.js.map +1 -0
- package/dist/downloaders/task/index.d.ts +4 -0
- package/dist/downloaders/task/index.d.ts.map +1 -0
- package/dist/downloaders/task/index.js +3 -0
- package/dist/downloaders/task/index.js.map +1 -0
- package/dist/downloaders/templates/CampaignInfo.d.ts +3 -0
- package/dist/downloaders/templates/CampaignInfo.d.ts.map +1 -0
- package/dist/downloaders/templates/CampaignInfo.js +58 -0
- package/dist/downloaders/templates/CampaignInfo.js.map +1 -0
- package/dist/downloaders/templates/PostInfo.d.ts +4 -0
- package/dist/downloaders/templates/PostInfo.d.ts.map +1 -0
- package/dist/downloaders/templates/PostInfo.js +45 -0
- package/dist/downloaders/templates/PostInfo.js.map +1 -0
- package/dist/downloaders/templates/ProductInfo.d.ts +3 -0
- package/dist/downloaders/templates/ProductInfo.d.ts.map +1 -0
- package/dist/downloaders/templates/ProductInfo.js +20 -0
- package/dist/downloaders/templates/ProductInfo.js.map +1 -0
- package/dist/entities/Attachment.d.ts +7 -0
- package/dist/entities/Attachment.d.ts.map +1 -0
- package/dist/entities/Attachment.js +2 -0
- package/dist/entities/Attachment.js.map +1 -0
- package/dist/entities/Campaign.d.ts +19 -0
- package/dist/entities/Campaign.d.ts.map +1 -0
- package/dist/entities/Campaign.js +2 -0
- package/dist/entities/Campaign.js.map +1 -0
- package/dist/entities/Downloadable.d.ts +6 -0
- package/dist/entities/Downloadable.d.ts.map +1 -0
- package/dist/entities/Downloadable.js +5 -0
- package/dist/entities/Downloadable.js.map +1 -0
- package/dist/entities/MediaItem.d.ts +95 -0
- package/dist/entities/MediaItem.d.ts.map +1 -0
- package/dist/entities/MediaItem.js +2 -0
- package/dist/entities/MediaItem.js.map +1 -0
- package/dist/entities/Post.d.ts +87 -0
- package/dist/entities/Post.d.ts.map +1 -0
- package/dist/entities/Post.js +2 -0
- package/dist/entities/Post.js.map +1 -0
- package/dist/entities/Product.d.ts +17 -0
- package/dist/entities/Product.d.ts.map +1 -0
- package/dist/entities/Product.js +2 -0
- package/dist/entities/Product.js.map +1 -0
- package/dist/entities/Reward.d.ts +14 -0
- package/dist/entities/Reward.d.ts.map +1 -0
- package/dist/entities/Reward.js +2 -0
- package/dist/entities/Reward.js.map +1 -0
- package/dist/entities/User.d.ts +15 -0
- package/dist/entities/User.d.ts.map +1 -0
- package/dist/entities/User.js +2 -0
- package/dist/entities/User.js.map +1 -0
- package/dist/entities/index.d.ts +9 -0
- package/dist/entities/index.d.ts.map +1 -0
- package/dist/entities/index.js +6 -0
- package/dist/entities/index.js.map +1 -0
- package/dist/index.d.ts +8 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +8 -0
- package/dist/index.js.map +1 -0
- package/dist/parsers/PageParser.d.ts +6 -0
- package/dist/parsers/PageParser.d.ts.map +1 -0
- package/dist/parsers/PageParser.js +23 -0
- package/dist/parsers/PageParser.js.map +1 -0
- package/dist/parsers/Parser.d.ts +43 -0
- package/dist/parsers/Parser.d.ts.map +1 -0
- package/dist/parsers/Parser.js +439 -0
- package/dist/parsers/Parser.js.map +1 -0
- package/dist/parsers/PostParser.d.ts +7 -0
- package/dist/parsers/PostParser.d.ts.map +1 -0
- package/dist/parsers/PostParser.js +259 -0
- package/dist/parsers/PostParser.js.map +1 -0
- package/dist/parsers/ProductParser.d.ts +7 -0
- package/dist/parsers/ProductParser.d.ts.map +1 -0
- package/dist/parsers/ProductParser.js +70 -0
- package/dist/parsers/ProductParser.js.map +1 -0
- package/dist/utils/AttachmentFilenameResolver.d.ts +9 -0
- package/dist/utils/AttachmentFilenameResolver.d.ts.map +1 -0
- package/dist/utils/AttachmentFilenameResolver.js +73 -0
- package/dist/utils/AttachmentFilenameResolver.js.map +1 -0
- package/dist/utils/FSHelper.d.ts +57 -0
- package/dist/utils/FSHelper.d.ts.map +1 -0
- package/dist/utils/FSHelper.js +214 -0
- package/dist/utils/FSHelper.js.map +1 -0
- package/dist/utils/Fetcher.d.ts +45 -0
- package/dist/utils/Fetcher.d.ts.map +1 -0
- package/dist/utils/Fetcher.js +192 -0
- package/dist/utils/Fetcher.js.map +1 -0
- package/dist/utils/FetcherProgressMonitor.d.ts +18 -0
- package/dist/utils/FetcherProgressMonitor.d.ts.map +1 -0
- package/dist/utils/FetcherProgressMonitor.js +56 -0
- package/dist/utils/FetcherProgressMonitor.js.map +1 -0
- package/dist/utils/FilenameFormatHelper.d.ts +44 -0
- package/dist/utils/FilenameFormatHelper.d.ts.map +1 -0
- package/dist/utils/FilenameFormatHelper.js +98 -0
- package/dist/utils/FilenameFormatHelper.js.map +1 -0
- package/dist/utils/FllenameResolver.d.ts +20 -0
- package/dist/utils/FllenameResolver.d.ts.map +1 -0
- package/dist/utils/FllenameResolver.js +55 -0
- package/dist/utils/FllenameResolver.js.map +1 -0
- package/dist/utils/Formatter.d.ts +21 -0
- package/dist/utils/Formatter.d.ts.map +1 -0
- package/dist/utils/Formatter.js +112 -0
- package/dist/utils/Formatter.js.map +1 -0
- package/dist/utils/MediaFilenameResolver.d.ts +9 -0
- package/dist/utils/MediaFilenameResolver.d.ts.map +1 -0
- package/dist/utils/MediaFilenameResolver.js +90 -0
- package/dist/utils/MediaFilenameResolver.js.map +1 -0
- package/dist/utils/Misc.d.ts +14 -0
- package/dist/utils/Misc.d.ts.map +1 -0
- package/dist/utils/Misc.js +4 -0
- package/dist/utils/Misc.js.map +1 -0
- package/dist/utils/ObjectHelper.d.ts +4 -0
- package/dist/utils/ObjectHelper.d.ts.map +1 -0
- package/dist/utils/ObjectHelper.js +30 -0
- package/dist/utils/ObjectHelper.js.map +1 -0
- package/dist/utils/PackageInfo.d.ts +10 -0
- package/dist/utils/PackageInfo.d.ts.map +1 -0
- package/dist/utils/PackageInfo.js +33 -0
- package/dist/utils/PackageInfo.js.map +1 -0
- package/dist/utils/URLHelper.d.ts +40 -0
- package/dist/utils/URLHelper.d.ts.map +1 -0
- package/dist/utils/URLHelper.js +192 -0
- package/dist/utils/URLHelper.js.map +1 -0
- package/dist/utils/index.d.ts +2 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +2 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/logging/ChainLogger.d.ts +11 -0
- package/dist/utils/logging/ChainLogger.d.ts.map +1 -0
- package/dist/utils/logging/ChainLogger.js +50 -0
- package/dist/utils/logging/ChainLogger.js.map +1 -0
- package/dist/utils/logging/ConsoleLogger.d.ts +31 -0
- package/dist/utils/logging/ConsoleLogger.d.ts.map +1 -0
- package/dist/utils/logging/ConsoleLogger.js +126 -0
- package/dist/utils/logging/ConsoleLogger.js.map +1 -0
- package/dist/utils/logging/FileLogger.d.ts +26 -0
- package/dist/utils/logging/FileLogger.d.ts.map +1 -0
- package/dist/utils/logging/FileLogger.js +147 -0
- package/dist/utils/logging/FileLogger.js.map +1 -0
- package/dist/utils/logging/Logger.d.ts +12 -0
- package/dist/utils/logging/Logger.d.ts.map +1 -0
- package/dist/utils/logging/Logger.js +15 -0
- package/dist/utils/logging/Logger.js.map +1 -0
- package/dist/utils/logging/index.d.ts +7 -0
- package/dist/utils/logging/index.d.ts.map +1 -0
- package/dist/utils/logging/index.js +7 -0
- package/dist/utils/logging/index.js.map +1 -0
- package/package.json +78 -0
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
2
|
+
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
3
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
4
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
5
|
+
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
6
|
+
};
|
|
7
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
8
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
9
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
10
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
11
|
+
};
|
|
12
|
+
var _FileLogger_instances, _FileLogger_logDirNameFormat, _FileLogger_logFilenameFormat, _FileLogger_fileExistsAction, _FileLogger_stream, _FileLogger_firstRun, _FileLogger_init, _FileLogger_getStream;
|
|
13
|
+
import fs from 'fs';
|
|
14
|
+
import dateFormat from 'dateformat';
|
|
15
|
+
import sanitizeFilename from 'sanitize-filename';
|
|
16
|
+
import { pickDefined } from '../Misc.js';
|
|
17
|
+
import ConsoleLogger from './ConsoleLogger.js';
|
|
18
|
+
import Formatter from '../Formatter.js';
|
|
19
|
+
import path from 'path';
|
|
20
|
+
import FSHelper from '../FSHelper.js';
|
|
21
|
+
import { EOL } from 'os';
|
|
22
|
+
import { getDefaultDownloaderOutDir } from '../../downloaders/DownloaderOptions.js';
|
|
23
|
+
const DEFAULT_LOGGER_CONFIG = {
|
|
24
|
+
enabled: true,
|
|
25
|
+
logDir: '{out.dir}/logs/{target.url.path}',
|
|
26
|
+
logFilename: '{datetime.yyyymmdd}-{log.level}.log',
|
|
27
|
+
fileExistsAction: 'append',
|
|
28
|
+
logFilePath: '',
|
|
29
|
+
logLevel: 'info',
|
|
30
|
+
include: {
|
|
31
|
+
dateTime: true,
|
|
32
|
+
level: true,
|
|
33
|
+
originator: true,
|
|
34
|
+
errorStack: false
|
|
35
|
+
},
|
|
36
|
+
dateTimeFormat: 'mmm dd HH:MM:ss',
|
|
37
|
+
color: false
|
|
38
|
+
};
|
|
39
|
+
export default class FileLogger extends ConsoleLogger {
|
|
40
|
+
constructor(init, options) {
|
|
41
|
+
super(options);
|
|
42
|
+
_FileLogger_instances.add(this);
|
|
43
|
+
_FileLogger_logDirNameFormat.set(this, void 0);
|
|
44
|
+
_FileLogger_logFilenameFormat.set(this, void 0);
|
|
45
|
+
_FileLogger_fileExistsAction.set(this, void 0);
|
|
46
|
+
_FileLogger_stream.set(this, void 0);
|
|
47
|
+
_FileLogger_firstRun.set(this, void 0);
|
|
48
|
+
const defaultLogDir = DEFAULT_LOGGER_CONFIG.logDir.replaceAll('/', path.sep);
|
|
49
|
+
__classPrivateFieldSet(this, _FileLogger_logDirNameFormat, options?.logDir || defaultLogDir, "f");
|
|
50
|
+
__classPrivateFieldSet(this, _FileLogger_logFilenameFormat, options?.logFilename || DEFAULT_LOGGER_CONFIG.logFilename, "f");
|
|
51
|
+
__classPrivateFieldSet(this, _FileLogger_fileExistsAction, options?.fileExistsAction || DEFAULT_LOGGER_CONFIG.fileExistsAction, "f");
|
|
52
|
+
__classPrivateFieldSet(this, _FileLogger_stream, null, "f");
|
|
53
|
+
__classPrivateFieldSet(this, _FileLogger_firstRun, true, "f");
|
|
54
|
+
this.config.color = pickDefined(options?.color, DEFAULT_LOGGER_CONFIG.color);
|
|
55
|
+
__classPrivateFieldGet(this, _FileLogger_instances, "m", _FileLogger_init).call(this, init);
|
|
56
|
+
}
|
|
57
|
+
getConfig() {
|
|
58
|
+
return this.config;
|
|
59
|
+
}
|
|
60
|
+
toOutput(_level, msg) {
|
|
61
|
+
const stream = __classPrivateFieldGet(this, _FileLogger_instances, "m", _FileLogger_getStream).call(this);
|
|
62
|
+
stream.write(msg.join(' '));
|
|
63
|
+
stream.write(EOL);
|
|
64
|
+
}
|
|
65
|
+
end() {
|
|
66
|
+
return new Promise((resolve) => {
|
|
67
|
+
if (__classPrivateFieldGet(this, _FileLogger_stream, "f")) {
|
|
68
|
+
__classPrivateFieldGet(this, _FileLogger_stream, "f").once('finish', () => {
|
|
69
|
+
__classPrivateFieldSet(this, _FileLogger_stream, null, "f");
|
|
70
|
+
resolve();
|
|
71
|
+
});
|
|
72
|
+
__classPrivateFieldGet(this, _FileLogger_stream, "f").end();
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
resolve();
|
|
76
|
+
}
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
_FileLogger_logDirNameFormat = new WeakMap(), _FileLogger_logFilenameFormat = new WeakMap(), _FileLogger_fileExistsAction = new WeakMap(), _FileLogger_stream = new WeakMap(), _FileLogger_firstRun = new WeakMap(), _FileLogger_instances = new WeakSet(), _FileLogger_init = function _FileLogger_init(data) {
|
|
81
|
+
const date = data.date || new Date();
|
|
82
|
+
const __getDateTimeFieldValues = (format, addTo) => {
|
|
83
|
+
const dateTimeRegex = /{(datetime\.(.+?))}/g;
|
|
84
|
+
const dateTimeFields = [];
|
|
85
|
+
let m;
|
|
86
|
+
while ((m = dateTimeRegex.exec(format)) !== null) {
|
|
87
|
+
dateTimeFields.push({
|
|
88
|
+
name: m[1],
|
|
89
|
+
pattern: m[2]
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
return dateTimeFields.reduce((result, field) => {
|
|
93
|
+
if (!result[field.name]) {
|
|
94
|
+
result[field.name] = dateFormat(date, field.pattern);
|
|
95
|
+
}
|
|
96
|
+
return result;
|
|
97
|
+
}, addTo);
|
|
98
|
+
};
|
|
99
|
+
// Prepare variables for generating log dir and filenames
|
|
100
|
+
let urlPath = new URL(data.targetURL).pathname.trim();
|
|
101
|
+
while (urlPath.startsWith('/')) {
|
|
102
|
+
urlPath = urlPath.slice(1);
|
|
103
|
+
}
|
|
104
|
+
while (urlPath.endsWith('/')) {
|
|
105
|
+
urlPath = urlPath.slice(0, urlPath.length - 1);
|
|
106
|
+
}
|
|
107
|
+
urlPath = sanitizeFilename(urlPath.replaceAll('/', '_'));
|
|
108
|
+
const logDirDTValues = __getDateTimeFieldValues(__classPrivateFieldGet(this, _FileLogger_logDirNameFormat, "f"), {});
|
|
109
|
+
const allDTValues = __getDateTimeFieldValues(__classPrivateFieldGet(this, _FileLogger_logFilenameFormat, "f"), logDirDTValues);
|
|
110
|
+
// Pass to Formatter and get log dir and filename
|
|
111
|
+
const logDirDict = {
|
|
112
|
+
'out.dir': data.outDir || getDefaultDownloaderOutDir(),
|
|
113
|
+
'target.url.path': urlPath,
|
|
114
|
+
...allDTValues
|
|
115
|
+
};
|
|
116
|
+
const logFilenameDict = {
|
|
117
|
+
'target.url.path': urlPath,
|
|
118
|
+
'log.level': this.config.logLevel,
|
|
119
|
+
...allDTValues
|
|
120
|
+
};
|
|
121
|
+
this.config.logDir = FSHelper.sanitizeFilePath(Formatter.format(__classPrivateFieldGet(this, _FileLogger_logDirNameFormat, "f"), logDirDict).result);
|
|
122
|
+
this.config.logFilename = sanitizeFilename(Formatter.format(__classPrivateFieldGet(this, _FileLogger_logFilenameFormat, "f"), logFilenameDict).result);
|
|
123
|
+
this.config.logFilePath = path.resolve(this.config.logDir, this.config.logFilename);
|
|
124
|
+
this.config.created = date;
|
|
125
|
+
}, _FileLogger_getStream = function _FileLogger_getStream() {
|
|
126
|
+
if (__classPrivateFieldGet(this, _FileLogger_stream, "f")) {
|
|
127
|
+
return __classPrivateFieldGet(this, _FileLogger_stream, "f");
|
|
128
|
+
}
|
|
129
|
+
// Ensure log directory exists
|
|
130
|
+
FSHelper.createDir(this.config.logDir);
|
|
131
|
+
// Create write stream
|
|
132
|
+
let flags;
|
|
133
|
+
if (fs.existsSync(this.config.logFilePath) && (!__classPrivateFieldGet(this, _FileLogger_firstRun, "f") || __classPrivateFieldGet(this, _FileLogger_fileExistsAction, "f") === 'append')) {
|
|
134
|
+
flags = 'a';
|
|
135
|
+
}
|
|
136
|
+
else {
|
|
137
|
+
flags = 'w';
|
|
138
|
+
}
|
|
139
|
+
__classPrivateFieldSet(this, _FileLogger_stream, fs.createWriteStream(this.config.logFilePath, { flags, encoding: 'utf-8', autoClose: false }), "f");
|
|
140
|
+
if (__classPrivateFieldGet(this, _FileLogger_firstRun, "f")) {
|
|
141
|
+
const initDateTimeStr = dateFormat(this.config.created, 'mmm dd yyyy HH:MM:ss').toUpperCase();
|
|
142
|
+
__classPrivateFieldGet(this, _FileLogger_stream, "f").write(`${EOL}*************** LOG BEGIN ${initDateTimeStr} ***************${EOL}`);
|
|
143
|
+
__classPrivateFieldSet(this, _FileLogger_firstRun, false, "f");
|
|
144
|
+
}
|
|
145
|
+
return __classPrivateFieldGet(this, _FileLogger_stream, "f");
|
|
146
|
+
};
|
|
147
|
+
//# sourceMappingURL=FileLogger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FileLogger.js","sourceRoot":"","sources":["../../../src/utils/logging/FileLogger.ts"],"names":[],"mappings":"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","sourcesContent":["import fs from 'fs';\nimport dateFormat from 'dateformat';\nimport sanitizeFilename from 'sanitize-filename';\nimport { LogLevel } from '../../utils/logging/Logger.js';\nimport { DeepRequired, pickDefined } from '../Misc.js';\nimport ConsoleLogger, { ConsoleLoggerOptions } from './ConsoleLogger.js';\nimport Formatter from '../Formatter.js';\nimport path from 'path';\nimport FSHelper from '../FSHelper.js';\nimport { EOL } from 'os';\nimport { getDefaultDownloaderOutDir } from '../../downloaders/DownloaderOptions.js';\n\nexport interface FileLoggerOptions extends ConsoleLoggerOptions {\n logDir?: string;\n logFilename?: string;\n fileExistsAction?: 'append' | 'overwrite';\n}\n\nexport interface FileLoggerConfig extends DeepRequired<FileLoggerOptions> {\n logFilePath: string;\n created: Date;\n}\n\nconst DEFAULT_LOGGER_CONFIG: Omit<FileLoggerConfig, 'created'> = {\n enabled: true,\n logDir: '{out.dir}/logs/{target.url.path}',\n logFilename: '{datetime.yyyymmdd}-{log.level}.log',\n fileExistsAction: 'append',\n logFilePath: '',\n logLevel: 'info',\n include: {\n dateTime: true,\n level: true,\n originator: true,\n errorStack: false\n },\n dateTimeFormat: 'mmm dd HH:MM:ss',\n color: false\n};\n\nexport interface FileLoggerInit {\n targetURL: string;\n outDir?: string;\n date?: Date;\n}\n\nexport default class FileLogger extends ConsoleLogger {\n\n protected config: FileLoggerConfig;\n #logDirNameFormat: string;\n #logFilenameFormat: string;\n #fileExistsAction: FileLoggerConfig['fileExistsAction'];\n #stream: fs.WriteStream | null;\n #firstRun: boolean;\n\n constructor(init: FileLoggerInit, options?: FileLoggerOptions) {\n super(options);\n const defaultLogDir = DEFAULT_LOGGER_CONFIG.logDir.replaceAll('/', path.sep);\n this.#logDirNameFormat = options?.logDir || defaultLogDir;\n this.#logFilenameFormat = options?.logFilename || DEFAULT_LOGGER_CONFIG.logFilename;\n this.#fileExistsAction = options?.fileExistsAction || DEFAULT_LOGGER_CONFIG.fileExistsAction;\n this.#stream = null;\n this.#firstRun = true;\n this.config.color = pickDefined(options?.color, DEFAULT_LOGGER_CONFIG.color);\n this.#init(init);\n }\n\n #init(data: FileLoggerInit) {\n const date = data.date || new Date();\n\n const __getDateTimeFieldValues = (format: string, addTo: Record<string, string>) => {\n const dateTimeRegex = /{(datetime\\.(.+?))}/g;\n const dateTimeFields: { name: string; pattern: string; }[] = [];\n let m;\n while ((m = dateTimeRegex.exec(format)) !== null) {\n dateTimeFields.push({\n name: m[1],\n pattern: m[2]\n });\n }\n return dateTimeFields.reduce<Record<string, string>>((result, field) => {\n if (!result[field.name]) {\n result[field.name] = dateFormat(date, field.pattern);\n }\n return result;\n }, addTo);\n };\n\n // Prepare variables for generating log dir and filenames\n let urlPath = new URL(data.targetURL).pathname.trim();\n while (urlPath.startsWith('/')) {\n urlPath = urlPath.slice(1);\n }\n while (urlPath.endsWith('/')) {\n urlPath = urlPath.slice(0, urlPath.length - 1);\n }\n urlPath = sanitizeFilename(urlPath.replaceAll('/', '_'));\n\n const logDirDTValues = __getDateTimeFieldValues(this.#logDirNameFormat, {});\n const allDTValues = __getDateTimeFieldValues(this.#logFilenameFormat, logDirDTValues);\n\n // Pass to Formatter and get log dir and filename\n const logDirDict = {\n 'out.dir': data.outDir || getDefaultDownloaderOutDir(),\n 'target.url.path': urlPath,\n ...allDTValues\n };\n\n const logFilenameDict = {\n 'target.url.path': urlPath,\n 'log.level': this.config.logLevel,\n ...allDTValues\n };\n\n this.config.logDir = FSHelper.sanitizeFilePath(Formatter.format(this.#logDirNameFormat, logDirDict).result);\n this.config.logFilename = sanitizeFilename(Formatter.format(this.#logFilenameFormat, logFilenameDict).result);\n this.config.logFilePath = path.resolve(this.config.logDir, this.config.logFilename);\n this.config.created = date;\n }\n\n #getStream() {\n if (this.#stream) {\n return this.#stream;\n }\n // Ensure log directory exists\n FSHelper.createDir(this.config.logDir);\n\n // Create write stream\n let flags: 'a' | 'w';\n if (fs.existsSync(this.config.logFilePath) && (!this.#firstRun || this.#fileExistsAction === 'append')) {\n flags = 'a';\n }\n else {\n flags = 'w';\n }\n this.#stream = fs.createWriteStream(this.config.logFilePath, { flags, encoding: 'utf-8', autoClose: false });\n if (this.#firstRun) {\n const initDateTimeStr = dateFormat(this.config.created, 'mmm dd yyyy HH:MM:ss').toUpperCase();\n this.#stream.write(`${EOL}*************** LOG BEGIN ${initDateTimeStr} ***************${EOL}`);\n this.#firstRun = false;\n }\n return this.#stream;\n }\n\n getConfig() {\n return this.config;\n }\n\n protected toOutput(_level: LogLevel, msg: string[]) {\n const stream = this.#getStream();\n stream.write(msg.join(' '));\n stream.write(EOL);\n }\n\n end(): Promise<void> {\n return new Promise((resolve) => {\n if (this.#stream) {\n this.#stream.once('finish', () => {\n this.#stream = null;\n resolve();\n });\n this.#stream.end();\n }\n else {\n resolve();\n }\n });\n }\n}\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export type LogLevel = 'info' | 'debug' | 'warn' | 'error';
|
|
2
|
+
export interface LogEntry {
|
|
3
|
+
level: LogLevel;
|
|
4
|
+
originator?: string;
|
|
5
|
+
message: any[];
|
|
6
|
+
}
|
|
7
|
+
export default abstract class Logger {
|
|
8
|
+
abstract log(entry: LogEntry): void;
|
|
9
|
+
end(): Promise<void>;
|
|
10
|
+
}
|
|
11
|
+
export declare function commonLog(logger: Logger | null | undefined, level: LogLevel, originator: string | null | undefined, ...message: any[]): void;
|
|
12
|
+
//# sourceMappingURL=Logger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Logger.d.ts","sourceRoot":"","sources":["../../../src/utils/logging/Logger.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,QAAQ,GAAG,MAAM,GAAG,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC;AAE3D,MAAM,WAAW,QAAQ;IACvB,KAAK,EAAE,QAAQ,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,EAAE,GAAG,EAAE,CAAA;CACf;AAED,MAAM,CAAC,OAAO,CAAC,QAAQ,OAAO,MAAM;IAClC,QAAQ,CAAC,GAAG,CAAC,KAAK,EAAE,QAAQ,GAAG,IAAI;IAEnC,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CAGrB;AAED,wBAAgB,SAAS,CACvB,MAAM,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,EACjC,KAAK,EAAE,QAAQ,EACf,UAAU,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,EACrC,GAAG,OAAO,EAAE,GAAG,EAAE,QASlB"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export default class Logger {
|
|
2
|
+
end() {
|
|
3
|
+
return Promise.resolve();
|
|
4
|
+
}
|
|
5
|
+
}
|
|
6
|
+
export function commonLog(logger, level, originator, ...message) {
|
|
7
|
+
if (logger) {
|
|
8
|
+
logger.log({
|
|
9
|
+
level,
|
|
10
|
+
originator: originator || undefined,
|
|
11
|
+
message
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=Logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Logger.js","sourceRoot":"","sources":["../../../src/utils/logging/Logger.ts"],"names":[],"mappings":"AAQA,MAAM,CAAC,OAAO,OAAgB,MAAM;IAGlC,GAAG;QACD,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;IAC3B,CAAC;CACF;AAED,MAAM,UAAU,SAAS,CACvB,MAAiC,EACjC,KAAe,EACf,UAAqC,EACrC,GAAG,OAAc;IAEjB,IAAI,MAAM,EAAE;QACV,MAAM,CAAC,GAAG,CAAC;YACT,KAAK;YACL,UAAU,EAAE,UAAU,IAAI,SAAS;YACnC,OAAO;SACR,CAAC,CAAC;KACJ;AACH,CAAC","sourcesContent":["export type LogLevel = 'info' | 'debug' | 'warn' | 'error';\n\nexport interface LogEntry {\n level: LogLevel,\n originator?: string,\n message: any[]\n}\n\nexport default abstract class Logger {\n abstract log(entry: LogEntry): void;\n\n end(): Promise<void> {\n return Promise.resolve();\n }\n}\n\nexport function commonLog(\n logger: Logger | null | undefined,\n level: LogLevel,\n originator: string | null | undefined,\n ...message: any[]) {\n\n if (logger) {\n logger.log({\n level,\n originator: originator || undefined,\n message\n });\n }\n}\n"]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export { default as ChainLogger } from './ChainLogger.js';
|
|
2
|
+
export { default as ConsoleLogger } from './ConsoleLogger.js';
|
|
3
|
+
export { default as FileLogger } from './FileLogger.js';
|
|
4
|
+
export { default as Logger, LogLevel, LogEntry } from './Logger.js';
|
|
5
|
+
export * from './ConsoleLogger.js';
|
|
6
|
+
export * from './FileLogger.js';
|
|
7
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/utils/logging/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC1D,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAC9D,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,iBAAiB,CAAC;AACxD,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEpE,cAAc,oBAAoB,CAAC;AACnC,cAAc,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export { default as ChainLogger } from './ChainLogger.js';
|
|
2
|
+
export { default as ConsoleLogger } from './ConsoleLogger.js';
|
|
3
|
+
export { default as FileLogger } from './FileLogger.js';
|
|
4
|
+
export { default as Logger } from './Logger.js';
|
|
5
|
+
export * from './ConsoleLogger.js';
|
|
6
|
+
export * from './FileLogger.js';
|
|
7
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utils/logging/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC1D,OAAO,EAAE,OAAO,IAAI,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAC9D,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,iBAAiB,CAAC;AACxD,OAAO,EAAE,OAAO,IAAI,MAAM,EAAsB,MAAM,aAAa,CAAC;AAEpE,cAAc,oBAAoB,CAAC;AACnC,cAAc,iBAAiB,CAAC","sourcesContent":["export { default as ChainLogger } from './ChainLogger.js';\nexport { default as ConsoleLogger } from './ConsoleLogger.js';\nexport { default as FileLogger } from './FileLogger.js';\nexport { default as Logger, LogLevel, LogEntry } from './Logger.js';\n\nexport * from './ConsoleLogger.js';\nexport * from './FileLogger.js';\n"]}
|
package/package.json
ADDED
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "patreon-dl",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"description": "Patreon Downloader",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"exports": "./dist/index.js",
|
|
7
|
+
"types": "./dist/index.d.ts",
|
|
8
|
+
"scripts": {
|
|
9
|
+
"build": "rm -rf dist && npx tsc -p tsconfig.json",
|
|
10
|
+
"lint": "npx eslint ./src",
|
|
11
|
+
"lint:fix": "npx eslint ./src --fix",
|
|
12
|
+
"doc": "npx typedoc"
|
|
13
|
+
},
|
|
14
|
+
"bin": {
|
|
15
|
+
"patreon-dl": "./bin/patreon-dl.js"
|
|
16
|
+
},
|
|
17
|
+
"author": "Patrick Kan <patrickkfkan@gmail.com> (https://github.com/patrickkfkan)",
|
|
18
|
+
"repository": {
|
|
19
|
+
"type": "git",
|
|
20
|
+
"url": "https://github.com/patrickkfkan/patreon-dl.git"
|
|
21
|
+
},
|
|
22
|
+
"license": "MIT",
|
|
23
|
+
"directories": {
|
|
24
|
+
"dist": "./dist"
|
|
25
|
+
},
|
|
26
|
+
"engines": {
|
|
27
|
+
"node": ">=16.16.0"
|
|
28
|
+
},
|
|
29
|
+
"devDependencies": {
|
|
30
|
+
"@types/capitalize": "^2.0.2",
|
|
31
|
+
"@types/cli-color": "^2.0.5",
|
|
32
|
+
"@types/command-line-args": "^5.2.2",
|
|
33
|
+
"@types/command-line-usage": "^5.0.4",
|
|
34
|
+
"@types/content-disposition": "^0.5.7",
|
|
35
|
+
"@types/dateformat": "^5.0.2",
|
|
36
|
+
"@types/deep-freeze": "^0.1.5",
|
|
37
|
+
"@types/fluent-ffmpeg": "^2.1.24",
|
|
38
|
+
"@types/fs-extra": "^9.0.0",
|
|
39
|
+
"@types/mime-types": "^2.1.3",
|
|
40
|
+
"@types/node": "^16.18.62",
|
|
41
|
+
"@types/progress-stream": "^2.0.3",
|
|
42
|
+
"@types/prompt-sync": "^4.2.3",
|
|
43
|
+
"@typescript-eslint/eslint-plugin": "^5.56.0",
|
|
44
|
+
"@typescript-eslint/parser": "^5.56.0",
|
|
45
|
+
"eslint": "^8.36.0",
|
|
46
|
+
"typedoc": "^0.25.3",
|
|
47
|
+
"typedoc-plugin-markdown": "^3.17.1",
|
|
48
|
+
"typedoc-plugin-rename-defaults": "^0.7.0",
|
|
49
|
+
"typescript": "^4.9.5"
|
|
50
|
+
},
|
|
51
|
+
"dependencies": {
|
|
52
|
+
"bottleneck": "^2.19.5",
|
|
53
|
+
"capitalize": "^2.0.4",
|
|
54
|
+
"cli-color": "^2.0.3",
|
|
55
|
+
"command-line-args": "^5.2.1",
|
|
56
|
+
"command-line-usage": "^7.0.1",
|
|
57
|
+
"configparser": "^0.3.10",
|
|
58
|
+
"content-disposition": "^0.5.4",
|
|
59
|
+
"dateformat": "^5.0.3",
|
|
60
|
+
"deep-freeze": "^0.0.1",
|
|
61
|
+
"escape-string-regexp": "^5.0.0",
|
|
62
|
+
"fluent-ffmpeg": "^2.1.2",
|
|
63
|
+
"fs-extra": "^9.1.0",
|
|
64
|
+
"hasha": "^5.2.2",
|
|
65
|
+
"make-dir": "^4.0.0",
|
|
66
|
+
"mime-types": "^2.1.35",
|
|
67
|
+
"node-fetch": "^3.3.2",
|
|
68
|
+
"progress-stream": "^2.0.0",
|
|
69
|
+
"prompt-sync": "^4.2.0",
|
|
70
|
+
"sanitize-filename": "^1.6.3",
|
|
71
|
+
"semver": "^7.5.4"
|
|
72
|
+
},
|
|
73
|
+
"keywords": [
|
|
74
|
+
"patreon",
|
|
75
|
+
"download",
|
|
76
|
+
"downloader"
|
|
77
|
+
]
|
|
78
|
+
}
|