Welcome to Catdocs! This repository contains tools, libraries, and a CLI for managing OpenAPI documentation, specifically designed for teams working collaboratively on APIs.
Catdocs is an OpenAPI documentation tool that streamlines the process of managing API documentation for teams. By enabling the splitting of OpenAPI documents, Catdocs allows different teams or individuals to work on separate parts of the API documentation, ensuring efficient and organized collaboration.
Catdocs is a powerful command-line interface (CLI) tool offering robust support for API management similar to the capabilities provided by the Redocly CLI. This tool comes with comprehensive support for all API management commands in Redocly, excluding the generation of OpenAPI documentation previews and related commands.
- OpenAPI Documentation Management: Easily handle large OpenAPI documents by splitting them into manageable parts.
- Team Collaboration: Supports collaborative work by allowing different team members to edit specific sections of the API documentation.
- External Reference Handling: Automatically resolves and manages external references in OpenAPI documents.
- CLI Tool: Includes a command-line interface for easy integration into your workflow.
- Validation: Validates OpenAPI documents to catch errors before publishing.
- Version Control Integration: Seamlessly integrates with Git for version control, enabling team members to push and pull changes effortlessly.
- Scalability: Manage large and complex OpenAPI documents by breaking them down into smaller, manageable parts.
- Team Efficiency: Improve team efficiency by allowing members to focus on their specific areas of responsibility.
- Error Reduction: Reduce errors by validating OpenAPI documents before publishing.
- Seamless Integration: Integrate Catdocs into your existing workflow with ease, thanks to its CLI and version control capabilities.
- Splitting Documentation: Catdocs splits your main OpenAPI document into multiple files, each representing different parts of the API (e.g., paths, responses, schemas).
- Editing Parts Independently: Team members can work on their assigned parts independently, using their preferred tools.
- Merging Changes: Catdocs merges the individual parts back into a single cohesive OpenAPI document, resolving any references.
- Validation: Before finalizing the documentation, Catdocs validates the OpenAPI document to ensure there are no errors.
- Version Control: Use Git to manage changes, enabling team collaboration and maintaining a history of modifications.
You should check if .NET 8 is already installed on your system, you can run the following command in your terminal:
dotnet --version
If not, for Windows you have to download .NET 8 SDK, for Linux you can run:
sudo apt-get update && \
sudo apt-get install -y dotnet-sdk-8.0
And for Mac:
brew update
brew install --cask dotnet-sdk
Run the following command to clone the repository:
git clone https://github.com/imaun/catdocs.git
Navigate to the cloned repository's directory and build the project:
cd catdocs
dotnet build
You can now run Catdocs using the dotnet run command followed by the specific command you wish to use. For example, to get statistics of an OpenAPI document:
dotnet run -- stats --file path/to/your/openapi.yaml --format yaml
Catdocs supports several commands to help you work with OpenAPI documents: stats, split, bundle, and convert.
The stats command analyzes an OpenAPI specification file, validates it, and prints out information about its components such as the number of API paths, request bodies, and responses.
Usage:
catdocs --file example-openapi.yaml --spec-ver 3 --format json
Options:
- --file (Aliases: --source, --spec, -s): The path to the OpenAPI spec file.
- --spec-ver (Aliases: --spec-version, -v): The OpenAPI specification version (2 or 3). Default is 3.
- --format: The format of the OpenAPI file (json or yaml). Default is based on the file extension.
This command splits an OpenAPI document into separate reusable components, each in its own file, with the main document containing references to these components.
Usage:
catdocs split --file OpenApi.yaml --spec-ver 3 --format yaml --outputDir examples/bundle-pipeline
Options:
- --file (Aliases: --source, --spec, -s): Path to the source OpenAPI documentation file.
- --spec-ver (Aliases: --spec-version, -v): The OpenAPI specification version (2 or 3). Default is 3.
- --format: The format of the OpenAPI file (json or yaml). Default is based on the file extension.
- --outputDir: The directory path where the output files will be saved. This directory will contain an OpenAPI file with external references to each component file path.
This command bundles a previously split OpenAPI file by putting its components back into their places, validates the document, logs any errors, and outputs a single bundled OpenAPI file if there are no validation errors.
Usage:
catdocs bundle --file examples/bundle-pipeline/OpenApi.yaml --spec-ver 3 --format yaml --output examples/bundle-pipeline/output.yaml
Options:
- --file (Aliases: --source, --spec, -s): The path to the OpenAPI spec file.
- --spec-ver (Aliases: --spec-version, -v): The OpenAPI specification version (2 or 3). Default is 3.
- --format: The format of the OpenAPI file (json or yaml). Default is based on the file extension.
- --output: The destination filename for the output of this command, a bundled OpenAPI file.
Converts an OpenAPI document from JSON to YAML or vice versa, depending on the source file format. It also validates the source file and lists any errors found during the process.
Usage:
catdocs convert --file docs.json --spec-ver 3 --format json --output docs.yaml
Options:
- --file (Aliases: --source, --spec, -s): The source OpenAPI filename.
- --spec-ver (Aliases: --spec-version, -v): The OpenAPI specification version (2 or 3). Default is 3.
- --format: The source file format (json or yaml). The output will be in the opposite format.
- --output: The destination filename for the output file of this command.
Catdocs is particularly effective when integrated into CI/CD pipelines, facilitating the management of large OpenAPI specifications within a team. By utilizing the bundle command, you can automate the process of combining multiple OpenAPI components into a single document. This is crucial for teams where different members or groups work on separate parts of the API specification.
Imagine a scenario where your API specification is split into multiple components, each maintained in separate files as per the split command's functionality. Each team member contributes to different aspects of the API, such as paths, responses, or schemas, by updating their respective files. Once changes are committed and pushed to the repository, you need a reliable way to combine these individual components back into a cohesive API document.
To facilitate this, you can incorporate Catdocs into your CI/CD pipeline. Upon a merge request or push to a specific branch (typically main or master), the pipeline triggers the bundle command to automatically assemble the updated components into a final OpenAPI specification. This bundled file can then be pushed back to the repository or passed along to other stages in your pipeline, such as API testing or deployment.
Actually, Catdocs CI pipeline itself, is an example of a sample pipeline using GitHub Actions. This setup assumes that the OpenAPI components are stored in a directory structure created by the split command and that the final bundle should be updated in the repository.
Since Catdocs OpenAPI is built for .NET developers, integrating it into your existing .NET applications is seamless. After adding the package to your project, you can use it's library in your projects.
To begin using Catdocs OpenAPI in your .NET projects, you can easily install it via NuGet. The tool is packaged as a .NET 8 library, making it straightforward to integrate into your existing applications.
You can install the Catdocs.OpenAPI package by running the following command in your project directory:
dotnet add package Catdocs.OpenAPI
This command will download and add the Catdocs.OpenAPI package to your project, allowing you to utilize its features directly within your .NET environment.
or integrate it into your build and CI/CD pipelines. This integration ensures that your API management processes are tightly coupled with your development workflow, enhancing efficiency and reliability.
We welcome contributions!
This project is licensed under the MIT License. See the LICENSE file for details.
imun22 with gmail at the end!