@graphql-tools/utils
Version:
Common package containing utils and types for GraphQL tools
44 lines (43 loc) • 1.93 kB
text/typescript
import { ASTNode } from 'graphql';
/**
* Checks if the given string is a valid URL.
*
* @param str - The string to validate as a URL
* @returns A boolean indicating whether the string is a valid URL
*
* @remarks
* This function first attempts to use the `URL.canParse` method if available.
* If not, it falls back to creating a new `URL` object to validate the string.
*/
export declare function isUrl(str: string): boolean;
export declare const asArray: <T>(fns: T | T[]) => T[];
/**
* Determines if a given input is a valid GraphQL document string.
*
* @param str - The input to validate as a GraphQL document
* @returns A boolean indicating whether the input is a valid GraphQL document string
*
* @remarks
* This function performs several validation checks:
* - Ensures the input is a string
* - Filters out strings with invalid document extensions
* - Excludes URLs
* - Attempts to parse the string as a GraphQL document
*
* @throws {Error} If the document fails to parse and is empty except GraphQL comments
*/
export declare function isDocumentString(str: any): boolean;
/**
* Checkes whether the `str` contains any path illegal characters.
*
* A string may sometimes look like a path but is not (like an SDL of a simple
* GraphQL schema). To make sure we don't yield false-positives in such cases,
* we disallow new lines in paths (even though most Unix systems support new
* lines in file names).
*/
export declare function isValidPath(str: any): boolean;
export declare function compareStrings<A, B>(a: A, b: B): 0 | 1 | -1;
export declare function nodeToString(a: ASTNode): string;
export declare function compareNodes(a: ASTNode, b: ASTNode, customFn?: (a: any, b: any) => number): number;
export declare function isSome<T>(input: T): input is Exclude<T, null | undefined>;
export declare function assertSome<T>(input: T, message?: string): asserts input is Exclude<T, null | undefined>;