Skip to content

Latest commit

 

History

History
79 lines (54 loc) · 3.08 KB

README.md

File metadata and controls

79 lines (54 loc) · 3.08 KB

Gitbook plugin for bulk redirects

Note This is a fork of the original plugin on npm here. A fork was required because links in the redirect files created by this plugin are being picked up as containing bad links by the Dronecode gitbook link checker htmlproofer. Essentially all this change does is add the data-proofer-ignore attribute to the generated HTML so that it is ignored by our link checker.

This plugin lets you create bulk redirects of URLs as part of Gitbook generation. This is useful if you need to add multiple redirects for articles without adding them to the SUMMARY.md.

If you need to redirect individual pages, use the redirect plugin.

Installation

Add this to your book.json plugin list:

{
    "plugins": [ "bulk-redirect@git+https://github.com/Dronecode/gitbook-plugin-bulk-redirect.git"]
}

Usage

Configuration for this plugin is specified in book.json in the pluginsConfig object, with the key bulk-redirect. There are two important configuration options for this plugin (discussed below): basepath and redirectsFile.

"pluginsConfig": {
    "bulk-redirect": {
        "basepath": "/",
        "redirectsFile": "redirects.json"
    }
}

basepath

basepath is a string containing a path against which the to URLs in the redirects list (present in redirectsFile) are resolved. It can be used to specify path to the directory in which the compiled book will be hosted, relative to the root of the domain. E.g., if the book is to be hosted at http://example.com/book/, then set the value of basepath to /book/. The trailing slash is necessary to ensure URLs resolve properly.

If the book is hosted at the root of the domain, e.g. http://example.com/, then you can leave this unspecified.

For example:

"pluginsConfig": {
    "bulk-redirect": {
        "basepath": "/user/current/",
        "redirectsFile": "redirects.json"
    }
}

redirects in redirects.json

The redirects contains an array of objects. This array should be present in another file. This relative path of this file should be passed in the redirectsFile field.

Each object in the redirects array has 2 important keys: from and to.

  • from: This key should contain the URL of the old HTML, relative to the root of the book output.
  • to: This key should contain the URL of the new HTML, relative to the root of the book output. If a basepath is provided, it is used to resolve the URL given in to.

For example: redirects.json

{
    "redirects": [
            {
                "from": "oldpage.html",
                "to": "newpage.html"
            },
            {
                "from": "olddir/oldpage.html",
                "to": "newdir/newpage.html"
            },
        ]
}

This will create the pages oldpage.html and olddir/oldpage.html in the output and they will redirect to /newpage.html and /newdir/newpage.html respectively.