cross-seed 6.0.0-9 → 6.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 (70) hide show
  1. package/dist/action.js +177 -68
  2. package/dist/action.js.map +1 -1
  3. package/dist/arr.js +62 -54
  4. package/dist/arr.js.map +1 -1
  5. package/dist/clients/Deluge.js +70 -46
  6. package/dist/clients/Deluge.js.map +1 -1
  7. package/dist/clients/QBittorrent.js +110 -68
  8. package/dist/clients/QBittorrent.js.map +1 -1
  9. package/dist/clients/RTorrent.js +45 -22
  10. package/dist/clients/RTorrent.js.map +1 -1
  11. package/dist/clients/TorrentClient.js +14 -1
  12. package/dist/clients/TorrentClient.js.map +1 -1
  13. package/dist/clients/Transmission.js +29 -9
  14. package/dist/clients/Transmission.js.map +1 -1
  15. package/dist/cmd.js +46 -23
  16. package/dist/cmd.js.map +1 -1
  17. package/dist/config.template.cjs +53 -57
  18. package/dist/config.template.cjs.map +1 -1
  19. package/dist/configSchema.js +89 -25
  20. package/dist/configSchema.js.map +1 -1
  21. package/dist/configuration.js +4 -1
  22. package/dist/configuration.js.map +1 -1
  23. package/dist/constants.js +69 -10
  24. package/dist/constants.js.map +1 -1
  25. package/dist/dataFiles.js +4 -5
  26. package/dist/dataFiles.js.map +1 -1
  27. package/dist/db.js +2 -1
  28. package/dist/db.js.map +1 -1
  29. package/dist/decide.js +231 -146
  30. package/dist/decide.js.map +1 -1
  31. package/dist/diff.js +13 -3
  32. package/dist/diff.js.map +1 -1
  33. package/dist/errors.js.map +1 -1
  34. package/dist/indexers.js +94 -33
  35. package/dist/indexers.js.map +1 -1
  36. package/dist/inject.js +448 -0
  37. package/dist/inject.js.map +1 -0
  38. package/dist/jobs.js +13 -6
  39. package/dist/jobs.js.map +1 -1
  40. package/dist/logger.js +27 -9
  41. package/dist/logger.js.map +1 -1
  42. package/dist/migrations/00-initialSchema.js.map +1 -1
  43. package/dist/migrations/05-caps.js.map +1 -1
  44. package/dist/migrations/06-uniqueDecisions.js +29 -0
  45. package/dist/migrations/06-uniqueDecisions.js.map +1 -0
  46. package/dist/migrations/07-limits.js +12 -0
  47. package/dist/migrations/07-limits.js.map +1 -0
  48. package/dist/migrations/migrations.js +4 -0
  49. package/dist/migrations/migrations.js.map +1 -1
  50. package/dist/parseTorrent.js +6 -0
  51. package/dist/parseTorrent.js.map +1 -1
  52. package/dist/pipeline.js +224 -108
  53. package/dist/pipeline.js.map +1 -1
  54. package/dist/preFilter.js +122 -55
  55. package/dist/preFilter.js.map +1 -1
  56. package/dist/pushNotifier.js +7 -5
  57. package/dist/pushNotifier.js.map +1 -1
  58. package/dist/searchee.js +198 -17
  59. package/dist/searchee.js.map +1 -1
  60. package/dist/server.js +106 -54
  61. package/dist/server.js.map +1 -1
  62. package/dist/startup.js +16 -7
  63. package/dist/startup.js.map +1 -1
  64. package/dist/torrent.js +100 -37
  65. package/dist/torrent.js.map +1 -1
  66. package/dist/torznab.js +323 -153
  67. package/dist/torznab.js.map +1 -1
  68. package/dist/utils.js +228 -43
  69. package/dist/utils.js.map +1 -1
  70. package/package.json +11 -6
package/dist/inject.js ADDED
@@ -0,0 +1,448 @@
1
+ import chalk from "chalk";
2
+ import { stat, unlink } from "fs/promises";
3
+ import ms from "ms";
4
+ import { copyFileSync, existsSync } from "fs";
5
+ import path, { basename, dirname } from "path";
6
+ import { linkAllFilesInMetafile, performAction } from "./action.js";
7
+ import { getClient, waitForTorrentToComplete, } from "./clients/TorrentClient.js";
8
+ import { appDir } from "./configuration.js";
9
+ import { Decision, InjectionResult, isAnyMatchedDecision, SaveResult, TORRENT_CACHE_FOLDER, UNKNOWN_TRACKER, } from "./constants.js";
10
+ import { assessCandidate } from "./decide.js";
11
+ import { Label, logger } from "./logger.js";
12
+ import { findAllSearchees } from "./pipeline.js";
13
+ import { sendResultsNotification } from "./pushNotifier.js";
14
+ import { resultOf, resultOfErr } from "./Result.js";
15
+ import { getRuntimeConfig } from "./runtimeConfig.js";
16
+ import { findAllTorrentFilesInDir, parseMetadataFromFilename, parseTorrentFromFilename, } from "./torrent.js";
17
+ import { areMediaTitlesSimilar, comparing, formatAsList, getLogString, isTruthy, MediaType, sanitizeInfoHash, } from "./utils.js";
18
+ function getTorrentFilePathLog(torrentFilePath) {
19
+ return chalk.bold.magenta(torrentFilePath.replace(/\[([a-z0-9]{40})].torrent$/i, (match, hash) => match.replace(hash, sanitizeInfoHash(hash))));
20
+ }
21
+ async function deleteTorrentFileIfSafe(torrentFilePath) {
22
+ const { tracker, name, mediaType } = parseMetadataFromFilename(basename(torrentFilePath));
23
+ // we are confident cross-seed created the torrent,
24
+ // or it is intended for use with cross-seed
25
+ const isSafeToDelete = tracker && name && mediaType;
26
+ if (!isSafeToDelete)
27
+ return;
28
+ const filePathLog = getTorrentFilePathLog(torrentFilePath);
29
+ logger.verbose({
30
+ label: Label.INJECT,
31
+ message: `Deleting ${filePathLog}`,
32
+ });
33
+ try {
34
+ await unlink(torrentFilePath);
35
+ }
36
+ catch (e) {
37
+ if (e.code !== "ENOENT") {
38
+ logger.error({
39
+ label: Label.INJECT,
40
+ message: `Failed to delete ${filePathLog}`,
41
+ });
42
+ logger.debug(e);
43
+ }
44
+ }
45
+ }
46
+ async function deleteTorrentFileIfComplete(torrentFilePath, infoHash) {
47
+ if (await waitForTorrentToComplete(infoHash)) {
48
+ await deleteTorrentFileIfSafe(torrentFilePath);
49
+ }
50
+ else {
51
+ logger.info({
52
+ label: Label.INJECT,
53
+ message: `Will not delete ${getTorrentFilePathLog(torrentFilePath)}: torrent is incomplete`,
54
+ });
55
+ }
56
+ }
57
+ async function whichSearcheesMatchTorrent(meta, searchees) {
58
+ const isSimilar = (searchee, meta) => areMediaTitlesSimilar(searchee.title, meta.title) ||
59
+ areMediaTitlesSimilar(searchee.title, meta.name) ||
60
+ areMediaTitlesSimilar(searchee.name, meta.name) ||
61
+ areMediaTitlesSimilar(searchee.name, meta.title) ||
62
+ meta.files.some((metaFile) => searchee.files.some((searcheeFile) => areMediaTitlesSimilar(searcheeFile.name, metaFile.name)));
63
+ let foundBlocked = false;
64
+ const matches = [];
65
+ for (const searchee of searchees) {
66
+ const { decision } = await assessCandidate(meta, searchee, []);
67
+ if (decision === Decision.BLOCKED_RELEASE) {
68
+ if (isSimilar(searchee, meta))
69
+ foundBlocked = true;
70
+ continue;
71
+ }
72
+ else if (!isAnyMatchedDecision(decision)) {
73
+ continue;
74
+ }
75
+ if (!isSimilar(searchee, meta)) {
76
+ logger.warn({
77
+ label: Label.INJECT,
78
+ message: `Skipping likely false positive for ${getLogString(meta, chalk.bold.white)} from ${getLogString(searchee, chalk.bold.white)}`,
79
+ });
80
+ continue;
81
+ }
82
+ matches.push({ searchee, decision });
83
+ }
84
+ /**
85
+ * full matches, then size only matches, then partial matches
86
+ * torrent, then data, then virtual
87
+ * prefer more files for partials
88
+ */
89
+ matches.sort(comparing((match) =>
90
+ // indexOf returns -1 for not found
91
+ -[Decision.MATCH_SIZE_ONLY, Decision.MATCH].indexOf(match.decision), (match) => !match.searchee.infoHash, (match) => !match.searchee.path, (match) => -match.searchee.files.length));
92
+ return { matches, foundBlocked };
93
+ }
94
+ async function injectInitialAction(meta, matches, tracker) {
95
+ let injectionResult = InjectionResult.FAILURE;
96
+ let matchedSearchee;
97
+ let matchedDecision;
98
+ let linkedNewFiles = false;
99
+ for (const { searchee, decision } of matches) {
100
+ if (injectionResult === InjectionResult.TORRENT_NOT_COMPLETE &&
101
+ !searchee.infoHash) {
102
+ continue; // Data/virtual searchee doesn't know if torrent is complete
103
+ }
104
+ const res = await performAction(meta, decision, searchee, tracker);
105
+ const result = res.actionResult;
106
+ if (res.linkedNewFiles) {
107
+ linkedNewFiles = true;
108
+ }
109
+ if (injectionResult === InjectionResult.SUCCESS ||
110
+ result === InjectionResult.FAILURE ||
111
+ result === SaveResult.SAVED) {
112
+ continue;
113
+ }
114
+ if (result === InjectionResult.ALREADY_EXISTS) {
115
+ injectionResult = result;
116
+ continue;
117
+ }
118
+ if (result === InjectionResult.TORRENT_NOT_COMPLETE) {
119
+ if (injectionResult !== InjectionResult.ALREADY_EXISTS) {
120
+ injectionResult = result;
121
+ matchedSearchee = searchee;
122
+ matchedDecision = decision;
123
+ }
124
+ continue;
125
+ }
126
+ injectionResult = InjectionResult.SUCCESS;
127
+ matchedSearchee = searchee;
128
+ matchedDecision = decision;
129
+ }
130
+ return {
131
+ injectionResult,
132
+ matchedSearchee,
133
+ matchedDecision,
134
+ linkedNewFiles,
135
+ };
136
+ }
137
+ function injectionFailed({ progress, injectionResult, summary, filePathLog, }) {
138
+ logger.error({
139
+ label: Label.INJECT,
140
+ message: `${progress} Failed to inject ${filePathLog} - ${chalk.red(injectionResult)}`,
141
+ });
142
+ summary.FAILED++;
143
+ }
144
+ async function injectFromStalledTorrent({ meta, matches, tracker, injectionResult, progress, filePathLog, }) {
145
+ let linkedNewFiles = false;
146
+ let inClient = (await getClient().isTorrentComplete(meta.infoHash)).isOk();
147
+ let injected = false;
148
+ for (const { searchee, decision } of matches) {
149
+ const linkedFilesRootResult = await linkAllFilesInMetafile(searchee, meta, tracker, decision, { onlyCompleted: false });
150
+ const linkResult = linkedFilesRootResult.isOk()
151
+ ? linkedFilesRootResult.unwrap()
152
+ : null;
153
+ if (linkResult && linkResult.linkedNewFiles) {
154
+ linkedNewFiles = true;
155
+ }
156
+ if (!inClient) {
157
+ if (linkedFilesRootResult.isOk()) {
158
+ const destinationDir = dirname(linkResult.contentPath);
159
+ const result = await getClient().inject(meta, searchee, Decision.MATCH_PARTIAL, // Should always be considered partial
160
+ destinationDir);
161
+ // result is only SUCCESS or FAILURE here but still log original injectionResult
162
+ if (result === InjectionResult.SUCCESS) {
163
+ logger.info({
164
+ label: Label.INJECT,
165
+ message: `${progress} Injected ${filePathLog} using stalled source, you will need to resume or remove from client - ${chalk.green(injectionResult)}`,
166
+ });
167
+ inClient = true;
168
+ injected = true;
169
+ }
170
+ else {
171
+ logger.warn({
172
+ label: Label.INJECT,
173
+ message: `${progress} Failed to inject ${filePathLog} using stalled source - ${chalk.yellow(injectionResult)}`,
174
+ });
175
+ }
176
+ }
177
+ else {
178
+ logger.warn({
179
+ label: Label.INJECT,
180
+ message: `${progress} Failed to link files for ${filePathLog}, ${linkedFilesRootResult.unwrapErr()} - ${chalk.yellow(injectionResult)}`,
181
+ });
182
+ }
183
+ }
184
+ }
185
+ if (inClient && !injected) {
186
+ if (linkedNewFiles) {
187
+ logger.info({
188
+ label: Label.INJECT,
189
+ message: `${progress} Rechecking ${filePathLog} as new files were linked - ${chalk.green(injectionResult)}`,
190
+ });
191
+ await getClient().recheckTorrent(meta.infoHash);
192
+ }
193
+ else {
194
+ logger.warn({
195
+ label: Label.INJECT,
196
+ message: `${progress} No new files linked for ${filePathLog}, resume or remove from client - ${chalk.yellow(injectionResult)}`,
197
+ });
198
+ }
199
+ }
200
+ }
201
+ async function injectionTorrentNotComplete(injectionAftermath) {
202
+ const { progress, torrentFilePath, injectionResult, summary, filePathLog } = injectionAftermath;
203
+ const { linkDir } = getRuntimeConfig();
204
+ if (!linkDir ||
205
+ (await stat(torrentFilePath)).mtimeMs >= Date.now() - ms("1 day")) {
206
+ // Normal case where source is likely still downloading
207
+ logger.warn({
208
+ label: Label.INJECT,
209
+ message: `${progress} Unable to inject ${filePathLog} - ${chalk.yellow(injectionResult)}`,
210
+ });
211
+ }
212
+ else {
213
+ // Since source is stalled, add to client paused so user can resume later if desired
214
+ // Try linking all possible matches as they may have different files
215
+ await injectFromStalledTorrent(injectionAftermath);
216
+ }
217
+ summary.INCOMPLETE_SEARCHEES++;
218
+ }
219
+ async function injectionAlreadyExists({ progress, torrentFilePath, injectionResult, summary, linkedNewFiles, meta, matches, filePathLog, }) {
220
+ const result = await getClient().isTorrentComplete(meta.infoHash);
221
+ let isComplete = result.isOk() ? result.unwrap() : false;
222
+ const anyFullMatch = matches.some((m) => m.decision === Decision.MATCH ||
223
+ m.decision === Decision.MATCH_SIZE_ONLY);
224
+ if (linkedNewFiles) {
225
+ logger.info({
226
+ label: Label.INJECT,
227
+ message: `${progress} Rechecking ${filePathLog} as new files were linked - ${chalk.green(injectionResult)}`,
228
+ });
229
+ await getClient().recheckTorrent(meta.infoHash);
230
+ }
231
+ else if (anyFullMatch && !isComplete) {
232
+ logger.info({
233
+ label: Label.INJECT,
234
+ message: `${progress} Rechecking ${filePathLog} as it's not complete but has all files - ${chalk.green(injectionResult)}`,
235
+ });
236
+ await getClient().recheckTorrent(meta.infoHash);
237
+ isComplete = true; // Prevent infinite recheck in rare case of corrupted cross seed
238
+ }
239
+ else {
240
+ logger.warn({
241
+ label: Label.INJECT,
242
+ message: `${progress} Unable to inject ${filePathLog} - ${chalk.yellow(injectionResult)}${isComplete ? "" : " (incomplete)"}`,
243
+ });
244
+ }
245
+ summary.ALREADY_EXISTS++;
246
+ summary.INCOMPLETE_CANDIDATES += isComplete ? 0 : 1;
247
+ if (isComplete) {
248
+ await deleteTorrentFileIfSafe(torrentFilePath);
249
+ }
250
+ else {
251
+ deleteTorrentFileIfComplete(torrentFilePath, meta.infoHash);
252
+ }
253
+ }
254
+ async function injectionSuccess({ progress, torrentFilePath, injectionResult, summary, matchedSearchee, matchedDecision, meta, tracker, filePathLog, }) {
255
+ logger.info({
256
+ label: Label.INJECT,
257
+ message: `${progress} Injected ${filePathLog} - ${chalk.green(injectionResult)}`,
258
+ });
259
+ sendResultsNotification(matchedSearchee, [
260
+ [
261
+ { decision: matchedDecision, metafile: meta },
262
+ tracker,
263
+ injectionResult,
264
+ ],
265
+ ]);
266
+ summary.INJECTED++;
267
+ if (matchedDecision === Decision.MATCH_PARTIAL) {
268
+ summary.PARTIAL_MATCHES++;
269
+ }
270
+ else {
271
+ summary.FULL_MATCHES++;
272
+ }
273
+ deleteTorrentFileIfComplete(torrentFilePath, meta.infoHash);
274
+ }
275
+ async function loadMetafile(torrentFilePath, progress, summary) {
276
+ const filePathLog = getTorrentFilePathLog(torrentFilePath);
277
+ let meta;
278
+ try {
279
+ meta = await parseTorrentFromFilename(torrentFilePath);
280
+ }
281
+ catch (e) {
282
+ logger.error({
283
+ label: Label.INJECT,
284
+ message: `${progress} Failed to parse ${filePathLog}`,
285
+ });
286
+ logger.debug(e);
287
+ return resultOfErr("FAILED_TO_PARSE");
288
+ }
289
+ const { tracker: trackerFromFilename } = parseMetadataFromFilename(basename(torrentFilePath));
290
+ summary.FOUND_BAD_FORMAT ||= !trackerFromFilename;
291
+ const tracker = trackerFromFilename ?? UNKNOWN_TRACKER;
292
+ return resultOf({ meta, tracker });
293
+ }
294
+ async function injectSavedTorrent(progress, torrentFilePath, summary, searchees) {
295
+ const metafileResult = await loadMetafile(torrentFilePath, progress, summary);
296
+ if (metafileResult.isErr())
297
+ return;
298
+ const { meta, tracker } = metafileResult.unwrap();
299
+ const filePathLog = getTorrentFilePathLog(torrentFilePath);
300
+ const metaLog = getLogString(meta, chalk.bold.white);
301
+ const { matches, foundBlocked } = await whichSearcheesMatchTorrent(meta, searchees);
302
+ if (!matches.length && foundBlocked) {
303
+ logger.info({
304
+ label: Label.INJECT,
305
+ message: `${progress} ${metaLog} ${chalk.yellow("possibly blocklisted")}: ${filePathLog}`,
306
+ });
307
+ summary.BLOCKED++;
308
+ await deleteTorrentFileIfSafe(torrentFilePath);
309
+ return;
310
+ }
311
+ else if (!matches.length) {
312
+ logger.info({
313
+ label: Label.INJECT,
314
+ message: `${progress} ${metaLog} ${chalk.red("has no matches")}: ${filePathLog}`,
315
+ });
316
+ summary.UNMATCHED++;
317
+ await deleteTorrentFileIfSafe(torrentFilePath);
318
+ return;
319
+ }
320
+ const { injectionResult, matchedSearchee, matchedDecision, linkedNewFiles, } = await injectInitialAction(meta, matches, tracker);
321
+ const injectionAftermath = {
322
+ progress,
323
+ torrentFilePath,
324
+ injectionResult,
325
+ summary,
326
+ meta,
327
+ tracker,
328
+ matches,
329
+ matchedSearchee,
330
+ matchedDecision,
331
+ linkedNewFiles,
332
+ filePathLog,
333
+ };
334
+ switch (injectionResult) {
335
+ case InjectionResult.SUCCESS:
336
+ await injectionSuccess(injectionAftermath);
337
+ break;
338
+ case InjectionResult.FAILURE:
339
+ injectionFailed(injectionAftermath);
340
+ break;
341
+ case InjectionResult.ALREADY_EXISTS:
342
+ await injectionAlreadyExists(injectionAftermath);
343
+ break;
344
+ case InjectionResult.TORRENT_NOT_COMPLETE:
345
+ await injectionTorrentNotComplete(injectionAftermath);
346
+ break;
347
+ }
348
+ }
349
+ function logInjectSummary(summary, flatLinking) {
350
+ const incompleteMsg = `${chalk.bold.yellow(summary.ALREADY_EXISTS)} existed in client${summary.INCOMPLETE_CANDIDATES
351
+ ? chalk.dim(` (${summary.INCOMPLETE_CANDIDATES} were incomplete)`)
352
+ : ""}`;
353
+ const resultMsg = formatAsList([
354
+ `Injected ${chalk.bold.green(summary.INJECTED)}/${chalk.bold.white(summary.TOTAL)} torrents`,
355
+ summary.FULL_MATCHES &&
356
+ `${chalk.bold.green(summary.FULL_MATCHES)} were full matches`,
357
+ summary.PARTIAL_MATCHES &&
358
+ `${chalk.bold.yellow(summary.PARTIAL_MATCHES)} were partial matches`,
359
+ summary.INCOMPLETE_SEARCHEES &&
360
+ `${chalk.bold.yellow(summary.INCOMPLETE_SEARCHEES)} had incomplete sources`,
361
+ summary.ALREADY_EXISTS && incompleteMsg,
362
+ summary.BLOCKED &&
363
+ `${chalk.bold.yellow(summary.BLOCKED)} were possibly blocklisted`,
364
+ summary.FAILED &&
365
+ `${chalk.bold.red(summary.FAILED)} failed to inject`,
366
+ summary.UNMATCHED &&
367
+ `${chalk.bold.red(summary.UNMATCHED)} had no matches`,
368
+ ].filter(isTruthy), { sort: false, type: "unit" });
369
+ logger.info({ label: Label.INJECT, message: chalk.cyan(resultMsg) });
370
+ if (summary.UNMATCHED > 0) {
371
+ logger.info({
372
+ label: Label.INJECT,
373
+ message: `Use "${chalk.bold.white("cross-seed diff")}" to get the reasons two torrents are not considered matches`,
374
+ });
375
+ }
376
+ if (summary.FOUND_BAD_FORMAT && !flatLinking) {
377
+ logger.warn({
378
+ label: Label.INJECT,
379
+ message: `Some torrents could be linked to linkDir/${UNKNOWN_TRACKER} - follow .torrent naming format in the docs to avoid this`,
380
+ });
381
+ }
382
+ logger.info({
383
+ label: Label.INJECT,
384
+ message: `Waiting on post-injection tasks to complete...`,
385
+ });
386
+ }
387
+ function createSummary(total) {
388
+ return {
389
+ TOTAL: total,
390
+ INJECTED: 0,
391
+ FULL_MATCHES: 0,
392
+ PARTIAL_MATCHES: 0,
393
+ BLOCKED: 0,
394
+ ALREADY_EXISTS: 0,
395
+ INCOMPLETE_CANDIDATES: 0,
396
+ INCOMPLETE_SEARCHEES: 0,
397
+ FAILED: 0,
398
+ UNMATCHED: 0,
399
+ FOUND_BAD_FORMAT: false,
400
+ };
401
+ }
402
+ export async function injectSavedTorrents() {
403
+ const { flatLinking, injectDir, outputDir } = getRuntimeConfig();
404
+ const targetDir = injectDir ?? outputDir;
405
+ const targetDirLog = chalk.bold.magenta(targetDir);
406
+ const torrentFilePaths = await findAllTorrentFilesInDir(targetDir);
407
+ if (torrentFilePaths.length === 0) {
408
+ logger.info({
409
+ label: Label.INJECT,
410
+ message: `No torrent files found to inject in ${targetDirLog}`,
411
+ });
412
+ return;
413
+ }
414
+ logger.info({
415
+ label: Label.INJECT,
416
+ message: `Found ${chalk.bold.white(torrentFilePaths.length)} torrent file(s) to inject in ${targetDirLog}`,
417
+ });
418
+ const summary = createSummary(torrentFilePaths.length);
419
+ const searchees = await findAllSearchees(Label.INJECT);
420
+ for (const [i, torrentFilePath] of torrentFilePaths.entries()) {
421
+ const progress = chalk.blue(`(${i + 1}/${torrentFilePaths.length})`);
422
+ await injectSavedTorrent(progress, torrentFilePath, summary, searchees);
423
+ }
424
+ logInjectSummary(summary, flatLinking);
425
+ }
426
+ export async function restoreFromTorrentCache() {
427
+ const { outputDir } = getRuntimeConfig();
428
+ const torrentFilePaths = await findAllTorrentFilesInDir(path.join(appDir(), TORRENT_CACHE_FOLDER));
429
+ if (torrentFilePaths.length === 0) {
430
+ console.log("No torrent files found to restore from cache");
431
+ return;
432
+ }
433
+ console.log(`Found ${chalk.bold.white(torrentFilePaths.length)} torrent file(s) to restore from cache, copying to outputDir...`);
434
+ let existed = 0;
435
+ for (const [i, torrentFilePath] of torrentFilePaths.entries()) {
436
+ const dest = path.join(outputDir, `[${MediaType.OTHER}][${UNKNOWN_TRACKER}]${basename(torrentFilePath)}`);
437
+ if (existsSync(dest)) {
438
+ existed++;
439
+ continue;
440
+ }
441
+ copyFileSync(torrentFilePath, dest);
442
+ if ((i + 1) % 100 === 0) {
443
+ console.log(`${chalk.blue(`(${i + 1}/${torrentFilePaths.length})`)} ${chalk.bold.magenta(dest)}`);
444
+ }
445
+ }
446
+ console.log(`Copied ${chalk.bold.green(torrentFilePaths.length - existed)}/${chalk.bold.white(torrentFilePaths.length)} torrent file(s) from cache to outputDir, run "${chalk.bold.white("cross-seed inject")}" to inject into client using your dataDirs`);
447
+ }
448
+ //# sourceMappingURL=inject.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"inject.js","sourceRoot":"","sources":["../src/inject.ts"],"names":[],"mappings":"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"}
package/dist/jobs.js CHANGED
@@ -1,9 +1,12 @@
1
1
  import ms from "ms";
2
+ import { Action } from "./constants.js";
2
3
  import { db } from "./db.js";
3
- import { main, scanRssFeeds } from "./pipeline.js";
4
4
  import { exitOnCrossSeedErrors } from "./errors.js";
5
+ import { injectSavedTorrents } from "./inject.js";
5
6
  import { Label, logger } from "./logger.js";
7
+ import { main, scanRssFeeds } from "./pipeline.js";
6
8
  import { getRuntimeConfig } from "./runtimeConfig.js";
9
+ import { updateCaps } from "./torznab.js";
7
10
  class Job {
8
11
  name;
9
12
  cadence;
@@ -34,13 +37,17 @@ class Job {
34
37
  }
35
38
  }
36
39
  function getJobs() {
37
- const { rssCadence, searchCadence, torznab } = getRuntimeConfig();
40
+ const { action, rssCadence, searchCadence, torznab } = getRuntimeConfig();
38
41
  const jobs = [];
42
+ if (rssCadence)
43
+ jobs.push(new Job("rss", rssCadence, scanRssFeeds));
44
+ if (searchCadence)
45
+ jobs.push(new Job("search", searchCadence, main));
39
46
  if (torznab.length > 0) {
40
- if (rssCadence)
41
- jobs.push(new Job("rss", rssCadence, scanRssFeeds));
42
- if (searchCadence)
43
- jobs.push(new Job("search", searchCadence, main));
47
+ jobs.push(new Job("updateIndexerCaps", ms("1 day"), updateCaps));
48
+ }
49
+ if (action === Action.INJECT) {
50
+ jobs.push(new Job("inject", ms("1 hour"), injectSavedTorrents));
44
51
  }
45
52
  return jobs;
46
53
  }
package/dist/jobs.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"jobs.js","sourceRoot":"","sources":["../src/jobs.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"jobs.js","sourceRoot":"","sources":["../src/jobs.ts"],"names":[],"mappings":"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"}
package/dist/logger.js CHANGED
@@ -1,4 +1,5 @@
1
1
  import { join } from "path";
2
+ import stripAnsi from "strip-ansi";
2
3
  import winston from "winston";
3
4
  import DailyRotateFile from "winston-daily-rotate-file";
4
5
  import { appDir, createAppDir } from "./configuration.js";
@@ -10,6 +11,7 @@ export var Label;
10
11
  Label["TRANSMISSION"] = "transmission";
11
12
  Label["DELUGE"] = "deluge";
12
13
  Label["DECIDE"] = "decide";
14
+ Label["INJECT"] = "inject";
13
15
  Label["PREFILTER"] = "prefilter";
14
16
  Label["CONFIGDUMP"] = "configdump";
15
17
  Label["TORZNAB"] = "torznab";
@@ -18,8 +20,10 @@ export var Label;
18
20
  Label["SCHEDULER"] = "scheduler";
19
21
  Label["SEARCH"] = "search";
20
22
  Label["RSS"] = "rss";
23
+ Label["ANNOUNCE"] = "announce";
24
+ Label["WEBHOOK"] = "webhook";
21
25
  Label["PERF"] = "perf";
22
- Label["REVERSE_LOOKUP"] = "reverselookup";
26
+ Label["ARRS"] = "arrs";
23
27
  Label["RADARR"] = "radarr";
24
28
  Label["SONARR"] = "sonarr";
25
29
  })(Label || (Label = {}));
@@ -48,8 +52,11 @@ function redactMessage(message, options) {
48
52
  }
49
53
  const runtimeConfig = options ?? getRuntimeConfig();
50
54
  let ret = message;
51
- // redact torznab api keys
52
- ret = ret.replace(/apikey=[a-zA-Z0-9]+/g, `apikey=${redactionMsg}`);
55
+ ret = ret.replace(/key=[a-zA-Z0-9]+/g, `key=${redactionMsg}`);
56
+ ret = ret.replace(/pass=[a-zA-Z0-9]+/g, `pass=${redactionMsg}`);
57
+ ret = ret.replace(/(?:(?:auto|download)[./]\d+[./])([a-zA-Z0-9]+)/g, (match, key) => match.replace(key, redactionMsg));
58
+ ret = ret.replace(/(?:\d+[./](?:auto|download)[./])([a-zA-Z0-9]+)/g, (match, key) => match.replace(key, redactionMsg));
59
+ ret = ret.replace(/apiKey: '.+'/g, `apiKey: ${redactionMsg}`);
53
60
  ret = ret.replace(/\/notification\/crossSeed\/[a-zA-Z-0-9_-]+/g, `/notification/crossSeed/${redactionMsg}`);
54
61
  for (const [key, urlStr] of Object.entries(runtimeConfig)) {
55
62
  if (key.endsWith("Url") && urlStr) {
@@ -58,11 +65,22 @@ function redactMessage(message, options) {
58
65
  }
59
66
  return ret;
60
67
  }
61
- const logOnceCache = [];
62
- export function logOnce(cacheKey, cb) {
63
- if (!logOnceCache.includes(cacheKey)) {
64
- logOnceCache.push(cacheKey);
68
+ function stripAnsiChars(message) {
69
+ if (typeof message !== "string") {
70
+ return message;
71
+ }
72
+ return stripAnsi(message);
73
+ }
74
+ const logOnceCache = new Set();
75
+ export function logOnce(cacheKey, cb, ttl) {
76
+ if (!logOnceCache.has(cacheKey)) {
77
+ logOnceCache.add(cacheKey);
65
78
  cb();
79
+ if (ttl) {
80
+ setTimeout(() => {
81
+ logOnceCache.delete(cacheKey);
82
+ }, ttl).unref();
83
+ }
66
84
  }
67
85
  }
68
86
  export function initializeLogger(options) {
@@ -71,8 +89,8 @@ export function initializeLogger(options) {
71
89
  level: "info",
72
90
  format: winston.format.combine(winston.format.timestamp({
73
91
  format: "YYYY-MM-DD HH:mm:ss",
74
- }), winston.format.errors({ stack: true }), winston.format.splat(), winston.format.colorize(), winston.format.printf(({ level, message, label, timestamp }) => {
75
- return `${timestamp} ${level}: ${label ? `[${label}] ` : ""}${redactMessage(message, options)}`;
92
+ }), winston.format.errors({ stack: true }), winston.format.splat(), winston.format.printf(({ level, message, label, timestamp, stack }) => {
93
+ return `${timestamp} ${level}: ${label ? `[${label}] ` : ""}${stripAnsiChars(redactMessage(stack ? stack : message, options))}`;
76
94
  })),
77
95
  transports: [
78
96
  new DailyRotateFile({
@@ -1 +1 @@
1
- {"version":3,"file":"logger.js","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"00-initialSchema.js","sourceRoot":"","sources":["../../src/migrations/00-initialSchema.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"00-initialSchema.js","sourceRoot":"","sources":["../../src/migrations/00-initialSchema.ts"],"names":[],"mappings":"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"}