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.
Files changed (223) hide show
  1. package/README.md +422 -0
  2. package/bin/patreon-dl.js +5 -0
  3. package/dist/cli/CLIOptionValidator.d.ts +9 -0
  4. package/dist/cli/CLIOptionValidator.d.ts.map +1 -0
  5. package/dist/cli/CLIOptionValidator.js +85 -0
  6. package/dist/cli/CLIOptionValidator.js.map +1 -0
  7. package/dist/cli/CLIOptions.d.ts +20 -0
  8. package/dist/cli/CLIOptions.d.ts.map +1 -0
  9. package/dist/cli/CLIOptions.js +75 -0
  10. package/dist/cli/CLIOptions.js.map +1 -0
  11. package/dist/cli/CommandLineParser.d.ts +11 -0
  12. package/dist/cli/CommandLineParser.d.ts.map +1 -0
  13. package/dist/cli/CommandLineParser.js +212 -0
  14. package/dist/cli/CommandLineParser.js.map +1 -0
  15. package/dist/cli/ConfigFileParser.d.ts +9 -0
  16. package/dist/cli/ConfigFileParser.d.ts.map +1 -0
  17. package/dist/cli/ConfigFileParser.js +163 -0
  18. package/dist/cli/ConfigFileParser.js.map +1 -0
  19. package/dist/cli/index.d.ts +7 -0
  20. package/dist/cli/index.d.ts.map +1 -0
  21. package/dist/cli/index.js +162 -0
  22. package/dist/cli/index.js.map +1 -0
  23. package/dist/downloaders/Bootstrap.d.ts +29 -0
  24. package/dist/downloaders/Bootstrap.d.ts.map +1 -0
  25. package/dist/downloaders/Bootstrap.js +51 -0
  26. package/dist/downloaders/Bootstrap.js.map +1 -0
  27. package/dist/downloaders/Downloader.d.ts +59 -0
  28. package/dist/downloaders/Downloader.d.ts.map +1 -0
  29. package/dist/downloaders/Downloader.js +357 -0
  30. package/dist/downloaders/Downloader.js.map +1 -0
  31. package/dist/downloaders/DownloaderEvent.d.ts +47 -0
  32. package/dist/downloaders/DownloaderEvent.d.ts.map +1 -0
  33. package/dist/downloaders/DownloaderEvent.js +6 -0
  34. package/dist/downloaders/DownloaderEvent.js.map +1 -0
  35. package/dist/downloaders/DownloaderOptions.d.ts +39 -0
  36. package/dist/downloaders/DownloaderOptions.d.ts.map +1 -0
  37. package/dist/downloaders/DownloaderOptions.js +69 -0
  38. package/dist/downloaders/DownloaderOptions.js.map +1 -0
  39. package/dist/downloaders/PostDownloader.d.ts +8 -0
  40. package/dist/downloaders/PostDownloader.d.ts.map +1 -0
  41. package/dist/downloaders/PostDownloader.js +428 -0
  42. package/dist/downloaders/PostDownloader.js.map +1 -0
  43. package/dist/downloaders/ProductDownloader.d.ts +8 -0
  44. package/dist/downloaders/ProductDownloader.d.ts.map +1 -0
  45. package/dist/downloaders/ProductDownloader.js +171 -0
  46. package/dist/downloaders/ProductDownloader.js.map +1 -0
  47. package/dist/downloaders/cache/StatusCache.d.ts +43 -0
  48. package/dist/downloaders/cache/StatusCache.d.ts.map +1 -0
  49. package/dist/downloaders/cache/StatusCache.js +206 -0
  50. package/dist/downloaders/cache/StatusCache.js.map +1 -0
  51. package/dist/downloaders/index.d.ts +7 -0
  52. package/dist/downloaders/index.d.ts.map +1 -0
  53. package/dist/downloaders/index.js +6 -0
  54. package/dist/downloaders/index.js.map +1 -0
  55. package/dist/downloaders/task/DownloadTask.d.ts +89 -0
  56. package/dist/downloaders/task/DownloadTask.d.ts.map +1 -0
  57. package/dist/downloaders/task/DownloadTask.js +240 -0
  58. package/dist/downloaders/task/DownloadTask.js.map +1 -0
  59. package/dist/downloaders/task/DownloadTaskBatch.d.ts +45 -0
  60. package/dist/downloaders/task/DownloadTaskBatch.d.ts.map +1 -0
  61. package/dist/downloaders/task/DownloadTaskBatch.js +195 -0
  62. package/dist/downloaders/task/DownloadTaskBatch.js.map +1 -0
  63. package/dist/downloaders/task/DownloadTaskBatchEvent.d.ts +32 -0
  64. package/dist/downloaders/task/DownloadTaskBatchEvent.d.ts.map +1 -0
  65. package/dist/downloaders/task/DownloadTaskBatchEvent.js +2 -0
  66. package/dist/downloaders/task/DownloadTaskBatchEvent.js.map +1 -0
  67. package/dist/downloaders/task/DownloadTaskFactory.d.ts +20 -0
  68. package/dist/downloaders/task/DownloadTaskFactory.d.ts.map +1 -0
  69. package/dist/downloaders/task/DownloadTaskFactory.js +177 -0
  70. package/dist/downloaders/task/DownloadTaskFactory.js.map +1 -0
  71. package/dist/downloaders/task/FFmpegDownloadTask.d.ts +27 -0
  72. package/dist/downloaders/task/FFmpegDownloadTask.d.ts.map +1 -0
  73. package/dist/downloaders/task/FFmpegDownloadTask.js +206 -0
  74. package/dist/downloaders/task/FFmpegDownloadTask.js.map +1 -0
  75. package/dist/downloaders/task/FetcherDownloadTask.d.ts +21 -0
  76. package/dist/downloaders/task/FetcherDownloadTask.d.ts.map +1 -0
  77. package/dist/downloaders/task/FetcherDownloadTask.js +213 -0
  78. package/dist/downloaders/task/FetcherDownloadTask.js.map +1 -0
  79. package/dist/downloaders/task/index.d.ts +4 -0
  80. package/dist/downloaders/task/index.d.ts.map +1 -0
  81. package/dist/downloaders/task/index.js +3 -0
  82. package/dist/downloaders/task/index.js.map +1 -0
  83. package/dist/downloaders/templates/CampaignInfo.d.ts +3 -0
  84. package/dist/downloaders/templates/CampaignInfo.d.ts.map +1 -0
  85. package/dist/downloaders/templates/CampaignInfo.js +58 -0
  86. package/dist/downloaders/templates/CampaignInfo.js.map +1 -0
  87. package/dist/downloaders/templates/PostInfo.d.ts +4 -0
  88. package/dist/downloaders/templates/PostInfo.d.ts.map +1 -0
  89. package/dist/downloaders/templates/PostInfo.js +45 -0
  90. package/dist/downloaders/templates/PostInfo.js.map +1 -0
  91. package/dist/downloaders/templates/ProductInfo.d.ts +3 -0
  92. package/dist/downloaders/templates/ProductInfo.d.ts.map +1 -0
  93. package/dist/downloaders/templates/ProductInfo.js +20 -0
  94. package/dist/downloaders/templates/ProductInfo.js.map +1 -0
  95. package/dist/entities/Attachment.d.ts +7 -0
  96. package/dist/entities/Attachment.d.ts.map +1 -0
  97. package/dist/entities/Attachment.js +2 -0
  98. package/dist/entities/Attachment.js.map +1 -0
  99. package/dist/entities/Campaign.d.ts +19 -0
  100. package/dist/entities/Campaign.d.ts.map +1 -0
  101. package/dist/entities/Campaign.js +2 -0
  102. package/dist/entities/Campaign.js.map +1 -0
  103. package/dist/entities/Downloadable.d.ts +6 -0
  104. package/dist/entities/Downloadable.d.ts.map +1 -0
  105. package/dist/entities/Downloadable.js +5 -0
  106. package/dist/entities/Downloadable.js.map +1 -0
  107. package/dist/entities/MediaItem.d.ts +95 -0
  108. package/dist/entities/MediaItem.d.ts.map +1 -0
  109. package/dist/entities/MediaItem.js +2 -0
  110. package/dist/entities/MediaItem.js.map +1 -0
  111. package/dist/entities/Post.d.ts +87 -0
  112. package/dist/entities/Post.d.ts.map +1 -0
  113. package/dist/entities/Post.js +2 -0
  114. package/dist/entities/Post.js.map +1 -0
  115. package/dist/entities/Product.d.ts +17 -0
  116. package/dist/entities/Product.d.ts.map +1 -0
  117. package/dist/entities/Product.js +2 -0
  118. package/dist/entities/Product.js.map +1 -0
  119. package/dist/entities/Reward.d.ts +14 -0
  120. package/dist/entities/Reward.d.ts.map +1 -0
  121. package/dist/entities/Reward.js +2 -0
  122. package/dist/entities/Reward.js.map +1 -0
  123. package/dist/entities/User.d.ts +15 -0
  124. package/dist/entities/User.d.ts.map +1 -0
  125. package/dist/entities/User.js +2 -0
  126. package/dist/entities/User.js.map +1 -0
  127. package/dist/entities/index.d.ts +9 -0
  128. package/dist/entities/index.d.ts.map +1 -0
  129. package/dist/entities/index.js +6 -0
  130. package/dist/entities/index.js.map +1 -0
  131. package/dist/index.d.ts +8 -0
  132. package/dist/index.d.ts.map +1 -0
  133. package/dist/index.js +8 -0
  134. package/dist/index.js.map +1 -0
  135. package/dist/parsers/PageParser.d.ts +6 -0
  136. package/dist/parsers/PageParser.d.ts.map +1 -0
  137. package/dist/parsers/PageParser.js +23 -0
  138. package/dist/parsers/PageParser.js.map +1 -0
  139. package/dist/parsers/Parser.d.ts +43 -0
  140. package/dist/parsers/Parser.d.ts.map +1 -0
  141. package/dist/parsers/Parser.js +439 -0
  142. package/dist/parsers/Parser.js.map +1 -0
  143. package/dist/parsers/PostParser.d.ts +7 -0
  144. package/dist/parsers/PostParser.d.ts.map +1 -0
  145. package/dist/parsers/PostParser.js +259 -0
  146. package/dist/parsers/PostParser.js.map +1 -0
  147. package/dist/parsers/ProductParser.d.ts +7 -0
  148. package/dist/parsers/ProductParser.d.ts.map +1 -0
  149. package/dist/parsers/ProductParser.js +70 -0
  150. package/dist/parsers/ProductParser.js.map +1 -0
  151. package/dist/utils/AttachmentFilenameResolver.d.ts +9 -0
  152. package/dist/utils/AttachmentFilenameResolver.d.ts.map +1 -0
  153. package/dist/utils/AttachmentFilenameResolver.js +73 -0
  154. package/dist/utils/AttachmentFilenameResolver.js.map +1 -0
  155. package/dist/utils/FSHelper.d.ts +57 -0
  156. package/dist/utils/FSHelper.d.ts.map +1 -0
  157. package/dist/utils/FSHelper.js +214 -0
  158. package/dist/utils/FSHelper.js.map +1 -0
  159. package/dist/utils/Fetcher.d.ts +45 -0
  160. package/dist/utils/Fetcher.d.ts.map +1 -0
  161. package/dist/utils/Fetcher.js +192 -0
  162. package/dist/utils/Fetcher.js.map +1 -0
  163. package/dist/utils/FetcherProgressMonitor.d.ts +18 -0
  164. package/dist/utils/FetcherProgressMonitor.d.ts.map +1 -0
  165. package/dist/utils/FetcherProgressMonitor.js +56 -0
  166. package/dist/utils/FetcherProgressMonitor.js.map +1 -0
  167. package/dist/utils/FilenameFormatHelper.d.ts +44 -0
  168. package/dist/utils/FilenameFormatHelper.d.ts.map +1 -0
  169. package/dist/utils/FilenameFormatHelper.js +98 -0
  170. package/dist/utils/FilenameFormatHelper.js.map +1 -0
  171. package/dist/utils/FllenameResolver.d.ts +20 -0
  172. package/dist/utils/FllenameResolver.d.ts.map +1 -0
  173. package/dist/utils/FllenameResolver.js +55 -0
  174. package/dist/utils/FllenameResolver.js.map +1 -0
  175. package/dist/utils/Formatter.d.ts +21 -0
  176. package/dist/utils/Formatter.d.ts.map +1 -0
  177. package/dist/utils/Formatter.js +112 -0
  178. package/dist/utils/Formatter.js.map +1 -0
  179. package/dist/utils/MediaFilenameResolver.d.ts +9 -0
  180. package/dist/utils/MediaFilenameResolver.d.ts.map +1 -0
  181. package/dist/utils/MediaFilenameResolver.js +90 -0
  182. package/dist/utils/MediaFilenameResolver.js.map +1 -0
  183. package/dist/utils/Misc.d.ts +14 -0
  184. package/dist/utils/Misc.d.ts.map +1 -0
  185. package/dist/utils/Misc.js +4 -0
  186. package/dist/utils/Misc.js.map +1 -0
  187. package/dist/utils/ObjectHelper.d.ts +4 -0
  188. package/dist/utils/ObjectHelper.d.ts.map +1 -0
  189. package/dist/utils/ObjectHelper.js +30 -0
  190. package/dist/utils/ObjectHelper.js.map +1 -0
  191. package/dist/utils/PackageInfo.d.ts +10 -0
  192. package/dist/utils/PackageInfo.d.ts.map +1 -0
  193. package/dist/utils/PackageInfo.js +33 -0
  194. package/dist/utils/PackageInfo.js.map +1 -0
  195. package/dist/utils/URLHelper.d.ts +40 -0
  196. package/dist/utils/URLHelper.d.ts.map +1 -0
  197. package/dist/utils/URLHelper.js +192 -0
  198. package/dist/utils/URLHelper.js.map +1 -0
  199. package/dist/utils/index.d.ts +2 -0
  200. package/dist/utils/index.d.ts.map +1 -0
  201. package/dist/utils/index.js +2 -0
  202. package/dist/utils/index.js.map +1 -0
  203. package/dist/utils/logging/ChainLogger.d.ts +11 -0
  204. package/dist/utils/logging/ChainLogger.d.ts.map +1 -0
  205. package/dist/utils/logging/ChainLogger.js +50 -0
  206. package/dist/utils/logging/ChainLogger.js.map +1 -0
  207. package/dist/utils/logging/ConsoleLogger.d.ts +31 -0
  208. package/dist/utils/logging/ConsoleLogger.d.ts.map +1 -0
  209. package/dist/utils/logging/ConsoleLogger.js +126 -0
  210. package/dist/utils/logging/ConsoleLogger.js.map +1 -0
  211. package/dist/utils/logging/FileLogger.d.ts +26 -0
  212. package/dist/utils/logging/FileLogger.d.ts.map +1 -0
  213. package/dist/utils/logging/FileLogger.js +147 -0
  214. package/dist/utils/logging/FileLogger.js.map +1 -0
  215. package/dist/utils/logging/Logger.d.ts +12 -0
  216. package/dist/utils/logging/Logger.d.ts.map +1 -0
  217. package/dist/utils/logging/Logger.js +15 -0
  218. package/dist/utils/logging/Logger.js.map +1 -0
  219. package/dist/utils/logging/index.d.ts +7 -0
  220. package/dist/utils/logging/index.d.ts.map +1 -0
  221. package/dist/utils/logging/index.js +7 -0
  222. package/dist/utils/logging/index.js.map +1 -0
  223. 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
+ }