@promptbook/vercel 0.80.0 → 0.81.0-7
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 +6 -0
- package/esm/index.es.js +109 -5
- package/esm/index.es.js.map +1 -1
- package/esm/typings/books/index.d.ts +15 -0
- package/esm/typings/src/_packages/core.index.d.ts +2 -6
- package/esm/typings/src/_packages/editable.index.d.ts +10 -0
- package/esm/typings/src/_packages/templates.index.d.ts +4 -0
- package/esm/typings/src/_packages/types.index.d.ts +4 -0
- package/esm/typings/src/_packages/utils.index.d.ts +10 -2
- package/esm/typings/src/config.d.ts +26 -0
- package/esm/typings/src/execution/ExecutionTools.d.ts +7 -0
- package/esm/typings/src/execution/PromptbookFetch.d.ts +5 -0
- package/esm/typings/src/execution/PromptbookFetch.test-type.d.ts +5 -0
- package/esm/typings/src/expectations/drafts/isDomainNameFree.d.ts +2 -1
- package/esm/typings/src/expectations/drafts/isGithubNameFree.d.ts +2 -1
- package/esm/typings/src/high-level-abstractions/index.d.ts +10 -0
- package/esm/typings/src/other/templates/getBookTemplate.d.ts +12 -0
- package/esm/typings/src/other/templates/getTemplatesPipelineCollection.d.ts +10 -0
- package/esm/typings/src/pipeline/PipelineJson/PipelineJson.d.ts +10 -0
- package/esm/typings/src/scrapers/_common/utils/makeKnowledgeSourceHandler.d.ts +1 -1
- package/esm/typings/src/scrapers/_common/utils/scraperFetch.d.ts +7 -0
- package/esm/typings/src/utils/editable/types/PipelineEditableSerialized.d.ts +27 -0
- package/esm/typings/src/{conversion → utils/editable}/utils/removePipelineCommand.d.ts +3 -3
- package/esm/typings/src/{conversion → utils/editable}/utils/renamePipelineParameter.d.ts +3 -3
- package/esm/typings/src/{conversion → utils/editable}/utils/stringifyPipelineJson.d.ts +2 -2
- package/esm/typings/src/utils/parameters/numberToString.d.ts +7 -0
- package/esm/typings/src/utils/parameters/{replaceParameters.d.ts → templateParameters.d.ts} +6 -2
- package/esm/typings/src/utils/parameters/valueToString.d.ts +17 -0
- package/esm/typings/src/utils/parameters/valueToString.test.d.ts +1 -0
- package/esm/typings/src/utils/serialization/asSerializable.d.ts +4 -0
- package/esm/typings/src/version.d.ts +7 -0
- package/package.json +2 -2
- package/umd/index.umd.js +109 -5
- package/umd/index.umd.js.map +1 -1
- package/esm/typings/src/utils/formatNumber.d.ts +0 -6
- /package/esm/typings/src/{conversion → utils/editable}/utils/removePipelineCommand.test.d.ts +0 -0
- /package/esm/typings/src/{conversion → utils/editable}/utils/renamePipelineParameter.test.d.ts +0 -0
- /package/esm/typings/src/{conversion → utils/editable}/utils/stringifyPipelineJson.test.d.ts +0 -0
- /package/esm/typings/src/utils/{formatNumber.test.d.ts → parameters/numberToString.test.d.ts} +0 -0
- /package/esm/typings/src/utils/parameters/{replaceParameters.test.d.ts → templateParameters.test.d.ts} +0 -0
|
@@ -1,8 +1,9 @@
|
|
|
1
|
+
import type { PromptbookFetch } from '../../execution/PromptbookFetch';
|
|
1
2
|
import type { string_name } from '../../types/typeAliases';
|
|
2
3
|
/**
|
|
3
4
|
* @private still in development
|
|
4
5
|
*/
|
|
5
|
-
export declare function isGithubNameFree(name: string_name): Promise<boolean>;
|
|
6
|
+
export declare function isGithubNameFree(name: string_name, fetch: PromptbookFetch): Promise<boolean>;
|
|
6
7
|
/**
|
|
7
8
|
* TODO: [🍓][🧠] Test and implement `isGithubNameFree`
|
|
8
9
|
* TODO: Export via some (and probably new) NPM package
|
|
@@ -18,6 +18,11 @@ export declare const HIGH_LEVEL_ABSTRACTIONS: readonly [{
|
|
|
18
18
|
readonly knowledgePieces: import("../_packages/types.index").KnowledgePiecePreparedJson[];
|
|
19
19
|
readonly personas: (import("../_packages/types.index").PersonaJson | import("../_packages/types.index").PersonaPreparedJson)[];
|
|
20
20
|
readonly preparations: import("../_packages/types.index").PreparationJson[];
|
|
21
|
+
readonly sources: readonly {
|
|
22
|
+
type: "BOOK";
|
|
23
|
+
path: string | null;
|
|
24
|
+
content: import("../pipeline/PipelineString").PipelineString;
|
|
25
|
+
}[];
|
|
21
26
|
readonly formfactorName?: "CHATBOT" | "GENERATOR" | "GENERIC" | "EXPERIMENTAL_MATCHER" | "SHEETS" | "TRANSLATOR" | undefined;
|
|
22
27
|
}>): void;
|
|
23
28
|
}, {
|
|
@@ -35,6 +40,11 @@ export declare const HIGH_LEVEL_ABSTRACTIONS: readonly [{
|
|
|
35
40
|
readonly knowledgePieces: import("../_packages/types.index").KnowledgePiecePreparedJson[];
|
|
36
41
|
readonly personas: (import("../_packages/types.index").PersonaJson | import("../_packages/types.index").PersonaPreparedJson)[];
|
|
37
42
|
readonly preparations: import("../_packages/types.index").PreparationJson[];
|
|
43
|
+
readonly sources: readonly {
|
|
44
|
+
type: "BOOK";
|
|
45
|
+
path: string | null;
|
|
46
|
+
content: import("../pipeline/PipelineString").PipelineString;
|
|
47
|
+
}[];
|
|
38
48
|
readonly formfactorName?: "CHATBOT" | "GENERATOR" | "GENERIC" | "EXPERIMENTAL_MATCHER" | "SHEETS" | "TRANSLATOR" | undefined;
|
|
39
49
|
}>): void;
|
|
40
50
|
}];
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { string_formfactor_name } from '../../formfactors/_common/string_formfactor_name';
|
|
2
|
+
import type { PipelineJson } from '../../pipeline/PipelineJson/PipelineJson';
|
|
3
|
+
/**
|
|
4
|
+
* Get template for new book
|
|
5
|
+
*
|
|
6
|
+
* @public exported from `@promptbook/templates`
|
|
7
|
+
*/
|
|
8
|
+
export declare function getBookTemplate(formfactorName: string_formfactor_name): Promise<PipelineJson | null>;
|
|
9
|
+
/**
|
|
10
|
+
* TODO: [🧠] Which is the best place for this function
|
|
11
|
+
* TODO: !!!!!! `book string template notation
|
|
12
|
+
*/
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { PipelineCollection } from '../../collection/PipelineCollection';
|
|
2
|
+
/**
|
|
3
|
+
* Get pipeline collection for Untitled Promptbook project
|
|
4
|
+
*
|
|
5
|
+
* ⚠️ WARNING: This code has been generated by `@promptbook/cli` so that any manual changes will be overwritten
|
|
6
|
+
*
|
|
7
|
+
* @generated
|
|
8
|
+
* @returns {PipelineCollection} Library of promptbooks for Untitled Promptbook project
|
|
9
|
+
*/
|
|
10
|
+
export declare function getTemplatesPipelineCollection(): PipelineCollection;
|
|
@@ -3,7 +3,9 @@ import type { ModelRequirements } from '../../types/ModelRequirements';
|
|
|
3
3
|
import type { string_filename } from '../../types/typeAliases';
|
|
4
4
|
import type { string_markdown_text } from '../../types/typeAliases';
|
|
5
5
|
import type { string_pipeline_url } from '../../types/typeAliases';
|
|
6
|
+
import type { string_relative_filename } from '../../types/typeAliases';
|
|
6
7
|
import type { string_semantic_version } from '../../types/typeAliases';
|
|
8
|
+
import type { PipelineString } from '../PipelineString';
|
|
7
9
|
import type { KnowledgePiecePreparedJson } from './KnowledgePieceJson';
|
|
8
10
|
import type { KnowledgeSourceJson } from './KnowledgeSourceJson';
|
|
9
11
|
import type { KnowledgeSourcePreparedJson } from './KnowledgeSourceJson';
|
|
@@ -91,6 +93,14 @@ export type PipelineJson = {
|
|
|
91
93
|
* @see https://github.com/webgptorg/promptbook/discussions/78
|
|
92
94
|
*/
|
|
93
95
|
readonly preparations: Array<PreparationJson>;
|
|
96
|
+
/**
|
|
97
|
+
* Backup of the original book source
|
|
98
|
+
*/
|
|
99
|
+
readonly sources: ReadonlyArray<{
|
|
100
|
+
type: 'BOOK';
|
|
101
|
+
path: string_relative_filename | null;
|
|
102
|
+
content: PipelineString;
|
|
103
|
+
}>;
|
|
94
104
|
};
|
|
95
105
|
/**
|
|
96
106
|
* TODO: [🛳] Default PERSONA for the pipeline `defaultPersonaName` (same as `defaultModelRequirements`)
|
|
@@ -8,4 +8,4 @@ import type { ScraperSourceHandler } from '../Scraper';
|
|
|
8
8
|
*
|
|
9
9
|
* @public exported from `@promptbook/core`
|
|
10
10
|
*/
|
|
11
|
-
export declare function makeKnowledgeSourceHandler(knowledgeSource: SetOptional<KnowledgeSourceJson, 'name'>, tools: Pick<ExecutionTools, 'fs'>, options?: Pick<PrepareAndScrapeOptions, 'rootDirname' | 'isVerbose'>): Promise<ScraperSourceHandler>;
|
|
11
|
+
export declare function makeKnowledgeSourceHandler(knowledgeSource: SetOptional<KnowledgeSourceJson, 'name'>, tools: Pick<ExecutionTools, 'fs' | 'fetch'>, options?: Pick<PrepareAndScrapeOptions, 'rootDirname' | 'isVerbose'>): Promise<ScraperSourceHandler>;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { PromptbookFetch } from '../../../execution/PromptbookFetch';
|
|
2
|
+
/**
|
|
3
|
+
* The built-in `fetch' function with a lightweight error handling wrapper as default fetch function used in Promptbook scrapers
|
|
4
|
+
*
|
|
5
|
+
* @private as default `fetch` function used in Promptbook scrapers
|
|
6
|
+
*/
|
|
7
|
+
export declare const scraperFetch: PromptbookFetch;
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import type { ErrorJson } from '../../../errors/utils/ErrorJson';
|
|
2
|
+
import type { PipelineJson } from '../../../pipeline/PipelineJson/PipelineJson';
|
|
3
|
+
import type { string_date_iso8601 } from '../../../types/typeAliases';
|
|
4
|
+
/**
|
|
5
|
+
* Represents a single pipeline in PromptbookStudio
|
|
6
|
+
*
|
|
7
|
+
* This is simple extension of PipelineJson with additional metadata
|
|
8
|
+
* Note: There are two similar entities:
|
|
9
|
+
* 1) Type (interface) `PipelineEditableSerialized` which represents just data in database
|
|
10
|
+
* 2) Class `PipelineEditable` which implements `PipelineEditableSerialized` and adds error handling and editing capabilities
|
|
11
|
+
*
|
|
12
|
+
* @public exported from `@promptbook/editable`
|
|
13
|
+
*/
|
|
14
|
+
export type PipelineEditableSerialized = PipelineJson & {
|
|
15
|
+
/**
|
|
16
|
+
* When was the pipeline created
|
|
17
|
+
*/
|
|
18
|
+
readonly createdAt: string_date_iso8601;
|
|
19
|
+
/**
|
|
20
|
+
* When was the pipeline last modified
|
|
21
|
+
*/
|
|
22
|
+
readonly updatedAt: string_date_iso8601 | null;
|
|
23
|
+
/**
|
|
24
|
+
* Known errors to transfer to new PipelineEditable
|
|
25
|
+
*/
|
|
26
|
+
readonly knownErrors: Array<ErrorJson>;
|
|
27
|
+
};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import type { CommandType } from '
|
|
2
|
-
import type { PipelineString } from '
|
|
1
|
+
import type { CommandType } from '../../../commands/_common/types/CommandType';
|
|
2
|
+
import type { PipelineString } from '../../../pipeline/PipelineString';
|
|
3
3
|
/**
|
|
4
4
|
* Options for `removePipelineCommand`
|
|
5
5
|
*/
|
|
@@ -16,7 +16,7 @@ type RemovePipelineCommandOptions = {
|
|
|
16
16
|
/**
|
|
17
17
|
* Function `removePipelineCommand` will remove one command from pipeline string
|
|
18
18
|
*
|
|
19
|
-
* @public exported from `@promptbook/
|
|
19
|
+
* @public exported from `@promptbook/editable`
|
|
20
20
|
*/
|
|
21
21
|
export declare function removePipelineCommand(options: RemovePipelineCommandOptions): PipelineString;
|
|
22
22
|
export {};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import type { PipelineJson } from '
|
|
2
|
-
import type { string_name } from '
|
|
1
|
+
import type { PipelineJson } from '../../../pipeline/PipelineJson/PipelineJson';
|
|
2
|
+
import type { string_name } from '../../../types/typeAliases';
|
|
3
3
|
type RenameParameterOptions = {
|
|
4
4
|
/**
|
|
5
5
|
* Pipeline to search and replace for parameters
|
|
@@ -20,7 +20,7 @@ type RenameParameterOptions = {
|
|
|
20
20
|
* In other words, it will find all parameters that are not used in the task itseld and all its dependencies
|
|
21
21
|
*
|
|
22
22
|
* @throws {PipelineLogicError} If the new parameter name is already used in the pipeline
|
|
23
|
-
* @public exported from `@promptbook/
|
|
23
|
+
* @public exported from `@promptbook/editable`
|
|
24
24
|
*/
|
|
25
25
|
export declare function renamePipelineParameter(options: RenameParameterOptions): PipelineJson;
|
|
26
26
|
export {};
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import type { string_json } from '
|
|
1
|
+
import type { string_json } from '../../../types/typeAliases';
|
|
2
2
|
/**
|
|
3
3
|
* Stringify the PipelineJson with proper formatting
|
|
4
4
|
*
|
|
5
5
|
* Note: [0] It can be used for more JSON types like whole collection of pipelines, single knowledge piece, etc.
|
|
6
6
|
* Note: In contrast to JSON.stringify, this function ensures that **embedding index** is on single line
|
|
7
7
|
*
|
|
8
|
-
* @public exported from `@promptbook/
|
|
8
|
+
* @public exported from `@promptbook/editable`
|
|
9
9
|
*/
|
|
10
10
|
export declare function stringifyPipelineJson<TType>(pipeline: TType): string_json<TType>;
|
|
11
11
|
/**
|
|
@@ -1,12 +1,16 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { string_parameter_name } from '../../types/typeAliases';
|
|
2
2
|
import type { string_template } from '../../types/typeAliases';
|
|
3
|
+
import type { really_unknown } from '../organization/really_unknown';
|
|
3
4
|
/**
|
|
4
5
|
* Replaces parameters in template with values from parameters object
|
|
5
6
|
*
|
|
7
|
+
* Note: This function is not places strings into string,
|
|
8
|
+
* It's more complex and can handle this operation specifically for LLM models
|
|
9
|
+
*
|
|
6
10
|
* @param template the template with parameters in {curly} braces
|
|
7
11
|
* @param parameters the object with parameters
|
|
8
12
|
* @returns the template with replaced parameters
|
|
9
13
|
* @throws {PipelineExecutionError} if parameter is not defined, not closed, or not opened
|
|
10
14
|
* @public exported from `@promptbook/utils`
|
|
11
15
|
*/
|
|
12
|
-
export declare function
|
|
16
|
+
export declare function templateParameters(template: string_template, parameters: Record<string_parameter_name, really_unknown>): string;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { string_parameter_value } from '../../types/typeAliases';
|
|
2
|
+
import type { really_unknown } from '../organization/really_unknown';
|
|
3
|
+
/**
|
|
4
|
+
* Function `valueToString` will convert the given value to string
|
|
5
|
+
* This is useful and used in the `templateParameters` function
|
|
6
|
+
*
|
|
7
|
+
* Note: This function is not just calling `toString` method
|
|
8
|
+
* It's more complex and can handle this conversion specifically for LLM models
|
|
9
|
+
* See `VALUE_STRINGS`
|
|
10
|
+
*
|
|
11
|
+
* Note: There are 2 similar functions
|
|
12
|
+
* - `valueToString` converts value to string for LLM models as human-readable string
|
|
13
|
+
* - `asSerializable` converts value to string to preserve full information to be able to convert it back
|
|
14
|
+
*
|
|
15
|
+
* @public exported from `@promptbook/utils`
|
|
16
|
+
*/
|
|
17
|
+
export declare function valueToString(value: really_unknown): string_parameter_value;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -6,6 +6,10 @@ import type { really_any } from '../organization/really_any';
|
|
|
6
6
|
* For example:
|
|
7
7
|
* - `Date` objects will be converted to string
|
|
8
8
|
*
|
|
9
|
+
* Note: There are 2 similar functions
|
|
10
|
+
* - `valueToString` converts value to string for LLM models as human-readable string
|
|
11
|
+
* - `asSerializable` converts value to string to preserve full information to be able to convert it back
|
|
12
|
+
*
|
|
9
13
|
* @private Internal helper function
|
|
10
14
|
*/
|
|
11
15
|
export declare function asSerializable(value: really_any): really_any;
|
|
@@ -2,15 +2,22 @@ import type { string_semantic_version } from './types/typeAliases';
|
|
|
2
2
|
/**
|
|
3
3
|
* The version of the Book language
|
|
4
4
|
*
|
|
5
|
+
* @generated
|
|
5
6
|
* @see https://github.com/webgptorg/book
|
|
6
7
|
*/
|
|
7
8
|
export declare const BOOK_LANGUAGE_VERSION: string_semantic_version;
|
|
8
9
|
/**
|
|
9
10
|
* The version of the Promptbook engine
|
|
10
11
|
*
|
|
12
|
+
* @generated
|
|
11
13
|
* @see https://github.com/webgptorg/promptbook
|
|
12
14
|
*/
|
|
13
15
|
export declare const PROMPTBOOK_ENGINE_VERSION: string_promptbook_version;
|
|
16
|
+
/**
|
|
17
|
+
* @@@
|
|
18
|
+
*
|
|
19
|
+
* @generated
|
|
20
|
+
*/
|
|
14
21
|
export type string_promptbook_version = string_semantic_version;
|
|
15
22
|
/**
|
|
16
23
|
* TODO: string_promptbook_version should be constrained to the all versions of Promptbook engine
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@promptbook/vercel",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.81.0-7",
|
|
4
4
|
"description": "It's time for a paradigm shift. The future of software in plain English, French or Latin",
|
|
5
5
|
"--note-0": " <- [🐊]",
|
|
6
6
|
"private": false,
|
|
@@ -54,7 +54,7 @@
|
|
|
54
54
|
"module": "./esm/index.es.js",
|
|
55
55
|
"typings": "./esm/typings/src/_packages/vercel.index.d.ts",
|
|
56
56
|
"peerDependencies": {
|
|
57
|
-
"@promptbook/core": "0.
|
|
57
|
+
"@promptbook/core": "0.81.0-7"
|
|
58
58
|
},
|
|
59
59
|
"dependencies": {
|
|
60
60
|
"colors": "1.4.0",
|
package/umd/index.umd.js
CHANGED
|
@@ -13,15 +13,17 @@
|
|
|
13
13
|
/**
|
|
14
14
|
* The version of the Book language
|
|
15
15
|
*
|
|
16
|
+
* @generated
|
|
16
17
|
* @see https://github.com/webgptorg/book
|
|
17
18
|
*/
|
|
18
19
|
var BOOK_LANGUAGE_VERSION = '1.0.0';
|
|
19
20
|
/**
|
|
20
21
|
* The version of the Promptbook engine
|
|
21
22
|
*
|
|
23
|
+
* @generated
|
|
22
24
|
* @see https://github.com/webgptorg/promptbook
|
|
23
25
|
*/
|
|
24
|
-
var PROMPTBOOK_ENGINE_VERSION = '0.
|
|
26
|
+
var PROMPTBOOK_ENGINE_VERSION = '0.81.0-6';
|
|
25
27
|
/**
|
|
26
28
|
* TODO: string_promptbook_version should be constrained to the all versions of Promptbook engine
|
|
27
29
|
* Note: [💞] Ignore a discrepancy between file name and entity name
|
|
@@ -295,6 +297,26 @@
|
|
|
295
297
|
* @private within the repository - too low-level in comparison with other `MAX_...`
|
|
296
298
|
*/
|
|
297
299
|
var LOOP_LIMIT = 1000;
|
|
300
|
+
/**
|
|
301
|
+
* Strings to represent various values in the context of parameter values
|
|
302
|
+
*
|
|
303
|
+
* @public exported from `@promptbook/utils`
|
|
304
|
+
*/
|
|
305
|
+
var VALUE_STRINGS = {
|
|
306
|
+
empty: '(nothing; empty string)',
|
|
307
|
+
null: '(no value; null)',
|
|
308
|
+
undefined: '(unknown value; undefined)',
|
|
309
|
+
nan: '(not a number; NaN)',
|
|
310
|
+
infinity: '(infinity; ∞)',
|
|
311
|
+
negativeInfinity: '(negative infinity; -∞)',
|
|
312
|
+
unserializable: '(unserializable value)',
|
|
313
|
+
};
|
|
314
|
+
/**
|
|
315
|
+
* Small number limit
|
|
316
|
+
*
|
|
317
|
+
* @public exported from `@promptbook/utils`
|
|
318
|
+
*/
|
|
319
|
+
var SMALL_NUMBER = 0.001;
|
|
298
320
|
// <- TODO: [🧜♂️]
|
|
299
321
|
/**
|
|
300
322
|
* @@@
|
|
@@ -598,16 +620,94 @@
|
|
|
598
620
|
return LimitReachedError;
|
|
599
621
|
}(Error));
|
|
600
622
|
|
|
623
|
+
/**
|
|
624
|
+
* Format either small or big number
|
|
625
|
+
*
|
|
626
|
+
* @public exported from `@promptbook/utils`
|
|
627
|
+
*/
|
|
628
|
+
function numberToString(value) {
|
|
629
|
+
if (value === 0) {
|
|
630
|
+
return '0';
|
|
631
|
+
}
|
|
632
|
+
else if (Number.isNaN(value)) {
|
|
633
|
+
return VALUE_STRINGS.nan;
|
|
634
|
+
}
|
|
635
|
+
else if (value === Infinity) {
|
|
636
|
+
return VALUE_STRINGS.infinity;
|
|
637
|
+
}
|
|
638
|
+
else if (value === -Infinity) {
|
|
639
|
+
return VALUE_STRINGS.negativeInfinity;
|
|
640
|
+
}
|
|
641
|
+
for (var exponent = 0; exponent < 15; exponent++) {
|
|
642
|
+
var factor = Math.pow(10, exponent);
|
|
643
|
+
var valueRounded = Math.round(value * factor) / factor;
|
|
644
|
+
if (Math.abs(value - valueRounded) / value < SMALL_NUMBER) {
|
|
645
|
+
return valueRounded.toFixed(exponent);
|
|
646
|
+
}
|
|
647
|
+
}
|
|
648
|
+
return value.toString();
|
|
649
|
+
}
|
|
650
|
+
|
|
651
|
+
/**
|
|
652
|
+
* Function `valueToString` will convert the given value to string
|
|
653
|
+
* This is useful and used in the `templateParameters` function
|
|
654
|
+
*
|
|
655
|
+
* Note: This function is not just calling `toString` method
|
|
656
|
+
* It's more complex and can handle this conversion specifically for LLM models
|
|
657
|
+
* See `VALUE_STRINGS`
|
|
658
|
+
*
|
|
659
|
+
* Note: There are 2 similar functions
|
|
660
|
+
* - `valueToString` converts value to string for LLM models as human-readable string
|
|
661
|
+
* - `asSerializable` converts value to string to preserve full information to be able to convert it back
|
|
662
|
+
*
|
|
663
|
+
* @public exported from `@promptbook/utils`
|
|
664
|
+
*/
|
|
665
|
+
function valueToString(value) {
|
|
666
|
+
try {
|
|
667
|
+
if (value === '') {
|
|
668
|
+
return VALUE_STRINGS.empty;
|
|
669
|
+
}
|
|
670
|
+
else if (value === null) {
|
|
671
|
+
return VALUE_STRINGS.null;
|
|
672
|
+
}
|
|
673
|
+
else if (value === undefined) {
|
|
674
|
+
return VALUE_STRINGS.undefined;
|
|
675
|
+
}
|
|
676
|
+
else if (typeof value === 'string') {
|
|
677
|
+
return value;
|
|
678
|
+
}
|
|
679
|
+
else if (typeof value === 'number') {
|
|
680
|
+
return numberToString(value);
|
|
681
|
+
}
|
|
682
|
+
else if (value instanceof Date) {
|
|
683
|
+
return value.toISOString();
|
|
684
|
+
}
|
|
685
|
+
else {
|
|
686
|
+
return JSON.stringify(value);
|
|
687
|
+
}
|
|
688
|
+
}
|
|
689
|
+
catch (error) {
|
|
690
|
+
if (!(error instanceof Error)) {
|
|
691
|
+
throw error;
|
|
692
|
+
}
|
|
693
|
+
console.error(error);
|
|
694
|
+
return VALUE_STRINGS.unserializable;
|
|
695
|
+
}
|
|
696
|
+
}
|
|
697
|
+
|
|
601
698
|
/**
|
|
602
699
|
* Replaces parameters in template with values from parameters object
|
|
603
700
|
*
|
|
701
|
+
* Note: This function is not places strings into string,
|
|
702
|
+
* It's more complex and can handle this operation specifically for LLM models
|
|
703
|
+
*
|
|
604
704
|
* @param template the template with parameters in {curly} braces
|
|
605
705
|
* @param parameters the object with parameters
|
|
606
706
|
* @returns the template with replaced parameters
|
|
607
707
|
* @throws {PipelineExecutionError} if parameter is not defined, not closed, or not opened
|
|
608
708
|
* @public exported from `@promptbook/utils`
|
|
609
709
|
*/
|
|
610
|
-
function
|
|
710
|
+
function templateParameters(template, parameters) {
|
|
611
711
|
var e_1, _a;
|
|
612
712
|
try {
|
|
613
713
|
for (var _b = __values(Object.entries(parameters)), _c = _b.next(); !_c.done; _c = _b.next()) {
|
|
@@ -633,7 +733,7 @@
|
|
|
633
733
|
var loopLimit = LOOP_LIMIT;
|
|
634
734
|
var _loop_1 = function () {
|
|
635
735
|
if (loopLimit-- < 0) {
|
|
636
|
-
throw new LimitReachedError('Loop limit reached during parameters replacement in `
|
|
736
|
+
throw new LimitReachedError('Loop limit reached during parameters replacement in `templateParameters`');
|
|
637
737
|
}
|
|
638
738
|
var precol = match.groups.precol;
|
|
639
739
|
var parameterName = match.groups.parameterName;
|
|
@@ -650,7 +750,7 @@
|
|
|
650
750
|
if (parameterValue === undefined) {
|
|
651
751
|
throw new PipelineExecutionError("Parameter `{".concat(parameterName, "}` is not defined"));
|
|
652
752
|
}
|
|
653
|
-
parameterValue = parameterValue
|
|
753
|
+
parameterValue = valueToString(parameterValue);
|
|
654
754
|
if (parameterValue.includes('\n') && /^\s*\W{0,3}\s*$/.test(precol)) {
|
|
655
755
|
parameterValue = parameterValue
|
|
656
756
|
.split('\n')
|
|
@@ -684,6 +784,10 @@
|
|
|
684
784
|
* For example:
|
|
685
785
|
* - `Date` objects will be converted to string
|
|
686
786
|
*
|
|
787
|
+
* Note: There are 2 similar functions
|
|
788
|
+
* - `valueToString` converts value to string for LLM models as human-readable string
|
|
789
|
+
* - `asSerializable` converts value to string to preserve full information to be able to convert it back
|
|
790
|
+
*
|
|
687
791
|
* @private Internal helper function
|
|
688
792
|
*/
|
|
689
793
|
function asSerializable(value) {
|
|
@@ -761,7 +865,7 @@
|
|
|
761
865
|
return [4 /*yield*/, vercelProvider.chat(modelName, __assign({ user: (userId === null || userId === void 0 ? void 0 : userId.toString()) || undefined }, additionalChatSettings))];
|
|
762
866
|
case 1:
|
|
763
867
|
model = _b.sent();
|
|
764
|
-
rawPromptContent =
|
|
868
|
+
rawPromptContent = templateParameters(content, __assign(__assign({}, parameters), { modelName: modelName }));
|
|
765
869
|
rawRequest = {
|
|
766
870
|
// <- TODO: [☂]
|
|
767
871
|
inputFormat: 'messages',
|