X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/3ad7e33a2d50e9ed2298624ea5cac7cb5cd21a6f..9fbe0f44685e9c3c00f753bd36e858bd23c46680:/src/common/api/filter-builder.ts diff --git a/src/common/api/filter-builder.ts b/src/common/api/filter-builder.ts index 3f8e323c40..1f2107f151 100644 --- a/src/common/api/filter-builder.ts +++ b/src/common/api/filter-builder.ts @@ -2,34 +2,67 @@ // // SPDX-License-Identifier: AGPL-3.0 -export enum FilterField { - UUID = "uuid", - OWNER_UUID = "owner_uuid" -} +import * as _ from "lodash"; +import { Resource } from "./common-resource-service"; -export default class FilterBuilder { - private filters = ""; +export default class FilterBuilder { - private addCondition(field: FilterField, cond: string, value?: string) { - if (value) { - this.filters += `["${field}","${cond}","${value}"]`; - } - return this; + static create(resourcePrefix = "") { + return new FilterBuilder(resourcePrefix); } - public addEqual(field: FilterField, value?: string) { + constructor( + private resourcePrefix = "", + private filters = "") { } + + public addEqual(field: keyof T, value?: string) { return this.addCondition(field, "=", value); } - public addLike(field: FilterField, value?: string) { - return this.addCondition(field, "like", value); + public addLike(field: keyof T, value?: string) { + return this.addCondition(field, "like", value, "", "%"); + } + + public addILike(field: keyof T, value?: string) { + return this.addCondition(field, "ilike", value, "", "%"); + } + + public addIsA(field: keyof T, value?: string | string[]) { + return this.addCondition(field, "is_a", value); + } + + public addIn(field: keyof T, value?: string | string[]) { + return this.addCondition(field, "in", value); } - public addILike(field: FilterField, value?: string) { - return this.addCondition(field, "ilike", value); + public concat(filterBuilder: FilterBuilder) { + return new FilterBuilder(this.resourcePrefix, this.filters + this.getSeparator() + filterBuilder.getFilters()); } - public get() { + public getFilters() { + return this.filters; + } + + public serialize() { return "[" + this.filters + "]"; } + + private addCondition(field: keyof T, cond: string, value?: string | string[], prefix: string = "", postfix: string = "") { + if (value) { + value = typeof value === "string" + ? `"${prefix}${value}${postfix}"` + : `["${value.join(`","`)}"]`; + + const resourcePrefix = this.resourcePrefix + ? _.snakeCase(this.resourcePrefix) + "." + : ""; + + this.filters += `${this.getSeparator()}["${resourcePrefix}${_.snakeCase(field.toString())}","${cond}",${value}]`; + } + return this; + } + + private getSeparator () { + return this.filters ? "," : ""; + } }