Skip to content

Generate and publish your content from the command line with the help of AI (GPT) 🤯

Notifications You must be signed in to change notification settings

christophebe/julius-gpt

Repository files navigation

This Node.js CLI and API gives you the ability to generate content (blog post, landing pages, ...) with a LLM (OpenAI, ...). It can generate text in all languages supported by the available LLMs.

This project is using Langchain JS

Features

🔄 Different modes for generating content: automatic, interactive, or with a content template.

🧠 Supported LLMs : OpenAI (stable), Mistral (experimental), Claude (upcoming release), Groq (upcoming release).

🌍 All languages supported by the available LLMs.

🔥 SEO friendly : generate post title, description & slug.

✍️ Default or custom prompts.

⚙️ Fine-tuning with completion parameters.

📝 Publish content on WordPress.

🌐 API.

🔜 Upcoming features: image generations, RAG, publish on NextJS.

Table of Content

How it Works ?

This component can be used in different modes:

  • with the CLI ( interactive mode, automatic mode or with the help of a template).
  • In your application with the API.

1. Interactive / Automatic Mode

In interactive mode, the CLI will ask you for some parameters (topic/title, language, intent, audience, etc.).

In automatic mode, you need to supply all the necessary parameters to the command line. This mode of operation allows you to create a multitude of contents in series (for example, in a shell script).

Both modes will use different predefined prompts to generate the content:

  • Generate the outline of the post (with the SEO description, SEO title, the slug).
  • Generate the introduction.
  • Generate the content of the different heading of the outline.
  • Generate the conclusion.

The final result is in Markdown and HTML.

2. Template Mode

A template contains a document structure within a series of prompts. Each prompt will be executed in a specific order and will be replaced by the answer provided by the AI. It is possible to use different formats: Markdown, HTML, JSON, etc.

The main advantage of the template usage is the customisation of the output. You can use your own prompts. Templates are also interesting if you want to produce different contents based on the same structure (product pages, landing pages, etc.).

3. Completion Parameters

One of the problems of AI content generation is the repetition of the main keywords. This script also uses temperature, frequency_penalty, and presence_penalty parameters to try to minimize this. See the OpenAI API documentation for more details.

4. Publish on Wordpress

When generating, the CLI gives you the ability to publish the content to your WordPress blog. Other CMS will be supported in the future. We need to support some headless CMS.

Warning

This is an experimental project. You are welcome to suggest improvements, like other prompts and other values for the parameters. The cost of the API calls is not included in the price of the CLI. You need to have an OpenAI API key to use this CLI. In all cases, you have to review the final output. AI can provide incorrect information.

Examples

version 0.1.1 - Auto mode with custom prompts in french

Camping-cars écologiques ? Utopie ou réalité en 2024 ?

version 0.1.0 - Auto Mode

julius post -fp 1.5 -g -tp "5\ reasons\ to\ use\ AI\ for\ generating\ content" -f ./reasons-to-use-ai-content

Markdown result : 5 Reasons to Use AI for Generating Content

version 0.1.1 - Template Markdown

julius template-post -f ./dobermann  -t ./template.md  -i breed=dobermann -d

Template : template.md

Markdown result : dobermann.md

version 0.1.1 - Template HTML

julius template-post -f ./dobermann  -t ./template.html  -i breed=dobermann -d

Template : template.html

HTML result : dobermann.html

Installation

The CLI and API are available as a NPM package.

# for the API
npm install julius-gpt -S
# for the CLI
npm install -g julius-gpt

CLI

The CLI has 4 groups of commands:

  • prompt : custom prompt management.
  • post: generate a post in interactive or auto mode.
  • template-post : generate a content based on a template.
  • wp: wordpress related commands : list, add, remove, update WP sites & publish posts.
~ julius -h                      
Usage: julius [options] [command]

Generate and publish your content from the command line 🤯

Options:
  -V, --version            output the version number
  -h, --help               display help for command

Commands:
  prompt                   Prompt related commands
  post [options]           Generate a post in interactive or automatic mode
  template-post [options]  Generate a post based on a content template
  wp                       Wordpress related commands. The 

Generate a Post

You need to have an OpenAI API key to use this CLI. You can specify your OpenAI API key with the -k option or with the environment variable OPENAI_API_KEY.

See the CLI help to get the list of the different options.

 ~ julius post -h

Automatic Mode

 ~ julius post -tp "5 reasons to use AI for generating content"

Use the other parameters to personalize content even further.

A more advanced command

 ~ julius post -fp 1.5 -g -l french -tp "Emprunter\ avec\ un\ revenu\ de\ retraite\ :\ quelles\ sont\ les\ options\ \?" -f ./emprunter-argent-revenu-retraite -c Belgique -d

This command will generate a post in French with a frequency penalty of 1.5 for the audience of the country : Belgium. The topic (tp arg) is written in French.

Interactive Mode

 ~ julius post -i

It is not necessary to use the other parameters. The CLI will ask you some questions about the topic, language, ...

Generate Content Based on a Template

The template file can be in the markdown or HTML format. The template extension will be used to determine the final output.

 ~ julius template-post -t <file>.[md|html]

The CLI will execute all prompts mentioned in the template file. Each prompt short-code will be replaced by the output provided by the AI.

Template structure

Here is a simple example for the template file:

{{s:Your are an prompt tester. You have to write your answers in a makrdown block code.}}
{{c:your answer has to be "Content of prompt 1."}}

# Heading 1
{{c:your answer has to be "Content of prompt 2."}}

Prompt "s" is the system prompt Prompt with "c" are content prompt. they will be replaced by the output provided by the AI.

Like in Langchain, you can provide some input variables in the template like this one :

{{s:Your are an prompt tester. You have to write your answers in a makrdown block code in language : {language}.}}
{{c:Quelle est la capitale de la France ?"}}

# Heading 1
{{c: Quelle est la capitale de la Belgique ? "}}

Now, you can execute this template with the following command :

 ~ julius template-post -t <template-file>.md -i language=french

This is an experimental feature and the template syntax will be modified in an upcoming release.

Supported Models

By default, the CLI is using the latest Open AI model. We are working on the support of the following ones :

Provider Models Status .env variable API KEY
OpenAI gpt-4, gpt-4-turbo-preview Stable OPENAI_API_KEY
Mistral mistral-small-latest, mistral-medium-latest, mistral-large-latest Experimental MISTRAL_API_KEY
Anthropic Claude Next Release NA
Groq Mistral, Llama Next Release NA

All models require an API Key. You can provide it either in the .env file or with the CLI parameter '-k'

You can choose your model with the -m parameter :

 ~ julius post -m mistral-large-latest ....

Use the help to have the list of the models

 ~ julius post -h 

or

 ~ julius template-post -h 

Custom prompts

Why custom prompts?

  • Default one are too generic.
  • Julius's default prompts are written in English. Customs prompts can be created for a specific language.
  • Give the possibility to add persona, writing style, remove IA footprint, add custom editorial brief, ....

Default prompts

Julius uses a set of prompts for content generation that can be customized by creating a new version in a separate directory. Each prompt is stored in a different file.

File name Description Inputs
system.txt Can be used as an editorial brief or to add important information such as personas, editorial style, objectives, ... None
audience-intent.txt Use to generate the audience and intent based on the article's subject. {language} {topic}
outline.txt Use to generate article structure. {language} {topic} {country} {audience} {intent}
introduction.txt Use to generate the article's introduction. {language} {topic}
conclusion.txt Use to generate the article's conclusion. {language} {topic}
heading.txt Use to generate the content of each heading. {language} {headingTitle} {keywords}

Create a custom prompt

1. Make a copy of the default prompts

 ~ julius prompt create [name] [folder]

eg. :

 ~ julius prompt create discover ./my-prompts

This command will copy the default prompts into the folder : ./my-prompts/discover

2. Modify the prompts

Now, you can modify and/or translate the prompts in this folder

3. Use your prompts in the CLI

In the automatic mode, the cli will ask you the custom prompt path

 ~ julius -i 

You can also use a CLI parameter "pf" to specify the folder path

 ~ julius -pf ./my-prompts/discover ...

Wordpress related commands

list

This command displays the list of all registered Wordpress sites in the local file ~/.julius/wordpress.json.

The domain name or the id of the site can be used for the following commands.

~ julius wp ls

add

This command adds a new Wordpress site to the local file ~/.julius/wordpress.json.

~ julius wp add www.domain.com:username:password

info

This command displays the list of all registered Wordpress sites in the local file ~/.julius/wordpress.json.

~ julius wp info www.domain.com|id

rm

This command removes a Wordpress site from the local file ~/.julius/wordpress.json.

~ julius wp rm www.domain.com|id

export

This command exports the list of all registered Wordpress sites in the local file ~/.julius/wordpress.json.

~ julius wp export wordpress_sites.json

import

This command imports the list of all registered Wordpress sites in the local file ~/.julius/wordpress.json.

~ julius wp import wordpress_sites.json

categories

This command displays the list of all categories of a Wordpress site.

~ julius wp categories www.domain.com|id

post

This command creates a new post on a Wordpress site. the JSON file must have the following structure:

{
    "title": "The title of the post",
    "slug": "the-slug-of-the-post",
    "content": "The content of the post",
    "seoTitle": "The SEO title of the post",
    "seoDescription": "The SEO description of the post",
}

This JSON file can be generated with the command julius post or with the API.

By default, the Wordpress REST API doesn't allow you to update the SEO title and description. This information is managed by different plugins, such as Yoast SEO. You can code a plugin for this.

A plugin example for Yoast can be found in this directory: julius-wp-plugin You can create a zip and install it from the Wordpress dashboard.

You can code something similar for other SEO plugins.

~ julius wp post www.domain.com|id categoryId post.json
  • The first argument is the domain name or the ID of the site.
  • The second argument is the ID of the category on this WordPress. You can get the list of categories with the command julius wp categories www.domain.com|id
  • The third argument is a boolean to indicate if the WP used Yoast SEO plugin. If true, the SEO title and description will be published.
  • The fourth argument is the path to the JSON file containing the post.

update

This command updates a post on a Wordpress site (title, content, SEO title & SEO description). the JSON file must have the following structure:

{
    "title": "The title of the post",
    "slug": "the-slug-of-the-post",
    "content": "The content of the post",
    "seoTitle": "The SEO title of the post",
    "seoDescription": "The SEO description of the post",
}

This JSON file can be generated with the command julius post or with the API.

~ julius wp update www.domain.com|id slug post.json [-d, --update-date] 
  • The first argument is the domain name or the ID of the site.
  • The second argument is the slug of the post to update.
  • The third argument is the JSON file.
  • The fourth argument (optional) is to update the publication date or not.

API

See the unit tests : tests/test-api.spec.ts

Some Tools that can Help to Check Quality

  • Quillbot: AI-powered paraphrasing tool will enhance your writing, grammar checker and plagiarism checker.
  • Originality: AI Content Detector and Plagiarism Checker.

Credit