Tip
Requires AstrBot version >= 4.9.2.
Plugins can use AstrBot's simple key-value store to persist configuration or temporary data. The storage is scoped per plugin, so each plugin has its own isolated space.
class Main(star.Star):
@filter.command("hello")
async def hello(self, event: AstrMessageEvent):
"""Aloha!"""
await self.put_kv_data("greeted", True)
greeted = await self.get_kv_data("greeted", False)
await self.delete_kv_data("greeted")To keep large file handling consistent, store large files under data/plugin_data/{plugin_name}/.
You can fetch the plugin data directory with:
from astrbot.core.utils.astrbot_path import get_astrbot_data_path
plugin_data_path = get_astrbot_data_path() / "plugin_data" / self.name # self.name is the plugin name; available in v4.9.2 and above. For lower versions, specify the plugin name yourself.AstrBot's data directory (data/) contains the following important subdirectories:
| Directory | Description |
|---|---|
data/attachments/ |
Unified attachment storage for images, audio, files, etc. from WebChat and other platforms |
data/plugin_data/ |
Plugin data storage directory |
data/config/ |
Multi-configuration file storage (files starting with abconf_) |
data/dist/ |
Admin panel frontend files |
data/webchat/imgs/ |
(Deprecated) Legacy WebChat image directory; migrated to attachments/ in newer versions |
Note
To access attachment files from WebChat and other platforms, use the data/attachments/ directory. AstrBot automatically handles backward-compatible reading from both new and old locations.