ccjk 14.2.2 → 15.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +1 -1
- package/README.md +58 -341
- package/dist/cli.js +59 -0
- package/dist/cli.js.map +1 -0
- package/dist/commands/detect.js +15 -0
- package/dist/commands/detect.js.map +1 -0
- package/dist/commands/doctor.js +68 -0
- package/dist/commands/doctor.js.map +1 -0
- package/dist/commands/git-install.js +50 -0
- package/dist/commands/git-install.js.map +1 -0
- package/dist/commands/init.js +102 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/mcp.js +66 -0
- package/dist/commands/mcp.js.map +1 -0
- package/dist/commands/menu.js +33 -0
- package/dist/commands/menu.js.map +1 -0
- package/dist/core/detect.js +24 -0
- package/dist/core/detect.js.map +1 -0
- package/dist/core/lint.js +49 -0
- package/dist/core/lint.js.map +1 -0
- package/dist/core/mcp.js +41 -0
- package/dist/core/mcp.js.map +1 -0
- package/dist/core/paths.js +9 -0
- package/dist/core/paths.js.map +1 -0
- package/dist/core/providers.js +53 -0
- package/dist/core/providers.js.map +1 -0
- package/dist/core/settings.js +31 -0
- package/dist/core/settings.js.map +1 -0
- package/dist/core/slash-templates.js +56 -0
- package/dist/core/slash-templates.js.map +1 -0
- package/dist/core/tools.js +27 -0
- package/dist/core/tools.js.map +1 -0
- package/package.json +43 -164
- package/README.HONEST.md +0 -176
- package/README.en.md +0 -67
- package/README.ja.md +0 -67
- package/README.ko.md +0 -67
- package/README.zh-CN.md +0 -86
- package/bin/ccjk.mjs +0 -5
- package/bin/ccjk.ts +0 -222
- package/dist/chunks/agent-teams.mjs +0 -145
- package/dist/chunks/agent.mjs +0 -1439
- package/dist/chunks/agents.mjs +0 -3783
- package/dist/chunks/api-cli.mjs +0 -135
- package/dist/chunks/api-config-selector.mjs +0 -159
- package/dist/chunks/api-providers.mjs +0 -144
- package/dist/chunks/api.mjs +0 -115
- package/dist/chunks/auto-bootstrap.mjs +0 -358
- package/dist/chunks/auto-fixer.mjs +0 -95
- package/dist/chunks/auto-updater.mjs +0 -507
- package/dist/chunks/banner.mjs +0 -173
- package/dist/chunks/bash.mjs +0 -187
- package/dist/chunks/boost.mjs +0 -474
- package/dist/chunks/brain-config.mjs +0 -75
- package/dist/chunks/brain-status.mjs +0 -89
- package/dist/chunks/ccjk-agents.mjs +0 -416
- package/dist/chunks/ccjk-all.mjs +0 -1046
- package/dist/chunks/ccjk-config.mjs +0 -445
- package/dist/chunks/ccjk-hooks.mjs +0 -1074
- package/dist/chunks/ccjk-mcp.mjs +0 -763
- package/dist/chunks/ccjk-setup.mjs +0 -765
- package/dist/chunks/ccjk-skills.mjs +0 -518
- package/dist/chunks/ccr.mjs +0 -109
- package/dist/chunks/ccu.mjs +0 -40
- package/dist/chunks/check-updates.mjs +0 -117
- package/dist/chunks/claude-code-incremental-manager.mjs +0 -761
- package/dist/chunks/claude-config.mjs +0 -606
- package/dist/chunks/claude-config2.mjs +0 -62
- package/dist/chunks/claude-wrapper.mjs +0 -85
- package/dist/chunks/clavue-config.mjs +0 -1454
- package/dist/chunks/cleanup-migration.mjs +0 -20
- package/dist/chunks/cli-hook.mjs +0 -4096
- package/dist/chunks/cloud-sync.mjs +0 -29
- package/dist/chunks/code-type-resolver.mjs +0 -880
- package/dist/chunks/codex-config-switch.mjs +0 -452
- package/dist/chunks/codex-provider-manager.mjs +0 -238
- package/dist/chunks/codex-uninstaller.mjs +0 -404
- package/dist/chunks/codex.mjs +0 -2141
- package/dist/chunks/commands.mjs +0 -108
- package/dist/chunks/commands2.mjs +0 -421
- package/dist/chunks/commit.mjs +0 -140
- package/dist/chunks/completion.mjs +0 -517
- package/dist/chunks/config-consolidator.mjs +0 -172
- package/dist/chunks/config-switch.mjs +0 -334
- package/dist/chunks/config.mjs +0 -558
- package/dist/chunks/config2.mjs +0 -484
- package/dist/chunks/config3.mjs +0 -486
- package/dist/chunks/constants.mjs +0 -323
- package/dist/chunks/context-opt.mjs +0 -444
- package/dist/chunks/context.mjs +0 -974
- package/dist/chunks/dashboard.mjs +0 -481
- package/dist/chunks/doctor.mjs +0 -1301
- package/dist/chunks/eval.mjs +0 -502
- package/dist/chunks/evolution.mjs +0 -322
- package/dist/chunks/features.mjs +0 -715
- package/dist/chunks/fish.mjs +0 -181
- package/dist/chunks/fs-operations.mjs +0 -180
- package/dist/chunks/health-alerts.mjs +0 -830
- package/dist/chunks/help.mjs +0 -341
- package/dist/chunks/hook-installer.mjs +0 -48
- package/dist/chunks/impact.mjs +0 -651
- package/dist/chunks/index.mjs +0 -23
- package/dist/chunks/index10.mjs +0 -19
- package/dist/chunks/index11.mjs +0 -1171
- package/dist/chunks/index12.mjs +0 -218
- package/dist/chunks/index13.mjs +0 -679
- package/dist/chunks/index14.mjs +0 -1009
- package/dist/chunks/index15.mjs +0 -194
- package/dist/chunks/index2.mjs +0 -7637
- package/dist/chunks/index3.mjs +0 -171
- package/dist/chunks/index4.mjs +0 -26
- package/dist/chunks/index5.mjs +0 -19
- package/dist/chunks/index6.mjs +0 -19092
- package/dist/chunks/index7.mjs +0 -616
- package/dist/chunks/index8.mjs +0 -1602
- package/dist/chunks/index9.mjs +0 -5384
- package/dist/chunks/init.mjs +0 -1911
- package/dist/chunks/installer.mjs +0 -757
- package/dist/chunks/installer2.mjs +0 -103
- package/dist/chunks/interview.mjs +0 -2927
- package/dist/chunks/json-config.mjs +0 -60
- package/dist/chunks/linux.mjs +0 -3863
- package/dist/chunks/macos.mjs +0 -69
- package/dist/chunks/main.mjs +0 -635
- package/dist/chunks/manager.mjs +0 -1048
- package/dist/chunks/marketplace.mjs +0 -265
- package/dist/chunks/mcp-cli.mjs +0 -205
- package/dist/chunks/mcp-performance.mjs +0 -187
- package/dist/chunks/mcp.mjs +0 -667
- package/dist/chunks/memory-check.mjs +0 -2973
- package/dist/chunks/memory-paths.mjs +0 -259
- package/dist/chunks/memory-sync.mjs +0 -209
- package/dist/chunks/memory.mjs +0 -354
- package/dist/chunks/metrics-display.mjs +0 -153
- package/dist/chunks/monitor.mjs +0 -1856
- package/dist/chunks/notification.mjs +0 -1864
- package/dist/chunks/onboarding.mjs +0 -386
- package/dist/chunks/package.mjs +0 -3
- package/dist/chunks/paradigm.mjs +0 -74
- package/dist/chunks/permission-manager.mjs +0 -250
- package/dist/chunks/permissions.mjs +0 -265
- package/dist/chunks/persistence-manager.mjs +0 -801
- package/dist/chunks/persistence.mjs +0 -707
- package/dist/chunks/platform.mjs +0 -395
- package/dist/chunks/plugin.mjs +0 -1936
- package/dist/chunks/powershell.mjs +0 -213
- package/dist/chunks/prompts.mjs +0 -244
- package/dist/chunks/providers.mjs +0 -263
- package/dist/chunks/quick-actions.mjs +0 -335
- package/dist/chunks/quick-provider.mjs +0 -755
- package/dist/chunks/quick-setup.mjs +0 -421
- package/dist/chunks/remote.mjs +0 -497
- package/dist/chunks/research.mjs +0 -1904
- package/dist/chunks/rollback.mjs +0 -38
- package/dist/chunks/session-manager.mjs +0 -1371
- package/dist/chunks/session.mjs +0 -878
- package/dist/chunks/sessions.mjs +0 -106
- package/dist/chunks/silent-updater.mjs +0 -396
- package/dist/chunks/simple-config.mjs +0 -122
- package/dist/chunks/skill.mjs +0 -117
- package/dist/chunks/skill2.mjs +0 -9052
- package/dist/chunks/skills-sync.mjs +0 -1343
- package/dist/chunks/skills.mjs +0 -577
- package/dist/chunks/slash-commands.mjs +0 -208
- package/dist/chunks/smart-guide.mjs +0 -247
- package/dist/chunks/snapshot.mjs +0 -58
- package/dist/chunks/startup.mjs +0 -487
- package/dist/chunks/stats.mjs +0 -191
- package/dist/chunks/status.mjs +0 -471
- package/dist/chunks/team.mjs +0 -63
- package/dist/chunks/thinking.mjs +0 -626
- package/dist/chunks/trace.mjs +0 -57
- package/dist/chunks/uninstall.mjs +0 -852
- package/dist/chunks/update.mjs +0 -174
- package/dist/chunks/upgrade-manager.mjs +0 -204
- package/dist/chunks/upgrade.mjs +0 -133
- package/dist/chunks/version-checker.mjs +0 -891
- package/dist/chunks/vim.mjs +0 -903
- package/dist/chunks/windows.mjs +0 -14
- package/dist/chunks/workflows.mjs +0 -633
- package/dist/chunks/wsl.mjs +0 -129
- package/dist/chunks/zero-config.mjs +0 -871
- package/dist/chunks/zsh.mjs +0 -182
- package/dist/cli.d.mts +0 -1
- package/dist/cli.d.ts +0 -1
- package/dist/cli.mjs +0 -2684
- package/dist/i18n/locales/en/agent-teams.json +0 -18
- package/dist/i18n/locales/en/agentBrowser.json +0 -80
- package/dist/i18n/locales/en/agents.json +0 -135
- package/dist/i18n/locales/en/api.json +0 -63
- package/dist/i18n/locales/en/ccjk-agents.json +0 -33
- package/dist/i18n/locales/en/ccjk-all.json +0 -23
- package/dist/i18n/locales/en/ccjk-skills.json +0 -22
- package/dist/i18n/locales/en/ccjk.json +0 -276
- package/dist/i18n/locales/en/ccr.json +0 -65
- package/dist/i18n/locales/en/claude-md.json +0 -73
- package/dist/i18n/locales/en/cli.json +0 -148
- package/dist/i18n/locales/en/cloud-setup.json +0 -31
- package/dist/i18n/locales/en/cloud-sync.json +0 -147
- package/dist/i18n/locales/en/cloud.json +0 -40
- package/dist/i18n/locales/en/cloudPlugins.json +0 -118
- package/dist/i18n/locales/en/codex.json +0 -184
- package/dist/i18n/locales/en/cometix.json +0 -29
- package/dist/i18n/locales/en/common.json +0 -68
- package/dist/i18n/locales/en/config.json +0 -108
- package/dist/i18n/locales/en/configuration.json +0 -236
- package/dist/i18n/locales/en/context.json +0 -85
- package/dist/i18n/locales/en/dashboard.json +0 -78
- package/dist/i18n/locales/en/errors.json +0 -26
- package/dist/i18n/locales/en/evolution.json +0 -54
- package/dist/i18n/locales/en/hooks.json +0 -74
- package/dist/i18n/locales/en/hooksSync.json +0 -133
- package/dist/i18n/locales/en/installation.json +0 -83
- package/dist/i18n/locales/en/interview.json +0 -104
- package/dist/i18n/locales/en/language.json +0 -19
- package/dist/i18n/locales/en/lsp.json +0 -78
- package/dist/i18n/locales/en/marketplace.json +0 -116
- package/dist/i18n/locales/en/mcp.json +0 -180
- package/dist/i18n/locales/en/memory.json +0 -23
- package/dist/i18n/locales/en/menu.json +0 -299
- package/dist/i18n/locales/en/multi-config.json +0 -79
- package/dist/i18n/locales/en/notification.json +0 -307
- package/dist/i18n/locales/en/permissions.json +0 -95
- package/dist/i18n/locales/en/persistence.json +0 -127
- package/dist/i18n/locales/en/plugins.json +0 -146
- package/dist/i18n/locales/en/quick-actions.json +0 -78
- package/dist/i18n/locales/en/registry.json +0 -54
- package/dist/i18n/locales/en/remote.json +0 -93
- package/dist/i18n/locales/en/sandbox.json +0 -44
- package/dist/i18n/locales/en/setup.json +0 -44
- package/dist/i18n/locales/en/shencha.json +0 -14
- package/dist/i18n/locales/en/skills.json +0 -100
- package/dist/i18n/locales/en/skillsSync.json +0 -74
- package/dist/i18n/locales/en/smartGuide.json +0 -49
- package/dist/i18n/locales/en/stats.json +0 -20
- package/dist/i18n/locales/en/subagent.json +0 -69
- package/dist/i18n/locales/en/superpowers.json +0 -117
- package/dist/i18n/locales/en/team.json +0 -7
- package/dist/i18n/locales/en/thinking.json +0 -65
- package/dist/i18n/locales/en/tools.json +0 -42
- package/dist/i18n/locales/en/uninstall.json +0 -56
- package/dist/i18n/locales/en/updater.json +0 -29
- package/dist/i18n/locales/en/vim.json +0 -169
- package/dist/i18n/locales/en/workflow.json +0 -55
- package/dist/i18n/locales/en/workspace.json +0 -108
- package/dist/i18n/locales/zh-CN/agent-teams.json +0 -18
- package/dist/i18n/locales/zh-CN/agentBrowser.json +0 -80
- package/dist/i18n/locales/zh-CN/agents.json +0 -135
- package/dist/i18n/locales/zh-CN/api.json +0 -63
- package/dist/i18n/locales/zh-CN/ccjk-agents.json +0 -33
- package/dist/i18n/locales/zh-CN/ccjk-all.json +0 -23
- package/dist/i18n/locales/zh-CN/ccjk-skills.json +0 -22
- package/dist/i18n/locales/zh-CN/ccjk.json +0 -276
- package/dist/i18n/locales/zh-CN/ccr.json +0 -65
- package/dist/i18n/locales/zh-CN/claude-md.json +0 -73
- package/dist/i18n/locales/zh-CN/cli.json +0 -148
- package/dist/i18n/locales/zh-CN/cloud-setup.json +0 -31
- package/dist/i18n/locales/zh-CN/cloud-sync.json +0 -147
- package/dist/i18n/locales/zh-CN/cloud.json +0 -40
- package/dist/i18n/locales/zh-CN/cloudPlugins.json +0 -118
- package/dist/i18n/locales/zh-CN/codex.json +0 -184
- package/dist/i18n/locales/zh-CN/cometix.json +0 -29
- package/dist/i18n/locales/zh-CN/common.json +0 -68
- package/dist/i18n/locales/zh-CN/config.json +0 -108
- package/dist/i18n/locales/zh-CN/configuration.json +0 -234
- package/dist/i18n/locales/zh-CN/context.json +0 -85
- package/dist/i18n/locales/zh-CN/dashboard.json +0 -78
- package/dist/i18n/locales/zh-CN/errors.json +0 -26
- package/dist/i18n/locales/zh-CN/evolution.json +0 -54
- package/dist/i18n/locales/zh-CN/hooks.json +0 -74
- package/dist/i18n/locales/zh-CN/hooksSync.json +0 -133
- package/dist/i18n/locales/zh-CN/installation.json +0 -83
- package/dist/i18n/locales/zh-CN/interview.json +0 -104
- package/dist/i18n/locales/zh-CN/language.json +0 -19
- package/dist/i18n/locales/zh-CN/lsp.json +0 -78
- package/dist/i18n/locales/zh-CN/marketplace.json +0 -116
- package/dist/i18n/locales/zh-CN/mcp.json +0 -180
- package/dist/i18n/locales/zh-CN/memory.json +0 -23
- package/dist/i18n/locales/zh-CN/menu.json +0 -299
- package/dist/i18n/locales/zh-CN/multi-config.json +0 -79
- package/dist/i18n/locales/zh-CN/notification.json +0 -307
- package/dist/i18n/locales/zh-CN/permissions.json +0 -95
- package/dist/i18n/locales/zh-CN/persistence.json +0 -127
- package/dist/i18n/locales/zh-CN/plugins.json +0 -146
- package/dist/i18n/locales/zh-CN/quick-actions.json +0 -78
- package/dist/i18n/locales/zh-CN/registry.json +0 -54
- package/dist/i18n/locales/zh-CN/remote.json +0 -93
- package/dist/i18n/locales/zh-CN/sandbox.json +0 -44
- package/dist/i18n/locales/zh-CN/setup.json +0 -44
- package/dist/i18n/locales/zh-CN/shencha.json +0 -14
- package/dist/i18n/locales/zh-CN/skills.json +0 -100
- package/dist/i18n/locales/zh-CN/skillsSync.json +0 -74
- package/dist/i18n/locales/zh-CN/smartGuide.json +0 -49
- package/dist/i18n/locales/zh-CN/stats.json +0 -20
- package/dist/i18n/locales/zh-CN/subagent.json +0 -69
- package/dist/i18n/locales/zh-CN/superpowers.json +0 -117
- package/dist/i18n/locales/zh-CN/team.json +0 -7
- package/dist/i18n/locales/zh-CN/thinking.json +0 -65
- package/dist/i18n/locales/zh-CN/tools.json +0 -42
- package/dist/i18n/locales/zh-CN/uninstall.json +0 -56
- package/dist/i18n/locales/zh-CN/updater.json +0 -29
- package/dist/i18n/locales/zh-CN/vim.json +0 -169
- package/dist/i18n/locales/zh-CN/workflow.json +0 -55
- package/dist/i18n/locales/zh-CN/workspace.json +0 -108
- package/dist/index.d.mts +0 -5658
- package/dist/index.d.ts +0 -5658
- package/dist/index.mjs +0 -3732
- package/dist/shared/ccjk.5bEolFrk.mjs +0 -254
- package/dist/shared/ccjk.8oaxX4iR.mjs +0 -90
- package/dist/shared/ccjk.B2U7DsPy.mjs +0 -31
- package/dist/shared/ccjk.B2f-cwUP.mjs +0 -468
- package/dist/shared/ccjk.BAGoDD49.mjs +0 -36
- package/dist/shared/ccjk.BBtCGd_g.mjs +0 -899
- package/dist/shared/ccjk.BFQ7yr5S.mjs +0 -16
- package/dist/shared/ccjk.BLsIiTqO.mjs +0 -449
- package/dist/shared/ccjk.BXv8aYs1.mjs +0 -170
- package/dist/shared/ccjk.BnsY5WxD.mjs +0 -171
- package/dist/shared/ccjk.BoApaI4j.mjs +0 -28
- package/dist/shared/ccjk.Bq8TqZG_.mjs +0 -189
- package/dist/shared/ccjk.BtrioX1Z.mjs +0 -25
- package/dist/shared/ccjk.Bx_rmYfN.mjs +0 -69
- package/dist/shared/ccjk.BzPbSEP2.mjs +0 -115
- package/dist/shared/ccjk.C0WLUnFV.mjs +0 -293
- package/dist/shared/ccjk.C1hANZTu.mjs +0 -19
- package/dist/shared/ccjk.C2jHOZVP.mjs +0 -52
- package/dist/shared/ccjk.CNhnT6uQ.mjs +0 -636
- package/dist/shared/ccjk.COweQ1RR.mjs +0 -5
- package/dist/shared/ccjk.CfKKcvWy.mjs +0 -126
- package/dist/shared/ccjk.Cjgrln_h.mjs +0 -297
- package/dist/shared/ccjk.CoCHVXl3.mjs +0 -3951
- package/dist/shared/ccjk.CwGZSTAK.mjs +0 -319
- package/dist/shared/ccjk.CxpGa6MC.mjs +0 -2724
- package/dist/shared/ccjk.D-magaEx.mjs +0 -763
- package/dist/shared/ccjk.D0g2ABGg.mjs +0 -171
- package/dist/shared/ccjk.D6ycHbak.mjs +0 -270
- package/dist/shared/ccjk.D75wivnp.mjs +0 -142
- package/dist/shared/ccjk.DDL-4C-k.mjs +0 -100
- package/dist/shared/ccjk.DFRPtmK_.mjs +0 -75
- package/dist/shared/ccjk.DMV3x5Sd.mjs +0 -299
- package/dist/shared/ccjk.DZ2LLOa-.mjs +0 -2195
- package/dist/shared/ccjk.DbigonEQ.mjs +0 -698
- package/dist/shared/ccjk.DcMvE7lf.mjs +0 -618
- package/dist/shared/ccjk.DeWpAShp.mjs +0 -1828
- package/dist/shared/ccjk.DhJ1kyDR.mjs +0 -30
- package/dist/shared/ccjk.DlTXS9rP.mjs +0 -224
- package/dist/shared/ccjk.DopKzo3z.mjs +0 -305
- package/dist/shared/ccjk.DsZsc4LR.mjs +0 -1280
- package/dist/shared/ccjk.DuzJZlgj.mjs +0 -418
- package/dist/shared/ccjk.Dxgd2vjc.mjs +0 -444
- package/dist/shared/ccjk.J8YiPsOw.mjs +0 -259
- package/dist/shared/ccjk.KfSWcGlE.mjs +0 -38
- package/dist/shared/ccjk.L7yC58_i.mjs +0 -225
- package/dist/shared/ccjk.MwtjAULc.mjs +0 -1447
- package/dist/shared/ccjk.OJKHVSOb.mjs +0 -2005
- package/dist/shared/ccjk.OTnevPNE.mjs +0 -225
- package/dist/shared/ccjk.RyizuzOI.mjs +0 -21
- package/dist/shared/ccjk.T_cX87dY.mjs +0 -15
- package/dist/shared/ccjk.bQ7Dh1g4.mjs +0 -249
- package/dist/shared/ccjk.gDEDGD_t.mjs +0 -38
- package/dist/shared/ccjk.hoqrwWdN.mjs +0 -333
- package/dist/shared/ccjk.i_vn-9C3.mjs +0 -317
- package/dist/shared/ccjk.lG3ccFjm.mjs +0 -885
- package/dist/shared/ccjk.wLJHO0Af.mjs +0 -244
- package/dist/shared/ccjk.y-a_1vK4.mjs +0 -5127
- package/dist/templates/agents/README.md +0 -78
- package/dist/templates/agents/fullstack-developer.json +0 -70
- package/dist/templates/agents/go-expert.json +0 -69
- package/dist/templates/agents/index.json +0 -64
- package/dist/templates/agents/python-expert.json +0 -69
- package/dist/templates/agents/react-specialist.json +0 -69
- package/dist/templates/agents/testing-automation-expert.json +0 -70
- package/dist/templates/agents/typescript-architect.json +0 -69
- package/dist/templates/claude-code/common/settings.json +0 -109
- package/dist/templates/common/error-prevention.md +0 -267
- package/dist/templates/common/karpathy-baseline.md +0 -83
- package/dist/templates/common/output-styles/zh-CN/carmack-mode.md +0 -381
- package/dist/templates/common/output-styles/zh-CN/codex-rigor-mode.md +0 -114
- package/dist/templates/common/output-styles/zh-CN/dhh-mode.md +0 -265
- package/dist/templates/common/output-styles/zh-CN/evan-you-mode.md +0 -539
- package/dist/templates/common/output-styles/zh-CN/jobs-mode.md +0 -369
- package/dist/templates/common/output-styles/zh-CN/linus-mode.md +0 -135
- package/dist/templates/common/output-styles/zh-CN/uncle-bob-mode.md +0 -221
- package/dist/templates/common/workflow/continuousDelivery/en/continuous-delivery.md +0 -628
- package/dist/templates/common/workflow/continuousDelivery/zh-CN/continuous-delivery.md +0 -628
- package/dist/templates/common/workflow/essential/en/agents/ccjk-config-agent.md +0 -187
- package/dist/templates/common/workflow/essential/en/agents/ccjk-mcp-agent.md +0 -191
- package/dist/templates/common/workflow/essential/en/agents/ccjk-skill-agent.md +0 -249
- package/dist/templates/common/workflow/essential/en/agents/ccjk-workflow-agent.md +0 -277
- package/dist/templates/common/workflow/essential/en/agents/get-current-datetime.md +0 -29
- package/dist/templates/common/workflow/essential/en/agents/init-architect.md +0 -115
- package/dist/templates/common/workflow/essential/en/agents/ui-ux-designer.md +0 -91
- package/dist/templates/common/workflow/essential/en/feat.md +0 -92
- package/dist/templates/common/workflow/essential/en/goal.md +0 -147
- package/dist/templates/common/workflow/essential/en/init-project.md +0 -53
- package/dist/templates/common/workflow/essential/zh-CN/agents/get-current-datetime.md +0 -29
- package/dist/templates/common/workflow/essential/zh-CN/agents/init-architect.md +0 -115
- package/dist/templates/common/workflow/essential/zh-CN/agents/ui-ux-designer.md +0 -91
- package/dist/templates/common/workflow/essential/zh-CN/feat.md +0 -315
- package/dist/templates/common/workflow/essential/zh-CN/goal.md +0 -146
- package/dist/templates/common/workflow/essential/zh-CN/init-project.md +0 -53
- package/dist/templates/common/workflow/git/en/git-cleanBranches.md +0 -102
- package/dist/templates/common/workflow/git/en/git-commit.md +0 -205
- package/dist/templates/common/workflow/git/en/git-rollback.md +0 -90
- package/dist/templates/common/workflow/git/en/git-worktree.md +0 -276
- package/dist/templates/common/workflow/git/zh-CN/git-cleanBranches.md +0 -102
- package/dist/templates/common/workflow/git/zh-CN/git-commit.md +0 -205
- package/dist/templates/common/workflow/git/zh-CN/git-rollback.md +0 -90
- package/dist/templates/common/workflow/git/zh-CN/git-worktree.md +0 -276
- package/dist/templates/common/workflow/interview/en/interview.md +0 -67
- package/dist/templates/common/workflow/interview/zh-CN/interview.md +0 -67
- package/dist/templates/common/workflow/linearMethod/en/linear-method.md +0 -651
- package/dist/templates/common/workflow/linearMethod/zh-CN/linear-method.md +0 -752
- package/dist/templates/common/workflow/refactoringMaster/en/refactoring-master.md +0 -516
- package/dist/templates/common/workflow/refactoringMaster/zh-CN/refactoring-master.md +0 -812
- package/dist/templates/common/workflow/sixStep/en/workflow.md +0 -83
- package/dist/templates/common/workflow/sixStep/zh-CN/workflow.md +0 -359
- package/dist/templates/common/workflow/specFirstTDD/en/spec-first-tdd.md +0 -364
- package/dist/templates/common/workflow/specFirstTDD/zh-CN/spec-first-tdd.md +0 -366
- package/dist/templates/hooks/README.md +0 -212
- package/dist/templates/hooks/git-workflow-hooks.md +0 -551
- package/dist/templates/hooks/post-test/coverage.json +0 -21
- package/dist/templates/hooks/post-test/summary.json +0 -21
- package/dist/templates/hooks/post-test-coverage.md +0 -434
- package/dist/templates/hooks/pre-commit/eslint.json +0 -22
- package/dist/templates/hooks/pre-commit/prettier.json +0 -22
- package/dist/templates/hooks/pre-commit-black.md +0 -274
- package/dist/templates/hooks/pre-commit-eslint.md +0 -153
- package/dist/templates/hooks/pre-commit-gofmt.md +0 -284
- package/dist/templates/hooks/pre-commit-prettier.md +0 -212
- package/dist/templates/hooks/pre-commit-type-check.md +0 -377
- package/dist/templates/skills/ccjk-init.md +0 -154
- package/dist/templates/skills/ccjk-mcp-setup.md +0 -205
- package/dist/templates/skills/ccjk-troubleshoot.md +0 -228
- package/dist/templates/skills/django-patterns.md +0 -1016
- package/dist/templates/skills/git-workflow.md +0 -748
- package/dist/templates/skills/go-idioms.md +0 -963
- package/dist/templates/skills/index.json +0 -132
- package/dist/templates/skills/nextjs-optimization.md +0 -694
- package/dist/templates/skills/python-pep8.md +0 -852
- package/dist/templates/skills/react-patterns.md +0 -686
- package/dist/templates/skills/rust-patterns.md +0 -1057
- package/dist/templates/skills/security-best-practices.md +0 -1413
- package/dist/templates/skills/testing-best-practices.md +0 -1315
- package/dist/templates/skills/ts-best-practices.md +0 -354
- package/templates/agents/README.md +0 -78
- package/templates/agents/fullstack-developer.json +0 -70
- package/templates/agents/go-expert.json +0 -69
- package/templates/agents/index.json +0 -64
- package/templates/agents/python-expert.json +0 -69
- package/templates/agents/react-specialist.json +0 -69
- package/templates/agents/testing-automation-expert.json +0 -70
- package/templates/agents/typescript-architect.json +0 -69
- package/templates/claude-code/common/settings.json +0 -109
- package/templates/common/error-prevention.md +0 -267
- package/templates/common/karpathy-baseline.md +0 -83
- package/templates/common/output-styles/zh-CN/carmack-mode.md +0 -381
- package/templates/common/output-styles/zh-CN/codex-rigor-mode.md +0 -114
- package/templates/common/output-styles/zh-CN/dhh-mode.md +0 -265
- package/templates/common/output-styles/zh-CN/evan-you-mode.md +0 -539
- package/templates/common/output-styles/zh-CN/jobs-mode.md +0 -369
- package/templates/common/output-styles/zh-CN/linus-mode.md +0 -135
- package/templates/common/output-styles/zh-CN/uncle-bob-mode.md +0 -221
- package/templates/common/workflow/continuousDelivery/en/continuous-delivery.md +0 -628
- package/templates/common/workflow/continuousDelivery/zh-CN/continuous-delivery.md +0 -628
- package/templates/common/workflow/essential/en/agents/ccjk-config-agent.md +0 -187
- package/templates/common/workflow/essential/en/agents/ccjk-mcp-agent.md +0 -191
- package/templates/common/workflow/essential/en/agents/ccjk-skill-agent.md +0 -249
- package/templates/common/workflow/essential/en/agents/ccjk-workflow-agent.md +0 -277
- package/templates/common/workflow/essential/en/agents/get-current-datetime.md +0 -29
- package/templates/common/workflow/essential/en/agents/init-architect.md +0 -115
- package/templates/common/workflow/essential/en/agents/ui-ux-designer.md +0 -91
- package/templates/common/workflow/essential/en/feat.md +0 -92
- package/templates/common/workflow/essential/en/goal.md +0 -147
- package/templates/common/workflow/essential/en/init-project.md +0 -53
- package/templates/common/workflow/essential/zh-CN/agents/get-current-datetime.md +0 -29
- package/templates/common/workflow/essential/zh-CN/agents/init-architect.md +0 -115
- package/templates/common/workflow/essential/zh-CN/agents/ui-ux-designer.md +0 -91
- package/templates/common/workflow/essential/zh-CN/feat.md +0 -315
- package/templates/common/workflow/essential/zh-CN/goal.md +0 -146
- package/templates/common/workflow/essential/zh-CN/init-project.md +0 -53
- package/templates/common/workflow/git/en/git-cleanBranches.md +0 -102
- package/templates/common/workflow/git/en/git-commit.md +0 -205
- package/templates/common/workflow/git/en/git-rollback.md +0 -90
- package/templates/common/workflow/git/en/git-worktree.md +0 -276
- package/templates/common/workflow/git/zh-CN/git-cleanBranches.md +0 -102
- package/templates/common/workflow/git/zh-CN/git-commit.md +0 -205
- package/templates/common/workflow/git/zh-CN/git-rollback.md +0 -90
- package/templates/common/workflow/git/zh-CN/git-worktree.md +0 -276
- package/templates/common/workflow/interview/en/interview.md +0 -67
- package/templates/common/workflow/interview/zh-CN/interview.md +0 -67
- package/templates/common/workflow/linearMethod/en/linear-method.md +0 -651
- package/templates/common/workflow/linearMethod/zh-CN/linear-method.md +0 -752
- package/templates/common/workflow/refactoringMaster/en/refactoring-master.md +0 -516
- package/templates/common/workflow/refactoringMaster/zh-CN/refactoring-master.md +0 -812
- package/templates/common/workflow/sixStep/en/workflow.md +0 -83
- package/templates/common/workflow/sixStep/zh-CN/workflow.md +0 -359
- package/templates/common/workflow/specFirstTDD/en/spec-first-tdd.md +0 -364
- package/templates/common/workflow/specFirstTDD/zh-CN/spec-first-tdd.md +0 -366
- package/templates/hooks/README.md +0 -212
- package/templates/hooks/git-workflow-hooks.md +0 -551
- package/templates/hooks/post-test/coverage.json +0 -21
- package/templates/hooks/post-test/summary.json +0 -21
- package/templates/hooks/post-test-coverage.md +0 -434
- package/templates/hooks/pre-commit/eslint.json +0 -22
- package/templates/hooks/pre-commit/prettier.json +0 -22
- package/templates/hooks/pre-commit-black.md +0 -274
- package/templates/hooks/pre-commit-eslint.md +0 -153
- package/templates/hooks/pre-commit-gofmt.md +0 -284
- package/templates/hooks/pre-commit-prettier.md +0 -212
- package/templates/hooks/pre-commit-type-check.md +0 -377
- package/templates/skills/basic.hbs +0 -72
- package/templates/skills/ccjk-init.md +0 -154
- package/templates/skills/ccjk-mcp-setup.md +0 -205
- package/templates/skills/ccjk-troubleshoot.md +0 -228
- package/templates/skills/code-refactor.hbs +0 -133
- package/templates/skills/code-review.hbs +0 -141
- package/templates/skills/django-patterns.md +0 -1016
- package/templates/skills/git-workflow.md +0 -748
- package/templates/skills/go-idioms.md +0 -963
- package/templates/skills/index.json +0 -132
- package/templates/skills/nextjs-optimization.md +0 -694
- package/templates/skills/python-pep8.md +0 -852
- package/templates/skills/react-patterns.md +0 -686
- package/templates/skills/rust-patterns.md +0 -1057
- package/templates/skills/security-best-practices.md +0 -1413
- package/templates/skills/testing-best-practices.md +0 -1315
- package/templates/skills/ts-best-practices.md +0 -354
- package/templates/skills/type-fix.hbs +0 -132
|
@@ -1,618 +0,0 @@
|
|
|
1
|
-
import { existsSync, readFileSync, mkdirSync, unlinkSync } from 'node:fs';
|
|
2
|
-
import os__default, { homedir } from 'node:os';
|
|
3
|
-
import { c as createDefaultGateway } from './ccjk.D0g2ABGg.mjs';
|
|
4
|
-
import { CLOUD_ENDPOINTS } from '../chunks/constants.mjs';
|
|
5
|
-
import { writeFileAtomic } from '../chunks/fs-operations.mjs';
|
|
6
|
-
import { Buffer } from 'node:buffer';
|
|
7
|
-
import crypto from 'node:crypto';
|
|
8
|
-
import { j as join } from './ccjk.bQ7Dh1g4.mjs';
|
|
9
|
-
|
|
10
|
-
function validateBindRequest(request) {
|
|
11
|
-
const errors = [];
|
|
12
|
-
if (!request.code || typeof request.code !== "string") {
|
|
13
|
-
errors.push("code is required and must be a string");
|
|
14
|
-
} else if (request.code.length < 4) {
|
|
15
|
-
errors.push("code must be at least 4 characters");
|
|
16
|
-
}
|
|
17
|
-
if (!request.deviceInfo || typeof request.deviceInfo !== "object") {
|
|
18
|
-
errors.push("deviceInfo is required and must be an object");
|
|
19
|
-
} else {
|
|
20
|
-
if (!request.deviceInfo.name || typeof request.deviceInfo.name !== "string") {
|
|
21
|
-
errors.push("deviceInfo.name is required and must be a string");
|
|
22
|
-
}
|
|
23
|
-
if (!request.deviceInfo.platform || typeof request.deviceInfo.platform !== "string") {
|
|
24
|
-
errors.push("deviceInfo.platform is required and must be a string");
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
return {
|
|
28
|
-
valid: errors.length === 0,
|
|
29
|
-
errors
|
|
30
|
-
};
|
|
31
|
-
}
|
|
32
|
-
function validateNotifyRequest(request) {
|
|
33
|
-
const errors = [];
|
|
34
|
-
if (!request.title || typeof request.title !== "string") {
|
|
35
|
-
errors.push("title is required and must be a string");
|
|
36
|
-
} else if (request.title.length > 200) {
|
|
37
|
-
errors.push("title must be 200 characters or less");
|
|
38
|
-
}
|
|
39
|
-
if (!request.body || typeof request.body !== "string") {
|
|
40
|
-
errors.push("body is required and must be a string");
|
|
41
|
-
} else if (request.body.length > 4e3) {
|
|
42
|
-
errors.push("body must be 4000 characters or less");
|
|
43
|
-
}
|
|
44
|
-
if (request.type && !["info", "success", "warning", "error"].includes(request.type)) {
|
|
45
|
-
errors.push("type must be one of: info, success, warning, error");
|
|
46
|
-
}
|
|
47
|
-
if (request.actions) {
|
|
48
|
-
if (!Array.isArray(request.actions)) {
|
|
49
|
-
errors.push("actions must be an array");
|
|
50
|
-
} else {
|
|
51
|
-
request.actions.forEach((action, index) => {
|
|
52
|
-
if (!action.id || typeof action.id !== "string") {
|
|
53
|
-
errors.push(`actions[${index}].id is required and must be a string`);
|
|
54
|
-
}
|
|
55
|
-
if (!action.label || typeof action.label !== "string") {
|
|
56
|
-
errors.push(`actions[${index}].label is required and must be a string`);
|
|
57
|
-
}
|
|
58
|
-
if (!action.value || typeof action.value !== "string") {
|
|
59
|
-
errors.push(`actions[${index}].value is required and must be a string`);
|
|
60
|
-
}
|
|
61
|
-
});
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
return {
|
|
65
|
-
valid: errors.length === 0,
|
|
66
|
-
errors
|
|
67
|
-
};
|
|
68
|
-
}
|
|
69
|
-
function validateBindResponse(response) {
|
|
70
|
-
const errors = [];
|
|
71
|
-
if (typeof response.success !== "boolean") {
|
|
72
|
-
errors.push("success is required and must be a boolean");
|
|
73
|
-
}
|
|
74
|
-
if (response.success) {
|
|
75
|
-
if (!response.data) {
|
|
76
|
-
errors.push("data is required when success is true");
|
|
77
|
-
} else {
|
|
78
|
-
if (!response.data.deviceToken || typeof response.data.deviceToken !== "string") {
|
|
79
|
-
errors.push("data.deviceToken is required and must be a string");
|
|
80
|
-
}
|
|
81
|
-
if (!response.data.deviceId || typeof response.data.deviceId !== "string") {
|
|
82
|
-
errors.push("data.deviceId is required and must be a string");
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
} else {
|
|
86
|
-
if (!response.error || typeof response.error !== "string") {
|
|
87
|
-
errors.push("error is required when success is false");
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
return {
|
|
91
|
-
valid: errors.length === 0,
|
|
92
|
-
errors
|
|
93
|
-
};
|
|
94
|
-
}
|
|
95
|
-
function validateNotifyResponse(response) {
|
|
96
|
-
const errors = [];
|
|
97
|
-
if (typeof response.success !== "boolean") {
|
|
98
|
-
errors.push("success is required and must be a boolean");
|
|
99
|
-
}
|
|
100
|
-
if (response.success) {
|
|
101
|
-
if (!response.data) {
|
|
102
|
-
errors.push("data is required when success is true");
|
|
103
|
-
} else {
|
|
104
|
-
if (!response.data.notificationId || typeof response.data.notificationId !== "string") {
|
|
105
|
-
errors.push("data.notificationId is required and must be a string");
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
} else {
|
|
109
|
-
if (!response.error || typeof response.error !== "string") {
|
|
110
|
-
errors.push("error is required when success is false");
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
return {
|
|
114
|
-
valid: errors.length === 0,
|
|
115
|
-
errors
|
|
116
|
-
};
|
|
117
|
-
}
|
|
118
|
-
function validatePollResponse(response) {
|
|
119
|
-
const errors = [];
|
|
120
|
-
if (typeof response.success !== "boolean") {
|
|
121
|
-
errors.push("success is required and must be a boolean");
|
|
122
|
-
}
|
|
123
|
-
if (response.success) {
|
|
124
|
-
if (!response.data) {
|
|
125
|
-
errors.push("data is required when success is true");
|
|
126
|
-
} else if (response.data.reply !== null) {
|
|
127
|
-
const reply = response.data.reply;
|
|
128
|
-
if (!reply.content || typeof reply.content !== "string") {
|
|
129
|
-
errors.push("data.reply.content is required and must be a string");
|
|
130
|
-
}
|
|
131
|
-
if (!reply.timestamp || typeof reply.timestamp !== "string") {
|
|
132
|
-
errors.push("data.reply.timestamp is required and must be a string");
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
} else {
|
|
136
|
-
if (!response.error || typeof response.error !== "string") {
|
|
137
|
-
errors.push("error is required when success is false");
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
return {
|
|
141
|
-
valid: errors.length === 0,
|
|
142
|
-
errors
|
|
143
|
-
};
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
const TOKEN_PREFIX = "ccjk_";
|
|
147
|
-
const TOKEN_LENGTH = 64;
|
|
148
|
-
const TOKEN_VERSION = 1;
|
|
149
|
-
function generateDeviceToken() {
|
|
150
|
-
const randomBytes = crypto.randomBytes(TOKEN_LENGTH / 2);
|
|
151
|
-
const randomHex = randomBytes.toString("hex");
|
|
152
|
-
return `${TOKEN_PREFIX}${TOKEN_VERSION}${randomHex}`;
|
|
153
|
-
}
|
|
154
|
-
function isValidTokenFormat(token) {
|
|
155
|
-
if (!token || typeof token !== "string") {
|
|
156
|
-
return false;
|
|
157
|
-
}
|
|
158
|
-
if (!token.startsWith(TOKEN_PREFIX)) {
|
|
159
|
-
return false;
|
|
160
|
-
}
|
|
161
|
-
const expectedLength = TOKEN_PREFIX.length + 1 + TOKEN_LENGTH;
|
|
162
|
-
if (token.length !== expectedLength) {
|
|
163
|
-
return false;
|
|
164
|
-
}
|
|
165
|
-
const version = token[TOKEN_PREFIX.length];
|
|
166
|
-
if (!/^\d$/.test(version)) {
|
|
167
|
-
return false;
|
|
168
|
-
}
|
|
169
|
-
const hexPart = token.slice(TOKEN_PREFIX.length + 1);
|
|
170
|
-
if (!/^[a-f0-9]+$/i.test(hexPart)) {
|
|
171
|
-
return false;
|
|
172
|
-
}
|
|
173
|
-
return true;
|
|
174
|
-
}
|
|
175
|
-
function getDeviceInfo() {
|
|
176
|
-
return {
|
|
177
|
-
name: os__default.hostname(),
|
|
178
|
-
platform: os__default.platform(),
|
|
179
|
-
osVersion: os__default.release(),
|
|
180
|
-
arch: os__default.arch(),
|
|
181
|
-
username: os__default.userInfo().username,
|
|
182
|
-
machineId: generateMachineId()
|
|
183
|
-
};
|
|
184
|
-
}
|
|
185
|
-
function generateMachineId() {
|
|
186
|
-
const components = [
|
|
187
|
-
os__default.hostname(),
|
|
188
|
-
os__default.platform(),
|
|
189
|
-
os__default.arch(),
|
|
190
|
-
os__default.cpus()[0]?.model || "unknown",
|
|
191
|
-
os__default.userInfo().username,
|
|
192
|
-
// Add network interface MAC addresses for uniqueness
|
|
193
|
-
...Object.values(os__default.networkInterfaces()).flat().filter((iface) => iface && !iface.internal && iface.mac !== "00:00:00:00:00:00").map((iface) => iface?.mac).filter(Boolean).slice(0, 3)
|
|
194
|
-
// Limit to first 3 MACs
|
|
195
|
-
];
|
|
196
|
-
const combined = components.join("|");
|
|
197
|
-
return crypto.createHash("sha256").update(combined).digest("hex").slice(0, 32);
|
|
198
|
-
}
|
|
199
|
-
function deriveEncryptionKey() {
|
|
200
|
-
const machineId = generateMachineId();
|
|
201
|
-
const salt = "ccjk-notification-token-v1";
|
|
202
|
-
return crypto.pbkdf2Sync(machineId, salt, 1e5, 32, "sha256");
|
|
203
|
-
}
|
|
204
|
-
function encryptToken(token) {
|
|
205
|
-
const key = deriveEncryptionKey();
|
|
206
|
-
const iv = crypto.randomBytes(16);
|
|
207
|
-
const cipher = crypto.createCipheriv("aes-256-gcm", key, iv);
|
|
208
|
-
let encrypted = cipher.update(token, "utf8", "hex");
|
|
209
|
-
encrypted += cipher.final("hex");
|
|
210
|
-
const authTag = cipher.getAuthTag();
|
|
211
|
-
return `${iv.toString("hex")}:${authTag.toString("hex")}:${encrypted}`;
|
|
212
|
-
}
|
|
213
|
-
function decryptToken(encryptedToken) {
|
|
214
|
-
try {
|
|
215
|
-
const parts = encryptedToken.split(":");
|
|
216
|
-
if (parts.length !== 3) {
|
|
217
|
-
return null;
|
|
218
|
-
}
|
|
219
|
-
const [ivHex, authTagHex, encrypted] = parts;
|
|
220
|
-
const key = deriveEncryptionKey();
|
|
221
|
-
const iv = Buffer.from(ivHex, "hex");
|
|
222
|
-
const authTag = Buffer.from(authTagHex, "hex");
|
|
223
|
-
const decipher = crypto.createDecipheriv("aes-256-gcm", key, iv);
|
|
224
|
-
decipher.setAuthTag(authTag);
|
|
225
|
-
let decrypted = decipher.update(encrypted, "hex", "utf8");
|
|
226
|
-
decrypted += decipher.final("utf8");
|
|
227
|
-
return decrypted;
|
|
228
|
-
} catch {
|
|
229
|
-
return null;
|
|
230
|
-
}
|
|
231
|
-
}
|
|
232
|
-
function maskToken(token) {
|
|
233
|
-
if (!token || token.length < 12) {
|
|
234
|
-
return "***";
|
|
235
|
-
}
|
|
236
|
-
const prefix = token.slice(0, TOKEN_PREFIX.length + 1);
|
|
237
|
-
const suffix = token.slice(-4);
|
|
238
|
-
return `${prefix}***...***${suffix}`;
|
|
239
|
-
}
|
|
240
|
-
|
|
241
|
-
const CLOUD_API_BASE_URL = CLOUD_ENDPOINTS.MAIN.BASE_URL;
|
|
242
|
-
const POLL_TIMEOUT = 6e4;
|
|
243
|
-
const TOKEN_FILE_PATH = join(homedir(), ".ccjk", "cloud-token.json");
|
|
244
|
-
class CCJKCloudClient {
|
|
245
|
-
baseUrl;
|
|
246
|
-
deviceToken = null;
|
|
247
|
-
deviceId = null;
|
|
248
|
-
gateway = createDefaultGateway();
|
|
249
|
-
/**
|
|
250
|
-
* Create a new CCJKCloudClient instance
|
|
251
|
-
*
|
|
252
|
-
* @param baseUrl - Cloud API base URL (default: https://api.claudehome.cn)
|
|
253
|
-
*/
|
|
254
|
-
constructor(baseUrl = CLOUD_API_BASE_URL) {
|
|
255
|
-
this.baseUrl = baseUrl;
|
|
256
|
-
this.loadToken();
|
|
257
|
-
}
|
|
258
|
-
// ==========================================================================
|
|
259
|
-
// Token Management
|
|
260
|
-
// ==========================================================================
|
|
261
|
-
/**
|
|
262
|
-
* Load token from storage file
|
|
263
|
-
*/
|
|
264
|
-
loadToken() {
|
|
265
|
-
try {
|
|
266
|
-
if (existsSync(TOKEN_FILE_PATH)) {
|
|
267
|
-
const data = readFileSync(TOKEN_FILE_PATH, "utf-8");
|
|
268
|
-
const storage = JSON.parse(data);
|
|
269
|
-
this.deviceToken = storage.deviceToken;
|
|
270
|
-
this.deviceId = storage.deviceId || null;
|
|
271
|
-
}
|
|
272
|
-
} catch {
|
|
273
|
-
this.deviceToken = null;
|
|
274
|
-
this.deviceId = null;
|
|
275
|
-
}
|
|
276
|
-
}
|
|
277
|
-
/**
|
|
278
|
-
* Save token to storage file
|
|
279
|
-
*/
|
|
280
|
-
saveToken(storage) {
|
|
281
|
-
try {
|
|
282
|
-
const dir = join(homedir(), ".ccjk");
|
|
283
|
-
if (!existsSync(dir)) {
|
|
284
|
-
mkdirSync(dir, { recursive: true });
|
|
285
|
-
}
|
|
286
|
-
writeFileAtomic(TOKEN_FILE_PATH, JSON.stringify(storage, null, 2));
|
|
287
|
-
} catch (error) {
|
|
288
|
-
throw new Error(`Failed to save token: ${error instanceof Error ? error.message : String(error)}`);
|
|
289
|
-
}
|
|
290
|
-
}
|
|
291
|
-
/**
|
|
292
|
-
* Check if device is bound
|
|
293
|
-
*/
|
|
294
|
-
isBound() {
|
|
295
|
-
return this.deviceToken !== null && this.deviceToken.length > 0;
|
|
296
|
-
}
|
|
297
|
-
/**
|
|
298
|
-
* Get current device token
|
|
299
|
-
*/
|
|
300
|
-
getDeviceToken() {
|
|
301
|
-
return this.deviceToken;
|
|
302
|
-
}
|
|
303
|
-
/**
|
|
304
|
-
* Get current device ID
|
|
305
|
-
*/
|
|
306
|
-
getDeviceId() {
|
|
307
|
-
return this.deviceId;
|
|
308
|
-
}
|
|
309
|
-
/**
|
|
310
|
-
* Clear stored token (unbind device)
|
|
311
|
-
*/
|
|
312
|
-
clearToken() {
|
|
313
|
-
this.deviceToken = null;
|
|
314
|
-
this.deviceId = null;
|
|
315
|
-
try {
|
|
316
|
-
if (existsSync(TOKEN_FILE_PATH)) {
|
|
317
|
-
unlinkSync(TOKEN_FILE_PATH);
|
|
318
|
-
}
|
|
319
|
-
} catch {
|
|
320
|
-
}
|
|
321
|
-
}
|
|
322
|
-
// ==========================================================================
|
|
323
|
-
// Device Binding
|
|
324
|
-
// ==========================================================================
|
|
325
|
-
/**
|
|
326
|
-
* Bind device using a binding code
|
|
327
|
-
*
|
|
328
|
-
* The binding code is obtained from the CCJK mobile app or web dashboard.
|
|
329
|
-
* Once bound, the device can send and receive notifications.
|
|
330
|
-
*
|
|
331
|
-
* @param code - Binding code from mobile app
|
|
332
|
-
* @param deviceInfo - Optional device information (auto-detected if not provided)
|
|
333
|
-
* @returns Bind response with device token
|
|
334
|
-
*
|
|
335
|
-
* @example
|
|
336
|
-
* ```typescript
|
|
337
|
-
* const client = new CCJKCloudClient()
|
|
338
|
-
* const result = await client.bind('ABC123')
|
|
339
|
-
* if (result.success) {
|
|
340
|
-
* console.log('Device bound successfully!')
|
|
341
|
-
* }
|
|
342
|
-
* ```
|
|
343
|
-
*/
|
|
344
|
-
async bind(code, deviceInfo) {
|
|
345
|
-
const info = deviceInfo ? { ...getDeviceInfo(), ...deviceInfo } : getDeviceInfo();
|
|
346
|
-
const requestPayload = {
|
|
347
|
-
code,
|
|
348
|
-
deviceInfo: info
|
|
349
|
-
};
|
|
350
|
-
const requestValidation = validateBindRequest(requestPayload);
|
|
351
|
-
if (!requestValidation.valid) {
|
|
352
|
-
return {
|
|
353
|
-
success: false,
|
|
354
|
-
error: `Invalid bind request: ${requestValidation.errors.join(", ")}`,
|
|
355
|
-
code: "VALIDATION_ERROR"
|
|
356
|
-
};
|
|
357
|
-
}
|
|
358
|
-
const response = await this.gateway.request("notifications.bind", {
|
|
359
|
-
method: "POST",
|
|
360
|
-
body: requestPayload,
|
|
361
|
-
authToken: this.deviceToken || void 0
|
|
362
|
-
});
|
|
363
|
-
const responseValidation = validateBindResponse(response);
|
|
364
|
-
if (!responseValidation.valid) {
|
|
365
|
-
return {
|
|
366
|
-
success: false,
|
|
367
|
-
error: `Invalid bind response: ${responseValidation.errors.join(", ")}`,
|
|
368
|
-
code: "RESPONSE_VALIDATION_ERROR"
|
|
369
|
-
};
|
|
370
|
-
}
|
|
371
|
-
if (response.success && response.data) {
|
|
372
|
-
this.deviceToken = response.data.deviceToken;
|
|
373
|
-
this.deviceId = response.data.deviceId;
|
|
374
|
-
this.gateway.setAuthToken(response.data.deviceToken);
|
|
375
|
-
this.saveToken({
|
|
376
|
-
deviceToken: response.data.deviceToken,
|
|
377
|
-
deviceId: response.data.deviceId,
|
|
378
|
-
bindingCode: code,
|
|
379
|
-
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
380
|
-
deviceInfo: info
|
|
381
|
-
});
|
|
382
|
-
return {
|
|
383
|
-
success: true,
|
|
384
|
-
data: {
|
|
385
|
-
deviceToken: response.data.deviceToken,
|
|
386
|
-
deviceId: response.data.deviceId
|
|
387
|
-
}
|
|
388
|
-
};
|
|
389
|
-
}
|
|
390
|
-
return {
|
|
391
|
-
success: false,
|
|
392
|
-
error: response.error || "Failed to bind device",
|
|
393
|
-
code: response.code
|
|
394
|
-
};
|
|
395
|
-
}
|
|
396
|
-
// ==========================================================================
|
|
397
|
-
// Notification Sending
|
|
398
|
-
// ==========================================================================
|
|
399
|
-
/**
|
|
400
|
-
* Send a notification to the user
|
|
401
|
-
*
|
|
402
|
-
* @param options - Notification options
|
|
403
|
-
* @returns Notification response
|
|
404
|
-
*
|
|
405
|
-
* @example
|
|
406
|
-
* ```typescript
|
|
407
|
-
* const client = new CCJKCloudClient()
|
|
408
|
-
* await client.notify({
|
|
409
|
-
* title: 'Build Complete',
|
|
410
|
-
* body: 'Your project has been built successfully!',
|
|
411
|
-
* type: 'success'
|
|
412
|
-
* })
|
|
413
|
-
* ```
|
|
414
|
-
*/
|
|
415
|
-
async notify(options) {
|
|
416
|
-
if (!this.deviceToken) {
|
|
417
|
-
return {
|
|
418
|
-
success: false,
|
|
419
|
-
error: 'Device not bound. Please run "ccjk notification bind <code>" first.',
|
|
420
|
-
code: "NOT_BOUND"
|
|
421
|
-
};
|
|
422
|
-
}
|
|
423
|
-
const requestPayload = {
|
|
424
|
-
title: options.title,
|
|
425
|
-
body: options.body,
|
|
426
|
-
type: options.type || "info",
|
|
427
|
-
taskId: options.taskId,
|
|
428
|
-
metadata: options.metadata,
|
|
429
|
-
actions: options.actions
|
|
430
|
-
};
|
|
431
|
-
const requestValidation = validateNotifyRequest(requestPayload);
|
|
432
|
-
if (!requestValidation.valid) {
|
|
433
|
-
return {
|
|
434
|
-
success: false,
|
|
435
|
-
error: `Invalid notify request: ${requestValidation.errors.join(", ")}`,
|
|
436
|
-
code: "VALIDATION_ERROR"
|
|
437
|
-
};
|
|
438
|
-
}
|
|
439
|
-
const response = await this.gateway.request("notifications.send", {
|
|
440
|
-
method: "POST",
|
|
441
|
-
body: requestPayload,
|
|
442
|
-
authToken: this.deviceToken
|
|
443
|
-
});
|
|
444
|
-
const responseValidation = validateNotifyResponse(response);
|
|
445
|
-
if (!responseValidation.valid) {
|
|
446
|
-
return {
|
|
447
|
-
success: false,
|
|
448
|
-
error: `Invalid notify response: ${responseValidation.errors.join(", ")}`,
|
|
449
|
-
code: "RESPONSE_VALIDATION_ERROR"
|
|
450
|
-
};
|
|
451
|
-
}
|
|
452
|
-
if (response.success && response.data) {
|
|
453
|
-
return {
|
|
454
|
-
success: true,
|
|
455
|
-
data: {
|
|
456
|
-
notificationId: response.data.notificationId
|
|
457
|
-
}
|
|
458
|
-
};
|
|
459
|
-
}
|
|
460
|
-
return {
|
|
461
|
-
success: false,
|
|
462
|
-
error: response.error || "Failed to send notification",
|
|
463
|
-
code: response.code
|
|
464
|
-
};
|
|
465
|
-
}
|
|
466
|
-
// ==========================================================================
|
|
467
|
-
// Reply Polling
|
|
468
|
-
// ==========================================================================
|
|
469
|
-
/**
|
|
470
|
-
* Wait for a reply from the user
|
|
471
|
-
*
|
|
472
|
-
* Uses long-polling to wait for a user reply. The timeout parameter
|
|
473
|
-
* controls how long to wait before returning null.
|
|
474
|
-
*
|
|
475
|
-
* @param timeout - Timeout in milliseconds (default: 30000)
|
|
476
|
-
* @returns User reply or null if timeout
|
|
477
|
-
*
|
|
478
|
-
* @example
|
|
479
|
-
* ```typescript
|
|
480
|
-
* const client = new CCJKCloudClient()
|
|
481
|
-
* const reply = await client.waitForReply(60000) // Wait up to 60 seconds
|
|
482
|
-
* if (reply) {
|
|
483
|
-
* console.log('User replied:', reply.content)
|
|
484
|
-
* }
|
|
485
|
-
* ```
|
|
486
|
-
*/
|
|
487
|
-
async waitForReply(timeout = POLL_TIMEOUT) {
|
|
488
|
-
if (!this.deviceToken) {
|
|
489
|
-
throw new Error('Device not bound. Please run "ccjk notification bind <code>" first.');
|
|
490
|
-
}
|
|
491
|
-
const response = await this.gateway.request("notifications.poll", {
|
|
492
|
-
method: "GET",
|
|
493
|
-
query: { timeout },
|
|
494
|
-
authToken: this.deviceToken,
|
|
495
|
-
timeout
|
|
496
|
-
});
|
|
497
|
-
const responseValidation = validatePollResponse(response);
|
|
498
|
-
if (!responseValidation.valid) {
|
|
499
|
-
throw new Error(`Invalid poll response: ${responseValidation.errors.join(", ")}`);
|
|
500
|
-
}
|
|
501
|
-
if (!response.success) {
|
|
502
|
-
throw new Error(response.error || "Failed to poll for reply");
|
|
503
|
-
}
|
|
504
|
-
if (response.data?.reply) {
|
|
505
|
-
return {
|
|
506
|
-
content: response.data.reply.content,
|
|
507
|
-
timestamp: new Date(response.data.reply.timestamp),
|
|
508
|
-
notificationId: response.data.reply.notificationId,
|
|
509
|
-
actionId: response.data.reply.actionId
|
|
510
|
-
};
|
|
511
|
-
}
|
|
512
|
-
return null;
|
|
513
|
-
}
|
|
514
|
-
// ==========================================================================
|
|
515
|
-
// Ask and Wait
|
|
516
|
-
// ==========================================================================
|
|
517
|
-
/**
|
|
518
|
-
* Ask the user a question and wait for their reply
|
|
519
|
-
*
|
|
520
|
-
* This is a convenience method that combines notify() and waitForReply().
|
|
521
|
-
* It sends a notification with the question and waits for the user to respond.
|
|
522
|
-
*
|
|
523
|
-
* @param question - Question to ask the user
|
|
524
|
-
* @param options - Additional notification options
|
|
525
|
-
* @param timeout - Timeout in milliseconds (default: 60000)
|
|
526
|
-
* @returns User reply
|
|
527
|
-
*
|
|
528
|
-
* @example
|
|
529
|
-
* ```typescript
|
|
530
|
-
* const client = new CCJKCloudClient()
|
|
531
|
-
* const reply = await client.ask('Deploy to production?', {
|
|
532
|
-
* actions: [
|
|
533
|
-
* { id: 'yes', label: 'Yes', value: 'yes' },
|
|
534
|
-
* { id: 'no', label: 'No', value: 'no' }
|
|
535
|
-
* ]
|
|
536
|
-
* })
|
|
537
|
-
* if (reply.actionId === 'yes') {
|
|
538
|
-
* // Proceed with deployment
|
|
539
|
-
* }
|
|
540
|
-
* ```
|
|
541
|
-
*/
|
|
542
|
-
async ask(question, options, timeout = POLL_TIMEOUT) {
|
|
543
|
-
const notifyResult = await this.notify({
|
|
544
|
-
title: options?.title || "CCJK Question",
|
|
545
|
-
body: question,
|
|
546
|
-
type: "info",
|
|
547
|
-
...options
|
|
548
|
-
});
|
|
549
|
-
if (!notifyResult.success) {
|
|
550
|
-
throw new Error(notifyResult.error || "Failed to send question");
|
|
551
|
-
}
|
|
552
|
-
const reply = await this.waitForReply(timeout);
|
|
553
|
-
if (!reply) {
|
|
554
|
-
throw new Error("No reply received within timeout");
|
|
555
|
-
}
|
|
556
|
-
return reply;
|
|
557
|
-
}
|
|
558
|
-
// ==========================================================================
|
|
559
|
-
// Status Check
|
|
560
|
-
// ==========================================================================
|
|
561
|
-
/**
|
|
562
|
-
* Get binding status and device information
|
|
563
|
-
*
|
|
564
|
-
* @returns Binding status information
|
|
565
|
-
*/
|
|
566
|
-
async getStatus() {
|
|
567
|
-
if (!this.deviceToken) {
|
|
568
|
-
return { bound: false };
|
|
569
|
-
}
|
|
570
|
-
try {
|
|
571
|
-
if (existsSync(TOKEN_FILE_PATH)) {
|
|
572
|
-
const data = readFileSync(TOKEN_FILE_PATH, "utf-8");
|
|
573
|
-
const storage = JSON.parse(data);
|
|
574
|
-
return {
|
|
575
|
-
bound: true,
|
|
576
|
-
deviceId: storage.deviceId,
|
|
577
|
-
deviceInfo: storage.deviceInfo,
|
|
578
|
-
lastUsed: storage.lastUsedAt
|
|
579
|
-
};
|
|
580
|
-
}
|
|
581
|
-
} catch {
|
|
582
|
-
}
|
|
583
|
-
return {
|
|
584
|
-
bound: true,
|
|
585
|
-
deviceId: this.deviceId || void 0
|
|
586
|
-
};
|
|
587
|
-
}
|
|
588
|
-
// Note: HTTP requests now handled by CloudApiGateway
|
|
589
|
-
}
|
|
590
|
-
let cloudClientInstance = null;
|
|
591
|
-
function getCloudNotificationClient() {
|
|
592
|
-
if (!cloudClientInstance) {
|
|
593
|
-
cloudClientInstance = new CCJKCloudClient();
|
|
594
|
-
}
|
|
595
|
-
return cloudClientInstance;
|
|
596
|
-
}
|
|
597
|
-
async function bindDevice(code, deviceInfo) {
|
|
598
|
-
const client = getCloudNotificationClient();
|
|
599
|
-
return client.bind(code, deviceInfo);
|
|
600
|
-
}
|
|
601
|
-
async function sendNotification(options) {
|
|
602
|
-
const client = getCloudNotificationClient();
|
|
603
|
-
return client.notify(options);
|
|
604
|
-
}
|
|
605
|
-
function isDeviceBound() {
|
|
606
|
-
const client = getCloudNotificationClient();
|
|
607
|
-
return client.isBound();
|
|
608
|
-
}
|
|
609
|
-
async function getBindingStatus() {
|
|
610
|
-
const client = getCloudNotificationClient();
|
|
611
|
-
return client.getStatus();
|
|
612
|
-
}
|
|
613
|
-
function unbindDevice() {
|
|
614
|
-
const client = getCloudNotificationClient();
|
|
615
|
-
client.clearToken();
|
|
616
|
-
}
|
|
617
|
-
|
|
618
|
-
export { isValidTokenFormat as a, bindDevice as b, generateDeviceToken as c, decryptToken as d, encryptToken as e, getDeviceInfo as f, getBindingStatus as g, isDeviceBound as i, maskToken as m, sendNotification as s, unbindDevice as u };
|