Files
bDS2/API.md
2026-04-25 08:28:49 +02:00

37 KiB

API Documentation

Contract version: 0.4.0

This reference documents the Lua runtime API available through bds in embedded bDS2 scripts.

bds is available in project-scoped Lua scripts executed through the bDS2 scripting runtime.

Usage

local project = bds.projects.get_active()
local meta = bds.meta.get_project_metadata()

Table of contents

app

app.copy_to_clipboard

Copy text to the system clipboard.

Parameters

  • text (string, required)

Response specification

  • Return type: boolean

Example call

local result = bds.app.copy_to_clipboard("value")

app.get_blogmark_bookmarklet

Return the Blogmark bookmarklet JavaScript source.

Parameters

  • None

Response specification

  • Return type: string

Example call

local result = bds.app.get_blogmark_bookmarklet()

app.get_data_paths

Return filesystem paths for the current application and project data.

Parameters

  • None

Response specification

  • Return type: table

Example call

local result = bds.app.get_data_paths()

app.get_default_project_path

Return the current project's filesystem path.

Parameters

  • None

Response specification

  • Return type: string | nil

Example call

local result = bds.app.get_default_project_path()

app.get_system_language

Return the current UI locale.

Parameters

  • None

Response specification

  • Return type: string | nil

Example call

local result = bds.app.get_system_language()

app.get_title_bar_metrics

Return desktop title bar inset metrics when available.

Parameters

  • None

Response specification

  • Return type: table | nil

Example call

local result = bds.app.get_title_bar_metrics()

app.notify_renderer_ready

Notify the host application that the renderer is ready.

Parameters

  • None

Response specification

  • Return type: boolean

Example call

local result = bds.app.notify_renderer_ready()

app.open_folder

Open a folder in the system file manager.

Parameters

  • folder_path (string, required)

Response specification

  • Return type: string

Example call

local result = bds.app.open_folder("value")

app.read_project_metadata

Read project metadata from a project folder path.

Parameters

  • folder_path (string, required)

Response specification

  • Return type: ProjectMetadata | nil

Example call

local result = bds.app.read_project_metadata("value")

app.select_folder

Show the native folder picker and return the chosen path.

Parameters

  • title (string, optional)

Response specification

  • Return type: string | nil

Example call

local result = bds.app.select_folder("value")

app.set_preview_post_target

Set the current preview-post target used by desktop integrations.

Parameters

  • post_id (string, optional)

Response specification

  • Return type: boolean

Example call

local result = bds.app.set_preview_post_target("value")

app.show_item_in_folder

Reveal a file or folder in the system file manager.

Parameters

  • item_path (string, required)

Response specification

  • Return type: nil

Example call

local result = bds.app.show_item_in_folder("value")

app.trigger_menu_action

Trigger a native menu action by action id.

Parameters

  • action (string, required)

Response specification

  • Return type: nil

Example call

local result = bds.app.trigger_menu_action("value")

chat

chat.analyze_media_image

Analyze a media image using the configured AI runtime.

Parameters

  • media_id (string, required)

Response specification

  • Return type: table | nil

Example call

local result = bds.chat.analyze_media_image("value")

chat.analyze_post

Analyze a post using the configured AI runtime.

Parameters

  • post_id (string, required)

Response specification

  • Return type: table | nil

Example call

local result = bds.chat.analyze_post("value")

chat.detect_media_language

Detect the language of media metadata.

Parameters

  • title (string, required)
  • alt (string, optional)
  • caption (string, optional)

Response specification

  • Return type: table

Example call

local result = bds.chat.detect_media_language("value", "value", "value")

chat.detect_post_language

Detect the language of post title and content.

Parameters

  • title (string, required)
  • content (string, required)

Response specification

  • Return type: table

Example call

local result = bds.chat.detect_post_language("value", "value")

chat.translate_media_metadata

Translate media metadata and persist the translation.

Parameters

  • media_id (string, required)
  • language (string, required)

Response specification

  • Return type: table | nil

Example call

local result = bds.chat.translate_media_metadata("value", "value")

chat.translate_post

Translate a post and persist the translation.

Parameters

  • post_id (string, required)
  • language (string, required)

Response specification

  • Return type: table | nil

Example call

local result = bds.chat.translate_post("value", "value")

embeddings

embeddings.compute_similarities

Compute similarity scores from one source post to target posts.

Parameters

  • post_id (string, required)
  • target_ids (table, required)

Response specification

  • Return type: table | nil

Example call

local result = bds.embeddings.compute_similarities("value", {})

embeddings.dismiss_pair

Dismiss a duplicate candidate pair.

Parameters

  • post_id_a (string, required)
  • post_id_b (string, required)

Response specification

  • Return type: boolean

Example call

local result = bds.embeddings.dismiss_pair("value", "value")

embeddings.find_duplicates

Find duplicate post candidates for the current project.

Parameters

  • None

Response specification

  • Return type: table | nil

Example call

local result = bds.embeddings.find_duplicates()

embeddings.find_similar

Find posts similar to the given post id.

Parameters

  • post_id (string, required)
  • limit (integer, optional)

Response specification

  • Return type: table | nil

Example call

local result = bds.embeddings.find_similar("value", 1)

embeddings.get_progress

Get embedding index progress for the current project.

Parameters

  • None

Response specification

  • Return type: table | nil

Example call

local result = bds.embeddings.get_progress()

embeddings.index_unindexed_posts

Index posts missing embeddings for the current project.

Parameters

  • None

Response specification

  • Return type: table | nil

Example call

local result = bds.embeddings.index_unindexed_posts()

embeddings.suggest_tags

Suggest tags for a post from semantic similarity.

Parameters

  • post_id (string, required)
  • exclude_tags (table, optional)

Response specification

  • Return type: table | nil

Example call

local result = bds.embeddings.suggest_tags("value", {})

media

media.delete_translation

Delete a media translation by language.

Parameters

  • media_id (string, required)
  • language (string, required)

Response specification

  • Return type: boolean

Example call

local result = bds.media.delete_translation("value", "value")

media.filter

Filter media using year, month, tags, language, or date range fields.

Parameters

  • filters (table, required)

Response specification

  • Return type: MediaData[]

Example call

local result = bds.media.filter({})

media.import

Import media into the current project.

Parameters

  • data (table, required)

Response specification

  • Return type: MediaData | nil

Example call

local result = bds.media.import({})

media.get_by_year_month

Get media counts grouped by year and month.

Parameters

  • None

Response specification

  • Return type: table[]

Example call

local result = bds.media.get_by_year_month()

media.get_file_path

Return the absolute file path for a media item.

Parameters

  • media_id (string, required)

Response specification

  • Return type: string | nil

Example call

local result = bds.media.get_file_path("value")

media.update

Update media metadata by id.

Parameters

  • id (string, required)
  • data (table, required)

Response specification

  • Return type: MediaData | nil

Example call

local result = bds.media.update("value", {})

media.delete

Delete a media item by id.

Parameters

  • id (string, required)

Response specification

  • Return type: boolean

Example call

local result = bds.media.delete("value")

media.get

Fetch one media item by id.

Parameters

  • id (string, required)

Response specification

  • Return type: MediaData | nil

Example call

local result = bds.media.get("value")

media.get_all

Fetch all media in the current project.

Parameters

  • None

Response specification

  • Return type: MediaData[]

Example call

local result = bds.media.get_all()

media.get_tags

Return tag names used by media in the current project.

Parameters

  • None

Response specification

  • Return type: string[]

Example call

local result = bds.media.get_tags()

media.get_tags_with_counts

Return media tags with usage counts.

Parameters

  • None

Response specification

  • Return type: table[]

Example call

local result = bds.media.get_tags_with_counts()

media.get_thumbnail

Return a media thumbnail as a data URL for the requested size.

Parameters

  • media_id (string, required)
  • size (string, optional)

Response specification

  • Return type: string | nil

Example call

local result = bds.media.get_thumbnail("value", "value")

media.get_translation

Return one media translation by language.

Parameters

  • media_id (string, required)
  • language (string, required)

Response specification

  • Return type: table | nil

Example call

local result = bds.media.get_translation("value", "value")

media.get_translations

Return all translations for a media item.

Parameters

  • media_id (string, required)

Response specification

  • Return type: table[]

Example call

local result = bds.media.get_translations("value")

media.get_url

Return the project-relative public URL path for a media item.

Parameters

  • media_id (string, required)

Response specification

  • Return type: string | nil

Example call

local result = bds.media.get_url("value")

media.rebuild_from_files

Rebuild media records from sidecar files on disk.

Parameters

  • None

Response specification

  • Return type: MediaData[] | nil

Example call

local result = bds.media.rebuild_from_files()

media.regenerate_missing_thumbnails

Generate thumbnails for media items that are missing them.

Parameters

  • None

Response specification

  • Return type: table

Example call

local result = bds.media.regenerate_missing_thumbnails()

media.regenerate_thumbnails

Regenerate all thumbnails for one media item.

Parameters

  • media_id (string, required)

Response specification

  • Return type: table | nil

Example call

local result = bds.media.regenerate_thumbnails("value")

media.reindex_text

Reindex post and media search text for the current project.

Parameters

  • None

Response specification

  • Return type: boolean

Example call

local result = bds.media.reindex_text()

media.replace_file

Replace the binary file behind an existing media item.

Parameters

  • media_id (string, required)
  • source_path (string, required)

Response specification

  • Return type: MediaData | nil

Example call

local result = bds.media.replace_file("value", "value")

media.search

Search media by free-text query.

Parameters

  • query (string, required)

Response specification

  • Return type: MediaData[] | nil

Example call

local result = bds.media.search("value")

media.upsert_translation

Create or update a media translation.

Parameters

  • media_id (string, required)
  • language (string, required)
  • data (table, required)

Response specification

  • Return type: table | nil

Example call

local result = bds.media.upsert_translation("value", "value", {})

meta

meta.add_category

Add a category to the current project.

Parameters

  • name (string, required)

Response specification

  • Return type: ProjectMetadata | nil

Example call

local result = bds.meta.add_category("value")

meta.add_tag

Add a tag record to the current project if it does not already exist.

Parameters

  • name (string, required)

Response specification

  • Return type: string[]

Example call

local result = bds.meta.add_tag("value")

meta.clear_publishing_preferences

Reset publishing preferences to defaults.

Parameters

  • None

Response specification

  • Return type: table | nil

Example call

local result = bds.meta.clear_publishing_preferences()

meta.get_categories

Get project categories.

Parameters

  • None

Response specification

  • Return type: string[]

Example call

local result = bds.meta.get_categories()

meta.get_project_metadata

Read metadata for the current project.

Parameters

  • None

Response specification

  • Return type: ProjectMetadata

Example call

local result = bds.meta.get_project_metadata()

meta.get_publishing_preferences

Get publishing preferences for the current project.

Parameters

  • None

Response specification

  • Return type: table | nil

Example call

local result = bds.meta.get_publishing_preferences()

meta.get_tags

Get tag names for the current project.

Parameters

  • None

Response specification

  • Return type: string[]

Example call

local result = bds.meta.get_tags()

meta.remove_category

Remove a category from the current project.

Parameters

  • name (string, required)

Response specification

  • Return type: ProjectMetadata | nil

Example call

local result = bds.meta.remove_category("value")

meta.remove_tag

Remove a tag record from the current project by name.

Parameters

  • name (string, required)

Response specification

  • Return type: string[]

Example call

local result = bds.meta.remove_tag("value")

meta.set_project_metadata

Replace project metadata fields for the current project.

Parameters

  • updates (table, required)

Response specification

  • Return type: ProjectMetadata | nil

Example call

local result = bds.meta.set_project_metadata({})

meta.set_publishing_preferences

Set publishing preferences for the current project.

Parameters

  • prefs (table, required)

Response specification

  • Return type: table | nil

Example call

local result = bds.meta.set_publishing_preferences({})

meta.sync_on_startup

Synchronize startup metadata state and return tags, categories, and project metadata.

Parameters

  • None

Response specification

  • Return type: table

Example call

local result = bds.meta.sync_on_startup()

meta.update_project_metadata

Update metadata for the current project.

Parameters

  • updates (table, required)

Response specification

  • Return type: ProjectMetadata | nil

Example call

local result = bds.meta.update_project_metadata({})

posts

posts.create

Create a post in the current project.

Parameters

  • data (table, required)

Response specification

  • Return type: PostData | nil

Example call

local result = bds.posts.create({})

posts.update

Update a post by id.

Parameters

  • id (string, required)
  • data (table, required)

Response specification

  • Return type: PostData | nil

Example call

local result = bds.posts.update("value", {})

posts.delete

Delete a post by id.

Parameters

  • id (string, required)

Response specification

  • Return type: boolean

Example call

local result = bds.posts.delete("value")

posts.discard

Discard unpublished post changes and restore the last published version from disk.

Parameters

  • id (string, required)

Response specification

  • Return type: PostData | nil

Example call

local result = bds.posts.discard("value")

posts.filter

Filter posts using status, tags, categories, language, year, month, or date range fields.

Parameters

  • filters (table, required)

Response specification

  • Return type: PostData[] | nil

Example call

local result = bds.posts.filter({})

posts.generate_unique_slug

Generate a unique slug from a title, optionally excluding one post id.

Parameters

  • title (string, required)
  • exclude_post_id (string, optional)

Response specification

  • Return type: string

Example call

local result = bds.posts.generate_unique_slug("value", "value")

posts.get

Fetch one post by id.

Parameters

  • id (string, required)

Response specification

  • Return type: PostData | nil

Example call

local result = bds.posts.get("value")

posts.get_all

Fetch all posts in the current project.

Parameters

  • None

Response specification

  • Return type: PostData[]

Example call

local result = bds.posts.get_all()

posts.get_by_slug

Fetch one post by slug.

Parameters

  • slug (string, required)

Response specification

  • Return type: PostData | nil

Example call

local result = bds.posts.get_by_slug("value")

posts.get_by_status

Fetch posts filtered by a specific status.

Parameters

  • status (string, required)

Response specification

  • Return type: PostData[]

Example call

local result = bds.posts.get_by_status("value")

posts.get_by_year_month

Get post counts grouped by year and month.

Parameters

  • None

Response specification

  • Return type: table[]

Example call

local result = bds.posts.get_by_year_month()

posts.get_categories

Get category names used by posts in the current project.

Parameters

  • None

Response specification

  • Return type: string[]

Example call

local result = bds.posts.get_categories()

posts.get_categories_with_counts

Get post categories with usage counts.

Parameters

  • None

Response specification

  • Return type: table[]

Example call

local result = bds.posts.get_categories_with_counts()

posts.get_dashboard_stats

Return aggregate post dashboard counts for the current project.

Parameters

  • None

Response specification

  • Return type: table

Example call

local result = bds.posts.get_dashboard_stats()

posts.get_linked_by

Return posts that link to the given post.

Parameters

  • post_id (string, required)

Response specification

  • Return type: table[]

Example call

local result = bds.posts.get_linked_by("value")

Return posts linked from the given post.

Parameters

  • post_id (string, required)

Response specification

  • Return type: table[]

Example call

local result = bds.posts.get_links_to("value")

posts.get_preview_url

Return the local preview URL for a post, optionally with draft and language query parameters.

Parameters

  • post_id (string, required)
  • options (table, optional)

Response specification

  • Return type: string | nil

Example call

local result = bds.posts.get_preview_url("value", {})

posts.get_tags

Get tag names used by posts in the current project.

Parameters

  • None

Response specification

  • Return type: string[]

Example call

local result = bds.posts.get_tags()

posts.get_tags_with_counts

Get post tags with usage counts.

Parameters

  • None

Response specification

  • Return type: table[]

Example call

local result = bds.posts.get_tags_with_counts()

posts.get_translation

Get a single translation for a post by language.

Parameters

  • post_id (string, required)
  • language (string, required)

Response specification

  • Return type: table | nil

Example call

local result = bds.posts.get_translation("value", "value")

posts.get_translations

Get all translations for a post.

Parameters

  • post_id (string, required)

Response specification

  • Return type: table[]

Example call

local result = bds.posts.get_translations("value")

posts.has_published_version

Check whether a post has a published version.

Parameters

  • post_id (string, required)

Response specification

  • Return type: boolean

Example call

local result = bds.posts.has_published_version("value")

posts.is_slug_available

Return whether a slug is available in the current project, optionally excluding one post id.

Parameters

  • slug (string, required)
  • exclude_post_id (string, optional)

Response specification

  • Return type: boolean

Example call

local result = bds.posts.is_slug_available("value", "value")

posts.publish

Publish a post by id.

Parameters

  • id (string, required)

Response specification

  • Return type: PostData | nil

Example call

local result = bds.posts.publish("value")

posts.publish_translation

Publish one translation of a post by language.

Parameters

  • post_id (string, required)
  • language (string, required)

Response specification

  • Return type: table | nil

Example call

local result = bds.posts.publish_translation("value", "value")

posts.rebuild_from_files

Rebuild post records from published files.

Parameters

  • None

Response specification

  • Return type: PostData[] | nil

Example call

local result = bds.posts.rebuild_from_files()

Rebuild the post link graph for the current project.

Parameters

  • None

Response specification

  • Return type: boolean

Example call

local result = bds.posts.rebuild_links()

posts.reindex_text

Reindex post and media search text for the current project.

Parameters

  • None

Response specification

  • Return type: boolean

Example call

local result = bds.posts.reindex_text()

posts.search

Search posts by free-text query.

Parameters

  • query (string, required)

Response specification

  • Return type: PostData[] | nil

Example call

local result = bds.posts.search("value")

projects

projects.create

Create a project.

Parameters

  • data (table, required)

Response specification

  • Return type: ProjectData | nil

Example call

local result = bds.projects.create({})

projects.delete

Delete a project by id.

Parameters

  • id (string, required)

Response specification

  • Return type: boolean

Example call

local result = bds.projects.delete("value")

projects.delete_with_data

Delete a project by id and remove its project directory.

Parameters

  • id (string, required)

Response specification

  • Return type: boolean

Example call

local result = bds.projects.delete_with_data("value")

projects.get

Fetch one project by id.

Parameters

  • id (string, required)

Response specification

  • Return type: ProjectData | nil

Example call

local result = bds.projects.get("value")

projects.get_all

Fetch all projects.

Parameters

  • None

Response specification

  • Return type: ProjectData[]

Example call

local result = bds.projects.get_all()

projects.get_active

Fetch the active project.

Parameters

  • None

Response specification

  • Return type: ProjectData | nil

Example call

local result = bds.projects.get_active()

projects.set_active

Set the active project by id.

Parameters

  • id (string, required)

Response specification

  • Return type: ProjectData | nil

Example call

local result = bds.projects.set_active("value")

projects.update

Update a project by id.

Parameters

  • id (string, required)
  • data (table, required)

Response specification

  • Return type: ProjectData | nil

Example call

local result = bds.projects.update("value", {})

publish

publish.upload_site

Upload the rendered site using the provided publishing credentials.

Parameters

  • credentials (table, required)

Response specification

  • Return type: TaskData | nil

Example call

local result = bds.publish.upload_site({})

scripts

scripts.create

Create a script in the current project.

Parameters

  • data (table, required)

Response specification

  • Return type: ScriptData | nil

Example call

local result = bds.scripts.create({})

scripts.update

Update a script by id.

Parameters

  • id (string, required)
  • data (table, required)

Response specification

  • Return type: ScriptData | nil

Example call

local result = bds.scripts.update("value", {})

scripts.delete

Delete a script by id.

Parameters

  • id (string, required)

Response specification

  • Return type: boolean

Example call

local result = bds.scripts.delete("value")

scripts.get

Fetch one script by id.

Parameters

  • id (string, required)

Response specification

  • Return type: ScriptData | nil

Example call

local result = bds.scripts.get("value")

scripts.get_all

Fetch all scripts in the current project.

Parameters

  • None

Response specification

  • Return type: ScriptData[]

Example call

local result = bds.scripts.get_all()

scripts.publish

Publish a script by id.

Parameters

  • id (string, required)

Response specification

  • Return type: ScriptData | nil

Example call

local result = bds.scripts.publish("value")

scripts.rebuild_from_files

Rebuild script records from published files.

Parameters

  • None

Response specification

  • Return type: ScriptData[] | nil

Example call

local result = bds.scripts.rebuild_from_files()

sync

sync.check_availability

Return whether Git is available on the current machine.

Parameters

  • None

Response specification

  • Return type: boolean

Example call

local result = bds.sync.check_availability()

sync.commit_all

Commit all pending repository changes for the current project.

Parameters

  • message (string, required)

Response specification

  • Return type: table | nil

Example call

local result = bds.sync.commit_all("value")

sync.fetch

Fetch remote Git refs for the current project.

Parameters

  • None

Response specification

  • Return type: table | nil

Example call

local result = bds.sync.fetch()

sync.get_history

Return commit history for the current project repository.

Parameters

  • None

Response specification

  • Return type: table | nil

Example call

local result = bds.sync.get_history()

sync.get_remote_state

Return remote repository state information for the current project.

Parameters

  • None

Response specification

  • Return type: table | nil

Example call

local result = bds.sync.get_remote_state()

sync.get_repo_state

Return repository state information for the current project.

Parameters

  • None

Response specification

  • Return type: table | nil

Example call

local result = bds.sync.get_repo_state()

sync.get_status

Return Git status information for the current project.

Parameters

  • None

Response specification

  • Return type: table | nil

Example call

local result = bds.sync.get_status()

sync.pull

Pull remote changes for the current project.

Parameters

  • None

Response specification

  • Return type: table | nil

Example call

local result = bds.sync.pull()

sync.push

Push local changes for the current project.

Parameters

  • None

Response specification

  • Return type: table | nil

Example call

local result = bds.sync.push()

tags

tags.create

Create a tag in the current project.

Parameters

  • data (table, required)

Response specification

  • Return type: TagData | nil

Example call

local result = bds.tags.create({})

tags.update

Update a tag by id.

Parameters

  • id (string, required)
  • data (table, required)

Response specification

  • Return type: TagData | nil

Example call

local result = bds.tags.update("value", {})

tags.delete

Delete a tag by id.

Parameters

  • id (string, required)

Response specification

  • Return type: boolean

Example call

local result = bds.tags.delete("value")

tags.get

Fetch one tag by id.

Parameters

  • id (string, required)

Response specification

  • Return type: TagData | nil

Example call

local result = bds.tags.get("value")

tags.get_all

Fetch all tags in the current project.

Parameters

  • None

Response specification

  • Return type: TagData[]

Example call

local result = bds.tags.get_all()

tags.get_by_name

Fetch one tag by name.

Parameters

  • name (string, required)

Response specification

  • Return type: TagData | nil

Example call

local result = bds.tags.get_by_name("value")

tags.get_posts_with_tag

Get post ids using a specific tag.

Parameters

  • tag_id (string, required)

Response specification

  • Return type: string[]

Example call

local result = bds.tags.get_posts_with_tag("value")

tags.get_with_counts

Fetch tags with usage counts.

Parameters

  • None

Response specification

  • Return type: table[]

Example call

local result = bds.tags.get_with_counts()

tags.merge

Merge source tags into a target tag.

Parameters

  • source_tag_ids (table, required)
  • target_tag_id (string, required)

Response specification

  • Return type: boolean

Example call

local result = bds.tags.merge({}, "value")

tags.rename

Rename a tag by id.

Parameters

  • id (string, required)
  • new_name (string, required)

Response specification

  • Return type: TagData | nil

Example call

local result = bds.tags.rename("value", "value")

tags.sync_from_posts

Sync tag records from post tags.

Parameters

  • None

Response specification

  • Return type: TagData[] | nil

Example call

local result = bds.tags.sync_from_posts()

tasks

tasks.cancel

Cancel a task by id.

Parameters

  • id (string, required)

Response specification

  • Return type: boolean

Example call

local result = bds.tasks.cancel("value")

tasks.clear_completed

Clear completed tasks from the in-memory task list.

Parameters

  • None

Response specification

  • Return type: boolean

Example call

local result = bds.tasks.clear_completed()

tasks.get

Fetch one task by id.

Parameters

  • id (string, required)

Response specification

  • Return type: TaskData | nil

Example call

local result = bds.tasks.get("value")

tasks.get_all

Fetch all tasks currently tracked by the task manager.

Parameters

  • None

Response specification

  • Return type: TaskData[]

Example call

local result = bds.tasks.get_all()

tasks.get_running

Fetch running tasks currently tracked by the task manager.

Parameters

  • None

Response specification

  • Return type: TaskData[]

Example call

local result = bds.tasks.get_running()

tasks.status_snapshot

Fetch the current task status snapshot.

Parameters

  • None

Response specification

  • Return type: TaskStatus

Example call

local result = bds.tasks.status_snapshot()

templates

templates.create

Create a template in the current project.

Parameters

  • data (table, required)

Response specification

  • Return type: TemplateData | nil

Example call

local result = bds.templates.create({})

templates.update

Update a template by id.

Parameters

  • id (string, required)
  • data (table, required)

Response specification

  • Return type: TemplateData | nil

Example call

local result = bds.templates.update("value", {})

templates.delete

Delete a template by id.

Parameters

  • id (string, required)

Response specification

  • Return type: boolean

Example call

local result = bds.templates.delete("value")

templates.get

Fetch one template by id.

Parameters

  • id (string, required)

Response specification

  • Return type: TemplateData | nil

Example call

local result = bds.templates.get("value")

templates.get_all

Fetch all templates in the current project.

Parameters

  • None

Response specification

  • Return type: TemplateData[]

Example call

local result = bds.templates.get_all()

templates.get_enabled_by_kind

Fetch enabled templates filtered by kind.

Parameters

  • kind (string, required)

Response specification

  • Return type: TemplateData[]

Example call

local result = bds.templates.get_enabled_by_kind("value")

templates.publish

Publish a template by id.

Parameters

  • id (string, required)

Response specification

  • Return type: TemplateData | nil

Example call

local result = bds.templates.publish("value")

templates.rebuild_from_files

Rebuild template records from published files.

Parameters

  • None

Response specification

  • Return type: TemplateData[] | nil

Example call

local result = bds.templates.rebuild_from_files()

templates.validate

Validate Liquid template syntax.

Parameters

  • content (string, required)

Response specification

  • Return type: ValidationResult | nil

Example call

local result = bds.templates.validate("value")

Data Structures

ProjectData

Project record stored in the application database.

  • id: string
  • name: string
  • slug: string
  • description: string | nil
  • data_path: string | nil
  • is_active: boolean
  • created_at: integer
  • updated_at: integer

ProjectMetadata

Current project metadata and publishing settings snapshot.

  • name: string
  • description: string | nil
  • public_url: string | nil
  • main_language: string | nil
  • default_author: string | nil
  • categories: string[]
  • blog_languages: string[]
  • publishing_preferences: table

PostData

Post record with link graph data added for scripting.

  • id: string
  • project_id: string
  • title: string
  • slug: string
  • status: string
  • language: string | nil
  • tags: string[]
  • categories: string[]
  • backlinks: table[]
  • links_to: table[]

MediaData

Media record stored for a project.

  • id: string
  • project_id: string
  • original_name: string
  • mime_type: string
  • file_path: string
  • title: string | nil
  • alt: string | nil
  • caption: string | nil
  • tags: string[]

ScriptData

Lua script record.

  • id: string
  • project_id: string
  • slug: string
  • title: string
  • kind: string
  • entrypoint: string
  • enabled: boolean
  • status: string

TemplateData

Template record for site rendering.

  • id: string
  • project_id: string
  • slug: string
  • title: string
  • kind: string
  • enabled: boolean
  • status: string

TagData

Tag record stored for a project.

  • id: string
  • project_id: string
  • name: string
  • color: string | nil
  • post_template_slug: string | nil

TaskData

Public task snapshot returned by the task manager.

  • id: string
  • name: string
  • status: string
  • progress: number | table | nil
  • message: string | nil

TaskStatus

Aggregate task status snapshot.

  • active_count: integer
  • running_count: integer
  • pending_count: integer
  • tasks: TaskData[]

ValidationResult

Template validation result.

  • valid: boolean
  • errors: string[]