hexo icon indicating copy to clipboard operation
hexo copied to clipboard

Save database such as Asset in processor is not working

Open wherewhere opened this issue 4 months ago • 3 comments

Check List

  • [x] I have already read Docs page & Troubleshooting page.
  • [x] I have already searched existing issues and they are not help to me.
  • [x] I examined error or warning messages and it's difficult to solve.
  • [x] I am using the latest version of Hexo. (run hexo version to check)
  • [x] My Node.js is matched the required version.

Expected behavior

Should add to database.

Actual behavior

Nonething happened.

How to reproduce?

Write a plugin to save something in Asset model.

hexo.extend.processor.register("_posts/:slug\.md", () => {
  const Asset = hexo.model("Asset");
  const test = Asset.findById("Test");
  if (!test) {
    return Asset.save({
      _id: "Test",
      path: "Test",
      modified: true
    });
  }
});

Your Node.js & npm version

v23.11.0
10.9.2

Your Hexo and Plugin version

[email protected]
+-- [email protected]
+-- [email protected]
+-- [email protected]
+-- [email protected]
+-- [email protected]
+-- [email protected]
+-- [email protected]
+-- [email protected]
+-- [email protected]
+-- [email protected] -> .\..\PagePluginTest
`-- [email protected]

Your package.json

{
  "name": "hexo-site",
  "version": "0.0.0",
  "private": true,
  "scripts": {
    "build": "hexo generate",
    "clean": "hexo clean",
    "deploy": "hexo deploy",
    "server": "hexo server"
  },
  "hexo": {
    "version": "7.3.0"
  },
  "dependencies": {
    "hexo": "^7.3.0",
    "hexo-generator-archive": "^2.0.0",
    "hexo-generator-category": "^2.0.0",
    "hexo-generator-index": "^4.0.0",
    "hexo-generator-tag": "^2.0.0",
    "hexo-renderer-ejs": "^2.0.0",
    "hexo-renderer-marked": "^7.0.0",
    "hexo-renderer-stylus": "^3.0.1",
    "hexo-server": "^3.0.0",
    "hexo-theme-landscape": "^1.0.0",
    "hexo-wherlog-objects": "file:../PagePluginTest"
  }
}

Your site's _config.yml (Optional)

# Hexo Configuration
## Docs: https://hexo.io/docs/configuration.html
## Source: https://github.com/hexojs/hexo/

# Site
title: Hexo
subtitle: ''
description: ''
keywords:
author: John Doe
language: en
timezone: ''

# URL
## Set your site url here. For example, if you use GitHub Page, set url as 'https://username.github.io/project'
url: http://example.com
permalink: :year/:month/:day/:title/
permalink_defaults:
pretty_urls:
  trailing_index: true # Set to false to remove trailing 'index.html' from permalinks
  trailing_html: true # Set to false to remove trailing '.html' from permalinks

# Directory
source_dir: source
public_dir: public
tag_dir: tags
archive_dir: archives
category_dir: categories
code_dir: downloads/code
i18n_dir: :lang
skip_render:

# Writing
new_post_name: :title.md # File name of new posts
default_layout: post
titlecase: false # Transform title into titlecase
external_link:
  enable: true # Open external links in new tab
  field: site # Apply to the whole site
  exclude: ''
filename_case: 0
render_drafts: false
post_asset_folder: false
relative_link: false
future: true
syntax_highlighter: highlight.js
highlight:
  line_number: true
  auto_detect: false
  tab_replace: ''
  wrap: true
  hljs: false
prismjs:
  preprocess: true
  line_number: true
  tab_replace: ''

# Home page setting
# path: Root path for your blogs index page. (default = '')
# per_page: Posts displayed per page. (0 = disable pagination)
# order_by: Posts order. (Order by date descending by default)
index_generator:
  path: ''
  per_page: 10
  order_by: -date

# Category & Tag
default_category: uncategorized
category_map:
tag_map:

# Metadata elements
## https://developer.mozilla.org/en-US/docs/Web/HTML/Element/meta
meta_generator: true

# Date / Time format
## Hexo uses Moment.js to parse and display date
## You can customize the date format as defined in
## http://momentjs.com/docs/#/displaying/format/
date_format: YYYY-MM-DD
time_format: HH:mm:ss
## updated_option supports 'mtime', 'date', 'empty'
updated_option: 'mtime'

# Pagination
## Set per_page to 0 to disable pagination
per_page: 10
pagination_dir: page

# Include / Exclude file(s)
## include:/exclude: options only apply to the 'source/' folder
include:
exclude:
ignore:

# Extensions
## Plugins: https://hexo.io/plugins/
## Themes: https://hexo.io/themes/
theme: landscape

# Deployment
## Docs: https://hexo.io/docs/one-command-deployment
deploy:
  type: ''

Others

example

wherewhere avatar Jul 30 '25 10:07 wherewhere

Post model works fine. Is that need to set something?

hexo.extend.processor.register("_posts/:slug\.md", () => {
  const Post = ctx.model('Post');
  const test = Post.findById("Test");
  if (!test) {
    return Post.save({
      _id: "cmdpuk53y0000n4ywg8ki54j7",
      path: "Test",
      slug: "Test",
      source: "123",
      modified: true
    });
  }
});

wherewhere avatar Jul 30 '25 11:07 wherewhere

https://github.com/hexojs/hexo/blob/c69553c76d6f20c9bc7be1af98ed2c6c4e8c372c/lib/plugins/generator/asset.ts#L22-L23 If asset.source (join(base_dir, _id)) does not exist, it will be removed.

D-Sketon avatar Oct 05 '25 14:10 D-Sketon

So how can I create outside assets. The marked render need to check assets to generate relation url. Maybe we need a visual file system to manage assets.

wherewhere avatar Oct 06 '25 08:10 wherewhere