data:image/s3,"s3://crabby-images/2523c/2523ce4b8b64bade795ffc89574cfc29f35428d3" alt="Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility"
Security News
Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
Gqlimp is an executable npm package created for client applications that communicate with the graphql server. The reasons to create this tool are to accelerate development of server applications coded with graphql in the client part and to increase client - server interaction.
It is intended that the query scheme created on the graphql server can be used easily and accurately in the client application via Gqlimp.Thanks to perform programmatic processing when creating a query, it can be developped code more flexible and faster in client side.
When there is a change in the query scheme created on the server, the client will be aware of this change and will have to make the necessary arrangements thanks to the import mechanism.
$ npm install gqlimp
Parameters Guide
There are 2 basic public classes in the file created with gqlimp. Depending on the type of query to be used, one of the following classes is selected as root and the structure of the query is created.
query: string
args: any
Example of Gqlimp tool: Gqlimp requires a graphql server to create the client file.
type Phone {
gsm: String
note: String
}
type User {
id: Int
name: String
phone: Phone
}
type Query {
user(id: Int!): User
}
input PhoneInput {
gsm: String
note: String
}
input UserInput {
name: String
phone: PhoneInput
}
type Mutation {
createUser(user: UserInput): User
}
Let's assume that the Graphql server contains inputs and types in step-1. To import these schema types using the Gqlimp tool, the command in step-2 must be executed.
$ gqlimp --url http://localhost:5000/api -g
After running the command, the client file is created in the output folder.
export interface Phone_intf {
gsm? : boolean | number;
note? : boolean | number;
}
export interface User_intf {
id? : boolean | number;
name? : boolean | number;
phone? : User_phone;
}
export interface Query_intf {
user? : Query_user;
}
export interface Mutation_intf {
createUser? : Mutation_createUser;
}
/*
export class QueryObject ...
export class MutationObject ...
export class Query_user ...
export class User_phone ...
export class Mutation_createUser ...
*/
The structure of the generated file is like the structure of the fields on the graphql server. Gqlimp has created a class for each field.
Query Example:
import { QueryObject } from './schema-all';
const qo = new QueryObject({
user: new Query_user({
id: true,
name: true,
phone: new User_phone({
gsm: true,
note: true
})
})
});
console.log(qo.query);
/* Output
query {
user {
id
name
phone {
gsm
note
}
}
}
*/
Mutation Example:
import { QueryObject } from './schema-types';
const qo = new MutationObject({
createUser: new Mutation_createUser({
name: 'User 1',
phone: {
gsm: 'User Gsm',
note: 'Note'
}
},
{
id: true,
name: true
})
});
console.log(qo.query);
/* Output
mutation ($name: String, $phone: PhoneInput) {
createUser(name: $name, phone: $phone ) {
id
name
}
}
console.log(qo.args);
/* Output
{
name: 'User 1',
phone: {
gsm: 'User Gsm',
note: 'Note'
}
}
*/
In above examples, QueryObject class starts as root. This root object gives fields that can be queried.
These fields expect the object of their class. After defining the fields to be used, The QueryObject.query / MutationObject.query property gives a string query. If there is an argument in the generated query these arguments are accessed with QueryObject.args / MutationObject.args.
>= 6.x
;FAQs
Graphql Client Generator
The npm package gqlimp receives a total of 2 weekly downloads. As such, gqlimp popularity was classified as not popular.
We found that gqlimp 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
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
Security News
React's CRA deprecation announcement sparked community criticism over framework recommendations, leading to quick updates acknowledging build tools like Vite as valid alternatives.
Security News
Ransomware payment rates hit an all-time low in 2024 as law enforcement crackdowns, stronger defenses, and shifting policies make attacks riskier and less profitable.