Install
openclaw skills install @zhaobod1/huo15-huihuo-suiteUse this skill whenever the user wants to manage their work in the 火一五/辉火云 company Odoo system (www.huo15.com, db=huo15) — to-dos / tasks ("记个待办" "加任务" "我的待办"), projects, timesheets ("记工时"), CRM leads & opportunities ("新建商机" "跟进客户" "销售管道"), follow-up activities & reminders ("提醒我" "3天后回访"), calendar events & meetings ("安排会议" "我这周日程" "提前30分钟提醒"), knowledge-base articles ("查/写知识库" "产品手册"), or document files ("找文档" "上传文件"). Also a one-stop "我今天/本周要做什么" briefing. Triggers on odoo, 辉火云企业套件, 公司系统, /odoo/to-do /project /timesheets /crm /calendar /knowledge /documents /sale /purchase /inventory, or "登录公司系统/保存 odoo 账号". Treat bare work-context mentions of 待办/任务/项目/工时/客户/商机/会议/日程/提醒/知识库/文档/销售/采购/库存/订单/发货/收货 as this skill. First run: login.py init (地址/数据库/账号/密码 → ~/.huo15/tools.md). Pure standard library, zero dependencies.
openclaw skills install @zhaobod1/huo15-huihuo-suite通过 XML-RPC / JSON-RPC 操作公司 Odoo 系统(辉火云企业套件,www.huo15.com,db=huo15)。
十一大能力:待办、项目、工时单、CRM、活动、日历、知识库、文档、销售(/odoo/sale)、采购(/odoo/purchase)、库存(/odoo/inventory),外加 briefing.py 每日/每周总览。
完整命令 → references/commands.md API/字段细节 → todo · project · timesheet · crm · activity+calendar · calendar-advanced · knowledge+documents · sales+purchase+stock
所有脚本都依赖已保存的凭据。没配过就先初始化这 4 项,别直接跑 todo/project/timesheet。
| # | 输入项 | 示例 | 说明 |
|---|---|---|---|
| ① | 公司系统地址 | www.huo15.com | 只输域名即可,脚本自动补 https:// |
| ② | 数据库 | huo15 | 数据库名 |
| ③ | 账号 | 邮箱 / 用户名 | 登录账号 |
| ④ | 密码 | 密码或 API Key | 推荐 API Key(偏好设置→账户安全→新建,可随时吊销) |
保存到 ~/.huo15/tools.md(权限 600)。
printf '%s' "<用户输入的密码>" | python3 scripts/login.py set \
--url www.huo15.com --db huo15 --login "<账号>" --auth-type password
# 密码填的是 API Key 就把 --auth-type 换成 apikey
python3 scripts/login.py init # 交互式依次提示输入 ①地址 ②数据库 ③账号 ④密码(无参等效)
login.py 会先验证连接成功才落盘,写入 ~/.huo15/tools.md(权限 600);失败报中文原因(账号错 / db 错 / 网络)。验证:python3 scripts/login.py test。
凭据文件默认
~/.huo15/tools.md,可用环境变量HUO15_TOOLS_MD改路径。 临时/CI 可用环境变量免落盘:HUO15_ODOO_LOGIN/HUO15_ODOO_SECRET/HUO15_ODOO_DB/HUO15_ODOO_URL。 此文件含明文凭据,务必不要提交 git。
每个应用一个脚本,风格统一(add/list/… 子命令,名字可代 id,--json 输出,-h 看完整参数)。
完整命令示例 → references/commands.md;字段/API 细节 → 各 references/odoo-<app>-api.md。
| 应用 | 脚本 | 核心模型 | 主要子命令 |
|---|---|---|---|
📝 待办 /odoo/to-do | todo.py | project.task(私有态) | add list done reopen cancel update stages |
📁 项目 /odoo/project | project.py | project.project + task | list show add edit archive tasks task-add task-move task-assign task-done |
⏱️ 工时单 /odoo/timesheets | timesheet.py | account.analytic.line | by-employee by-project by-month detail log |
💼 CRM /odoo/crm | crm.py | crm.lead(线索/商机) | list show add move won lost restore convert pipeline activity |
| 🔔 活动 My Activities | activity.py | mail.activity | list add done cancel reschedule |
📅 日历 /odoo/calendar | agenda.py | calendar.event + alarm + attendee | list show add update cancel remind invite attendees rsvp busy(含重复事件/忙闲查询) |
📚 知识库 /odoo/knowledge | knowledge.py | knowledge.article | list search show add fav tree move |
📁 文档 /odoo/documents | documents.py | documents.document | folders list search upload link tags tag |
🛒 销售 /odoo/sale | sales.py | sale.order | list show add confirm cancel invoice |
🛍️ 采购 /odoo/purchase | purchase.py | purchase.order | list show add confirm approve cancel bill |
📦 库存 /odoo/inventory | stock.py | stock.quant/picking/move | qty pickings show validate locations warehouses |
| 🗓️ 每日总览 | briefing.py | 聚合待办+活动+会议 | briefing.py [today|week] —— 一站式「我今天/本周要做什么」 |
下方「命令速查」给最常用命令的具体写法,够日常用;要完整参数/示例读 references/commands.md。
| 想做 | 命令 |
|---|---|
| 初始化(交互) | python3 scripts/login.py init —— 提示输入 地址/数据库/账号/密码 |
| 配登录(代配) | printf '%s' "$PWD" | python3 scripts/login.py set --url www.huo15.com --db huo15 --login X |
| 测连接 | python3 scripts/login.py test |
| 新建待办 | todo.py add --title ... [--deadline --priority --stage --tags] |
| 我的待办 | todo.py list |
| 完成待办 | todo.py done <id> |
| 项目列表/详情 | project.py list / project.py show <id> |
| 建项目/任务 | project.py add --name ... / project.py task-add --project <id> --title ... |
| 移阶段/改负责人 | project.py task-move <id> --stage X / task-assign <id> --users a,b |
| 工时汇总 | timesheet.py by-employee|by-project|by-month [--month/--from/--to] |
| 工时明细 | timesheet.py detail --employee X --month YYYY-MM |
| CRM 商机 | crm.py list / crm.py add --name ... --customer ... --revenue N --user 我 |
| 赢/输/管道 | crm.py won|lost <id> / crm.py pipeline --by stage|user|team |
| 活动/提醒 | activity.py list / activity.py add --model crm.lead --id N --type call --date ... |
| 日历/会议 | agenda.py list / agenda.py add --name ... --start "... HH:MM" --with X --remind 30m |
| 重复/忙闲 | agenda.py add ... --repeat weekly --on mon --count 52 / agenda.py busy --who X --date Y / agenda.py attendees <id> |
| 知识库 | knowledge.py search <kw> / knowledge.py add --title ... --icon 📘 / knowledge.py show <id> |
| 文档 | documents.py folders / documents.py upload --file <path> --folder X / documents.py link <id> |
| 每日总览 | briefing.py / briefing.py week —— 聚合待办+活动+会议「我今天要做什么」 |
| 销售/采购 | sales.py add --customer X --line "产品:数量" / purchase.py add --vendor X --line ... / confirm <id> |
| 库存 | stock.py qty <产品> / stock.py pickings --in|--out / stock.py validate <id> |
所有脚本支持 --json 输出、--tools-md <path> 指定凭据文件。
| 坑 | 正确做法 |
|---|---|
| 待办放哪 | project.task 且 不传 project_id(保持 False)+ user_ids 含本人 |
| 截止日期 | date_deadline 是 Datetime / UTC,不是 date(脚本已自动本地→UTC) |
| 完成状态 | state='1_done';取消 '1_canceled';进行中 '01_in_progress';等待 '04_waiting_normal' |
| 任务负责人 | user_ids 是 Many2many,写 [(6,0,[ids])];不是 user_id |
| 分配工时 | 任务用 allocated_hours,不是 planned_hours(19 已删) |
| 工时小时数 | 工时单求和用 unit_amount(不是 amount,amount 是钱) |
| 是不是工时单 | 没有 is_timesheet 字段,判定 ('project_id','!=',False) |
| 分组统计 | read_group 多 groupby 必须 lazy=False;优先 formatted_read_group(脚本已封装) |
| 个人阶段筛选 | personal_stage_type_id 无 search,按阶段筛走 project.task.stage.personal 关联表(脚本已处理) |
| CRM 赢/输单 | 建商机必传 type='opportunity';负责人 user_id 单数;赢/输/复活调 action_set_won/lost/restore,别手动 write |
| CRM 字段 | 手机号写 phone(无 mobile);crm.stage.team_ids 复数 m2m(空=全团队);description 是 Html |
| 活动 | date_deadline 是 Date;完成=archive(action_feedback)不是删;state computed 无 search,查逾期用 date_deadline 比较 |
| 日历 | start/stop 是 Datetime/UTC(脚本自动转);写 partner_ids 自动建参与人;alarm 只有 notification/email |
| 日历重复/忙闲 | 重复走 calendar.event(recurrency=True),rrule 只读用结构化字段;改重复带 recurrence_update(all 不能改时间);忙闲用区间重叠+show_as=busy;crm 用 opportunity_id 关联 |
| 知识库 | 根文章必有 internal_permission(create 自动补 write);收藏 action_toggle_favorite;移动 move_to;权限走方法非直接写 member |
| 文档 | 19 版文件夹=document(type=folder),无 documents.folder/share;上传直接传 datas(base64);下载用 access_token;建标签需管理员 |
| 销售/采购 | state 无 done(用 locked);销售行 product_uom_qty+product_uom_id+tax_ids,采购行 product_qty;确认是写操作建交货/入库单;采购删除前先 cancel |
| 库存 | 查库存用 product free_qty/qty_available(限仓库走 context);明细 move_ids(无 _without_package);完成量 quantity(非 qty_done);validate 必传 skip_backorder |
这些都已在脚本里处理对。手工写新调用 / 改脚本时对照本表和 references/。
~/.huo15/tools.md(权限 600),永不进 git / commit / 日志。--secret-stdin,避免明文进 shell 历史。