Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions src/utilities/__tests__/getIntrospectionQuery-test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -138,4 +138,10 @@ describe('getIntrospectionQuery', () => {
2,
);
});

it('throw error if typeDepth is too high', () => {
expect(() => getIntrospectionQuery({ typeDepth: 101 })).to.throw(
'Please set typeDepth to a reasonable value between 0 and 100; the default is 9.',
);
});
});
64 changes: 27 additions & 37 deletions src/utilities/getIntrospectionQuery.ts
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,16 @@ export interface IntrospectionOptions {
* Default: false
*/
oneOf?: boolean;

/**
* How deep to recurse into nested types, larger values will result in more
* accurate results, but have a higher load on the server.
* Some servers might restrict the maximum query depth or complexity.
* If that's the case, try decreasing this value.
*
* Default: 9
*/
typeDepth?: number;
}

/**
Expand All @@ -52,6 +62,7 @@ export function getIntrospectionQuery(options?: IntrospectionOptions): string {
schemaDescription: false,
inputValueDeprecation: false,
oneOf: false,
typeDepth: 9,
...options,
};

Expand All @@ -70,6 +81,21 @@ export function getIntrospectionQuery(options?: IntrospectionOptions): string {
return optionsWithDefault.inputValueDeprecation ? str : '';
}
const oneOf = optionsWithDefault.oneOf ? 'isOneOf' : '';
function ofType(level: number, indent: string): string {
if (level <= 0) {
return '';
}
if (level > 100) {
throw new Error(
'Please set typeDepth to a reasonable value between 0 and 100; the default is 9.',
);
}
return `
${indent}ofType {
${indent} name
${indent} kind${ofType(level - 1, indent + ' ')}
${indent}}`;
}

return `
query IntrospectionQuery {
Expand Down Expand Up @@ -139,43 +165,7 @@ export function getIntrospectionQuery(options?: IntrospectionOptions): string {

fragment TypeRef on __Type {
kind
name
ofType {
kind
name
ofType {
kind
name
ofType {
kind
name
ofType {
kind
name
ofType {
kind
name
ofType {
kind
name
ofType {
kind
name
ofType {
kind
name
ofType {
kind
name
}
}
}
}
}
}
}
}
}
name${ofType(optionsWithDefault.typeDepth ?? 9, ' ')}
}
`;
}
Expand Down