diff --git a/.alexrc.yml b/.alexrc.yml
index b55e67dc3..6acbc675e 100644
--- a/.alexrc.yml
+++ b/.alexrc.yml
@@ -1 +1,3 @@
profanitySureness: 1
+allow:
+ - postman-postwoman
diff --git a/.prettierignore b/.prettierignore
index fe7685933..10e0b48c3 100644
--- a/.prettierignore
+++ b/.prettierignore
@@ -7,5 +7,5 @@ coverage/
# release build artifacts
CHANGELOG.md
dist/
-documentation/commands.md
+documentation/commands
dist-gha/
diff --git a/README.md b/README.md
index d227243ea..e5261c372 100644
--- a/README.md
+++ b/README.md
@@ -20,8 +20,6 @@
-
-
With `rdme`, you can manage your API definition (we support [OpenAPI](https://spec.openapis.org/oas/v3.1.0.html), [Swagger](https://swagger.io/specification/v2/), and [Postman](https://schema.postman.com/)) and sync it to your API reference docs on ReadMe. You can also access other parts of [ReadMe's RESTful API](https://docs.readme.com/reference), including syncing Markdown documentation with your ReadMe project and managing project versions.
Not using ReadMe for your docs? No worries. `rdme` has a variety of tools to help you identify issues with your API definition β no ReadMe account required.
@@ -29,42 +27,31 @@ Not using ReadMe for your docs? No worries. `rdme` has a variety of tools to hel
> [!WARNING]
> Heads up: our [new ReadMe Refactored experience](https://docs.readme.com/main/docs/welcome-to-readme-refactored) doesnβt yet support `rdme`. If your project is using the new ReadMe Refactored experience, we recommend [enabling bi-directional syncing via Git](https://docs.readme.com/main/docs/bi-directional-sync) for an even better editing experience for the technical and non-technical users on your team!
-## Table of Contents
+# Table of Contents
+
-
-- [CLI Configuration](#cli-configuration)
- - [Setup](#setup)
- - [Authentication](#authentication)
- - [Proxy](#proxy)
-- [GitHub Actions Configuration](#github-actions-configuration)
-- [Usage](#usage)
- - [Common `rdme` Options](#common-rdme-options)
- - [API Definitions π](#api-definitions-)
- - [Docs (a.k.a. Guides) π](#docs-aka-guides-)
- - [Changelog π£](#changelog-)
- - [Custom Pages π](#custom-pages-)
- - [Versions β³](#versions-)
- - [Categories πͺ£](#categories-)
- - [Open Your ReadMe Project in Your Browser](#open-your-readme-project-in-your-browser)
-- [Future](#future)
-
+* [Table of Contents](#table-of-contents)
+* [CLI Configuration](#cli-configuration)
+* [GitHub Actions Configuration](#github-actions-configuration)
+* [Usage](#usage)
+* [Command Topics](#command-topics)
+
-## CLI Configuration
+# CLI Configuration
-### Setup
+## Setup
> [!NOTE]
> These setup instructions are for CLI usage only. For usage in GitHub Actions, see [GitHub Actions Configuration](#github-actions-configuration) below.
@@ -73,7 +60,7 @@ https://github.com/jonschlinkert/markdown-toc/issues/119
To install the `rdme` CLI, you'll need to have [Node.js](https://nodejs.org) installed. Node.js comes bundled with [the `npm` CLI](https://github.com/npm/cli), which you'll need to install `rdme`. You can see our current Node.js version requirements in the green badge on the right.
-#### Installing `rdme` to Your Local Machine
+### Installing `rdme` to Your Local Machine
The simplest way to use `rdme` is to install it globally:
@@ -83,7 +70,7 @@ npm install -g rdme
With a global installation, you'll be able to run `rdme` within any directory on your local machine. If you log in once, you can quickly access your project without having to remember your API key (see the [Authentication](#authentication) section below).
-#### Installing `rdme` to a Project
+### Installing `rdme` to a Project
The recommended approach for shared projects is to install `rdme` in your project's dependencies, that way you don't run into unexpected behavior with mismatching versions of `rdme`. We also suggest using the `--save-dev` flag since `rdme` is typically used as part of a CI process and is unlikely to be running in your production application:
@@ -99,7 +86,7 @@ npx rdme openapi:validate [file]
To ensure you're getting the latest features and security updates, we recommend using a tool like [Dependabot](https://docs.github.com/code-security/dependabot/dependabot-version-updates/about-dependabot-version-updates) to keep `rdme` (and your other dependencies) up-to-date.
-### Authentication
+## Authentication
For local CLI usage with a single project, you can authenticate `rdme` to your ReadMe project using `rdme login`. Once you follow the prompts and are successfully authenticated, your API key will be saved to a local configuration file (`~/.config/configstore/rdme-production.json`) and you won't have to provide the `--key` option to commands that require it.
@@ -115,7 +102,7 @@ You can also pass in your API key via environmental variable. Here is the order
`rdme whoami` is also available to you to determine who is logged in, and to what project. You can clear your stored credentials with `rdme logout`.
-#### 1Password
+### 1Password
As a secure alternative to the `rdme login` approach to using the CLI locally, [1Password](https://1password.com/) users can set up the [ReadMe shell plugin](https://developer.1password.com/docs/cli/shell-plugins/readme/). With this approach, you can store your ReadMe API key in 1Password and securely pass it in your `rdme` commands using biometrics. See below for a demo of this behavior:
@@ -123,7 +110,7 @@ https://user-images.githubusercontent.com/8854718/208739413-590aa265-072d-4800-b
To set this up, check out [1Password's documentation on the ReadMe shell plugin](https://developer.1password.com/docs/cli/shell-plugins/readme/).
-### Proxy
+## Proxy
`rdme` makes API requests to the ReadMe API, which is located at [dash.readme.com](https://dash.readme.com). If you need to configure a proxy for these requests, you can do so by setting the `HTTPS_PROXY` environmental variable.
@@ -132,7 +119,7 @@ export HTTPS_PROXY=https://proxy.example.com:5678
rdme openapi
```
-## GitHub Actions Configuration
+# GitHub Actions Configuration
> [!NOTE]
> For a full GitHub Workflow file example and additional information on GitHub Actions usage, check out [our docs](https://docs.readme.com/docs/rdme#github-actions-usage).
@@ -147,312 +134,64 @@ This will run through the `openapi` command, ask you a few quick questions, and
You can see examples featuring the latest version in [our docs](https://docs.readme.com/docs/rdme#github-actions-examples). We recommend [configuring Dependabot to keep your actions up-to-date](https://docs.github.com/code-security/dependabot/working-with-dependabot/keeping-your-actions-up-to-date-with-dependabot).
-## Usage
-
-If you wish to get more information about any command within `rdme`, you can execute `rdme help ` or `rdme --help`. You an also execute `rdme help` to see a global list of commands that `rdme` offers.
-
-### Common `rdme` Options
-
-- `--key `: The API key associated with your ReadMe project. Note that most of the commands below require API key authentication, even though the `--key` flag is omitted from the examples. See the [Authentication](#authentication) section above for more information.
-- `--version `: Your project version. See [our docs](https://docs.readme.com/docs/versions) for more information.
-
-### API Definitions π
-
-With `rdme`, you have access to a variety of tools to manage your API definition, most of which don't require an account on ReadMe. These tools include:
-
-- [Syncing](#syncing-an-api-definition-to-readme) π¦
-- [Validation](#validating-an-api-definition) β
-- [Reduction](#reducing-an-api-definition) π
-- [Inspection](#inspecting-an-api-definition) π
-- [Conversion](#converting-an-api-definition) β©
-
-`rdme` supports [OpenAPI 3.1](https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md), [OpenAPI 3.0](https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.3.md), and [Swagger 2.x](https://github.com/OAI/OpenAPI-Specification/blob/main/versions/2.0.md).
-
-
-
-You can also pass in [Postman Collections](https://www.postman.com/collection/). Postman Collections are converted to OpenAPI using [`postman-to-openapi`](https://github.com/joolfe/postman-to-openapi) prior to any syncing/validation/etc.
-
-The following examples use JSON files, but `rdme` supports API Definitions that are written in either JSON or YAML.
-
-#### Syncing an API Definition to ReadMe
-
-`rdme openapi` locates your API definition (if [you don't supply one](#omitting-the-file-path)), validates it, and then syncs it to your API reference on ReadMe.
-
-> [!NOTE]
-> The `rdme openapi` command supports both OpenAPI and Swagger API definitions.
-
-If you wish to programmatically access any of this script's results (such as the API definition ID or the link to the corresponding docs in your dashboard), supply the `--raw` flag and the command will return a JSON output.
-
-This command also has a dry run mode, which can be useful for initial setup and debugging. You can perform a dry run by supplying the `--dryRun` flag.
-
-##### Omitting the File Path
-
-If you run `rdme` within a directory that contains your OpenAPI or Swagger definition, you can omit the file path. `rdme` will then look for JSON or YAML files (including in sub-directories) that contain a top-level [`openapi`](https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md#fixed-fields) or [`swagger`](https://github.com/OAI/OpenAPI-Specification/blob/main/versions/2.0.md#fixed-fields) property.
-
-> [!NOTE]
->
-> `rdme` will not scan anything in the following:
->
-> - Any `.git/` directories (if they exist)
-> - Any files/directories specified in `.gitignore` files (including any `.gitignore` files in subdirectories, if they exist)
-
-```sh
-rdme openapi
-```
-
-##### Uploading a New API Definition to ReadMe
-
-This will upload the API definition at the given URL or path to your project and return an ID and URL for you to later update your file, and view it in the client.
-
-```sh
-rdme openapi [url-or-local-path-to-file]
-```
-
-If you want to bypass the prompt to create or update an API definition, you can pass the `--create` flag:
-
-```sh
-rdme openapi [url-or-local-path-to-file] --version={project-version} --create
-```
-
-##### Editing (Re-Syncing) an Existing API Definition
-
-This will edit (re-sync) an existing API definition (identified by `--id`) within your ReadMe project. **This is the recommended approach for usage in CI environments.**
-
-```sh
-rdme openapi [url-or-local-path-to-file] --id={existing-id}
-```
-
-##### Uploading or Editing an API Definition in a Project Version
-
-You can additionally include a version flag, specifying the target version for your file's destination. This approach will provide you with CLI prompts, so we do not recommend this technique in CI environments.
-
-```sh
-rdme openapi [url-or-local-path-to-file] --version={project-version}
-```
-
-If you wish to use the version specified [in the `info.version` field of your API definition](https://spec.openapis.org/oas/v3.1.0#fixed-fields-0), you can pass the `--useSpecVersion` option. For example, say [the `info` object](https://spec.openapis.org/oas/v3.1.0#info-object) of your API definition looks like this:
-
-```json
-{
- "version": "1.2.3",
- "title": "Single Path",
- "description": "This is a slimmed down single path version of the Petstore definition."
-}
-```
-
-You can pass in the `--useSpecVersion` option, which would be equivalent to passing in `--version=1.2.3`:
-
-```sh
-rdme openapi [url-or-local-path-to-file] --useSpecVersion
-```
-
-You can add `--update` to the command so if there's only one API definition for the given project version to update, it will select it without any prompts:
-
-```sh
-rdme openapi [url-or-local-path-to-file] --version={project-version} --update
-```
-
-##### Override the Working Directory
-
-By default, `rdme` bundles all [references](https://swagger.io/docs/specification/using-ref/) with paths based on the directory that `rdme` is being run in. You can override the working directory using the `--workingDirectory` option, which can be helpful for bundling certain external references (see [here](__tests__/__fixtures__/relative-ref-oas/petstore.json) for an example file).
-
-```sh
-rdme openapi petstore.json --workingDirectory=[path to directory]
-```
-
-#### Validating an API Definition
-
-You can also perform a local validation of your API definition (no ReadMe account required!), which can be useful when constructing or editing your API definition.
-
-```sh
-rdme openapi:validate [url-or-local-path-to-file]
-```
-
-Similar to the `openapi` command, you can also [omit the file path](#omitting-the-file-path).
-
-#### Reducing an API Definition
-
-We also offer a tool that allows you to reduce a large API definition down to a specific set of tags or paths (again, no ReadMe account required!). This can be useful if you're debugging a problematic schema somewhere, or if you have a file that is too big to maintain.
-
-```sh
-rdme openapi:reduce [url-or-local-path-to-file]
-```
-
-The command will ask you a couple questions about how you wish to reduce the file and then do so. If you wish to automate this command, you can pass in CLI arguments to bypass the prompts. Here's an example use case:
-
-- The input API definition is called `petstore.json`
-- The file is reduced to only the `/pet/{id}` path and the `GET` and `PUT` methods
-- The output file is called `petstore.reduced.json`
-
-Here's what the resulting command looks like:
-
-```
-rdme openapi:reduce petstore.json --path /pet/{id} --method get --method put --out petstore.reduced.json
-```
-
-As with the `openapi` command, you can also [omit the file path](#omitting-the-file-path).
-
-#### Inspecting an API Definition
-
-This tool can also perform a comprehensive analysis (again, no ReadMe account required!) of your API definition to determine how it's utilizing aspects of [the OpenAPI Specification](https://spec.openapis.org/oas/v3.1.0.html) (such as circular references, polymorphism, etc.) and any [ReadMe-specific extensions](https://docs.readme.com/main/docs/openapi-extensions) you might be using.
-
-```sh
-rdme openapi:inspect [url-or-local-path-to-file]
-```
-
-This command contains a `--feature` flag so you can filter for one or several specific features. If you pass in one or more `--feature` flags, the command returns a `0` exit code if your definition contains all of the given features and a `1` exit code if your definition lacks any of the given features.
+# Usage
-```sh
-rdme openapi:inspect [url-or-local-path-to-file] --feature circularRefs --feature polymorphism
-```
-
-As with the `openapi` command, you can also [omit the file path](#omitting-the-file-path).
-
-#### Converting an API definition
-
-
-
-You can also convert any Swagger or Postman Collection to an OpenAPI 3.0 definition.
-
-```sh
-rdme openapi:convert [url-or-local-path-to-file]
-```
-
-Similar to the `openapi` command, you can also [omit the file path](#omitting-the-file-path).
-
-> [!NOTE]
-> All of our OpenAPI commands already do this conversion automatically, but in case you need to utilize this exclusive functionality outside of the context of those, you can.
-
-### Docs (a.k.a. Guides) π
-
-The Markdown files will require YAML front matter with certain ReadMe documentation attributes. Check out [our docs](https://docs.readme.com/docs/rdme#markdown-file-setup) for more info on setting up your front matter.
-
-Passing in a path to a directory will also sync any Markdown files that are located in subdirectories. The path input can also be individual Markdown files.
-
-```sh
-rdme docs [path] --version={project-version}
-```
-
-This command also has an alias called `guides`:
-
-```
-rdme guides [path] --version={project-version}
-```
-
-This command also has a dry run mode, which can be useful for initial setup and debugging. You can read more about dry run mode [in our docs](https://docs.readme.com/docs/rdme#dry-run-mode).
-
-#### Prune
-
-If you wish to delete documents from ReadMe that are no longer present in your local directory:
-
-```sh
-rdme docs:prune [path-to-directory-of-markdown]
-```
-
-Run with `--confirm` to bypass the confirmation prompt (useful for CI environments).
-
-This command also has an alias called `guides:prune`:
-
-```sh
-rdme guides:prune path-to-directory-of-markdown
-```
-
-### Changelog π£
-
-The Markdown files will require YAML front matter with certain ReadMe documentation attributes. Check out [our docs](https://docs.readme.com/docs/rdme#markdown-file-setup) for more info on setting up your front matter.
-
-Passing in a path to a directory will also sync any Markdown files that are located in subdirectories. The path input can also be individual Markdown files.
-
-```sh
-rdme changelogs [path]
-```
-
-This command also has a dry run mode, which can be useful for initial setup and debugging. You can read more about dry run mode [in our docs](https://docs.readme.com/docs/rdme#dry-run-mode).
-
-### Custom Pages π
-
-Custom Pages has support for both Markdown and HTML files. These files will require YAML front matter with certain ReadMe documentation attributes. Check out [our docs](https://docs.readme.com/docs/rdme#markdown-file-setup) for more info on setting up your front matter.
-
-Passing in a path to a directory will also sync any HTML/Markdown files that are located in subdirectories. The path input can also be individual HTML/Markdown files.
-
-```sh
-rdme custompages [path]
-```
-
-This command also has a dry run mode, which can be useful for initial setup and debugging. You can read more about dry run mode [in our docs](https://docs.readme.com/docs/rdme#dry-run-mode).
-
-### Versions β³
-
-#### Get All Versions Associated With Your Project
-
-```sh
-rdme versions
-```
-
-##### Get All Information About a Particular Version
-
-```sh
-rdme versions --version={project-version}
-```
-
-#### Create a New Version
-
-```sh
-rdme versions:create
-```
-
-If you wish to automate the process of creating a new project version, and not have the CLI prompt you for input, you can do so by supplying the necessary flags to `versions:create`. The best way to ensure that you have supplied all the necessary flags is by running the command locally and verifying that the CLI does not prompt you.
+
-Like `versions:create`, if you wish to automate this process and not be blocked by CLI input, you can supply the necessary flags to this command. See `rdme versions:update --help` for a full list of flags.
-
-#### Delete a Version
-
-You can remove a specific version from your project, as well as all of the attached specs
-
-```sh
-rdme versions:delete
-```
+
+
+```sh-session
+$ npm install -g rdme
+$ rdme COMMAND
+running command...
+$ rdme (--version)
+rdme/9.0.0-next.30 darwin-arm64 node-v20.18.0
+$ rdme --help [COMMAND]
+USAGE
+ $ rdme COMMAND
+...
+```
+
+
-### Categories πͺ£
+## Common `rdme` Options
-#### Get All Categories Associated to Your Project Version
+- `--key `: The API key associated with your ReadMe project. Note that most of the commands below require API key authentication, even though the `--key` flag is omitted from the examples. See the [Authentication](#authentication) section above for more information.
+- `--version `: Your project version. See [our docs](https://docs.readme.com/docs/versions) for more information.
-```sh
-rdme categories --version={project-version}
-```
+
-## Future
-
-We are continually expanding and improving the offerings of this application as we expand our public API and are able. Some interactions may change over time, but we will do our best to retain backwards compatibility.
+
+
+# Command Topics
+
+* [`rdme autocomplete`](documentation/commands/autocomplete.md) - Display autocomplete installation instructions.
+* [`rdme categories`](documentation/commands/categories.md) - List or create categories in your ReadMe developer hub.
+* [`rdme changelogs`](documentation/commands/changelogs.md) - Sync Markdown files to your ReadMe project as Changelog posts.
+* [`rdme custompages`](documentation/commands/custompages.md) - Sync Markdown/HTML files to your ReadMe project as Custom Pages.
+* [`rdme docs`](documentation/commands/docs.md) - Sync or prune Guides pages in your ReadMe developer hub.
+* [`rdme help`](documentation/commands/help.md) - Display help for rdme.
+* [`rdme login`](documentation/commands/login.md) - Login to a ReadMe project.
+* [`rdme logout`](documentation/commands/logout.md) - Logs the currently authenticated user out of ReadMe.
+* [`rdme openapi`](documentation/commands/openapi.md) - Manage your API definition (e.g., syncing, validation, analysis, conversion, etc.). Supports OpenAPI, Swagger, and Postman collections, in either JSON or YAML formats.
+* [`rdme versions`](documentation/commands/versions.md) - Manage your documentation versions.
+* [`rdme whoami`](documentation/commands/whoami.md) - Displays the current user and project authenticated with ReadMe.
+
+
+
diff --git a/bin/run.js b/bin/run.js
index 741250a32..0c3827a11 100755
--- a/bin/run.js
+++ b/bin/run.js
@@ -11,7 +11,7 @@ async function main() {
opts.args = stringArgv(process.env.INPUT_RDME);
}
await execute(opts).then(msg => {
- if (msg) {
+ if (msg && typeof msg === 'string') {
// eslint-disable-next-line no-console
console.log(msg);
}
diff --git a/documentation/commands.md b/documentation/commands.md
deleted file mode 100644
index 24f69c144..000000000
--- a/documentation/commands.md
+++ /dev/null
@@ -1,495 +0,0 @@
-# Table of contents
-
-
-* [Table of contents](#table-of-contents)
-* [Example Usage](#example-usage)
-* [Command Reference](#command-reference)
-
-
-# Example Usage
-
-
-```sh-session
-$ npm install -g rdme
-$ rdme COMMAND
-running command...
-$ rdme (--version)
-rdme/9.0.0-next.30 linux-x64 node-v20.18.0
-$ rdme --help [COMMAND]
-USAGE
- $ rdme COMMAND
-...
-```
-
-
-# Command Reference
-
-
-* [`rdme autocomplete [SHELL]`](#rdme-autocomplete-shell)
-* [`rdme categories`](#rdme-categories)
-* [`rdme categories:create TITLE`](#rdme-categoriescreate-title)
-* [`rdme changelogs PATH`](#rdme-changelogs-path)
-* [`rdme custompages PATH`](#rdme-custompages-path)
-* [`rdme docs PATH`](#rdme-docs-path)
-* [`rdme docs:prune FOLDER`](#rdme-docsprune-folder)
-* [`rdme help [COMMAND]`](#rdme-help-command)
-* [`rdme login`](#rdme-login)
-* [`rdme logout`](#rdme-logout)
-* [`rdme openapi [SPEC]`](#rdme-openapi-spec)
-* [`rdme openapi:convert [SPEC]`](#rdme-openapiconvert-spec)
-* [`rdme openapi:inspect [SPEC]`](#rdme-openapiinspect-spec)
-* [`rdme openapi:reduce [SPEC]`](#rdme-openapireduce-spec)
-* [`rdme openapi:validate [SPEC]`](#rdme-openapivalidate-spec)
-* [`rdme versions`](#rdme-versions)
-* [`rdme versions:create VERSION`](#rdme-versionscreate-version)
-* [`rdme versions:delete [VERSION]`](#rdme-versionsdelete-version)
-* [`rdme versions:update [VERSION]`](#rdme-versionsupdate-version)
-* [`rdme whoami`](#rdme-whoami)
-
-## `rdme autocomplete [SHELL]`
-
-Display autocomplete installation instructions.
-
-```
-USAGE
- $ rdme autocomplete [SHELL] [-r]
-
-ARGUMENTS
- SHELL (zsh|bash|powershell) Shell type
-
-FLAGS
- -r, --refresh-cache Refresh cache (ignores displaying instructions)
-
-DESCRIPTION
- Display autocomplete installation instructions.
-
-EXAMPLES
- $ rdme autocomplete
-
- $ rdme autocomplete bash
-
- $ rdme autocomplete zsh
-
- $ rdme autocomplete powershell
-
- $ rdme autocomplete --refresh-cache
-```
-
-_See code: [@oclif/plugin-autocomplete](https://github.com/oclif/plugin-autocomplete/blob/v3.2.8/src/commands/autocomplete/index.ts)_
-
-## `rdme categories`
-
-Get all categories in your ReadMe project.
-
-```
-USAGE
- $ rdme categories --key [--version ]
-
-FLAGS
- --key= (required) Project API key
- --version= Project version. If running command in a CI environment and this option is not passed, the main
- project version will be used.
-
-DESCRIPTION
- Get all categories in your ReadMe project.
-```
-
-## `rdme categories:create TITLE`
-
-Create a category with the specified title and guide in your ReadMe project.
-
-```
-USAGE
- $ rdme categories:create TITLE --categoryType guide|reference --key [--preventDuplicates] [--version ]
-
-ARGUMENTS
- TITLE Title of the category
-
-FLAGS
- --categoryType=