
Security News
AI Agent Lands PRs in Major OSS Projects, Targets Maintainers via Cold Outreach
An AI agent is merging PRs into major OSS projects and cold-emailing maintainers to drum up more work.
json-api-query
Advanced tools
A javascript client helper for APIs built with https://www.jsonapi.net/
NOTE: this is not an API client - it's a query builder for you to use in your client code.
The design / inspiration of this API was lifted quite heavily from https://github.com/typeorm/typeorm - though it is not meant to match it.
The query builder aims to support all of the terms found in the [since v4.0] docs found here: https://www.jsonapi.net/usage/reading/filtering.html
Legacy syntax is not supported, there is some consideration in the code to add this later (as well as supporting evolved syntax later on) but I am not sure how worthwhile that would be.
The latest version of this package now uses typescript-json-schema. This was required so that the types can be infered in the query bulder code. Unlike C#, Typescript's type system is unavailable at runtime, so tailoring the query generation for HasMany relations is AFAICS impossible without providing some schema information.
To this end I have introduced typescript-json-schema. Generating schemas for your models is as easy as adding typescript-json-schema tsconfig.schema.json \"*\" > test/Models/schema.json to your NPM commands section. See this projects package.json for an example.
import * as schema from "./Models/schema.json"
new QueryBuilder<TestClass>("TestClass", schema)
.find({
where: {
numProp: 1,
},
})
.build()
Generates the following:
?filter=equals(numProp,'1')
import * as schema from "./Models/schema.json"
new QueryBuilder<TestClass>("TestClass", schema)
.find({
where: {
numProp: Any([1, 2, 3]),
},
})
.build()
Generates the following:
?filter=any(numProp,1,2,3)
import * as schema from "./Models/schema.json"
new QueryBuilder<TestClass>("TestClass", schema)
.find({
where: {
numProp: Contains('lol'),
},
})
.build()
Generates the following:
?filter=contains(prop12,'lol')
import * as schema from "./Models/schema.json"
new QueryBuilder<TestClass>("TestClass", schema)
.find({
where: {
numProp: Not(Equals(1)),
},
})
.build()
Generates the following:
?filter=not(equals(numProp,'1'))
import * as schema from "./Models/schema.json"
new QueryBuilder<TestClass>("TestClass", schema)
.find({
where: {
numProp: Or([Has([1, 2, 3]), Equals(1)]),
},
})
.build()
Generates the following:
?filter=or(has(numProp,1,2,3),equals(numProp,'1'))
import * as schema from "./Models/schema.json"
new QueryBuilder<TestClass>("TestClass", schema)
.find({
where: [
{
numProp: Has([1, 2, 3]),
},
{
numProp: Equals(1),
},
],
})
.build()
Generates the following:
?filter=or(has(numProp,1,2,3),equals(numProp,'1'))
import * as schema from "./Models/schema.json"
new QueryBuilder<TestClass>("TestClass", schema)
.find({
where: {
nested: {
property1Nested: Equals('test'),
},
},
})
.build()
Generates the following:
?filter[nested]=equals(property1Nested,'test')
import * as schema from "./Models/schema.json"
new QueryBuilder<TestClass>("TestClass", schema)
.find({
relations: {
nested: {
nestedAgain: true,
},
},
})
.build()
Generates the following:
?include=nested.nestedAgain
import * as schema from "./Models/schema.json"
new QueryBuilder<TestClass>("TestClass", schema)
.find({
fields: {
property2: true,
},
})
.build()
Generates the following:
?fields=property2
import * as schema from "./Models/schema.json"
new QueryBuilder<TestClass>("TestClass", schema)
.find({
order: {
property2: 'ASC',
nested: {
property1Nested: 'DESC',
property2Nested: {
direction: 'ASC',
},
},
},
})
.build()
Generates the following:
?sort=property2&sort[nested]=property1Nested,-property2Nested
import * as schema from "./Models/schema.json"
new QueryBuilder<TestClass>("TestClass", schema)
.find({
where: {
a: Contains('lol'),
not1: Not(Equals('not5')),
nested: {
property2Nested: true,
property1Nested: Has(['one', 'two']),
nestedAgain: {
property1Nested: EndsWith('wot'),
},
},
},
relations: {
nested: true,
},
fields: {
firstName: true,
lastName: true,
nested: {
property2Nested: true,
},
},
number: 10,
size: 0,
order: {
property2: 'ASC',
nested: {
property1Nested: 'DESC',
},
},
})
.build()
Generates the following:
?sort=property2
&sort[nested]=property1Nested
&filter=and(contains(a,'lol'),not(equals(not1,'not5')))
&include=nested
&fields=firstName,lastName
&fields[nested]=property2Nested
&page[size]=0
&page[number]=10
&filter[nested]=and(equals(property2Nested,'true'),has(property1Nested,one,two))
&filter[nestedAgain]=endsWith(property1Nested,'wot')
FAQs
A query builder for JSONAPIDotNetCore
We found that json-api-query demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
An AI agent is merging PRs into major OSS projects and cold-emailing maintainers to drum up more work.

Research
/Security News
Chrome extension CL Suite by @CLMasters neutralizes 2FA for Facebook and Meta Business accounts while exfiltrating Business Manager contact and analytics data.

Security News
After Matplotlib rejected an AI-written PR, the agent fired back with a blog post, igniting debate over AI contributions and maintainer burden.