/docfx-companion-tools

A suite of tools, pipelines templates to take the very best of DocFX

Primary LanguageC#MIT LicenseMIT

DocFX Companion Tools

This repository contains a series of tools, templates, tips and tricks to make your DocFX life even better.

Tools

  • DocFxTocGenerator: generate a Table of Contents (TOC) in YAML format for DocFX. It has features like the ability to configure the order of files and the names of documents and folders.
  • DocLinkChecker: validate links in documents and check for orphaned attachments in the .attachments folder. The tool indicates whether there are errors or warnings, so it can be used in a CI pipeline. It can also clean up orphaned attachments automatically. And it can validate table syntax.
  • DocLanguageTranslator: allows to generate and translate automatically missing files or identify missing files in multi language pattern directories.
  • DocFxOpenApi: converts existing OpenAPI specification files into the format compatible with DocFX (OpenAPI v2 JSON files). It allows DocFX to generate HTML pages from the OpenAPI specification. OpenAPI is also known as Swagger.

Creating PR's

The main branch is protected. Features and fixes can be done through PR's only. Make sure you use a proper title for the PR and keep them as small as possible. If you want the PR to pop up in the CHANGELOG, you have to provide one or more labels with the PR. The list of labels that are used:

Category Description Labels
🚀 Features New or modified features feature, enhancement
🐛 Fixes All (bug) fixes fix, bug
📄 Documentation Documentation additions or changes documentation

Build and Publish

If you have this repo on your local machine, you can run the same scripts for building and packaging as we're using in the workflows. To build the tools use the build script. In PowerShell run this command:

.\build.ps1

The result of this script is an output folder containing the executables of all solutions. They are all published as single exe's without the framework. They depend on .NET 5 being installed in the environment. The LICENSE file is copied to the output folder as well. The contents of this folder is then compressed in a zip-file in the root with the name 'tools.zip'.

To package and publish the tools, you must first have run the build script. Next you can run the pack script we're using from the worklows as well. In PowerShell run this command, where you provide the correct version:

.\pack.ps1 -publish -version "1.0.0"

The script determine the hash of the tools.zip, change the Chocolatey nuspec and install script to contain the hash and the correct versions. Then the Chocolatey package is created. If the CHOCO_TOKEN environment variable is set containing the secret to use for Chocolatey publication, the script will also publish the package to Chocolatey. Otherwise a warning is given that the publish step is skipped.

If you omit the -publish parameter, the script will run in develop mode. It will not publish to Chocolatey and it will output the changes of the Chocolatey files for inspection.

Note

If you run the pack script locally, files are changed (deploy\chocolatey\docfx-companion-tools.nuspec and deploy\chocolatey\tools\chocolateyinstall.ps1). Maybe it's best not to commit that into the repo, although it's not secret information. Next run will overwrite the correct values anyway.

Version release and publish to Chocolatey

If you have one or more PR's and want to release a new version, just make sure that all PR's are labeled where needed (see above) and merged into main. Run the manual Release & Publish workflow manually on the main branch. This will bump the version, create a release and publish a new package to Chocolatey.

Install

Chocolatey

The tools can be installed by downloading the zip-file of a release or use Chocolatey like this:

choco install docfx-companion-tools

Note

The tools expect the .NET Framework 6 to be installed locally. If you need to run them in a framework which is higher, add --roll-forward Major as a parameter like this: ~/.dotnet/tools/DocLinkChecker --roll-forward Major

dotnet tool

You can as well install the tools through dotnet tool.

dotnet tool install DocFxTocGenerator -g
dotnet tool install DocLanguageTranslator -g
dotnet tool install DocLinkChecker -g
dotnet tool install DocFxOpenApi -g

usage

Once the tools are installed this way you can use them directly from the command line. For example:

DocFxTocGenerator -d .\docs -vsi
DocLanguageTranslator -d .\docs\en -k <key> -v
DocLinkChecker -d .\docs -va

CI Pipeline samples

Docker

Build a Docker image. Below example based on DocLinkChecker, adjust --tag and --build-arg accordantly for the other tools.

docker build --tag doclinkchecker:latest --build-arg tool=DocLinkChecker -f Dockerfile .

Run from PowerShell:

docker run --rm -v ${PWD}:/workspace doclinkchecker:latest -d /workspace

Run from Linux/macOS shell:

docker run --rm -v $(pwd):/workspace doclinkchecker:latest -d /workspace

Documentation

License

Please read the main license file and the sub folder license files and 3rd party notice. Most of those tools are coming from a work done with ZF.