- 移除 TodoItem 中的 priority、created_at 和 updated_at 字段 - 强制每个任务都必须有唯一 id,且由用户负责生成 - 修改合并模式逻辑,merge=true 下保留未提及的旧任务 - 支持已完成和已取消任务重新激活(状态改回 pending 或 in_progress) - 禁止 in_progress 状态退回到 pending,必须标记为 completed 或 cancelled - 优化状态转换校验,允许特定状态间合法切换 - 简化任务变更消息,移除详细的新增/更新/移除统计 - 更新文档和示例,明确 id 必须由用户生成和使用 - 修复和补充测试,增强状态转换和合并模式验证 - 调整任务时间戳生成逻辑,统一使用当前时间及索引 - 该变更提供更合理的任务状态机械及管理模式,提升稳定性和易用性
2.9 KiB
2.9 KiB
apps +html-publish
把本地 HTML 文件或静态目录发布为妙搭应用访问 URL。运行时命令事实以 lark-cli apps +html-publish --help 为准。
何时用
用于把已经存在的本地 HTML 文件或静态产物目录发布成妙搭访问 URL。它不负责生成 HTML 内容,也不负责全栈应用代码发布。
命令骨架
- 必填:
--app-id、--path。 --path可以是单个文件或目录;入口必须是index.html。- 可选:
--allow-sensitive,跳过凭据文件扫描。 - 客户端会打包 tar.gz 并上传发布;压缩包上限当前为 20MB,未压缩候选文件总量也有保护上限。
示例
lark-cli apps +create --name "Demo" --app-type html
lark-cli apps +html-publish --app-id app_xxx --path ./dist
lark-cli apps +html-publish --app-id app_xxx --path ./index.html --dry-run
输出契约
- 成功默认 JSON envelope 只关心
data.url;这是本轮 HTML 发布后的发布态访问链接。 - pretty 输出为
url: <url>,适合人看;自动化取字段用 JSON 或--jq '.data.url'。 - 业务失败如构建失败、应用不存在通常带
error.hint;优先转述 hint。网络/服务端失败则建议稍后重试。
链接边界
- 开发态链接可由
app_id拼出:https://miaoda.feishu.cn/app/{app_id},用于进入妙搭编辑/开发态。 - 发布态访问链接以本命令成功返回的
data.url为准。 - 重新发布前,
+list的is_published=true只能说明历史上发布过,不代表当前本地产物已经部署。
预览与发布边界
- 用户只说“用 HTML 写个 PPT/页面给我看看”时,先生成本地文件或目录,返回路径并问是否发布到妙搭分享;不要默认创建应用或部署。
- 用户明确说“部署出去/发链接/可分享”时,才创建
html应用并用+html-publish。 - 用户要发布但没有 app_id 时,先
+create --app-type html创建应用;应用名可从页面/站点主题生成,不要让用户手动提供 app_id。 - 若产物首页不是
index.html,发布前改名或复制为index.html;目录发布时只传干净产物目录,例如./dist。.git目录会被自动排除,不会进入压缩包;node_modules、源码缓存等仍建议手动精简以控制包体。 - 重新部署同一个 HTML 应用时复用原
app_id,只重新执行+html-publish --app-id <id> --path <dir-or-index.html>。
安全规则
默认会拦截 .env、.npmrc、.aws/credentials 等凭据文件。只有用户明确要发布凭据示例文件或教程内容时,才追加 --allow-sensitive;追加前先说明将包含哪些敏感候选文件。
常见失败
- 缺少
index.html:目录根放置index.html,或单文件路径直接指向名为index.html的文件。 - 包体过大:让用户精简
--path,不要把源码、依赖目录、构建缓存一起发布。