@promptbook/core 0.75.2 → 0.75.4

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
@@ -22,7 +22,7 @@ var BOOK_LANGUAGE_VERSION = '1.0.0';
22
22
  *
23
23
  * @see https://github.com/webgptorg/promptbook
24
24
  */
25
- var PROMPTBOOK_ENGINE_VERSION = '0.75.1';
25
+ var PROMPTBOOK_ENGINE_VERSION = '0.75.3';
26
26
  /**
27
27
  * TODO: string_promptbook_version should be constrained to the all versions of Promptbook engine
28
28
  * Note: [💞] Ignore a discrepancy between file name and entity name
@@ -835,6 +835,16 @@ var DEFAULT_CSV_SETTINGS = Object.freeze({
835
835
  * @public exported from `@promptbook/core`
836
836
  */
837
837
  var DEFAULT_IS_VERBOSE = false;
838
+ /**
839
+ * @@@
840
+ *
841
+ * Note: This is experimental feature
842
+ *
843
+ * @public exported from `@promptbook/core`
844
+ */
845
+ function SET_IS_VERBOSE(isVerbose) {
846
+ DEFAULT_IS_VERBOSE = isVerbose;
847
+ }
838
848
  /**
839
849
  * @@@
840
850
  *
@@ -5057,9 +5067,15 @@ var $Register = /** @class */ (function () {
5057
5067
  var existingRegistrationIndex = this.storage.findIndex(function (item) { return item.packageName === packageName && item.className === className; });
5058
5068
  var existingRegistration = this.storage[existingRegistrationIndex];
5059
5069
  if (!existingRegistration) {
5070
+ if (DEFAULT_IS_VERBOSE) {
5071
+ console.warn("[\uD83D\uDCE6] Registering `".concat(packageName, ".").concat(className, "` to `").concat(this.registerName, "`"));
5072
+ }
5060
5073
  this.storage.push(registered);
5061
5074
  }
5062
5075
  else {
5076
+ if (DEFAULT_IS_VERBOSE) {
5077
+ console.warn("[\uD83D\uDCE6] Re-registering `".concat(packageName, ".").concat(className, "` to `").concat(this.registerName, "`"));
5078
+ }
5063
5079
  this.storage[existingRegistrationIndex] = registered;
5064
5080
  }
5065
5081
  return {
@@ -5108,50 +5124,63 @@ var $scrapersRegister = new $Register('scraper_constructors');
5108
5124
  *
5109
5125
  * @private internal function of `createScrapersFromConfiguration` and `createScrapersFromEnv`
5110
5126
  */
5111
- function $registeredScrapersMessage() {
5112
- var e_1, _a, e_2, _b;
5127
+ function $registeredScrapersMessage(availableScrapers) {
5128
+ var e_1, _a, e_2, _b, e_3, _c;
5113
5129
  /**
5114
5130
  * Mixes registered scrapers from $scrapersMetadataRegister and $scrapersRegister
5115
5131
  */
5116
5132
  var all = [];
5117
- var _loop_1 = function (packageName, className) {
5133
+ var _loop_1 = function (packageName, className, mimeTypes, documentationUrl, isAvilableInBrowser) {
5118
5134
  if (all.some(function (item) { return item.packageName === packageName && item.className === className; })) {
5119
5135
  return "continue";
5120
5136
  }
5121
- all.push({ packageName: packageName, className: className });
5137
+ all.push({ packageName: packageName, className: className, mimeTypes: mimeTypes, documentationUrl: documentationUrl, isAvilableInBrowser: isAvilableInBrowser });
5122
5138
  };
5123
5139
  try {
5124
- for (var _c = __values($scrapersMetadataRegister.list()), _d = _c.next(); !_d.done; _d = _c.next()) {
5125
- var _e = _d.value, packageName = _e.packageName, className = _e.className;
5126
- _loop_1(packageName, className);
5140
+ for (var _d = __values($scrapersMetadataRegister.list()), _e = _d.next(); !_e.done; _e = _d.next()) {
5141
+ var _f = _e.value, packageName = _f.packageName, className = _f.className, mimeTypes = _f.mimeTypes, documentationUrl = _f.documentationUrl, isAvilableInBrowser = _f.isAvilableInBrowser;
5142
+ _loop_1(packageName, className, mimeTypes, documentationUrl, isAvilableInBrowser);
5127
5143
  }
5128
5144
  }
5129
5145
  catch (e_1_1) { e_1 = { error: e_1_1 }; }
5130
5146
  finally {
5131
5147
  try {
5132
- if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
5148
+ if (_e && !_e.done && (_a = _d.return)) _a.call(_d);
5133
5149
  }
5134
5150
  finally { if (e_1) throw e_1.error; }
5135
5151
  }
5136
- var _loop_2 = function (packageName, className) {
5152
+ var _loop_2 = function (packageName, className, mimeTypes, documentationUrl, isAvilableInBrowser) {
5137
5153
  if (all.some(function (item) { return item.packageName === packageName && item.className === className; })) {
5138
5154
  return "continue";
5139
5155
  }
5140
- all.push({ packageName: packageName, className: className });
5156
+ all.push({ packageName: packageName, className: className, mimeTypes: mimeTypes, documentationUrl: documentationUrl, isAvilableInBrowser: isAvilableInBrowser });
5141
5157
  };
5142
5158
  try {
5143
- for (var _f = __values($scrapersRegister.list()), _g = _f.next(); !_g.done; _g = _f.next()) {
5144
- var _h = _g.value, packageName = _h.packageName, className = _h.className;
5145
- _loop_2(packageName, className);
5159
+ for (var _g = __values($scrapersRegister.list()), _h = _g.next(); !_h.done; _h = _g.next()) {
5160
+ var _j = _h.value, packageName = _j.packageName, className = _j.className, mimeTypes = _j.mimeTypes, documentationUrl = _j.documentationUrl, isAvilableInBrowser = _j.isAvilableInBrowser;
5161
+ _loop_2(packageName, className, mimeTypes, documentationUrl, isAvilableInBrowser);
5146
5162
  }
5147
5163
  }
5148
5164
  catch (e_2_1) { e_2 = { error: e_2_1 }; }
5149
5165
  finally {
5150
5166
  try {
5151
- if (_g && !_g.done && (_b = _f.return)) _b.call(_f);
5167
+ if (_h && !_h.done && (_b = _g.return)) _b.call(_g);
5152
5168
  }
5153
5169
  finally { if (e_2) throw e_2.error; }
5154
5170
  }
5171
+ try {
5172
+ for (var availableScrapers_1 = __values(availableScrapers), availableScrapers_1_1 = availableScrapers_1.next(); !availableScrapers_1_1.done; availableScrapers_1_1 = availableScrapers_1.next()) {
5173
+ var metadata_1 = availableScrapers_1_1.value.metadata;
5174
+ all.push(metadata_1);
5175
+ }
5176
+ }
5177
+ catch (e_3_1) { e_3 = { error: e_3_1 }; }
5178
+ finally {
5179
+ try {
5180
+ if (availableScrapers_1_1 && !availableScrapers_1_1.done && (_c = availableScrapers_1.return)) _c.call(availableScrapers_1);
5181
+ }
5182
+ finally { if (e_3) throw e_3.error; }
5183
+ }
5155
5184
  var metadata = all.map(function (metadata) {
5156
5185
  var isMetadataAviailable = $scrapersMetadataRegister
5157
5186
  .list()
@@ -5165,38 +5194,44 @@ function $registeredScrapersMessage() {
5165
5194
  var packageName = _a.packageName, className = _a.className;
5166
5195
  return metadata.packageName === packageName && metadata.className === className;
5167
5196
  });
5168
- return __assign(__assign({}, metadata), { isMetadataAviailable: isMetadataAviailable, isInstalled: isInstalled });
5197
+ var isAvilableInTools = availableScrapers.some(function (_a) {
5198
+ var _b = _a.metadata, packageName = _b.packageName, className = _b.className;
5199
+ return metadata.packageName === packageName && metadata.className === className;
5200
+ });
5201
+ return __assign(__assign({}, metadata), { isMetadataAviailable: isMetadataAviailable, isInstalled: isInstalled, isAvilableInTools: isAvilableInTools });
5169
5202
  });
5170
5203
  if (metadata.length === 0) {
5171
- return "No scrapers are available";
5204
+ return spaceTrim("\n **No scrapers are available**\n\n This is a unexpected behavior, you are probably using some broken version of Promptbook\n At least there should be available the metadata of the scrapers\n ");
5172
5205
  }
5173
5206
  return spaceTrim(function (block) { return "\n Available scrapers are:\n ".concat(block(metadata
5174
5207
  .map(function (_a, i) {
5175
- var packageName = _a.packageName, className = _a.className, isMetadataAviailable = _a.isMetadataAviailable, isInstalled = _a.isInstalled;
5176
- var more;
5177
- if (just(false)) {
5178
- more = '';
5179
- }
5180
- else if (!isMetadataAviailable && !isInstalled) {
5181
- // TODO: [�][�] Maybe do allow to do auto-install if package not registered and not found
5182
- more = "(not installed and no metadata, looks like a unexpected behavior)";
5183
- }
5184
- else if (isMetadataAviailable && !isInstalled) {
5185
- // TODO: [�][�]
5186
- more = "(not installed)";
5187
- }
5188
- else if (!isMetadataAviailable && isInstalled) {
5189
- more = "(no metadata, looks like a unexpected behavior)";
5190
- }
5191
- else if (isMetadataAviailable && isInstalled) {
5192
- more = "(installed)";
5193
- }
5194
- else {
5195
- more = "(unknown state, looks like a unexpected behavior)";
5196
- }
5197
- return "".concat(i + 1, ") `").concat(className, "` from `").concat(packageName, "` ").concat(more);
5208
+ var packageName = _a.packageName, className = _a.className, isMetadataAviailable = _a.isMetadataAviailable, isInstalled = _a.isInstalled, mimeTypes = _a.mimeTypes, isAvilableInBrowser = _a.isAvilableInBrowser, isAvilableInTools = _a.isAvilableInTools;
5209
+ var more = [];
5210
+ // TODO: [🧠] Maybe use `documentationUrl`
5211
+ if (isMetadataAviailable) {
5212
+ more.push("\u2B1C Metadata registered");
5213
+ } // not else
5214
+ if (isInstalled) {
5215
+ more.push("\uD83D\uDFE9 Installed");
5216
+ } // not else
5217
+ if (isAvilableInTools) {
5218
+ more.push("\uD83D\uDFE6 Available in tools");
5219
+ } // not else
5220
+ if (!isMetadataAviailable && isInstalled) {
5221
+ more.push("When no metadata registered but scraper is installed, it is an unexpected behavior");
5222
+ } // not else
5223
+ if (!isInstalled && isAvilableInTools) {
5224
+ more.push("When the scraper is not installed but available in tools, it is an unexpected compatibility behavior");
5225
+ } // not else
5226
+ if (!isAvilableInBrowser) {
5227
+ more.push("Not usable in browser");
5228
+ }
5229
+ var moreText = more.length === 0 ? '' : " *(".concat(more.join('; '), ")*");
5230
+ return "".concat(i + 1, ") `").concat(className, "` from `").concat(packageName, "` compatible to scrape ").concat(mimeTypes
5231
+ .map(function (mimeType) { return "\"".concat(mimeType, "\""); })
5232
+ .join(', ')).concat(moreText);
5198
5233
  })
5199
- .join('\n')), "\n "); });
5234
+ .join('\n')), "\n\n Legend:\n - \u2B1C **Metadata registered** means that Promptbook knows about the scraper, it is similar to registration in some registry\n - \uD83D\uDFE9 **Installed** means that you have imported package with particular scraper\n - \uD83D\uDFE6 **Available in tools** means that you have passed scraper as dependency into prepare or execution process\n\n "); });
5200
5235
  }
5201
5236
  /**
5202
5237
  * TODO: [®] DRY Register logic
@@ -5532,54 +5567,75 @@ function prepareKnowledgePieces(knowledgeSources, tools, options) {
5532
5567
  _a = options.maxParallelCount, maxParallelCount = _a === void 0 ? DEFAULT_MAX_PARALLEL_COUNT : _a, rootDirname = options.rootDirname, _b = options.isVerbose, isVerbose = _b === void 0 ? DEFAULT_IS_VERBOSE : _b;
5533
5568
  knowledgePreparedUnflatten = new Array(knowledgeSources.length);
5534
5569
  return [4 /*yield*/, forEachAsync(knowledgeSources, { maxParallelCount: maxParallelCount }, function (knowledgeSource, index) { return __awaiter(_this, void 0, void 0, function () {
5535
- var partialPieces, sourceHandler, _a, _b, scraper, partialPiecesUnchecked, e_1_1, pieces;
5536
- var e_1, _c;
5537
- return __generator(this, function (_d) {
5538
- switch (_d.label) {
5570
+ var partialPieces, sourceHandler, scrapers, _loop_1, scrapers_1, scrapers_1_1, scraper, state_1, e_1_1, pieces;
5571
+ var e_1, _a;
5572
+ return __generator(this, function (_b) {
5573
+ switch (_b.label) {
5539
5574
  case 0:
5540
5575
  partialPieces = null;
5541
5576
  return [4 /*yield*/, makeKnowledgeSourceHandler(knowledgeSource, tools, { rootDirname: rootDirname, isVerbose: isVerbose })];
5542
5577
  case 1:
5543
- sourceHandler = _d.sent();
5544
- _d.label = 2;
5578
+ sourceHandler = _b.sent();
5579
+ scrapers = arrayableToArray(tools.scrapers);
5580
+ _loop_1 = function (scraper) {
5581
+ var partialPiecesUnchecked;
5582
+ return __generator(this, function (_c) {
5583
+ switch (_c.label) {
5584
+ case 0:
5585
+ if (!scraper.metadata.mimeTypes.includes(sourceHandler.mimeType)
5586
+ // <- TODO: [🦔] Implement mime-type wildcards
5587
+ ) {
5588
+ return [2 /*return*/, "continue"];
5589
+ }
5590
+ return [4 /*yield*/, scraper.scrape(sourceHandler)];
5591
+ case 1:
5592
+ partialPiecesUnchecked = _c.sent();
5593
+ if (partialPiecesUnchecked !== null) {
5594
+ partialPieces = __spreadArray([], __read(partialPiecesUnchecked), false);
5595
+ return [2 /*return*/, "break"];
5596
+ }
5597
+ console.warn(spaceTrim(function (block) { return "\n Cannot scrape knowledge from source despite the scraper `".concat(scraper.metadata.className, "` supports the mime type \"").concat(sourceHandler.mimeType, "\".\n \n The source:\n > ").concat(block(knowledgeSource.sourceContent
5598
+ .split('\n')
5599
+ .map(function (line) { return "> ".concat(line); })
5600
+ .join('\n')), "\n\n ").concat(block($registeredScrapersMessage(scrapers)), "\n\n\n "); }));
5601
+ return [2 /*return*/];
5602
+ }
5603
+ });
5604
+ };
5605
+ _b.label = 2;
5545
5606
  case 2:
5546
- _d.trys.push([2, 7, 8, 9]);
5547
- _a = __values(arrayableToArray(tools.scrapers)), _b = _a.next();
5548
- _d.label = 3;
5607
+ _b.trys.push([2, 7, 8, 9]);
5608
+ scrapers_1 = __values(scrapers), scrapers_1_1 = scrapers_1.next();
5609
+ _b.label = 3;
5549
5610
  case 3:
5550
- if (!!_b.done) return [3 /*break*/, 6];
5551
- scraper = _b.value;
5552
- if (!scraper.metadata.mimeTypes.includes(sourceHandler.mimeType)
5553
- // <- TODO: [🦔] Implement mime-type wildcards
5554
- ) {
5555
- return [3 /*break*/, 5];
5556
- }
5557
- return [4 /*yield*/, scraper.scrape(sourceHandler)];
5611
+ if (!!scrapers_1_1.done) return [3 /*break*/, 6];
5612
+ scraper = scrapers_1_1.value;
5613
+ return [5 /*yield**/, _loop_1(scraper)];
5558
5614
  case 4:
5559
- partialPiecesUnchecked = _d.sent();
5560
- if (partialPiecesUnchecked !== null) {
5561
- partialPieces = __spreadArray([], __read(partialPiecesUnchecked), false);
5562
- // <- TODO: [🪓] Here should be no need for spreading new array, just `partialPieces = partialPiecesUnchecked`
5615
+ state_1 = _b.sent();
5616
+ if (state_1 === "break")
5563
5617
  return [3 /*break*/, 6];
5564
- }
5565
- _d.label = 5;
5618
+ _b.label = 5;
5566
5619
  case 5:
5567
- _b = _a.next();
5620
+ scrapers_1_1 = scrapers_1.next();
5568
5621
  return [3 /*break*/, 3];
5569
5622
  case 6: return [3 /*break*/, 9];
5570
5623
  case 7:
5571
- e_1_1 = _d.sent();
5624
+ e_1_1 = _b.sent();
5572
5625
  e_1 = { error: e_1_1 };
5573
5626
  return [3 /*break*/, 9];
5574
5627
  case 8:
5575
5628
  try {
5576
- if (_b && !_b.done && (_c = _a.return)) _c.call(_a);
5629
+ if (scrapers_1_1 && !scrapers_1_1.done && (_a = scrapers_1.return)) _a.call(scrapers_1);
5577
5630
  }
5578
5631
  finally { if (e_1) throw e_1.error; }
5579
5632
  return [7 /*endfinally*/];
5580
5633
  case 9:
5581
5634
  if (partialPieces === null) {
5582
- throw new KnowledgeScrapeError(spaceTrim(function (block) { return "\n Cannot scrape knowledge from source: ".concat(knowledgeSource.sourceContent, "\n\n No scraper found for the mime type \"").concat(sourceHandler.mimeType, "\"\n\n ").concat(block($registeredScrapersMessage()), "\n\n\n "); }));
5635
+ throw new KnowledgeScrapeError(spaceTrim(function (block) { return "\n Cannot scrape knowledge\n \n The source:\n > ".concat(block(knowledgeSource.sourceContent
5636
+ .split('\n')
5637
+ .map(function (line) { return "> ".concat(line); })
5638
+ .join('\n')), "\n\n No scraper found for the mime type \"").concat(sourceHandler.mimeType, "\"\n\n ").concat(block($registeredScrapersMessage(scrapers)), "\n\n\n "); }));
5583
5639
  }
5584
5640
  pieces = partialPieces.map(function (partialPiece) { return (__assign(__assign({}, partialPiece), { sources: [
5585
5641
  {
@@ -10113,7 +10169,56 @@ function getPipelineInterface(pipeline) {
10113
10169
  * @public exported from `@promptbook/core`
10114
10170
  */
10115
10171
  function isPipelineInterfacesEqual(pipelineInterface1, pipelineInterface2) {
10116
- return JSON.stringify(Object.keys(pipelineInterface1)) === JSON.stringify(Object.keys(pipelineInterface2));
10172
+ var e_1, _a, e_2, _b;
10173
+ try {
10174
+ for (var _c = __values(['inputParameters', 'outputParameters']), _d = _c.next(); !_d.done; _d = _c.next()) {
10175
+ var whichParameters = _d.value;
10176
+ var parameters1 = pipelineInterface1[whichParameters]; // <- Note: `isPipelineInterfacesEqual` is just temporary solution, no need to fix this
10177
+ var parameters2 = pipelineInterface2[whichParameters];
10178
+ if (parameters1.length !== parameters2.length) {
10179
+ return false;
10180
+ }
10181
+ var _loop_1 = function (parameter) {
10182
+ var matchingParameter = parameters2.find(function (_a) {
10183
+ var name = _a.name;
10184
+ return name === parameter.name;
10185
+ });
10186
+ if (!matchingParameter) {
10187
+ return { value: false };
10188
+ }
10189
+ // Note: Do not compare description, it is not relevant for compatibility
10190
+ if (matchingParameter.isInput !== parameter.isInput) {
10191
+ return { value: false };
10192
+ }
10193
+ if (matchingParameter.isOutput !== parameter.isOutput) {
10194
+ return { value: false };
10195
+ }
10196
+ };
10197
+ try {
10198
+ for (var parameters1_1 = (e_2 = void 0, __values(parameters1)), parameters1_1_1 = parameters1_1.next(); !parameters1_1_1.done; parameters1_1_1 = parameters1_1.next()) {
10199
+ var parameter = parameters1_1_1.value;
10200
+ var state_1 = _loop_1(parameter);
10201
+ if (typeof state_1 === "object")
10202
+ return state_1.value;
10203
+ }
10204
+ }
10205
+ catch (e_2_1) { e_2 = { error: e_2_1 }; }
10206
+ finally {
10207
+ try {
10208
+ if (parameters1_1_1 && !parameters1_1_1.done && (_b = parameters1_1.return)) _b.call(parameters1_1);
10209
+ }
10210
+ finally { if (e_2) throw e_2.error; }
10211
+ }
10212
+ }
10213
+ }
10214
+ catch (e_1_1) { e_1 = { error: e_1_1 }; }
10215
+ finally {
10216
+ try {
10217
+ if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
10218
+ }
10219
+ finally { if (e_1) throw e_1.error; }
10220
+ }
10221
+ return true;
10117
10222
  }
10118
10223
 
10119
10224
  /**
@@ -10349,5 +10454,5 @@ var PrefixStorage = /** @class */ (function () {
10349
10454
  return PrefixStorage;
10350
10455
  }());
10351
10456
 
10352
- export { $llmToolsMetadataRegister, $llmToolsRegister, $scrapersMetadataRegister, $scrapersRegister, AbstractFormatError, BOOK_LANGUAGE_VERSION, BlackholeStorage, BoilerplateFormfactorDefinition, CLAIM, CallbackInterfaceTools, ChatbotFormfactorDefinition, CollectionError, CsvFormatDefinition, CsvFormatError, DEFAULT_BOOKS_DIRNAME, DEFAULT_CSV_SETTINGS, DEFAULT_EXECUTIONS_CACHE_DIRNAME, DEFAULT_INTERMEDIATE_FILES_STRATEGY, DEFAULT_IS_AUTO_INSTALLED, DEFAULT_IS_VERBOSE, DEFAULT_MAX_EXECUTION_ATTEMPTS, DEFAULT_MAX_KNOWLEDGE_SOURCES_SCRAPING_DEPTH, DEFAULT_MAX_KNOWLEDGE_SOURCES_SCRAPING_TOTAL, DEFAULT_MAX_PARALLEL_COUNT, DEFAULT_PIPELINE_COLLECTION_BASE_FILENAME, DEFAULT_REMOTE_URL, DEFAULT_REMOTE_URL_PATH, DEFAULT_SCRAPE_CACHE_DIRNAME, DEFAULT_TITLE, ERRORS, EXPECTATION_UNITS, EnvironmentMismatchError, ExecutionReportStringOptionsDefaults, ExpectError, FORMFACTOR_DEFINITIONS, GENERIC_PIPELINE_INTERFACE, GeneratorFormfactorDefinition, GenericFormfactorDefinition, KnowledgeScrapeError, LOGO_DARK_SRC, LOGO_LIGHT_SRC, LimitReachedError, MANDATORY_CSV_SETTINGS, MAX_FILENAME_LENGTH, MODEL_VARIANTS, MatcherFormfactorDefinition, MemoryStorage, MissingToolsError, MultipleLlmExecutionTools, NAME, NonTaskSectionTypes, NotFoundError, NotYetImplementedError, PROMPTBOOK_ENGINE_VERSION, ParseError, PipelineExecutionError, PipelineLogicError, PipelineUrlError, PrefixStorage, RESERVED_PARAMETER_NAMES, SectionTypes, SheetsFormfactorDefinition, TaskTypes, TextFormatDefinition, TranslatorFormfactorDefinition, UNCERTAIN_USAGE, UnexpectedError, ZERO_USAGE, _AnthropicClaudeMetadataRegistration, _AzureOpenAiMetadataRegistration, _DocumentScraperMetadataRegistration, _LegacyDocumentScraperMetadataRegistration, _MarkdownScraperMetadataRegistration, _OpenAiAssistantMetadataRegistration, _OpenAiMetadataRegistration, _PdfScraperMetadataRegistration, _WebsiteScraperMetadataRegistration, addUsage, assertsExecutionSuccessful, cacheLlmTools, collectionToJson, countTotalUsage, createCollectionFromJson, createCollectionFromPromise, createCollectionFromUrl, createLlmToolsFromConfiguration, createPipelineExecutor, createSubcollection, embeddingVectorToString, executionReportJsonToString, getPipelineInterface, isPassingExpectations, isPipelineImplementingInterface, isPipelineInterfacesEqual, isPipelinePrepared, joinLlmExecutionTools, limitTotalUsage, makeKnowledgeSourceHandler, pipelineJsonToString, pipelineStringToJson, pipelineStringToJsonSync, prepareKnowledgePieces, preparePersona, preparePipeline, prepareTasks, prettifyPipelineString, stringifyPipelineJson, unpreparePipeline, usageToHuman, usageToWorktime, validatePipeline };
10457
+ export { $llmToolsMetadataRegister, $llmToolsRegister, $scrapersMetadataRegister, $scrapersRegister, AbstractFormatError, BOOK_LANGUAGE_VERSION, BlackholeStorage, BoilerplateFormfactorDefinition, CLAIM, CallbackInterfaceTools, ChatbotFormfactorDefinition, CollectionError, CsvFormatDefinition, CsvFormatError, DEFAULT_BOOKS_DIRNAME, DEFAULT_CSV_SETTINGS, DEFAULT_EXECUTIONS_CACHE_DIRNAME, DEFAULT_INTERMEDIATE_FILES_STRATEGY, DEFAULT_IS_AUTO_INSTALLED, DEFAULT_IS_VERBOSE, DEFAULT_MAX_EXECUTION_ATTEMPTS, DEFAULT_MAX_KNOWLEDGE_SOURCES_SCRAPING_DEPTH, DEFAULT_MAX_KNOWLEDGE_SOURCES_SCRAPING_TOTAL, DEFAULT_MAX_PARALLEL_COUNT, DEFAULT_PIPELINE_COLLECTION_BASE_FILENAME, DEFAULT_REMOTE_URL, DEFAULT_REMOTE_URL_PATH, DEFAULT_SCRAPE_CACHE_DIRNAME, DEFAULT_TITLE, ERRORS, EXPECTATION_UNITS, EnvironmentMismatchError, ExecutionReportStringOptionsDefaults, ExpectError, FORMFACTOR_DEFINITIONS, GENERIC_PIPELINE_INTERFACE, GeneratorFormfactorDefinition, GenericFormfactorDefinition, KnowledgeScrapeError, LOGO_DARK_SRC, LOGO_LIGHT_SRC, LimitReachedError, MANDATORY_CSV_SETTINGS, MAX_FILENAME_LENGTH, MODEL_VARIANTS, MatcherFormfactorDefinition, MemoryStorage, MissingToolsError, MultipleLlmExecutionTools, NAME, NonTaskSectionTypes, NotFoundError, NotYetImplementedError, PROMPTBOOK_ENGINE_VERSION, ParseError, PipelineExecutionError, PipelineLogicError, PipelineUrlError, PrefixStorage, RESERVED_PARAMETER_NAMES, SET_IS_VERBOSE, SectionTypes, SheetsFormfactorDefinition, TaskTypes, TextFormatDefinition, TranslatorFormfactorDefinition, UNCERTAIN_USAGE, UnexpectedError, ZERO_USAGE, _AnthropicClaudeMetadataRegistration, _AzureOpenAiMetadataRegistration, _DocumentScraperMetadataRegistration, _LegacyDocumentScraperMetadataRegistration, _MarkdownScraperMetadataRegistration, _OpenAiAssistantMetadataRegistration, _OpenAiMetadataRegistration, _PdfScraperMetadataRegistration, _WebsiteScraperMetadataRegistration, addUsage, assertsExecutionSuccessful, cacheLlmTools, collectionToJson, countTotalUsage, createCollectionFromJson, createCollectionFromPromise, createCollectionFromUrl, createLlmToolsFromConfiguration, createPipelineExecutor, createSubcollection, embeddingVectorToString, executionReportJsonToString, getPipelineInterface, isPassingExpectations, isPipelineImplementingInterface, isPipelineInterfacesEqual, isPipelinePrepared, joinLlmExecutionTools, limitTotalUsage, makeKnowledgeSourceHandler, pipelineJsonToString, pipelineStringToJson, pipelineStringToJsonSync, prepareKnowledgePieces, preparePersona, preparePipeline, prepareTasks, prettifyPipelineString, stringifyPipelineJson, unpreparePipeline, usageToHuman, usageToWorktime, validatePipeline };
10353
10458
  //# sourceMappingURL=index.es.js.map