Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/arranf/HugoToJSON
A Rust utility to produce a JSON representation of the contents of a Hugo static site
https://github.com/arranf/HugoToJSON
hugo index json lunr lunrjs rust search
Last synced: 2 months ago
JSON representation
A Rust utility to produce a JSON representation of the contents of a Hugo static site
- Host: GitHub
- URL: https://github.com/arranf/HugoToJSON
- Owner: arranf
- License: mit
- Created: 2019-01-13T11:49:41.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2021-04-03T22:57:42.000Z (almost 4 years ago)
- Last Synced: 2024-10-31T18:12:15.351Z (3 months ago)
- Topics: hugo, index, json, lunr, lunrjs, rust, search
- Language: Rust
- Homepage:
- Size: 167 KB
- Stars: 29
- Watchers: 4
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-starred - arranf/HugoToJSON - A Rust utility to produce a JSON representation of the contents of a Hugo static site (rust)
README
# HugoToJSON
[![CircleCI](https://circleci.com/gh/arranf/HugoToJSON/tree/master.svg?style=svg)](https://circleci.com/gh/arranf/HugoToJSON/tree/master)
[![Crate](https://img.shields.io/crates/v/hugo_to_json.svg)](https://crates.io/crates/hugo_to_json)A utility to produce a JSON representation of the key front matter and contents of Hugo documents. It's main intent is to produce JSON to be used by [Lunr](https://lunrjs.com/) (and [Lunr-like](http://elasticlunr.com/) packages) to support search on a static Hugo site. It's designed to be a fast and modern alternative to the now unsupported [hugo_lunr Node tool](https://www.npmjs.com/package/hugo-lunr).
Pull requests are welcome. A list of goals and work to be done is available in `ToDo.txt`.
It currently supports `.md` files and both YAML and TOML front matter.
## Using
`hugo_to_json HUGO_CONTENT_DIRECTORY -o OUTPUT_LOCATION`Example usage is shown below.
`hugo_to_json example/blog/content -o example/blog/static/index.json`Defaults to `./content` for the content directory and stdout for the index output.
## Fetching the Latest Version
If you want to use the latest version of this tool as part of a CI build process the following script should work.
```bash
#!/usr/bin/env bash
set -e# Based on
#https://blog.markvincze.com/download-artifacts-from-a-latest-github-release-in-sh-and-powershell/LATEST_RELEASE=$(curl -L -s -H 'Accept: application/json' https://github.com/arranf/HugoToJSON/releases/latest)
# The releases are returned in the format {"id":3622206,"tag_name":"hello-1.0.0.11",...}, we have to extract the tag_name.
LATEST_VERSION=$(echo $LATEST_RELEASE | sed -e 's/.*"tag_name":"\([^"]*\)".*/\1/')
ARTIFACT_URL="https://github.com/arranf/HugoToJSON/releases/download/$LATEST_VERSION/hugo_to_json"
INSTALL_DIRECTORY="."
INSTALL_NAME="hugo_to_json"
DOWNLOAD_FILE="$INSTALL_DIRECTORY/$INSTALL_NAME"echo "Fetching $ARTIFACT_URL.."
if test -x "$(command -v curl)"; then
code=$(curl -s -w '%{http_code}' -L "$ARTIFACT_URL" -o "$DOWNLOAD_FILE")
elif test -x "$(command -v wget)"; then
code=$(wget -q -O "$DOWNLOAD_FILE" --server-response "$ARTIFACT_URL" 2>&1 | awk '/^ HTTP/{print $2}' | tail -1)
else
echo "Neither curl nor wget was available to perform http requests."
exit 1
fiif [ "$code" != 200 ]; then
echo "Request failed with code $code"
exit 1
fichmod +x "$DOWNLOAD_FILE"
```