Skip to content

Commit

Permalink
Add set and range filters to filter validation
Browse files Browse the repository at this point in the history
  • Loading branch information
garrettgu10 committed Dec 18, 2024
1 parent 8def8c9 commit 7089424
Show file tree
Hide file tree
Showing 3 changed files with 34 additions and 30 deletions.
4 changes: 2 additions & 2 deletions packages/wrangler/src/__tests__/vectorize/vectorize.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -727,11 +727,11 @@ describe("vectorize commands", () => {
describe("vectorize query filter", () => {
it("should parse correctly", async () => {
let jsonString =
'{ "p1": "abc", "p2": { "$ne": true }, "p3": 10, "p4": false, "nested.p5": "abcd" }'; // Successful parse
'{ "p1": "abc", "p2": { "$ne": true }, "p3": 10, "p4": false, "nested.p5": "abcd", "p6": { "$in": ["a", 3, 4] }, "p7": {"$gt": 4, "$lte": "aaa"} }'; // Successful parse
expect(
JSON.stringify(validateQueryFilter(JSON.parse(jsonString)))
).toMatchInlineSnapshot(
`"{\\"p1\\":\\"abc\\",\\"p2\\":{\\"$ne\\":true},\\"p3\\":10,\\"p4\\":false,\\"nested.p5\\":\\"abcd\\"}"`
`"{\\"p1\\":\\"abc\\",\\"p2\\":{\\"$ne\\":true},\\"p3\\":10,\\"p4\\":false,\\"nested.p5\\":\\"abcd\\",\\"p6\\":{\\"$in\\":[\\"a\\",3,4]},\\"p7\\":{\\"$gt\\":4,\\"$lte\\":\\"aaa\\"}}"`
);

jsonString =
Expand Down
48 changes: 22 additions & 26 deletions packages/wrangler/src/vectorize/query.ts
Original file line number Diff line number Diff line change
Expand Up @@ -155,6 +155,10 @@ export async function handler(
logger.log(JSON.stringify(res, null, 2));
}

function validateQueryFilterInnerValue(innerValue: any) {

Check failure on line 158 in packages/wrangler/src/vectorize/query.ts

View workflow job for this annotation

GitHub Actions / Checks

Unexpected any. Specify a different type
return ["string", "number", "boolean"].includes(typeof innerValue);
}

export function validateQueryFilter(
input: object
): VectorizeVectorMetadataFilter | null {
Expand Down Expand Up @@ -186,38 +190,30 @@ export function validateQueryFilter(

if (typeof value === "object" && value !== null) {
// Handle nested objects
const innerObj: Partial<{
[Op in VectorizeVectorMetadataFilterOp]?: Exclude<
VectorizeVectorMetadataValue,
string[]
> | null;
}> = {};
const innerObj: any = {};

Check failure on line 193 in packages/wrangler/src/vectorize/query.ts

View workflow job for this annotation

GitHub Actions / Checks

Unexpected any. Specify a different type
let validInnerObj = true;

for (const op in value) {
if (Object.prototype.hasOwnProperty.call(value, op)) {
if (!["$eq", "$ne"].includes(op)) {
// Skip objects with invalid operators
validInnerObj = false;
break;
}
const innerValue = (value as VectorizeMetadataFilterInnerValue)[
op as VectorizeVectorMetadataFilterOp
];
if (Array.isArray(innerValue)) {
// Skip arrays in nested objects
const innerValue = (value as any)[op];

Check failure on line 198 in packages/wrangler/src/vectorize/query.ts

View workflow job for this annotation

GitHub Actions / Checks

Unexpected any. Specify a different type
if (["$eq", "$ne", "$lt", "$lte", "$gt", "gte"].includes(op)) {
if (!validateQueryFilterInnerValue(innerValue)) {
validInnerObj = false;
}
} else if (["$in", "$nin"].includes(op)) {
if (!Array.isArray(innerValue)) {
validInnerObj = false;
} else {
if (
!(innerValue as any[]).every(validateQueryFilterInnerValue)

Check failure on line 208 in packages/wrangler/src/vectorize/query.ts

View workflow job for this annotation

GitHub Actions / Checks

Unexpected any. Specify a different type
) {
validInnerObj = false;
}
}
} else {
validInnerObj = false;
break;
}
if (
typeof innerValue === "object" &&
innerValue !== null &&
Object.keys(innerValue).length === 0
) {
// Skip empty objects in nested objects
validInnerObj = false;
break;
}

innerObj[op as VectorizeVectorMetadataFilterOp] = innerValue;
}
}
Expand Down
12 changes: 10 additions & 2 deletions packages/wrangler/src/vectorize/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,11 +25,19 @@ export type VectorFloatArray = Float32Array | Float64Array;
*
* This list is expected to grow as support for more operations are released.
*/
export type VectorizeVectorMetadataFilterOp = "$eq" | "$ne";
export type VectorizeMetadataFilterEqualityOp = "$eq" | "$ne";
export type VectorizeMetadataFilterSetOp = "$in" | "$nin";
export type VectorizeMetadataFilterRangeOp = "$lt" | "$lte" | "$gt" | "$gte";

export type VectorizeVectorMetadataFilterOp =
| VectorizeMetadataFilterEqualityOp
| VectorizeMetadataFilterSetOp
| VectorizeMetadataFilterRangeOp;

export type VectorizeMetadataFilterInnerValue = Record<
VectorizeVectorMetadataFilterOp,
Exclude<VectorizeVectorMetadataValue, string[]>
| Exclude<VectorizeVectorMetadataValue, string[]>
| Exclude<VectorizeVectorMetadataValue, string[]>[]
>;

export type VectorizeMetadataFilterValue =
Expand Down

0 comments on commit 7089424

Please sign in to comment.