mirror of
https://git.mirrors.martin98.com/https://github.com/mendableai/firecrawl
synced 2025-08-08 18:59:00 +08:00
Merge pull request #955 from mendableai/rafa/fix-default-on-schema-llm-extract
fixed optional+default bug on llm schema
This commit is contained in:
commit
eba5fda9a1
@ -70,8 +70,8 @@ content-type: application/json
|
|||||||
"urls": ["firecrawl.dev"],
|
"urls": ["firecrawl.dev"],
|
||||||
"prompt": "What is the title, description and main product of the page?",
|
"prompt": "What is the title, description and main product of the page?",
|
||||||
"schema": {
|
"schema": {
|
||||||
"title": "string",
|
"title": { "type": "string" },
|
||||||
"description": "string",
|
"description": { "type": "string" },
|
||||||
"mainProduct": "string"
|
"mainProduct": { "type": "string" }
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -0,0 +1,33 @@
|
|||||||
|
import { removeDefaultProperty } from "./llmExtract";
|
||||||
|
|
||||||
|
describe("removeDefaultProperty", () => {
|
||||||
|
it("should remove the default property from a simple object", () => {
|
||||||
|
const input = { default: "test", test: "test" };
|
||||||
|
const expectedOutput = { test: "test" };
|
||||||
|
expect(removeDefaultProperty(input)).toEqual(expectedOutput);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should remove the default property from a nested object", () => {
|
||||||
|
const input = { default: "test", nested: { default: "nestedTest", test: "nestedTest" } };
|
||||||
|
const expectedOutput = { nested: { test: "nestedTest" } };
|
||||||
|
expect(removeDefaultProperty(input)).toEqual(expectedOutput);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should remove the default property from an array of objects", () => {
|
||||||
|
const input = { array: [{ default: "test1", test: "test1" }, { default: "test2", test: "test2" }] };
|
||||||
|
const expectedOutput = { array: [{ test: "test1" }, { test: "test2" }] };
|
||||||
|
expect(removeDefaultProperty(input)).toEqual(expectedOutput);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should handle objects without a default property", () => {
|
||||||
|
const input = { test: "test" };
|
||||||
|
const expectedOutput = { test: "test" };
|
||||||
|
expect(removeDefaultProperty(input)).toEqual(expectedOutput);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("should handle null and non-object inputs", () => {
|
||||||
|
expect(removeDefaultProperty(null)).toBeNull();
|
||||||
|
expect(removeDefaultProperty("string")).toBe("string");
|
||||||
|
expect(removeDefaultProperty(123)).toBe(123);
|
||||||
|
});
|
||||||
|
});
|
@ -121,6 +121,10 @@ export async function generateOpenAICompletions(
|
|||||||
}
|
}
|
||||||
|
|
||||||
let schema = options.schema;
|
let schema = options.schema;
|
||||||
|
if (schema) {
|
||||||
|
schema = removeDefaultProperty(schema);
|
||||||
|
}
|
||||||
|
|
||||||
if (schema && schema.type === "array") {
|
if (schema && schema.type === "array") {
|
||||||
schema = {
|
schema = {
|
||||||
type: "object",
|
type: "object",
|
||||||
@ -134,10 +138,12 @@ export async function generateOpenAICompletions(
|
|||||||
schema = {
|
schema = {
|
||||||
type: "object",
|
type: "object",
|
||||||
properties: Object.fromEntries(
|
properties: Object.fromEntries(
|
||||||
Object.entries(schema).map(([key, value]) => [key, { type: value }]),
|
Object.entries(schema).map(([key, value]) => {
|
||||||
|
return [key, removeDefaultProperty(value)];
|
||||||
|
})
|
||||||
),
|
),
|
||||||
required: Object.keys(schema),
|
required: Object.keys(schema),
|
||||||
additionalProperties: false,
|
additionalProperties: false
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -232,3 +238,19 @@ export async function performLLMExtract(
|
|||||||
|
|
||||||
return document;
|
return document;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function removeDefaultProperty(schema: any): any {
|
||||||
|
if (typeof schema !== 'object' || schema === null) return schema;
|
||||||
|
|
||||||
|
const { default: _, ...rest } = schema;
|
||||||
|
|
||||||
|
for (const key in rest) {
|
||||||
|
if (Array.isArray(rest[key])) {
|
||||||
|
rest[key] = rest[key].map((item: any) => removeDefaultProperty(item));
|
||||||
|
} else if (typeof rest[key] === 'object' && rest[key] !== null) {
|
||||||
|
rest[key] = removeDefaultProperty(rest[key]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return rest;
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user