Date & Time
OpenClaw 默认对传输时间戳使用主机本地时间,而用户时区仅在 system prompt 中使用。 Provider 时间戳会被保留,工具保持原始语义(当前时间可通过session_status 获得)。
消息信封(默认本地)
入站消息会被包裹时间戳(精度到分钟):envelopeTimezone: "utc"使用 UTC。envelopeTimezone: "local"使用主机时区。envelopeTimezone: "user"使用agents.defaults.userTimezone(未设置则回退主机时区)。- 使用显式 IANA 时区(例如
"America/Chicago")可固定时区。 envelopeTimestamp: "off"移除信封头的绝对时间戳。envelopeElapsed: "off"移除耗时后缀(+2m风格)。
示例
本地(默认):System prompt:Current Date & Time
若已知用户时区,system prompt 会包含专门的 Current Date & Time 分节,仅包含时区(不含时钟/时间格式),以保持 prompt 缓存稳定:session_status 工具;状态卡包含时间戳行。
System event 行(默认本地)
插入到 agent context 的排队系统事件,会使用与消息信封相同的时区选择(默认主机本地)前缀时间戳。配置用户时区 + 格式
userTimezone设置用户本地时区用于 prompt 上下文。timeFormat控制 prompt 中的 12h/24h 显示。auto跟随系统偏好。
时间格式检测(auto)
当timeFormat: "auto" 时,OpenClaw 会读取 OS 偏好(macOS/Windows),并回退到 locale 格式。检测值按进程缓存,避免重复系统调用。
工具载荷 + 连接器(原始 provider 时间 + 归一化字段)
渠道工具返回provider 原生时间戳,并添加归一化字段以保持一致:timestampMs:epoch 毫秒(UTC)timestampUtc:ISO 8601 UTC 字符串
- Slack:API 返回的类 epoch 字符串
- Discord:UTC ISO 时间戳
- Telegram/WhatsApp:provider 特定的数字/ISO 时间戳