- Core Functionality: AI Abstract Generation (using OpenAI API)
- Ignore Files via Tags
- Ignore Files via Title
- Ignore Files via Attribute
- Content Injection
npm install hexo-ai-abstract
Put hexo_ai_abstract
config in your hexo/_config.yml
.
hexo_ai_abstract:
enable: 'on' # ['auto', 'on', 'off']
apiKey: 'your-api-keys here'
apiUrl: 'https://api.openai.com/v1'
model: 'gpt-4o-mini'
prompt: 'You are a highly skilled AI trained in language comprehension and summarization. I would like you to read the text delimited by triple quotes and summarize it into a concise abstract paragraph. Aim to retain the most important points, providing a coherent and readable summary that could help a person understand the main points of the discussion without needing to read the entire text. Please avoid unnecessary details or tangential points. Only give me the output and nothing else. Do not wrap responses in quotes. Respond in the Chinese language.'
ignoreEl: [
'table', 'pre', 'figure'
]
ignores:
byTitle: [ '{{title}}' ]
byTag: [ 'about', 'encrypt' ]
byAttribute: ['password']
inject:
anchor: '<!-- more -->'
front: True
maxTokens: 5000
Note:
If enable
is set to 'on', it indicates that the plugin is in test mode.
For posts that are expected to generate AI abstract, the aiAbstract
property should be added to their Front-Matter and must be ensured to be empty.
This plugin will upload data.content
to the AI service to generate an abstract when you save a post without excerpt
Front-Matter.
The abstract will then be used to construct the excerpt.
The generated abstract will look like this:
---
title: Your Post Title
tags:
- notencrypt
aiabstract: >-
Generated Abstract.
---
You can set "enable" to "on" to test whether the plugin is working.
hexo_ai_abstract:
enable: 'on'
When "enable" is set to either "on" or "auto," the visualization results of the decision tree are as follows.
graph TD;
A(aiAbstract)-->B1(defined);
A-->B2(undefined);
B1-->C1(not null);
B1-->C2(null);
C1-->Z1;
C2-->Z0;
B2-->D1(enable is 'auto');
B2-->D2(enable is 'on');
D1-->Z0;
D2-->Z2;
Z0(Generate aiAbstract);
style Z0 color:#33aa33
Z1(Already exists, not Generate);
style Z1 color:#aa3333
Z2(Not Generate);
style Z2 color:#aa3333
Specifically, when "enable" is set to "on," the AI summary generation will only be executed if the aiAbstract
attribute of the post exists and is empty.
Consequently, you can test the plugin's availability by adding the aiAbstract
attribute to a post and leaving it empty.
For some personal post, e.g. encrypted posts, uploading the post's content might be undesirable.
To address this, hexo-ai-abstract
offers features to "Ignore Files via Tags", "Ignore Files via Title" and "Ignore Files via Attribute".
Ignore Files via Tags
You can filter out posts that you don't want to process by tagging them accordingly. For example:
title: Post Title
tags:
- secret
Then, in your _config.yml, you can specify the tags to ignore:
hexo_ai_abstract:
ignores:
byTag: [ 'secret', '...' ]
Any post tagged with a tag listed in ignoreTag will be skipped during the abstract generation process.
Ignore Files via Title
Some plugins and software may include post templates. However, generating summaries from the content of these templates is generally undesirable.
To address this, the option to "Ignore Files via Title" has been introduced. For example, using the "insect template" in Obsidian, if the post title is set to {{title}}:
---
title: '{{title}}'
toc: true
recommend: 1
keywords: '{{title}}'
uniqueId: '{{date}} {{time}}/{{title}}.html'
...
You can specify in the _config.yml
to ignore posts with the title "{{title}}":
hexo_ai_abstract:
ignores:
byTitle: [ '{{title}}' ]
After that, the plugin will not generate AI abstract for these posts.
Ignore Files via Attribute
In the plugin hexo-blog-encrypt
, you can encrypt posts not only by using tags but also by adding a password
in the post attributes.
Therefore, we have also incorporated the corresponding functionality.
For example, if a password is added to a post:
---
...
comments: false
password: pa33w@rd
...
You should also specify the password in the _config.yml
:
hexo_ai_abstract:
ignores:
byAttribute: [ 'password' ]
Subsequently, the plugin will ignore this post.
In our initial version, the generated AI summaries were stored in the excerpt
attribute.
However, if there is content in the excerpt, the content before the <!-- more -->
will not be displayed as an excerpt on the homepage, and the excerpt content cannot be rendered within the main body.
To address this issue, the hexo-ai-abstract
plugin has implemented the following changes after v1.1.0
:
- The generated AI abstract is now stored in the
aiAbstract
attribute. - An injection feature has been added: the content from
aiAbstract
is injected into the main content.
This functionality requires you to add configuration settings in the _config.yml
:
hexo_ai_abstract:
inject:
anchor: '<!-- more -->'
front: False
The plugin will first match the content in inject.anchor
and then determine whether to inject the AI summary content before or after inject.anchor
based on the inject.front
setting.
Taking anchor: '<!-- more -->'
as an example,
if front: True
, the AI summary will be generated before the <!-- more -->
tag.
Conversely, if front: False
, the AI summary will be generated after the <!-- more -->
tag.
We sincerely thank hexo-ai-excerpt and hexo-ai-summaries for their pioneering work, which served as an inspiration for the creation of hexo-ai-abstract.
hexo-ai-abstract
is released under the MIT License.
You are free to use, modify, and distribute this software under the terms of the MIT License.
We encourage contributions and feedback to help improve the project.