- 移除 TodoItem 中的 priority、created_at 和 updated_at 字段 - 强制每个任务都必须有唯一 id,且由用户负责生成 - 修改合并模式逻辑,merge=true 下保留未提及的旧任务 - 支持已完成和已取消任务重新激活(状态改回 pending 或 in_progress) - 禁止 in_progress 状态退回到 pending,必须标记为 completed 或 cancelled - 优化状态转换校验,允许特定状态间合法切换 - 简化任务变更消息,移除详细的新增/更新/移除统计 - 更新文档和示例,明确 id 必须由用户生成和使用 - 修复和补充测试,增强状态转换和合并模式验证 - 调整任务时间戳生成逻辑,统一使用当前时间及索引 - 该变更提供更合理的任务状态机械及管理模式,提升稳定性和易用性
5.4 KiB
5.4 KiB
lark-apps 本地全栈开发
适用:用户要把妙搭全栈应用源码拉到本地,用本地 code agent/IDE 开发、调试数据库,再发布。
新建 vs 已有应用
新建还是修改已有,由上方入口(SKILL.md「选择开发路径」)判定;进到本地流程后按分支走:
- 新建:从
+create开始走下面的端到端流程。 - 已有应用(本地还没有源码):跳过
+create,先按下方「存量应用入口」拿app_id,再+init(或+git-credential-init+git clone)把它拉到本地,然后照常开发。
端到端流程(新建应用)
+create(full_stack) -> +init(或手动 +git-credential-init + git clone)-> npm install && npm run dev -> 按需 +db-* 调库 -> git add + git commit(提交本次改动)-> git push origin sprint/default -> +release-create -> +release-get。
# 新建 full_stack 应用
lark-cli apps +create --name "审批系统" --app-type full_stack \
--description "支持登录、提交申请、多级审批、状态查询"
# 初始化本地仓库(--dir 取值见下方「领域规则」,勿照抄此处示例值)
lark-cli apps +init --app-id app_xxx --dir ./approval-app
# 进入仓库后按项目脚手架启动
cd ./approval-app
npm install
npm run dev
# 开发完成后:提交本次改动 -> git push origin sprint/default -> +release-create。
# +release-create 部署的是远端 sprint/default 上已 push 的代码,不是本地工作区——没 commit + push 的改动不会进入发布。
git add <本次开发的文件> # 提交粒度见下方「改完代码后部署上线」
git commit -m "feat: ..."
git push origin sprint/default
lark-cli apps +release-create --app-id app_xxx
+init 是推荐便捷入口;想逐步手动控制时,先 +git-credential-init 拿 repository_url,再用原生 git clone / git checkout sprint/default。
改完代码后部署上线
已拉到本地、改完代码,用户说"推上去""部署""上线""发布到云端"时,按此序列。
+release-create部署的是远端sprint/default上已 push 的代码,不是你本地工作区——未 commit / 未 push 的改动不会进入这次发布。所以发布前务必先把本次改动提交并推送。
git status看本次改动;git add <本次相关文件>暂存后git commit提交。只提交本次任务相关的改动即可,无关的零散文件不必强求清空——发布门禁是「本次相关改动已提交并推送」,不是「工作区绝对干净」。git push origin sprint/default把工作分支推到云端(遇非 fast-forward:先git pull --rebase origin sprint/default解决冲突再推,绝不 force-push)。lark-cli apps +release-create --app-id <app_id>发起部署上线,记下返回的release_id。lark-cli apps +release-get --app-id <app_id> --release-id <release_id>轮询:publishing继续轮询;finished成功时该命令输出已含online_url,直接读取它返回给用户(这是本轮发布完成后的可分享链接),无需再调+list;failed时该命令输出已含error_logs,直接据此给出失败原因(+list仅作独立查询入口)。
领域规则
- 代码读写走原生
git;CLI 负责凭证、初始化、发布和数据库调试。不存在apps +pull/apps +push/apps code +read这类代码读写 shortcut,不要臆造。 +init会编排+git-credential-init、git clone、切到sprint/default、运行脚手架,并在有变更时提交/推送。+init --dir选目录:用户已预授权或表达"不要询问"(见 SKILL.md「预授权判定」)→ 按应用名派生./<app-name>直接传--dir、不停问;否则先问用户用哪个目录再传。目标已存在/非空时回问换目录。sprint/default是工作分支;main是发布态快照,由+release-create成功后服务端 fast-forward 推进;服务端护栏禁直推main、拒 force-push、要求sprint/defaultfast-forward。- 已拉到本地后,pull/push/diff/log 都用原生 git;云端
sprint/default比本地新时,先git pull --rebase origin sprint/default,解决冲突后再 push 和 publish。 - 环境变量由脚手架在本地启动时处理;需要手动刷新时用
+env-pull。 - DB 调试用
+db-table-list/+db-table-get/+db-execute;不要裸连数据库或自行拼连接串。 - DB 分
dev/online;日常调试优先--env dev。dev 的库结构变更要上线时,仍按应用发布链路走+release-create,不要另造“数据库发布”步骤。 - 存量单库应用需要 dev/online 多环境时,用
+db-env-create --env dev。这是不可逆 high-risk 操作。 - 只从
+list看到is_published=true,不能证明本地刚推送的代码已经部署;必须有本轮+release-get finished。
存量应用入口
已有项目目录先读 .spark/meta.json 取 app_id;没有本地项目但知道应用名时用:
lark-cli apps +list --keyword "应用名"
拿到 app_id 后再 +init 或 +git-credential-init。
何时不用
- 用户只想发布现成 HTML / 静态目录拿分享链接:读
lark-apps-html-publish.md。 - 用户明确要云端妙搭 Agent 生成/迭代,而不是本地写代码:读
lark-apps-cloud-dev.md。