@promptbook/pdf 0.84.0-13 → 0.84.0-14

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/esm/index.es.js CHANGED
@@ -7,7 +7,7 @@ import { format } from 'prettier';
7
7
  import parserHtml from 'prettier/parser-html';
8
8
  import { forTime } from 'waitasecond';
9
9
  import sha256 from 'crypto-js/sha256';
10
- import { lookup } from 'mime-types';
10
+ import { lookup, extension } from 'mime-types';
11
11
  import { unparse, parse } from 'papaparse';
12
12
 
13
13
  // ⚠️ WARNING: This code has been generated so that any manual changes will be overwritten
@@ -24,7 +24,7 @@ var BOOK_LANGUAGE_VERSION = '1.0.0';
24
24
  * @generated
25
25
  * @see https://github.com/webgptorg/promptbook
26
26
  */
27
- var PROMPTBOOK_ENGINE_VERSION = '0.84.0-12';
27
+ var PROMPTBOOK_ENGINE_VERSION = '0.84.0-13';
28
28
  /**
29
29
  * TODO: string_promptbook_version should be constrained to the all versions of Promptbook engine
30
30
  * Note: [💞] Ignore a discrepancy between file name and entity name
@@ -3580,6 +3580,17 @@ function getFileExtension(value) {
3580
3580
  return match ? match[1].toLowerCase() : null;
3581
3581
  }
3582
3582
 
3583
+ /**
3584
+ * Convert mime type to file extension
3585
+ *
3586
+ * Note: If the mime type is invalid, `null` is returned
3587
+ *
3588
+ * @private within the repository
3589
+ */
3590
+ function mimeTypeToExtension(value) {
3591
+ return extension(value) || null;
3592
+ }
3593
+
3583
3594
  /**
3584
3595
  * The built-in `fetch' function with a lightweight error handling wrapper as default fetch function used in Promptbook scrapers
3585
3596
  *
@@ -3633,7 +3644,7 @@ function makeKnowledgeSourceHandler(knowledgeSource, tools, options) {
3633
3644
  case 1:
3634
3645
  response_1 = _l.sent();
3635
3646
  mimeType = ((_a = response_1.headers.get('content-type')) === null || _a === void 0 ? void 0 : _a.split(';')[0]) || 'text/html';
3636
- if (tools.fs === undefined || !url.endsWith('.pdf')) {
3647
+ if (tools.fs === undefined || !url.endsWith('.pdf' /* <- TODO: [💵] */)) {
3637
3648
  return [2 /*return*/, {
3638
3649
  source: name,
3639
3650
  filename: null,
@@ -3678,7 +3689,7 @@ function makeKnowledgeSourceHandler(knowledgeSource, tools, options) {
3678
3689
  basename = url.split('/').pop() || titleToName(url);
3679
3690
  hash = sha256(hexEncoder.parse(url)).toString( /* hex */);
3680
3691
  rootDirname_1 = join(process.cwd(), DEFAULT_DOWNLOAD_CACHE_DIRNAME);
3681
- filepath = join.apply(void 0, __spreadArray(__spreadArray([], __read(nameToSubfolderPath(hash /* <- TODO: [🎎] Maybe add some SHA256 prefix */)), false), ["".concat(basename.substring(0, MAX_FILENAME_LENGTH), ".pdf")], false));
3692
+ filepath = join.apply(void 0, __spreadArray(__spreadArray([], __read(nameToSubfolderPath(hash /* <- TODO: [🎎] Maybe add some SHA256 prefix */)), false), ["".concat(basename.substring(0, MAX_FILENAME_LENGTH), ".").concat(mimeTypeToExtension(mimeType))], false));
3682
3693
  return [4 /*yield*/, tools.fs.mkdir(dirname(join(rootDirname_1, filepath)), { recursive: true })];
3683
3694
  case 2:
3684
3695
  _l.sent();
@@ -3689,9 +3700,9 @@ function makeKnowledgeSourceHandler(knowledgeSource, tools, options) {
3689
3700
  case 3: return [4 /*yield*/, _g.apply(_f, _h.concat([_k.apply(_j, [_l.sent()])]))];
3690
3701
  case 4:
3691
3702
  _l.sent();
3692
- // TODO: !!!!!!!! Check the file security
3703
+ // TODO: [💵] Check the file security
3693
3704
  // TODO: !!!!!!!! Check the file size (if it is not too big)
3694
- // TODO: !!!!!!!! Delete the file
3705
+ // TODO: !!!!!!!! Delete the file after the scraping is done
3695
3706
  return [2 /*return*/, makeKnowledgeSourceHandler({ name: name, knowledgeSourceContent: filepath }, tools, __assign(__assign({}, options), { rootDirname: rootDirname_1 }))];
3696
3707
  case 5:
3697
3708
  if (!isValidFilePath(knowledgeSourceContent)) return [3 /*break*/, 7];
@@ -6310,7 +6321,7 @@ var markitdownScraperMetadata = $deepFreeze({
6310
6321
  className: 'MarkitdownScraper',
6311
6322
  mimeTypes: [
6312
6323
  'application/pdf',
6313
- // TODO: Make priority for scrapers and than allow all mime types here:
6324
+ // TODO: [💵] Make priority for scrapers and than analyze which mime-types can Markitdown scrape and allow all mime types here:
6314
6325
  // 'text/html',
6315
6326
  // 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
6316
6327
  ],