Skip to content

Commit

Permalink
feat: filterParameters opt for rtkq-codegen-openapi
Browse files Browse the repository at this point in the history
  • Loading branch information
sebws committed Mar 22, 2024
1 parent 1afcdd4 commit 2d7f3f3
Show file tree
Hide file tree
Showing 4 changed files with 1,717 additions and 2 deletions.
22 changes: 20 additions & 2 deletions packages/rtk-query-codegen-openapi/src/generate.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,15 @@ import ts from 'typescript';
import type { ObjectPropertyDefinitions } from './codegen';
import { generateCreateApiCall, generateEndpointDefinition, generateImportNode, generateTagTypes } from './codegen';
import { generateReactHooks } from './generators/react-hooks';
import type { EndpointMatcher, EndpointOverrides, GenerationOptions, OperationDefinition, TextMatcher } from './types';
import type {
ParameterDefinition,
ParameterMatcher,
EndpointMatcher,
EndpointOverrides,
GenerationOptions,
OperationDefinition,
TextMatcher,
} from './types';
import { capitalize, getOperationDefinitions, getV3Doc, removeUndefined, isQuery as testIsQuery } from './utils';
import { factory } from './utils/factory';

Expand Down Expand Up @@ -55,6 +63,15 @@ function operationMatches(pattern?: EndpointMatcher) {
};
}

function argumentMatches(pattern?: ParameterMatcher) {
const checkMatch = typeof pattern === 'function' ? pattern : patternMatches(pattern);
return function matcher(argumentDefinition: ParameterDefinition) {
if (!pattern || argumentDefinition.in === 'path') return true;
const argumentName = argumentDefinition.name;
return checkMatch(argumentName, argumentDefinition);
};
}

function withQueryComment<T extends ts.Node>(node: T, def: QueryArgDefinition, hasTrailingNewLine: boolean): T {
const comment = def.origin === 'param' ? def.param.description : def.body.description;
if (comment) {
Expand Down Expand Up @@ -89,6 +106,7 @@ export async function generateApi(
isDataResponse = defaultIsDataResponse,
filterEndpoints,
endpointOverrides,
filterParameters,
unionUndefined,
flattenArg = false,
useEnumType = false,
Expand Down Expand Up @@ -260,7 +278,7 @@ export async function generateApi(
const parameters = supportDeepObjects([
...apiGen.resolveArray(pathItem.parameters),
...apiGen.resolveArray(operation.parameters),
]);
]).filter(argumentMatches(filterParameters));

const allNames = parameters.map((p) => p.name);
const queryArg: QueryArgDefinitions = {};
Expand Down
10 changes: 10 additions & 0 deletions packages/rtk-query-codegen-openapi/src/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,8 @@ export type OperationDefinition = {
operation: OpenAPIV3.OperationObject;
};

export type ParameterDefinition = OpenAPIV3.ParameterObject;

type Require<T, K extends keyof T> = { [k in K]-?: NonNullable<T[k]> } & Omit<T, K>;
type Optional<T, K extends keyof T> = { [k in K]?: NonNullable<T[k]> } & Omit<T, K>;
type Id<T> = { [K in keyof T]: T[K] } & {};
Expand Down Expand Up @@ -80,9 +82,13 @@ export type EndpointMatcherFunction = (operationName: string, operationDefinitio

export type EndpointMatcher = TextMatcher | EndpointMatcherFunction;

export type ParameterMatcherFunction = (argumentName: string, argumentDefinition: ParameterDefinition) => boolean;
export type ParameterMatcher = TextMatcher | ParameterMatcherFunction;

export interface OutputFileOptions extends Partial<CommonOptions> {
outputFile: string;
filterEndpoints?: EndpointMatcher;
filterParameters?: ParameterMatcher;
endpointOverrides?: EndpointOverrides[];
/**
* defaults to false
Expand All @@ -91,6 +97,10 @@ export interface OutputFileOptions extends Partial<CommonOptions> {
useEnumType?: boolean;
}

export interface ArgumentFilters {
pattern: ParameterMatcher;
}

export interface EndpointOverrides {
pattern: EndpointMatcher;
type: 'mutation' | 'query';
Expand Down
Loading

0 comments on commit 2d7f3f3

Please sign in to comment.