Skip to content

Commit

Permalink
Merge branch 'next' into oleh/openapi-adding-command-to-solve-circula…
Browse files Browse the repository at this point in the history
…rity-and-recursiveness
  • Loading branch information
olehshh authored Dec 12, 2024
2 parents 4011248 + 0d0dbed commit 0400bae
Show file tree
Hide file tree
Showing 14 changed files with 65 additions and 43 deletions.
7 changes: 7 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,10 @@
## [9.0.4-next.3](https://github.com/readmeio/rdme/compare/v9.0.4-next.2...v9.0.4-next.3) (2024-12-12)


### Bug Fixes

* openapi arg doc enhancements, refactors ([#1122](https://github.com/readmeio/rdme/issues/1122)) ([b83b233](https://github.com/readmeio/rdme/commit/b83b23337c09f053bf470bf4b41615353b1f3eae))

## [9.0.4-next.2](https://github.com/readmeio/rdme/compare/v9.0.4-next.1...v9.0.4-next.2) (2024-12-11)


Expand Down
2 changes: 1 addition & 1 deletion bin/dev.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
async function main() {
const { execute } = await import('@oclif/core');
await execute({ development: true, dir: import.meta.url }).then(msg => {
if (msg) {
if (msg && typeof msg === 'string') {
// eslint-disable-next-line no-console
console.log(msg);
}
Expand Down
6 changes: 3 additions & 3 deletions dist-gha/commands.js

Large diffs are not rendered by default.

15 changes: 10 additions & 5 deletions documentation/commands/openapi.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,8 @@ USAGE
[--workingDirectory <value>] [--github] [--dryRun] [--useSpecVersion] [--raw] [--create | --update]
ARGUMENTS
SPEC A file/URL to your API definition
SPEC A path to your API definition — either a local file path or a URL. If your working directory and all
subdirectories contain a single OpenAPI file, you can omit the path.
FLAGS
--create Bypasses the create/update prompt and creates a new API definition in ReadMe.
Expand Down Expand Up @@ -122,7 +123,8 @@ USAGE
$ rdme openapi convert [SPEC] [--out <value>] [--title <value>] [--workingDirectory <value>]
ARGUMENTS
SPEC A file/URL to your API definition
SPEC A path to your API definition — either a local file path or a URL. If your working directory and all
subdirectories contain a single OpenAPI file, you can omit the path.
FLAGS
--out=<value> Output file path to write converted file to
Expand Down Expand Up @@ -159,7 +161,8 @@ USAGE
dme...] [--workingDirectory <value>]
ARGUMENTS
SPEC A file/URL to your API definition
SPEC A path to your API definition — either a local file path or a URL. If your working directory and all
subdirectories contain a single OpenAPI file, you can omit the path.
FLAGS
--feature=<option>... A specific OpenAPI or ReadMe feature you wish to see detailed information on (if it
Expand Down Expand Up @@ -204,7 +207,8 @@ USAGE
<value>] [--workingDirectory <value>]
ARGUMENTS
SPEC A file/URL to your API definition
SPEC A path to your API definition — either a local file path or a URL. If your working directory and all
subdirectories contain a single OpenAPI file, you can omit the path.
FLAGS
--method=<value>... Methods to reduce by (can only be used alongside the `path` option)
Expand Down Expand Up @@ -284,7 +288,8 @@ USAGE
$ rdme openapi validate [SPEC] [--github] [--workingDirectory <value>]
ARGUMENTS
SPEC A file/URL to your API definition
SPEC A path to your API definition — either a local file path or a URL. If your working directory and all
subdirectories contain a single OpenAPI file, you can omit the path.
FLAGS
--github Create a new GitHub Actions workflow for this command.
Expand Down
4 changes: 2 additions & 2 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "rdme",
"version": "9.0.4-next.2",
"version": "9.0.4-next.3",
"description": "ReadMe's official CLI and GitHub Action.",
"license": "MIT",
"author": "ReadMe <[email protected]> (https://readme.com)",
Expand Down
6 changes: 3 additions & 3 deletions src/commands/openapi/convert.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,12 @@ import type { OASDocument } from 'oas/types';
import fs from 'node:fs';
import path from 'node:path';

import { Args, Flags } from '@oclif/core';
import { Flags } from '@oclif/core';
import chalk from 'chalk';
import prompts from 'prompts';

import BaseCommand from '../../lib/baseCommand.js';
import { titleFlag, workingDirectoryFlag } from '../../lib/flags.js';
import { specArg, titleFlag, workingDirectoryFlag } from '../../lib/flags.js';
import { warn } from '../../lib/logger.js';
import prepareOas from '../../lib/prepareOas.js';
import promptTerminal from '../../lib/promptWrapper.js';
Expand All @@ -21,7 +21,7 @@ export default class OpenAPIConvertCommand extends BaseCommand<typeof OpenAPICon
'Converts Swagger files and Postman collections to OpenAPI and bundles any external references. **Note**: All of our other OpenAPI commands already do this conversion automatically, but this command is available in case you need this functionality exclusively.';

static args = {
spec: Args.string({ description: 'A file/URL to your API definition' }),
spec: specArg,
};

static flags = {
Expand Down
6 changes: 3 additions & 3 deletions src/commands/openapi/index.ts
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
import type { OpenAPIPromptOptions } from '../../lib/prompts.js';

import { Args, Flags } from '@oclif/core';
import { Flags } from '@oclif/core';
import chalk from 'chalk';
import ora from 'ora';
import parse from 'parse-link-header';

import BaseCommand from '../../lib/baseCommand.js';
import { githubFlag, keyFlag, titleFlag, versionFlag, workingDirectoryFlag } from '../../lib/flags.js';
import { githubFlag, keyFlag, specArg, titleFlag, versionFlag, workingDirectoryFlag } from '../../lib/flags.js';
import { info, oraOptions, warn } from '../../lib/logger.js';
import prepareOas from '../../lib/prepareOas.js';
import * as promptHandler from '../../lib/prompts.js';
Expand All @@ -31,7 +31,7 @@ export default class OpenAPICommand extends BaseCommand<typeof OpenAPICommand> {
};

static args = {
spec: Args.string({ description: 'A file/URL to your API definition' }),
spec: specArg,
};

static flags = {
Expand Down
6 changes: 3 additions & 3 deletions src/commands/openapi/inspect.ts
Original file line number Diff line number Diff line change
@@ -1,15 +1,15 @@
import type { Analysis, AnalyzedFeature } from '../../lib/analyzeOas.js';
import type { OASDocument } from 'oas/types';

import { Args, Flags } from '@oclif/core';
import { Flags } from '@oclif/core';
import chalk from 'chalk';
import ora from 'ora';
import pluralize from 'pluralize';
import { getBorderCharacters, table } from 'table';

import analyzeOas, { getSupportedFeatures } from '../../lib/analyzeOas.js';
import BaseCommand from '../../lib/baseCommand.js';
import { workingDirectoryFlag } from '../../lib/flags.js';
import { specArg, workingDirectoryFlag } from '../../lib/flags.js';
import { oraOptions } from '../../lib/logger.js';
import prepareOas from '../../lib/prepareOas.js';
import SoftError from '../../lib/softError.js';
Expand Down Expand Up @@ -178,7 +178,7 @@ export default class OpenAPIInspectCommand extends BaseCommand<typeof OpenAPIIns
"This command will perform a comprehensive analysis of your API definition to determine how it's utilizing aspects of the OpenAPI Specification (such as circular references, polymorphism, etc.) and any ReadMe-specific extensions you might be using.";

static args = {
spec: Args.string({ description: 'A file/URL to your API definition' }),
spec: specArg,
};

static flags = {
Expand Down
6 changes: 3 additions & 3 deletions src/commands/openapi/reduce.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,15 +3,15 @@ import type { OASDocument } from 'oas/types';
import fs from 'node:fs';
import path from 'node:path';

import { Args, Flags } from '@oclif/core';
import { Flags } from '@oclif/core';
import chalk from 'chalk';
import Oas from 'oas';
import oasReducer from 'oas/reducer';
import ora from 'ora';
import prompts from 'prompts';

import BaseCommand from '../../lib/baseCommand.js';
import { titleFlag, workingDirectoryFlag } from '../../lib/flags.js';
import { specArg, titleFlag, workingDirectoryFlag } from '../../lib/flags.js';
import { oraOptions } from '../../lib/logger.js';
import prepareOas from '../../lib/prepareOas.js';
import promptTerminal from '../../lib/promptWrapper.js';
Expand All @@ -24,7 +24,7 @@ export default class OpenAPIReduceCommand extends BaseCommand<typeof OpenAPIRedu
"Reduce your API definition down to a specific set of tags or paths, which can be useful if you're debugging a problematic schema somewhere, or if you have a file that is too big to maintain.";

static args = {
spec: Args.string({ description: 'A file/URL to your API definition' }),
spec: specArg,
};

static flags = {
Expand Down
5 changes: 2 additions & 3 deletions src/commands/openapi/validate.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,7 @@
import { Args } from '@oclif/core';
import chalk from 'chalk';

import BaseCommand from '../../lib/baseCommand.js';
import { githubFlag, workingDirectoryFlag } from '../../lib/flags.js';
import { githubFlag, specArg, workingDirectoryFlag } from '../../lib/flags.js';
import prepareOas from '../../lib/prepareOas.js';

export default class OpenAPIValidateCommand extends BaseCommand<typeof OpenAPIValidateCommand> {
Expand All @@ -15,7 +14,7 @@ export default class OpenAPIValidateCommand extends BaseCommand<typeof OpenAPIVa
static id = 'openapi validate' as const;

static args = {
spec: Args.string({ description: 'A file/URL to your API definition' }),
spec: specArg,
};

static examples = [
Expand Down
7 changes: 6 additions & 1 deletion src/lib/flags.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Flags } from '@oclif/core';
import { Args, Flags } from '@oclif/core';

/**
* Used in any command where `github` is a `flag.
Expand Down Expand Up @@ -62,3 +62,8 @@ export const baseVersionFlags = {
export const workingDirectoryFlag = Flags.string({
description: 'Working directory (for usage with relative external references)',
});

export const specArg = Args.string({
description:
'A path to your API definition — either a local file path or a URL. If your working directory and all subdirectories contain a single OpenAPI file, you can omit the path.',
});
3 changes: 1 addition & 2 deletions src/lib/logger.ts
Original file line number Diff line number Diff line change
Expand Up @@ -55,8 +55,7 @@ function info(
}

function oraOptions() {
// Disables spinner in tests so it doesn't pollute test output
const opts: Writable<OraOptions> = { isSilent: isTest() };
const opts: Writable<OraOptions> = {};

// Cleans up ora output so it prints nicely alongside debug logs
/* istanbul ignore next */
Expand Down
33 changes: 20 additions & 13 deletions src/lib/readmeAPIFetch.ts
Original file line number Diff line number Diff line change
Expand Up @@ -244,6 +244,23 @@ export async function handleAPIv1Res(res: Response, rejectOnJsonError = true) {
return Promise.reject(body);
}

/**
* If you supply `undefined` or `null` to the `Headers` API,
* it'll convert those to a string by default,
* so we instead filter those out here.
*/
function filterOutFalsyHeaders(inputHeaders: Headers) {
const headers = new Headers();

for (const header of inputHeaders.entries()) {
if (header[1] !== 'null' && header[1] !== 'undefined' && header[1].length > 0) {
headers.set(header[0], header[1]);
}
}

return headers;
}

/**
* Returns the basic auth header and any other defined headers for use in `fetch` calls against ReadMe API v1.
*
Expand All @@ -252,24 +269,14 @@ export function cleanAPIv1Headers(
key: string,
/** used for `x-readme-header` */
version?: string,
inputHeaders: Headers = new Headers(),
headers: Headers = new Headers(),
) {
const encodedKey = Buffer.from(`${key}:`).toString('base64');
const headers = new Headers({
Authorization: `Basic ${encodedKey}`,
});
headers.set('Authorization', `Basic ${encodedKey}`);

if (version) {
headers.set('x-readme-version', version);
}

for (const header of inputHeaders.entries()) {
// If you supply `undefined` or `null` to the `Headers` API it'll convert those to a string by default,
// so we instead filter those out here.
if (header[1] !== 'null' && header[1] !== 'undefined' && header[1].length > 0) {
headers.set(header[0], header[1]);
}
}

return headers;
return filterOutFalsyHeaders(headers);
}

0 comments on commit 0400bae

Please sign in to comment.