@newpeak/barista-cli 0.1.11 → 0.1.13

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.
Files changed (329) hide show
  1. package/dist/commands/liberica/dict-types/get.d.ts.map +1 -1
  2. package/dist/commands/liberica/dict-types/get.js +9 -1
  3. package/dist/commands/liberica/dict-types/get.js.map +1 -1
  4. package/dist/commands/liberica/dict-types/index.d.ts.map +1 -1
  5. package/dist/commands/liberica/dict-types/index.js +2 -0
  6. package/dist/commands/liberica/dict-types/index.js.map +1 -1
  7. package/dist/commands/liberica/dict-types/list.d.ts.map +1 -1
  8. package/dist/commands/liberica/dict-types/list.js +19 -1
  9. package/dist/commands/liberica/dict-types/list.js.map +1 -1
  10. package/dist/commands/liberica/dict-types/tenant-items.d.ts +3 -0
  11. package/dist/commands/liberica/dict-types/tenant-items.d.ts.map +1 -0
  12. package/dist/commands/liberica/dict-types/tenant-items.js +275 -0
  13. package/dist/commands/liberica/dict-types/tenant-items.js.map +1 -0
  14. package/dist/commands/liberica/dicts/get.d.ts.map +1 -1
  15. package/dist/commands/liberica/dicts/get.js +9 -1
  16. package/dist/commands/liberica/dicts/get.js.map +1 -1
  17. package/dist/commands/liberica/dicts/list.d.ts.map +1 -1
  18. package/dist/commands/liberica/dicts/list.js +9 -1
  19. package/dist/commands/liberica/dicts/list.js.map +1 -1
  20. package/dist/core/api/client.d.ts +7 -7
  21. package/dist/core/api/client.d.ts.map +1 -1
  22. package/dist/core/api/client.js +15 -12
  23. package/dist/core/api/client.js.map +1 -1
  24. package/dist/core/config/manager.d.ts.map +1 -1
  25. package/dist/core/config/manager.js +1 -0
  26. package/dist/core/config/manager.js.map +1 -1
  27. package/dist/index.js +1 -1
  28. package/dist/types/dict.d.ts +2 -0
  29. package/dist/types/dict.d.ts.map +1 -1
  30. package/dist/types/index.d.ts +2 -0
  31. package/dist/types/index.d.ts.map +1 -1
  32. package/dist/types/index.js.map +1 -1
  33. package/package.json +7 -3
  34. package/docs/ARCHITECTURE.md +0 -184
  35. package/docs/COMMANDS.md +0 -352
  36. package/docs/COMMAND_DESIGN_SPEC.md +0 -840
  37. package/docs/INTEGRATION_NOTES.md +0 -270
  38. package/docs/commands/REFERENCE.md +0 -323
  39. package/docs/commands/arabica/auth/index.md +0 -296
  40. package/docs/commands/liberica/auth/index.md +0 -133
  41. package/docs/commands/liberica/calendar/DESIGN.md +0 -333
  42. package/docs/commands/liberica/client-contacts/create.md +0 -152
  43. package/docs/commands/liberica/client-contacts/delete.md +0 -123
  44. package/docs/commands/liberica/client-contacts/get.md +0 -133
  45. package/docs/commands/liberica/client-contacts/list.md +0 -143
  46. package/docs/commands/liberica/client-contacts/update.md +0 -158
  47. package/docs/commands/liberica/context/index.md +0 -60
  48. package/docs/commands/liberica/currency/create.md +0 -145
  49. package/docs/commands/liberica/currency/delete.md +0 -121
  50. package/docs/commands/liberica/currency/disable.md +0 -119
  51. package/docs/commands/liberica/currency/enable.md +0 -115
  52. package/docs/commands/liberica/currency/get.md +0 -118
  53. package/docs/commands/liberica/currency/list.md +0 -149
  54. package/docs/commands/liberica/currency/update.md +0 -141
  55. package/docs/commands/liberica/employees/create.md +0 -185
  56. package/docs/commands/liberica/employees/disable.md +0 -138
  57. package/docs/commands/liberica/employees/enable.md +0 -137
  58. package/docs/commands/liberica/employees/get.md +0 -153
  59. package/docs/commands/liberica/employees/list.md +0 -168
  60. package/docs/commands/liberica/employees/update.md +0 -180
  61. package/docs/commands/liberica/locations/create.md +0 -195
  62. package/docs/commands/liberica/locations/list.md +0 -171
  63. package/docs/commands/liberica/materials/create.md +0 -293
  64. package/docs/commands/liberica/materials/delete.md +0 -240
  65. package/docs/commands/liberica/materials/disable.md +0 -150
  66. package/docs/commands/liberica/materials/enable.md +0 -146
  67. package/docs/commands/liberica/materials/get.md +0 -188
  68. package/docs/commands/liberica/materials/list.md +0 -198
  69. package/docs/commands/liberica/materials/update.md +0 -250
  70. package/docs/commands/liberica/orgs/list.md +0 -62
  71. package/docs/commands/liberica/positions/list.md +0 -61
  72. package/docs/commands/liberica/roles/list.md +0 -67
  73. package/docs/commands/liberica/stock/ledger.md +0 -209
  74. package/docs/commands/liberica/stock/list.md +0 -165
  75. package/docs/commands/liberica/supplier-contacts/create.md +0 -152
  76. package/docs/commands/liberica/supplier-contacts/delete.md +0 -123
  77. package/docs/commands/liberica/supplier-contacts/get.md +0 -133
  78. package/docs/commands/liberica/supplier-contacts/list.md +0 -143
  79. package/docs/commands/liberica/supplier-contacts/update.md +0 -158
  80. package/docs/commands/liberica/teams/issues/close.md +0 -161
  81. package/docs/commands/liberica/teams/issues/create.md +0 -212
  82. package/docs/commands/liberica/teams/issues/delete.md +0 -179
  83. package/docs/commands/liberica/teams/issues/get.md +0 -167
  84. package/docs/commands/liberica/teams/issues/list.md +0 -182
  85. package/docs/commands/liberica/teams/issues/tests-design.md +0 -341
  86. package/docs/commands/liberica/teams/issues/update.md +0 -202
  87. package/docs/commands/liberica/teams/projects/create.md +0 -174
  88. package/docs/commands/liberica/teams/projects/delete.md +0 -180
  89. package/docs/commands/liberica/teams/projects/get.md +0 -150
  90. package/docs/commands/liberica/teams/projects/list.md +0 -179
  91. package/docs/commands/liberica/teams/projects/update.md +0 -175
  92. package/docs/commands/liberica/teams/tasks/create.md +0 -163
  93. package/docs/commands/liberica/teams/tasks/delete.md +0 -109
  94. package/docs/commands/liberica/teams/tasks/get.md +0 -121
  95. package/docs/commands/liberica/teams/tasks/list.md +0 -148
  96. package/docs/commands/liberica/teams/tasks/update.md +0 -158
  97. package/docs/commands/liberica/teams/work-logs/create.md +0 -151
  98. package/docs/commands/liberica/teams/work-logs/delete.md +0 -130
  99. package/docs/commands/liberica/teams/work-logs/get.md +0 -131
  100. package/docs/commands/liberica/teams/work-logs/list.md +0 -153
  101. package/docs/commands/liberica/teams/work-logs/update.md +0 -150
  102. package/docs/commands/liberica/transfer-in-forms/batch-delete.md +0 -157
  103. package/docs/commands/liberica/transfer-in-forms/batch-review.md +0 -157
  104. package/docs/commands/liberica/transfer-in-forms/batch-unreview.md +0 -157
  105. package/docs/commands/liberica/transfer-in-forms/create.md +0 -220
  106. package/docs/commands/liberica/transfer-in-forms/get.md +0 -221
  107. package/docs/commands/liberica/transfer-in-forms/list.md +0 -242
  108. package/docs/commands/liberica/transfer-in-forms/update.md +0 -185
  109. package/docs/commands/liberica/transfer-out-forms/batch-delete.md +0 -187
  110. package/docs/commands/liberica/transfer-out-forms/batch-review.md +0 -157
  111. package/docs/commands/liberica/transfer-out-forms/batch-unreview.md +0 -157
  112. package/docs/commands/liberica/transfer-out-forms/create.md +0 -280
  113. package/docs/commands/liberica/transfer-out-forms/get.md +0 -211
  114. package/docs/commands/liberica/transfer-out-forms/list.md +0 -233
  115. package/docs/commands/liberica/transfer-out-forms/update.md +0 -286
  116. package/docs/commands/liberica/uoms/create.md +0 -136
  117. package/docs/commands/liberica/uoms/delete.md +0 -119
  118. package/docs/commands/liberica/uoms/disable.md +0 -117
  119. package/docs/commands/liberica/uoms/enable.md +0 -115
  120. package/docs/commands/liberica/uoms/get.md +0 -119
  121. package/docs/commands/liberica/uoms/list.md +0 -155
  122. package/docs/commands/liberica/uoms/update.md +0 -148
  123. package/docs/commands/liberica/users/create.md +0 -170
  124. package/docs/commands/liberica/users/get.md +0 -151
  125. package/docs/commands/liberica/users/list.md +0 -175
  126. package/docs/commands/liberica/warehouses/create.md +0 -222
  127. package/docs/commands/liberica/warehouses/list.md +0 -184
  128. package/src/commands/arabica/auth/index.ts +0 -277
  129. package/src/commands/arabica/auth/login.ts +0 -5
  130. package/src/commands/arabica/auth/logout.ts +0 -5
  131. package/src/commands/arabica/auth/register.ts +0 -5
  132. package/src/commands/arabica/auth/status.ts +0 -5
  133. package/src/commands/arabica/index.ts +0 -23
  134. package/src/commands/auth.ts +0 -107
  135. package/src/commands/context.ts +0 -60
  136. package/src/commands/liberica/auth/index.ts +0 -176
  137. package/src/commands/liberica/calendar/index.ts +0 -13
  138. package/src/commands/liberica/calendar/list.ts +0 -214
  139. package/src/commands/liberica/calendar/set.ts +0 -130
  140. package/src/commands/liberica/client-contacts/create.ts +0 -115
  141. package/src/commands/liberica/client-contacts/delete.ts +0 -140
  142. package/src/commands/liberica/client-contacts/get.ts +0 -103
  143. package/src/commands/liberica/client-contacts/index.ts +0 -19
  144. package/src/commands/liberica/client-contacts/list.ts +0 -118
  145. package/src/commands/liberica/client-contacts/update.ts +0 -137
  146. package/src/commands/liberica/clients/create.ts +0 -122
  147. package/src/commands/liberica/clients/delete.ts +0 -125
  148. package/src/commands/liberica/clients/get.ts +0 -88
  149. package/src/commands/liberica/clients/index.ts +0 -19
  150. package/src/commands/liberica/clients/list.ts +0 -123
  151. package/src/commands/liberica/clients/update.ts +0 -103
  152. package/src/commands/liberica/context/index.ts +0 -43
  153. package/src/commands/liberica/currency/create.ts +0 -183
  154. package/src/commands/liberica/currency/delete.ts +0 -124
  155. package/src/commands/liberica/currency/disable.ts +0 -147
  156. package/src/commands/liberica/currency/enable.ts +0 -128
  157. package/src/commands/liberica/currency/get.ts +0 -91
  158. package/src/commands/liberica/currency/index.ts +0 -23
  159. package/src/commands/liberica/currency/list.ts +0 -140
  160. package/src/commands/liberica/currency/update.ts +0 -129
  161. package/src/commands/liberica/dict-types/get.ts +0 -74
  162. package/src/commands/liberica/dict-types/index.ts +0 -15
  163. package/src/commands/liberica/dict-types/list.ts +0 -118
  164. package/src/commands/liberica/dict-types/update.ts +0 -134
  165. package/src/commands/liberica/dicts/create.ts +0 -175
  166. package/src/commands/liberica/dicts/delete.ts +0 -107
  167. package/src/commands/liberica/dicts/get.ts +0 -80
  168. package/src/commands/liberica/dicts/index.ts +0 -19
  169. package/src/commands/liberica/dicts/list.ts +0 -114
  170. package/src/commands/liberica/dicts/update.ts +0 -116
  171. package/src/commands/liberica/employees/create.ts +0 -275
  172. package/src/commands/liberica/employees/delete.ts +0 -122
  173. package/src/commands/liberica/employees/disable.ts +0 -97
  174. package/src/commands/liberica/employees/enable.ts +0 -97
  175. package/src/commands/liberica/employees/get.ts +0 -115
  176. package/src/commands/liberica/employees/index.ts +0 -23
  177. package/src/commands/liberica/employees/list.ts +0 -131
  178. package/src/commands/liberica/employees/update.ts +0 -157
  179. package/src/commands/liberica/index.ts +0 -81
  180. package/src/commands/liberica/materials/create.ts +0 -199
  181. package/src/commands/liberica/materials/delete.ts +0 -105
  182. package/src/commands/liberica/materials/disable.ts +0 -148
  183. package/src/commands/liberica/materials/enable.ts +0 -129
  184. package/src/commands/liberica/materials/get.ts +0 -83
  185. package/src/commands/liberica/materials/index.ts +0 -23
  186. package/src/commands/liberica/materials/list.ts +0 -142
  187. package/src/commands/liberica/materials/update.ts +0 -125
  188. package/src/commands/liberica/mould/get.ts +0 -111
  189. package/src/commands/liberica/mould/index.ts +0 -17
  190. package/src/commands/liberica/mould/list.ts +0 -157
  191. package/src/commands/liberica/mould/set-status.ts +0 -99
  192. package/src/commands/liberica/mould/stock-in.ts +0 -165
  193. package/src/commands/liberica/operations/active.ts +0 -153
  194. package/src/commands/liberica/operations/batch-delete.ts +0 -131
  195. package/src/commands/liberica/operations/copy.ts +0 -138
  196. package/src/commands/liberica/operations/create.ts +0 -223
  197. package/src/commands/liberica/operations/deactive.ts +0 -152
  198. package/src/commands/liberica/operations/delete.ts +0 -128
  199. package/src/commands/liberica/operations/design.md +0 -587
  200. package/src/commands/liberica/operations/get.ts +0 -112
  201. package/src/commands/liberica/operations/index.ts +0 -27
  202. package/src/commands/liberica/operations/list.ts +0 -180
  203. package/src/commands/liberica/operations/update.ts +0 -218
  204. package/src/commands/liberica/orgs/index.ts +0 -34
  205. package/src/commands/liberica/positions/index.ts +0 -30
  206. package/src/commands/liberica/roles/index.ts +0 -59
  207. package/src/commands/liberica/stock/index.ts +0 -13
  208. package/src/commands/liberica/stock/ledger.ts +0 -159
  209. package/src/commands/liberica/stock/list.ts +0 -128
  210. package/src/commands/liberica/supplier-contacts/create.ts +0 -120
  211. package/src/commands/liberica/supplier-contacts/delete.ts +0 -88
  212. package/src/commands/liberica/supplier-contacts/get.ts +0 -94
  213. package/src/commands/liberica/supplier-contacts/index.ts +0 -19
  214. package/src/commands/liberica/supplier-contacts/list.ts +0 -130
  215. package/src/commands/liberica/supplier-contacts/update.ts +0 -127
  216. package/src/commands/liberica/suppliers/create.ts +0 -149
  217. package/src/commands/liberica/suppliers/delete.ts +0 -102
  218. package/src/commands/liberica/suppliers/disable.ts +0 -145
  219. package/src/commands/liberica/suppliers/enable.ts +0 -126
  220. package/src/commands/liberica/suppliers/get.ts +0 -86
  221. package/src/commands/liberica/suppliers/index.ts +0 -23
  222. package/src/commands/liberica/suppliers/list.ts +0 -134
  223. package/src/commands/liberica/suppliers/update.ts +0 -128
  224. package/src/commands/liberica/teams/index.ts +0 -17
  225. package/src/commands/liberica/teams/issues/close.ts +0 -104
  226. package/src/commands/liberica/teams/issues/create.ts +0 -254
  227. package/src/commands/liberica/teams/issues/delete.ts +0 -58
  228. package/src/commands/liberica/teams/issues/get.ts +0 -78
  229. package/src/commands/liberica/teams/issues/index.ts +0 -21
  230. package/src/commands/liberica/teams/issues/list.ts +0 -144
  231. package/src/commands/liberica/teams/issues/update.ts +0 -141
  232. package/src/commands/liberica/teams/projects/create.ts +0 -159
  233. package/src/commands/liberica/teams/projects/delete.ts +0 -58
  234. package/src/commands/liberica/teams/projects/get.ts +0 -87
  235. package/src/commands/liberica/teams/projects/index.ts +0 -19
  236. package/src/commands/liberica/teams/projects/list.ts +0 -147
  237. package/src/commands/liberica/teams/projects/update.ts +0 -117
  238. package/src/commands/liberica/teams/tasks/create.ts +0 -102
  239. package/src/commands/liberica/teams/tasks/delete.ts +0 -92
  240. package/src/commands/liberica/teams/tasks/get.ts +0 -64
  241. package/src/commands/liberica/teams/tasks/index.ts +0 -19
  242. package/src/commands/liberica/teams/tasks/list.ts +0 -102
  243. package/src/commands/liberica/teams/tasks/update.ts +0 -122
  244. package/src/commands/liberica/teams/work-logs/create.ts +0 -204
  245. package/src/commands/liberica/teams/work-logs/delete.ts +0 -58
  246. package/src/commands/liberica/teams/work-logs/get.ts +0 -87
  247. package/src/commands/liberica/teams/work-logs/index.ts +0 -19
  248. package/src/commands/liberica/teams/work-logs/list.ts +0 -141
  249. package/src/commands/liberica/teams/work-logs/update.ts +0 -120
  250. package/src/commands/liberica/transfer-in-forms/batch-delete.ts +0 -152
  251. package/src/commands/liberica/transfer-in-forms/batch-review.ts +0 -151
  252. package/src/commands/liberica/transfer-in-forms/batch-unreview.ts +0 -152
  253. package/src/commands/liberica/transfer-in-forms/create.ts +0 -179
  254. package/src/commands/liberica/transfer-in-forms/get.ts +0 -107
  255. package/src/commands/liberica/transfer-in-forms/index.ts +0 -23
  256. package/src/commands/liberica/transfer-in-forms/list.ts +0 -97
  257. package/src/commands/liberica/transfer-in-forms/update.ts +0 -213
  258. package/src/commands/liberica/transfer-out-forms/batch-delete.ts +0 -83
  259. package/src/commands/liberica/transfer-out-forms/batch-review.ts +0 -148
  260. package/src/commands/liberica/transfer-out-forms/batch-unreview.ts +0 -56
  261. package/src/commands/liberica/transfer-out-forms/create.ts +0 -194
  262. package/src/commands/liberica/transfer-out-forms/get.ts +0 -114
  263. package/src/commands/liberica/transfer-out-forms/index.ts +0 -23
  264. package/src/commands/liberica/transfer-out-forms/list.ts +0 -125
  265. package/src/commands/liberica/transfer-out-forms/update.ts +0 -197
  266. package/src/commands/liberica/uoms/create.ts +0 -134
  267. package/src/commands/liberica/uoms/delete.ts +0 -105
  268. package/src/commands/liberica/uoms/disable.ts +0 -148
  269. package/src/commands/liberica/uoms/enable.ts +0 -129
  270. package/src/commands/liberica/uoms/get.ts +0 -83
  271. package/src/commands/liberica/uoms/index.ts +0 -23
  272. package/src/commands/liberica/uoms/list.ts +0 -129
  273. package/src/commands/liberica/uoms/update.ts +0 -124
  274. package/src/commands/liberica/users/create.ts +0 -133
  275. package/src/commands/liberica/users/delete.ts +0 -49
  276. package/src/commands/liberica/users/disable.ts +0 -41
  277. package/src/commands/liberica/users/enable.ts +0 -30
  278. package/src/commands/liberica/users/get.ts +0 -46
  279. package/src/commands/liberica/users/index.ts +0 -27
  280. package/src/commands/liberica/users/list.ts +0 -68
  281. package/src/commands/liberica/users/me.ts +0 -42
  282. package/src/commands/liberica/users/reset-password.ts +0 -42
  283. package/src/commands/liberica/users/update.ts +0 -48
  284. package/src/commands/liberica/warehouses/create.ts +0 -204
  285. package/src/commands/liberica/warehouses/delete.ts +0 -112
  286. package/src/commands/liberica/warehouses/disable.ts +0 -174
  287. package/src/commands/liberica/warehouses/enable.ts +0 -174
  288. package/src/commands/liberica/warehouses/get.ts +0 -101
  289. package/src/commands/liberica/warehouses/index.ts +0 -25
  290. package/src/commands/liberica/warehouses/list.ts +0 -136
  291. package/src/commands/liberica/warehouses/locations/create.ts +0 -209
  292. package/src/commands/liberica/warehouses/locations/delete.ts +0 -116
  293. package/src/commands/liberica/warehouses/locations/disable.ts +0 -174
  294. package/src/commands/liberica/warehouses/locations/enable.ts +0 -174
  295. package/src/commands/liberica/warehouses/locations/get.ts +0 -84
  296. package/src/commands/liberica/warehouses/locations/index.ts +0 -23
  297. package/src/commands/liberica/warehouses/locations/list.ts +0 -140
  298. package/src/commands/liberica/warehouses/locations/update.ts +0 -135
  299. package/src/commands/liberica/warehouses/update.ts +0 -142
  300. package/src/core/api/client.ts +0 -4443
  301. package/src/core/auth/token-manager.ts +0 -183
  302. package/src/core/config/manager.ts +0 -164
  303. package/src/index.ts +0 -35
  304. package/src/types/calendar.ts +0 -36
  305. package/src/types/client-contact.ts +0 -78
  306. package/src/types/client.ts +0 -115
  307. package/src/types/currency.ts +0 -90
  308. package/src/types/dict.ts +0 -121
  309. package/src/types/employee.ts +0 -102
  310. package/src/types/index.ts +0 -93
  311. package/src/types/location.ts +0 -66
  312. package/src/types/material.ts +0 -61
  313. package/src/types/mould-stock-in.ts +0 -82
  314. package/src/types/mould.ts +0 -74
  315. package/src/types/operation.ts +0 -72
  316. package/src/types/org.ts +0 -25
  317. package/src/types/position.ts +0 -24
  318. package/src/types/stock.ts +0 -161
  319. package/src/types/supplier-contact.ts +0 -78
  320. package/src/types/supplier.ts +0 -66
  321. package/src/types/team-issue.ts +0 -94
  322. package/src/types/team-project.ts +0 -74
  323. package/src/types/team-task.ts +0 -98
  324. package/src/types/team-work-log.ts +0 -87
  325. package/src/types/transfer-in-form.ts +0 -265
  326. package/src/types/transfer-out-form.ts +0 -290
  327. package/src/types/uom.ts +0 -60
  328. package/src/types/user.ts +0 -64
  329. package/src/types/warehouse.ts +0 -82
@@ -1,840 +0,0 @@
1
- # Barista CLI 命令设计规范
2
-
3
- ## 1. 文档目的
4
-
5
- 本规范定义 Barista CLI 每个命令的设计文档格式。每个命令在开发前必须按此模板编写设计文档,明确引用后端代码位置。
6
-
7
- ---
8
-
9
- ## 2. 命令设计文档模板
10
-
11
- 每个命令设计文档必须包含以下章节:
12
-
13
- ```markdown
14
- # 命令名称: barista <service> <resource> <action>
15
-
16
- ## 2.1 命令元数据
17
-
18
- | 字段 | 值 |
19
- |------|-----|
20
- | 完整命令 | `barista liberica orders create` |
21
- | 功能描述 | 创建销售订单 |
22
- | HTTP方法 | POST |
23
- | 是否需要认证 | ✅ 是 / ⬜ 否 |
24
- | 是否支持dry-run | ✅ 是 / ⬜ 否 |
25
-
26
- ## 2.2 后端接口引用
27
-
28
- ### Controller位置
29
- ```
30
- <coffee-liberica-end 或 coffee-arabica-end 相对路径>
31
- └── <Controller类全路径>
32
- └── <方法名>(@<MethodResource>)
33
- └── 方法签名
34
- ```
35
-
36
- **实际示例:**
37
- ```
38
- coffee-liberica-end/
39
- └── facade/liberica-facade-enterprise/
40
- └── src/main/java/com/newpeak/liberica/facade/enterprise/controller/sales/
41
- └── EnterpriseSalesOrderController.java
42
- └── add(@PostResource(path = "/add"))
43
- └── public ResponseData<SalesOrderResponse> add(
44
- @RequestHeader("X-TENANT-ID") Long tenantId,
45
- @RequestBody @Validated(BaseRequest.add.class) SalesOrderRequest request
46
- )
47
- ```
48
-
49
- ### Request DTO位置
50
- ```
51
- <模块>/src/main/java/<包路径>/
52
- └── <Request类名>.java
53
- └── 核心字段(列出CLI会用到的)
54
- ```
55
-
56
- **实际示例:**
57
- ```
58
- coffee-liberica-end/
59
- └── business/liberica-business-sales/sales-api/
60
- └── src/main/java/com/newpeak/liberica/sales/api/pojo/request/
61
- └── SalesOrderRequest.java
62
- ├── clientCode: String (@NotBlank)
63
- ├── clientName: String (@NotBlank)
64
- ├── materialNo: String
65
- ├── materialName: String
66
- ├── purchaseNumber: BigDecimal
67
- ├── deliveryDate: Date
68
- └── salesOrderStatus: String
69
- ```
70
-
71
- ### Response DTO位置
72
- ```
73
- <模块>/src/main/java/<包路径>/
74
- └── <Response类名>.java
75
- └── 核心字段(列出CLI会返回的)
76
- ```
77
-
78
- **实际示例:**
79
- ```
80
- coffee-liberica-end/
81
- └── business/liberica-business-sales/sales-api/
82
- └── src/main/java/com/newpeak/liberica/sales/api/pojo/response/
83
- └── SalesOrderResponse.java
84
- ├── salesOrderId: Long
85
- ├── salesOrderCode: String
86
- ├── clientName: String
87
- ├── materialName: String
88
- └── salesOrderStatus: String
89
- ```
90
-
91
- ## 2.3 CLI参数设计
92
-
93
- ### 命令结构
94
- ```bash
95
- barista <service> <resource> <action> [全局选项] [命令选项]
96
- ```
97
-
98
- ### 全局选项
99
- | 选项 | 类型 | 说明 |
100
- |------|------|------|
101
- | `--env` | string | 目标环境(dev/test/prod-cn/prod-jp) |
102
- | `--tenant` | string | 租户代码(仅Liberica) |
103
- | `--dry-run` | boolean | 预览模式 |
104
- | `--json` | boolean | JSON输出 |
105
-
106
- ### 命令选项
107
- | 选项 | 短选项 | 类型 | 必填 | 默认值 | 说明 | 对应DTO字段 |
108
- |------|--------|------|------|--------|------|-------------|
109
- | --client-code | -c | string | ✅ | - | 客户编码 | clientCode |
110
- | --client-name | -n | string | ✅ | - | 客户名称 | clientName |
111
- | --product-id | -p | string | ✅ | - | 产品号码 | materialNo |
112
- | --quantity | -q | number | ✅ | - | 订购数量 | purchaseNumber |
113
- | --due-date | -d | string | ⬜ | - | 交货日期(YYYY-MM-DD) | deliveryDate |
114
- | --status | -s | string | ⬜ | pending | 订单状态 | salesOrderStatus |
115
- | --remark | -r | string | ⬜ | - | 备注 | remark |
116
-
117
- ### 位置参数与选项参数混合支持
118
-
119
- CLI 命令应同时支持**位置参数**和**选项参数**,允许用户根据习惯灵活调用。
120
-
121
- **命令结构:**
122
- ```bash
123
- barista <service> <resource> <action> [位置参数...] [选项]
124
- ```
125
-
126
- **设计原则:**
127
- 1. 位置参数使用 `Commander.arguments()` 定义
128
- 2. 选项参数使用 `.option()` 定义
129
- 3. Action handler 中位置参数在前,options 对象在后
130
- 4. 解析优先级:**选项参数 > 位置参数 > 默认值**
131
-
132
- **实现示例:**
133
- ```typescript
134
- // 定义命令,同时支持位置参数和选项
135
- program
136
- .command('login')
137
- .arguments('<env> [tenant] [username] [password]')
138
- .option('--env <environment>', 'Environment')
139
- .option('--tenant <tenant>', 'Tenant name')
140
- .option('--username <username>', 'Username')
141
- .option('--password <password>', 'Password')
142
- .action(async (env, tenant, username, password, options) => {
143
- // 解析:选项参数优先,其次位置参数,最后默认值
144
- const resolvedEnv = options.env || env || defaultEnv;
145
- const resolvedTenant = options.tenant || tenant || defaultTenant;
146
- const resolvedUsername = options.username || username;
147
- const resolvedPassword = options.password || password;
148
- });
149
- ```
150
-
151
- **调用方式:**
152
- ```bash
153
- # 全位置参数
154
- barista liberica auth login dev shanghai admin pass
155
-
156
- # 全选项参数
157
- barista liberica auth login --env dev --tenant shanghai --username admin --password pass
158
-
159
- # 混合使用(常见)
160
- barista liberica auth login dev --username admin --password pass
161
-
162
- # 交互式(无参数)
163
- barista liberica auth login
164
- ```
165
-
166
- ## 2.4 字段映射表
167
-
168
- | CLI参数 | DTO字段 | 类型转换 | 验证规则 |
169
- |---------|---------|----------|----------|
170
- | --client-code | clientCode | 直接传递 | @NotBlank, max=255 |
171
- | --client-name | clientName | 直接传递 | @NotBlank, max=255 |
172
- | --product-id | materialNo | 直接传递 | - |
173
- | --quantity | purchaseNumber | string→BigDecimal | @NotNull, >0 |
174
- | --due-date | deliveryDate | string→Date | yyyy-MM-dd |
175
- | --status | salesOrderStatus | 直接传递 | enum验证 |
176
- | --remark | remark | 直接传递 | max=255 |
177
-
178
- ## 2.5 错误码引用
179
-
180
- ### ExceptionEnum位置
181
- ```
182
- <模块>/src/main/java/<包路径>/exception/enums/
183
- └── <ExceptionEnum>.java
184
- ```
185
-
186
- **实际示例:**
187
- ```
188
- coffee-liberica-end/
189
- └── business/liberica-business-sales/sales-api/
190
- └── src/main/java/com/newpeak/liberica/sales/api/exception/enums/
191
- └── SalesOrderExceptionEnum.java
192
- ├── SALES_ORDER_NOT_EXIST("xxx", "销售订单不存在")
193
- ├── SALES_ORDER_CODE_DUPLICATE("xxx", "销售订单编码重复")
194
- └── ...
195
- ```
196
-
197
- ### Service层业务校验
198
- ```
199
- <模块>/src/main/java/<包路径>/business/
200
- └── <Business类>.java
201
- └── <方法名>()
202
- └── 抛出异常的具体位置(行号或代码片段)
203
- ```
204
-
205
- **实际示例:**
206
- ```
207
- coffee-liberica-end/
208
- └── business/liberica-business-sales/sales-business/
209
- └── src/main/java/com/newpeak/liberica/sales/modular/business/
210
- └── SalesOrderBusiness.java
211
- └── add(SalesOrderRequest request)
212
- ├── Line 85: 检查客户是否存在
213
- │ └── throw new SalesException(ClientExceptionEnum.CLIENT_NOT_EXIST)
214
- ├── Line 102: 检查产品是否存在
215
- │ └── throw new MaterialException(MaterialExceptionEnum.MATERIAL_NOT_EXIST)
216
- └── Line 128: 检查编码是否重复
217
- └── throw new SalesException(SalesOrderExceptionEnum.SALES_ORDER_CODE_DUPLICATE)
218
- ```
219
-
220
- ### 已知错误码示例
221
- | 错误码 | 错误消息 | 触发条件 |
222
- |--------|----------|----------|
223
- | xxx | 销售订单不存在 | 编辑/详情时ID不存在 |
224
- | xxx | 销售订单编码重复 | 编码已存在 |
225
- | xxx | 客户不存在 | clientCode无效 |
226
- | xxx | 产品不存在 | materialNo无效 |
227
-
228
- ## 2.6 权限检查
229
-
230
- | 检查项 | 位置 | 说明 |
231
- |--------|------|------|
232
- | PermissionConstants | `.../constants/SalesOrderPermissionConstants.java` | ADD_SALES_ORDER |
233
- | 注解 | `@PostResource(requiredPermission = true, requirePermissionCode = ...)` | Controller方法上 |
234
-
235
- ## 2.7 公开接口声明(如适用)
236
-
237
- 如果此接口支持公开访问(无需认证):
238
-
239
- ```yaml
240
- public_endpoints:
241
- - service: "liberica"
242
- path: "/api/enterprise/sales/salesOrder/publicList"
243
- ```
244
-
245
- ---
246
-
247
- ## 3. 命令分类规范
248
-
249
- ### 3.1 服务(service)命名
250
- - `liberica` - Liberica生产管理
251
- - `arabica` - Arabica销售平台
252
-
253
- ### 3.2 资源(resource)命名
254
- 使用名词复数形式:
255
- - ✅ `orders` (订单)
256
- - ✅ `products` (产品)
257
- - ✅ `customers` (客户)
258
- - ❌ `order` (不规范)
259
- - ❌ `create-order` (动词不应出现在resource)
260
-
261
- ### 3.3 动作(action)命名
262
- 使用动词:
263
- | 动作 | 用途 | HTTP方法 |
264
- |------|------|----------|
265
- | list | 列表查询 | GET |
266
- | get | 详情查询 | GET |
267
- | create | 创建 | POST |
268
- | update | 更新 | POST/PUT |
269
- | delete | 删除 | POST/DELETE |
270
- | cancel | 取消 | POST |
271
- | search | 搜索 | GET |
272
-
273
- ---
274
-
275
- ## 4. 文档存放位置
276
-
277
- 命令设计文档存放在:
278
- ```
279
- coffee-barista-cli/
280
- └── docs/
281
- └── commands/
282
- ├── liberica/
283
- │ ├── employees/
284
- │ │ ├── create.md
285
- │ │ ├── list.md
286
- │ │ ├── get.md
287
- │ │ ├── update.md
288
- │ │ ├── enable.md
289
- │ │ └── delete.md
290
- │ ├── materials/
291
- │ │ ├── list.md
292
- │ │ ├── get.md
293
- │ │ ├── create.md
294
- │ │ ├── update.md
295
- │ │ ├── enable.md
296
- │ │ └── delete.md
297
- │ ├── uoms/
298
- │ │ ├── list.md
299
- │ │ ├── get.md
300
- │ │ ├── create.md
301
- │ │ ├── update.md
302
- │ │ ├── enable.md
303
- │ │ └── delete.md
304
- │ ├── clients/
305
- │ ├── suppliers/
306
- │ ├── currency/
307
- │ ├── users/
308
- │ ├── auth/
309
- │ ├── context/
310
- │ ├── orgs/
311
- │ ├── positions/
312
- │ └── roles/
313
- └── arabica/
314
- └── ...
315
- ```
316
-
317
- **命名规范:**
318
- - 每个命令资源一个子目录(如 `materials/`、`uoms/`)
319
- - 命令文档使用动作名称(如 `list.md`、`create.md`)
320
- - 禁止使用横杠连接(如 `materials-list.md` ❌)
321
- - 禁止扁平化存放(如 `materials-list.md` 与 `materials-get.md` 同目录 ❌)
322
-
323
- ---
324
-
325
- ## 5. 命令开发流程规范
326
-
327
- ### 5.1 流程概览
328
-
329
- 每个命令的开发必须遵循以下流程:
330
-
331
- ```
332
- ┌─────────────────────────────────────────────────────────────┐
333
- │ Phase 1: 设计阶段 (必须完成) │
334
- ├─────────────────────────────────────────────────────────────┤
335
- │ 1. 编写设计文档 → 2. 技术评审 → 3. 设计文档归档 │
336
- └─────────────────────────────────────────────────────────────┘
337
-
338
- ┌─────────────────────────────────────────────────────────────┐
339
- │ Phase 2: 开发阶段 │
340
- ├─────────────────────────────────────────────────────────────┤
341
- │ 4. 接口契约确认 → 5. 类型定义 → 6. 核心实现 → 7. 错误处理 │
342
- └─────────────────────────────────────────────────────────────┘
343
-
344
- ┌─────────────────────────────────────────────────────────────┐
345
- │ Phase 3: 验证阶段 │
346
- ├─────────────────────────────────────────────────────────────┤
347
- │ 8. 单元测试 → 9. 集成测试 → 10. Code Review → 11. 合并 │
348
- └─────────────────────────────────────────────────────────────┘
349
- ```
350
-
351
- ### 5.2 详细流程
352
-
353
- #### Phase 1: 设计阶段
354
-
355
- **Step 1: 编写设计文档** (预估: 30-60分钟)
356
- - [ ] 按第2节模板编写设计文档
357
- - [ ] 确认后端接口位置(查看Controller代码)
358
- - [ ] 确认DTO字段(查看Request/Response类)
359
- - [ ] 确认错误码(查看ExceptionEnum)
360
- - [ ] 输出: `docs/commands/<service>/<resource>-<action>.md`
361
-
362
- **Step 2: 技术评审** (预估: 15-30分钟)
363
- - [ ] 自检清单:
364
- - [ ] API路径正确性
365
- - [ ] 字段映射完整性
366
- - [ ] 必填/可选字段区分正确
367
- - [ ] 错误场景覆盖
368
- - [ ] 如有疑问,联系后端开发人员确认
369
-
370
- **Step 3: 设计文档归档**
371
- - [ ] 将设计文档提交到 Git
372
- - [ ] 提交信息: `docs: add design doc for <service> <resource> <action>`
373
-
374
- #### Phase 2: 开发阶段
375
-
376
- **Step 4: 接口契约确认** (预估: 15分钟)
377
- ```bash
378
- # 使用curl或Postman测试后端接口
379
- curl -X POST https://<env>/api/enterprise/sales/salesOrder/add \
380
- -H "Authorization: <token>" \
381
- -H "Content-Type: application/json" \
382
- -d '{
383
- "clientCode": "TEST001",
384
- "clientName": "测试客户",
385
- "materialNo": "MAT001",
386
- "purchaseNumber": 100
387
- }'
388
- ```
389
- - [ ] 确认接口可达
390
- - [ ] 确认认证方式
391
- - [ ] 记录实际响应格式
392
-
393
- **Step 5: 类型定义** (预估: 20-30分钟)
394
- - [ ] 在 `src/types/api.ts` 添加 TypeScript 接口
395
- - [ ] 在 `src/core/api/<service>-client.ts` 添加方法签名
396
- - [ ] 输出示例:
397
- ```typescript
398
- // src/types/api.ts
399
- export interface CreateSalesOrderRequest {
400
- clientCode: string;
401
- clientName: string;
402
- materialNo: string;
403
- purchaseNumber: number;
404
- deliveryDate?: string;
405
- }
406
-
407
- export interface SalesOrderResponse {
408
- salesOrderId: number;
409
- salesOrderCode: string;
410
- // ...
411
- }
412
-
413
- // src/core/api/liberica-client.ts
414
- async createOrder(data: CreateSalesOrderRequest): Promise<SalesOrderResponse>
415
- ```
416
-
417
- **Step 6: 核心实现** (预估: 30-60分钟)
418
- - [ ] 创建命令文件: `src/commands/<service>/<resource>/<action>.ts`
419
- - [ ] 实现命令逻辑:
420
- ```typescript
421
- export async function createOrderAction(options: CreateOrderOptions): Promise<void> {
422
- // 1. 获取API客户端
423
- const api = await ContextAwareAPIFactory.getLibericaClient();
424
-
425
- // 2. 构建请求参数
426
- const request: CreateSalesOrderRequest = {
427
- clientCode: options.clientCode,
428
- clientName: options.clientName,
429
- // ...
430
- };
431
-
432
- // 3. 执行API调用(支持dry-run)
433
- const result = await api.createOrder(request, options.dryRun);
434
-
435
- // 4. 格式化输出
436
- formatOutput(result, { command: 'liberica orders create' });
437
- }
438
- ```
439
- - [ ] 注册命令: 在 `src/commands/<service>/<resource>/index.ts` 注册
440
-
441
- **Step 7: 错误处理** (预估: 20-30分钟)
442
- - [ ] 实现错误捕获和转换
443
- - [ ] 映射后端错误码到友好提示
444
- - [ ] 添加错误修复建议
445
- - [ ] 示例:
446
- ```typescript
447
- try {
448
- await api.createOrder(request);
449
- } catch (error) {
450
- if (error.code === 'SALES_ORDER_CODE_DUPLICATE') {
451
- throw new CLIError(
452
- '订单编码已存在',
453
- 'DUPLICATE_CODE',
454
- { fix: '请使用不同的编码或使用 --code 参数指定' }
455
- );
456
- }
457
- // ...
458
- }
459
- ```
460
-
461
- #### Phase 3: 验证阶段
462
-
463
- **Step 8: 单元测试** (预估: 30-45分钟)
464
- - [ ] 创建测试文件: `tests/unit/commands/<service>/<resource>-<action>.test.ts`
465
- - [ ] 测试场景:
466
- - [ ] 正常创建
467
- - [ ] 缺少必填参数
468
- - [ ] 无效参数值
469
- - [ ] dry-run模式
470
- - [ ] 错误响应处理
471
-
472
- **Step 9: 集成测试** (预估: 20-30分钟)
473
- ```bash
474
- # 在dev环境测试
475
- barista context use-env dev
476
- barista auth login --service liberica --env dev --tenant companya
477
-
478
- # 测试命令
479
- barista liberica orders create \
480
- --client-code TEST001 \
481
- --client-name "测试客户" \
482
- --product-id MAT001 \
483
- --quantity 100 \
484
- --dry-run
485
-
486
- # 确认dry-run输出正确后,实际执行
487
- barista liberica orders create \
488
- --client-code TEST001 \
489
- --client-name "测试客户" \
490
- --product-id MAT001 \
491
- --quantity 100
492
- ```
493
- - [ ] 记录测试证据(截图或输出)
494
- - [ ] 保存到: `.sisyphus/evidence/<command>-test.md`
495
-
496
- **Step 10: Code Review** (预估: 15-30分钟)
497
- - [ ] 自检清单:
498
- - [ ] 代码符合项目规范(ESLint通过)
499
- - [ ] 类型定义完整
500
- - [ ] 错误处理完善
501
- - [ ] 文档注释清晰
502
- - [ ] 提交PR,指派Reviewer
503
-
504
- **Step 11: 合并与发布**
505
- - [ ] 通过CI/CD检查
506
- - [ ] 合并到main分支
507
- - [ ] 更新CHANGELOG
508
-
509
- ### 5.3 开发检查清单
510
-
511
- #### 实现前检查
512
- - [ ] 设计文档已编写并评审通过
513
- - [ ] 后端接口已确认可用
514
- - [ ] DTO字段已与后端对齐
515
-
516
- #### 实现中检查
517
- - [ ] 使用设计文档中的字段映射
518
- - [ ] 参数验证与后端一致
519
- - [ ] 支持 `--dry-run`(如适用)
520
- - [ ] 错误处理覆盖已知场景
521
-
522
- #### 实现后检查
523
- - [ ] 单元测试通过率 100%
524
- - [ ] 集成测试通过
525
- - [ ] 文档已更新
526
- - [ ] CHANGELOG已更新
527
-
528
- ### 5.4 时间估算参考
529
-
530
- | 步骤 | 预估时间 | 备注 |
531
- |------|---------|------|
532
- | 设计文档 | 30-60min | 复杂命令需要更长时间 |
533
- | 类型定义 | 20-30min | 依赖DTO复杂度 |
534
- | 核心实现 | 30-60min | 简单CRUD较快 |
535
- | 错误处理 | 20-30min | 需要查看Service代码 |
536
- | 单元测试 | 30-45min | TDD可合并到实现中 |
537
- | 集成测试 | 20-30min | 需要真实环境 |
538
- | Code Review | 15-30min | 包含修改时间 |
539
- | **总计** | **2.5-5h** | 简单命令约2.5h,复杂命令约5h |
540
-
541
- ### 5.5 交付物清单
542
-
543
- 每个命令开发完成后,必须包含:
544
-
545
- ```
546
- deliverables/
547
- ├── docs/commands/<service>/<resource>/<action>.md # 设计文档
548
- ├── src/
549
- │ ├── commands/<service>/<resource>/<action>.ts # 命令实现
550
- │ ├── types/<resource>.ts # 类型定义(更新)
551
- │ └── core/api/client.ts # API客户端(更新)
552
- ├── tests/
553
- │ └── unit/commands/<service>/<resource>/<action>.test.ts # 单元测试
554
- └── .sisyphus/evidence/
555
- └── <service>-<resource>-<action>-test.md # 集成测试证据
556
- ```
557
-
558
- ---
559
-
560
- ## 6. 示例:完整设计文档
561
-
562
- ### 6.1 示例:liberica auth login 命令
563
-
564
- #### 命令元数据
565
-
566
- | 字段 | 值 |
567
- |------|-----|
568
- | 完整命令 | `barista liberica auth login` |
569
- | 功能描述 | 登录 Liberica 租户账户 |
570
- | HTTP方法 | POST |
571
- | 是否需要认证 | ⬜ 否(登录接口无需认证) |
572
- | 是否支持dry-run | ⬜ 否(登录操作不适合dry-run) |
573
-
574
- #### 后端接口引用
575
-
576
- **Controller位置:**
577
- ```
578
- coffee-liberica-end/
579
- └── facade/liberica-facade-auth/
580
- └── src/main/java/com/newpeak/liberica/facade/auth/
581
- └── controller/AuthController.java
582
- └── login(@PostResource(path = "/login"))
583
- └── public ResponseData<LoginResponse> login(
584
- @RequestBody AuthLoginRequest request
585
- )
586
- ```
587
-
588
- **Request DTO:**
589
- ```
590
- coffee-liberica-end/
591
- └── business/liberica-business-auth/auth-api/
592
- └── src/main/java/com/newpeak/liberica/auth/api/pojo/request/
593
- └── AuthLoginRequest.java
594
- ├── username: String (@NotBlank)
595
- ├── password: String (@NotBlank)
596
- └── tenant: String
597
- ```
598
-
599
- **Response DTO:**
600
- ```
601
- coffee-liberica-end/
602
- └── business/liberica-business-auth/auth-api/
603
- └── src/main/java/com/newpeak/liberica/auth/api/pojo/response/
604
- └── LoginResponse.java
605
- ├── token: String
606
- └── expiresAt: String (optional)
607
- ```
608
-
609
- #### CLI参数设计
610
-
611
- **命令结构:**
612
- ```
613
- barista liberica auth login [env] [tenant] [username] [password] [options]
614
- ```
615
-
616
- **Arguments (位置参数):**
617
- | 参数 | 类型 | 必填 | 说明 |
618
- |------|------|------|------|
619
- | env | string | ⬜ | 目标环境 (dev\|test\|prod-cn\|prod-jp) |
620
- | tenant | string | ⬜ | 租户名称 |
621
- | username | string | ⬜ | 用户名 |
622
- | password | string | ⬜ | 密码 |
623
-
624
- **Options (选项参数):**
625
- | 选项 | 类型 | 必填 | 默认值 | 说明 |
626
- |------|------|------|--------|------|
627
- | --env | string | ⬜ | 当前上下文 | 目标环境 |
628
- | --tenant | string | ⬜ | 当前上下文 | 租户名称 |
629
- | --username | string | ⬜ | 交互输入 | 用户名 |
630
- | --password | string | ⬜ | 交互输入 | 密码 |
631
-
632
- #### 字段映射表
633
-
634
- | CLI参数 | DTO字段 | 类型转换 | 验证规则 |
635
- |---------|---------|----------|----------|
636
- | --tenant | tenant | 直接传递 | 可选 |
637
- | --username | username | 直接传递 | @NotBlank |
638
- | --password | password | 直接传递 | @NotBlank |
639
-
640
- #### 错误码引用
641
-
642
- **Service层业务校验:**
643
- ```
644
- coffee-liberica-end/
645
- └── business/liberica-business-auth/auth-business/
646
- └── src/main/java/com/newpeak/liberica/auth/modular/business/
647
- └── AuthBusiness.java
648
- └── login(AuthLoginRequest request)
649
- ├── Line 45: 验证用户是否存在
650
- │ └── throw new AuthException(AuthExceptionEnum.USER_NOT_EXIST)
651
- └── Line 62: 验证密码是否正确
652
- └── throw new AuthException(AuthExceptionEnum.PASSWORD_ERROR)
653
- ```
654
-
655
- **已知错误码:**
656
- | 错误码 | 错误消息 | 触发条件 |
657
- |--------|----------|----------|
658
- | USER_NOT_EXIST | 用户不存在 | 用户名未注册 |
659
- | PASSWORD_ERROR | 密码错误 | 密码不匹配 |
660
-
661
- #### 公开接口声明
662
-
663
- ```yaml
664
- public_endpoints:
665
- - service: "liberica"
666
- path: "/api/v1/auth/login"
667
- ```
668
-
669
- #### 实现要点
670
-
671
- 1. **交互式补全**:tenant/username/password 未提供时,使用 inquirer 交互输入
672
- 2. **Token存储**:登录成功后调用 `tokenManager.setToken()` 存入系统密钥链
673
- 3. **上下文更新**:调用 `configManager.setTenant()` 更新默认租户
674
- 4. **错误处理**:区分网络错误和业务错误,业务错误显示友好提示
675
-
676
- #### 实现代码
677
-
678
- ```typescript
679
- // src/commands/liberica/auth/index.ts
680
- export function createLibericaAuthCommand(): Command {
681
- const authCommand = new Command('auth');
682
- authCommand.description('Manage Liberica authentication');
683
-
684
- authCommand
685
- .command('login')
686
- .description('Login to Liberica')
687
- .arguments('<env> [tenant] [username] [password]')
688
- .option('--env <environment>', 'Environment (dev|test|prod-cn|prod-jp)')
689
- .option('--tenant <tenant>', 'Tenant name')
690
- .option('--username <username>', 'Username')
691
- .option('--password <password>', 'Password')
692
- .action(async (env, tenant, username, password, options) => {
693
- const context = configManager.getCurrentContext();
694
- const environment = (options.env as Environment) || env || context.environment;
695
- let resolvedTenant = options.tenant || tenant || context.tenant;
696
-
697
- if (!resolvedTenant) {
698
- const { tenant: inputTenant } = await inquirer.prompt([
699
- { type: 'input', name: 'tenant', message: 'Enter tenant name:' }
700
- ]);
701
- resolvedTenant = inputTenant;
702
- }
703
-
704
- let resolvedUsername = options.username || username;
705
- let resolvedPassword = options.password || password;
706
-
707
- if (!resolvedUsername) {
708
- const { username: inputUsername } = await inquirer.prompt([
709
- { type: 'input', name: 'username', message: 'Enter username:' }
710
- ]);
711
- resolvedUsername = inputUsername;
712
- }
713
-
714
- if (!resolvedPassword) {
715
- const { password: inputPassword } = await inquirer.prompt([
716
- { type: 'password', name: 'password', message: 'Enter password:' }
717
- ]);
718
- resolvedPassword = inputPassword;
719
- }
720
-
721
- const response = await apiClient.login('liberica', environment, resolvedTenant, resolvedUsername, resolvedPassword);
722
-
723
- if (response.success && response.data) {
724
- await tokenManager.setToken(
725
- { service: 'liberica', environment, tenant: resolvedTenant },
726
- response.data.token
727
- );
728
- await configManager.setTenant(resolvedTenant);
729
- console.log(chalk.green('\n✓ Login successful'));
730
- } else {
731
- console.error(chalk.red(`\n✗ Login failed: ${response.error?.message}\n`));
732
- process.exit(1);
733
- }
734
- });
735
-
736
- return authCommand;
737
- }
738
- ```
739
-
740
- **调用方式:**
741
- ```bash
742
- # 全位置参数
743
- barista liberica auth login dev shanghai admin pass
744
-
745
- # 全选项参数
746
- barista liberica auth login --env dev --tenant shanghai --username admin --password pass
747
-
748
- # 混合
749
- barista liberica auth login dev --username admin --password pass
750
-
751
- # 交互式
752
- barista liberica auth login
753
- ```
754
-
755
- ---
756
-
757
- ### 6.2 示例:liberica context show 命令
758
-
759
- #### 命令元数据
760
-
761
- | 字段 | 值 |
762
- |------|-----|
763
- | 完整命令 | `barista liberica context show` |
764
- | 功能描述 | 显示当前 Liberica 上下文 |
765
- | HTTP方法 | 无(仅读取本地配置) |
766
- | 是否需要认证 | ⬜ 否 |
767
- | 是否支持dry-run | ⬜ 否 |
768
-
769
- #### 实现要点
770
-
771
- 1. **无API调用**:仅读取 `configManager.getCurrentContext()` 和 `tokenManager.getToken()`
772
- 2. **Token状态检查**:检查密钥链中是否存在有效Token
773
- 3. **格式化输出**:使用 chalk 彩色输出当前环境、租户、认证状态
774
-
775
- #### 实现代码
776
-
777
- ```typescript
778
- // src/commands/liberica/context/index.ts
779
- export function createLibericaContextCommand(): Command {
780
- const contextCommand = new Command('context');
781
- contextCommand.description('Manage Liberica context (tenant, environment)');
782
-
783
- contextCommand
784
- .command('show')
785
- .description('Show current Liberica context')
786
- .action(async () => {
787
- const context = configManager.getCurrentContext();
788
- const token = await tokenManager.getToken({
789
- service: 'liberica',
790
- environment: context.environment,
791
- tenant: context.tenant,
792
- });
793
-
794
- console.log(chalk.bold('\n📋 Liberica Context\n'));
795
- console.log(` ${chalk.gray('Environment:')} ${chalk.green(context.environment)}`);
796
- console.log(` ${chalk.gray('Tenant:')} ${chalk.green(context.tenant)}`);
797
- console.log(
798
- ` ${chalk.gray('Auth Status:')} ${token ? chalk.green('✓ Logged in') : chalk.red('✗ Not logged in')}`
799
- );
800
- });
801
-
802
- return contextCommand;
803
- }
804
- ```
805
-
806
- ---
807
-
808
- ### 6.3 模式总结
809
-
810
- | 命令类型 | 特征 | 实现模式 |
811
- |----------|------|----------|
812
- | **认证类** (login, logout) | 调用API、存储Token | 使用 `apiClient.login()` + `tokenManager.setToken()` |
813
- | **状态类** (status, show) | 读取配置/密钥链 | 使用 `configManager` + `tokenManager.getToken()` |
814
- | **列表类** (list) | 调用API、表格输出 | 使用 `axios.get()` + `cli-table3` |
815
- | **写入类** (create, update, delete) | 调用API、支持dry-run | API调用 + dry-run预览 + 确认提示 |
816
-
817
- #### 核心模块依赖
818
-
819
- ```
820
- src/
821
- ├── core/
822
- │ ├── config/manager.ts # 配置管理 (getCurrentContext, setTenant, getEnvironmentUrl)
823
- │ ├── auth/token-manager.ts # Token存储 (getToken, setToken, deleteToken, findAllTokens)
824
- │ └── api/client.ts # API客户端 (login, createAPIClient)
825
- │ └── types/index.ts # 类型定义 (Environment, Service, Context, Config)
826
- └── commands/
827
- └── {service}/
828
- └── {resource}.ts # 命令实现
829
- ```
830
-
831
- #### 导入路径规范
832
-
833
- ```typescript
834
- import { configManager } from '../../../core/config/manager.js';
835
- import { tokenManager } from '../../../core/auth/token-manager.js';
836
- import { apiClient } from '../../../core/api/client.js';
837
- import { Environment } from '../../../types/index.js';
838
- ```
839
-
840
- **注意**:必须使用 `.js` 扩展名,即使源文件是 `.ts`