@newpeak/barista-cli 0.1.10 → 0.1.12

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 (298) hide show
  1. package/dist/index.js +1 -1
  2. package/package.json +7 -3
  3. package/docs/ARCHITECTURE.md +0 -184
  4. package/docs/COMMANDS.md +0 -352
  5. package/docs/COMMAND_DESIGN_SPEC.md +0 -840
  6. package/docs/INTEGRATION_NOTES.md +0 -270
  7. package/docs/commands/REFERENCE.md +0 -323
  8. package/docs/commands/arabica/auth/index.md +0 -296
  9. package/docs/commands/liberica/auth/index.md +0 -133
  10. package/docs/commands/liberica/calendar/DESIGN.md +0 -333
  11. package/docs/commands/liberica/client-contacts/create.md +0 -152
  12. package/docs/commands/liberica/client-contacts/delete.md +0 -123
  13. package/docs/commands/liberica/client-contacts/get.md +0 -133
  14. package/docs/commands/liberica/client-contacts/list.md +0 -143
  15. package/docs/commands/liberica/client-contacts/update.md +0 -158
  16. package/docs/commands/liberica/context/index.md +0 -60
  17. package/docs/commands/liberica/currency/create.md +0 -145
  18. package/docs/commands/liberica/currency/delete.md +0 -121
  19. package/docs/commands/liberica/currency/disable.md +0 -119
  20. package/docs/commands/liberica/currency/enable.md +0 -115
  21. package/docs/commands/liberica/currency/get.md +0 -118
  22. package/docs/commands/liberica/currency/list.md +0 -149
  23. package/docs/commands/liberica/currency/update.md +0 -141
  24. package/docs/commands/liberica/employees/create.md +0 -185
  25. package/docs/commands/liberica/employees/disable.md +0 -138
  26. package/docs/commands/liberica/employees/enable.md +0 -137
  27. package/docs/commands/liberica/employees/get.md +0 -153
  28. package/docs/commands/liberica/employees/list.md +0 -168
  29. package/docs/commands/liberica/employees/update.md +0 -180
  30. package/docs/commands/liberica/locations/create.md +0 -195
  31. package/docs/commands/liberica/locations/list.md +0 -171
  32. package/docs/commands/liberica/materials/create.md +0 -293
  33. package/docs/commands/liberica/materials/delete.md +0 -240
  34. package/docs/commands/liberica/materials/disable.md +0 -150
  35. package/docs/commands/liberica/materials/enable.md +0 -146
  36. package/docs/commands/liberica/materials/get.md +0 -188
  37. package/docs/commands/liberica/materials/list.md +0 -198
  38. package/docs/commands/liberica/materials/update.md +0 -250
  39. package/docs/commands/liberica/orgs/list.md +0 -62
  40. package/docs/commands/liberica/positions/list.md +0 -61
  41. package/docs/commands/liberica/roles/list.md +0 -67
  42. package/docs/commands/liberica/stock/ledger.md +0 -209
  43. package/docs/commands/liberica/stock/list.md +0 -165
  44. package/docs/commands/liberica/supplier-contacts/create.md +0 -152
  45. package/docs/commands/liberica/supplier-contacts/delete.md +0 -123
  46. package/docs/commands/liberica/supplier-contacts/get.md +0 -133
  47. package/docs/commands/liberica/supplier-contacts/list.md +0 -143
  48. package/docs/commands/liberica/supplier-contacts/update.md +0 -158
  49. package/docs/commands/liberica/teams/issues/close.md +0 -161
  50. package/docs/commands/liberica/teams/issues/create.md +0 -212
  51. package/docs/commands/liberica/teams/issues/delete.md +0 -179
  52. package/docs/commands/liberica/teams/issues/get.md +0 -167
  53. package/docs/commands/liberica/teams/issues/list.md +0 -182
  54. package/docs/commands/liberica/teams/issues/tests-design.md +0 -341
  55. package/docs/commands/liberica/teams/issues/update.md +0 -202
  56. package/docs/commands/liberica/teams/projects/create.md +0 -174
  57. package/docs/commands/liberica/teams/projects/delete.md +0 -180
  58. package/docs/commands/liberica/teams/projects/get.md +0 -150
  59. package/docs/commands/liberica/teams/projects/list.md +0 -179
  60. package/docs/commands/liberica/teams/projects/update.md +0 -175
  61. package/docs/commands/liberica/teams/tasks/create.md +0 -163
  62. package/docs/commands/liberica/teams/tasks/delete.md +0 -109
  63. package/docs/commands/liberica/teams/tasks/get.md +0 -121
  64. package/docs/commands/liberica/teams/tasks/list.md +0 -148
  65. package/docs/commands/liberica/teams/tasks/update.md +0 -158
  66. package/docs/commands/liberica/teams/work-logs/create.md +0 -151
  67. package/docs/commands/liberica/teams/work-logs/delete.md +0 -130
  68. package/docs/commands/liberica/teams/work-logs/get.md +0 -131
  69. package/docs/commands/liberica/teams/work-logs/list.md +0 -153
  70. package/docs/commands/liberica/teams/work-logs/update.md +0 -150
  71. package/docs/commands/liberica/transfer-in-forms/batch-delete.md +0 -157
  72. package/docs/commands/liberica/transfer-in-forms/batch-review.md +0 -157
  73. package/docs/commands/liberica/transfer-in-forms/batch-unreview.md +0 -157
  74. package/docs/commands/liberica/transfer-in-forms/create.md +0 -220
  75. package/docs/commands/liberica/transfer-in-forms/get.md +0 -221
  76. package/docs/commands/liberica/transfer-in-forms/list.md +0 -242
  77. package/docs/commands/liberica/transfer-in-forms/update.md +0 -185
  78. package/docs/commands/liberica/transfer-out-forms/batch-delete.md +0 -187
  79. package/docs/commands/liberica/transfer-out-forms/batch-review.md +0 -157
  80. package/docs/commands/liberica/transfer-out-forms/batch-unreview.md +0 -157
  81. package/docs/commands/liberica/transfer-out-forms/create.md +0 -280
  82. package/docs/commands/liberica/transfer-out-forms/get.md +0 -211
  83. package/docs/commands/liberica/transfer-out-forms/list.md +0 -233
  84. package/docs/commands/liberica/transfer-out-forms/update.md +0 -286
  85. package/docs/commands/liberica/uoms/create.md +0 -136
  86. package/docs/commands/liberica/uoms/delete.md +0 -119
  87. package/docs/commands/liberica/uoms/disable.md +0 -117
  88. package/docs/commands/liberica/uoms/enable.md +0 -115
  89. package/docs/commands/liberica/uoms/get.md +0 -119
  90. package/docs/commands/liberica/uoms/list.md +0 -155
  91. package/docs/commands/liberica/uoms/update.md +0 -148
  92. package/docs/commands/liberica/users/create.md +0 -170
  93. package/docs/commands/liberica/users/get.md +0 -151
  94. package/docs/commands/liberica/users/list.md +0 -175
  95. package/docs/commands/liberica/warehouses/create.md +0 -222
  96. package/docs/commands/liberica/warehouses/list.md +0 -184
  97. package/src/commands/arabica/auth/index.ts +0 -277
  98. package/src/commands/arabica/auth/login.ts +0 -5
  99. package/src/commands/arabica/auth/logout.ts +0 -5
  100. package/src/commands/arabica/auth/register.ts +0 -5
  101. package/src/commands/arabica/auth/status.ts +0 -5
  102. package/src/commands/arabica/index.ts +0 -23
  103. package/src/commands/auth.ts +0 -107
  104. package/src/commands/context.ts +0 -60
  105. package/src/commands/liberica/auth/index.ts +0 -176
  106. package/src/commands/liberica/calendar/index.ts +0 -13
  107. package/src/commands/liberica/calendar/list.ts +0 -214
  108. package/src/commands/liberica/calendar/set.ts +0 -130
  109. package/src/commands/liberica/client-contacts/create.ts +0 -115
  110. package/src/commands/liberica/client-contacts/delete.ts +0 -140
  111. package/src/commands/liberica/client-contacts/get.ts +0 -103
  112. package/src/commands/liberica/client-contacts/index.ts +0 -19
  113. package/src/commands/liberica/client-contacts/list.ts +0 -118
  114. package/src/commands/liberica/client-contacts/update.ts +0 -137
  115. package/src/commands/liberica/clients/create.ts +0 -122
  116. package/src/commands/liberica/clients/delete.ts +0 -125
  117. package/src/commands/liberica/clients/get.ts +0 -88
  118. package/src/commands/liberica/clients/index.ts +0 -19
  119. package/src/commands/liberica/clients/list.ts +0 -123
  120. package/src/commands/liberica/clients/update.ts +0 -103
  121. package/src/commands/liberica/context/index.ts +0 -43
  122. package/src/commands/liberica/currency/create.ts +0 -183
  123. package/src/commands/liberica/currency/delete.ts +0 -124
  124. package/src/commands/liberica/currency/disable.ts +0 -147
  125. package/src/commands/liberica/currency/enable.ts +0 -128
  126. package/src/commands/liberica/currency/get.ts +0 -91
  127. package/src/commands/liberica/currency/index.ts +0 -23
  128. package/src/commands/liberica/currency/list.ts +0 -140
  129. package/src/commands/liberica/currency/update.ts +0 -129
  130. package/src/commands/liberica/dict-types/get.ts +0 -74
  131. package/src/commands/liberica/dict-types/index.ts +0 -15
  132. package/src/commands/liberica/dict-types/list.ts +0 -118
  133. package/src/commands/liberica/dict-types/update.ts +0 -134
  134. package/src/commands/liberica/dicts/create.ts +0 -175
  135. package/src/commands/liberica/dicts/delete.ts +0 -107
  136. package/src/commands/liberica/dicts/get.ts +0 -80
  137. package/src/commands/liberica/dicts/index.ts +0 -19
  138. package/src/commands/liberica/dicts/list.ts +0 -114
  139. package/src/commands/liberica/dicts/update.ts +0 -116
  140. package/src/commands/liberica/employees/create.ts +0 -275
  141. package/src/commands/liberica/employees/delete.ts +0 -122
  142. package/src/commands/liberica/employees/disable.ts +0 -97
  143. package/src/commands/liberica/employees/enable.ts +0 -97
  144. package/src/commands/liberica/employees/get.ts +0 -115
  145. package/src/commands/liberica/employees/index.ts +0 -23
  146. package/src/commands/liberica/employees/list.ts +0 -131
  147. package/src/commands/liberica/employees/update.ts +0 -157
  148. package/src/commands/liberica/index.ts +0 -81
  149. package/src/commands/liberica/materials/create.ts +0 -199
  150. package/src/commands/liberica/materials/delete.ts +0 -105
  151. package/src/commands/liberica/materials/disable.ts +0 -148
  152. package/src/commands/liberica/materials/enable.ts +0 -129
  153. package/src/commands/liberica/materials/get.ts +0 -83
  154. package/src/commands/liberica/materials/index.ts +0 -23
  155. package/src/commands/liberica/materials/list.ts +0 -142
  156. package/src/commands/liberica/materials/update.ts +0 -125
  157. package/src/commands/liberica/mould/get.ts +0 -111
  158. package/src/commands/liberica/mould/index.ts +0 -17
  159. package/src/commands/liberica/mould/list.ts +0 -157
  160. package/src/commands/liberica/mould/set-status.ts +0 -99
  161. package/src/commands/liberica/mould/stock-in.ts +0 -165
  162. package/src/commands/liberica/operations/active.ts +0 -153
  163. package/src/commands/liberica/operations/batch-delete.ts +0 -131
  164. package/src/commands/liberica/operations/copy.ts +0 -138
  165. package/src/commands/liberica/operations/create.ts +0 -223
  166. package/src/commands/liberica/operations/deactive.ts +0 -152
  167. package/src/commands/liberica/operations/delete.ts +0 -128
  168. package/src/commands/liberica/operations/design.md +0 -587
  169. package/src/commands/liberica/operations/get.ts +0 -112
  170. package/src/commands/liberica/operations/index.ts +0 -27
  171. package/src/commands/liberica/operations/list.ts +0 -180
  172. package/src/commands/liberica/operations/update.ts +0 -218
  173. package/src/commands/liberica/orgs/index.ts +0 -34
  174. package/src/commands/liberica/positions/index.ts +0 -30
  175. package/src/commands/liberica/roles/index.ts +0 -59
  176. package/src/commands/liberica/stock/index.ts +0 -13
  177. package/src/commands/liberica/stock/ledger.ts +0 -159
  178. package/src/commands/liberica/stock/list.ts +0 -128
  179. package/src/commands/liberica/supplier-contacts/create.ts +0 -120
  180. package/src/commands/liberica/supplier-contacts/delete.ts +0 -88
  181. package/src/commands/liberica/supplier-contacts/get.ts +0 -94
  182. package/src/commands/liberica/supplier-contacts/index.ts +0 -19
  183. package/src/commands/liberica/supplier-contacts/list.ts +0 -130
  184. package/src/commands/liberica/supplier-contacts/update.ts +0 -127
  185. package/src/commands/liberica/suppliers/create.ts +0 -149
  186. package/src/commands/liberica/suppliers/delete.ts +0 -102
  187. package/src/commands/liberica/suppliers/disable.ts +0 -145
  188. package/src/commands/liberica/suppliers/enable.ts +0 -126
  189. package/src/commands/liberica/suppliers/get.ts +0 -86
  190. package/src/commands/liberica/suppliers/index.ts +0 -23
  191. package/src/commands/liberica/suppliers/list.ts +0 -134
  192. package/src/commands/liberica/suppliers/update.ts +0 -128
  193. package/src/commands/liberica/teams/index.ts +0 -17
  194. package/src/commands/liberica/teams/issues/close.ts +0 -104
  195. package/src/commands/liberica/teams/issues/create.ts +0 -254
  196. package/src/commands/liberica/teams/issues/delete.ts +0 -58
  197. package/src/commands/liberica/teams/issues/get.ts +0 -78
  198. package/src/commands/liberica/teams/issues/index.ts +0 -21
  199. package/src/commands/liberica/teams/issues/list.ts +0 -144
  200. package/src/commands/liberica/teams/issues/update.ts +0 -141
  201. package/src/commands/liberica/teams/projects/create.ts +0 -159
  202. package/src/commands/liberica/teams/projects/delete.ts +0 -58
  203. package/src/commands/liberica/teams/projects/get.ts +0 -87
  204. package/src/commands/liberica/teams/projects/index.ts +0 -19
  205. package/src/commands/liberica/teams/projects/list.ts +0 -147
  206. package/src/commands/liberica/teams/projects/update.ts +0 -117
  207. package/src/commands/liberica/teams/tasks/create.ts +0 -102
  208. package/src/commands/liberica/teams/tasks/delete.ts +0 -92
  209. package/src/commands/liberica/teams/tasks/get.ts +0 -64
  210. package/src/commands/liberica/teams/tasks/index.ts +0 -19
  211. package/src/commands/liberica/teams/tasks/list.ts +0 -102
  212. package/src/commands/liberica/teams/tasks/update.ts +0 -122
  213. package/src/commands/liberica/teams/work-logs/create.ts +0 -204
  214. package/src/commands/liberica/teams/work-logs/delete.ts +0 -58
  215. package/src/commands/liberica/teams/work-logs/get.ts +0 -87
  216. package/src/commands/liberica/teams/work-logs/index.ts +0 -19
  217. package/src/commands/liberica/teams/work-logs/list.ts +0 -141
  218. package/src/commands/liberica/teams/work-logs/update.ts +0 -120
  219. package/src/commands/liberica/transfer-in-forms/batch-delete.ts +0 -152
  220. package/src/commands/liberica/transfer-in-forms/batch-review.ts +0 -151
  221. package/src/commands/liberica/transfer-in-forms/batch-unreview.ts +0 -152
  222. package/src/commands/liberica/transfer-in-forms/create.ts +0 -179
  223. package/src/commands/liberica/transfer-in-forms/get.ts +0 -107
  224. package/src/commands/liberica/transfer-in-forms/index.ts +0 -23
  225. package/src/commands/liberica/transfer-in-forms/list.ts +0 -97
  226. package/src/commands/liberica/transfer-in-forms/update.ts +0 -213
  227. package/src/commands/liberica/transfer-out-forms/batch-delete.ts +0 -83
  228. package/src/commands/liberica/transfer-out-forms/batch-review.ts +0 -148
  229. package/src/commands/liberica/transfer-out-forms/batch-unreview.ts +0 -56
  230. package/src/commands/liberica/transfer-out-forms/create.ts +0 -194
  231. package/src/commands/liberica/transfer-out-forms/get.ts +0 -114
  232. package/src/commands/liberica/transfer-out-forms/index.ts +0 -23
  233. package/src/commands/liberica/transfer-out-forms/list.ts +0 -125
  234. package/src/commands/liberica/transfer-out-forms/update.ts +0 -197
  235. package/src/commands/liberica/uoms/create.ts +0 -134
  236. package/src/commands/liberica/uoms/delete.ts +0 -105
  237. package/src/commands/liberica/uoms/disable.ts +0 -148
  238. package/src/commands/liberica/uoms/enable.ts +0 -129
  239. package/src/commands/liberica/uoms/get.ts +0 -83
  240. package/src/commands/liberica/uoms/index.ts +0 -23
  241. package/src/commands/liberica/uoms/list.ts +0 -129
  242. package/src/commands/liberica/uoms/update.ts +0 -124
  243. package/src/commands/liberica/users/create.ts +0 -133
  244. package/src/commands/liberica/users/delete.ts +0 -49
  245. package/src/commands/liberica/users/disable.ts +0 -41
  246. package/src/commands/liberica/users/enable.ts +0 -30
  247. package/src/commands/liberica/users/get.ts +0 -46
  248. package/src/commands/liberica/users/index.ts +0 -27
  249. package/src/commands/liberica/users/list.ts +0 -68
  250. package/src/commands/liberica/users/me.ts +0 -42
  251. package/src/commands/liberica/users/reset-password.ts +0 -42
  252. package/src/commands/liberica/users/update.ts +0 -48
  253. package/src/commands/liberica/warehouses/create.ts +0 -204
  254. package/src/commands/liberica/warehouses/delete.ts +0 -112
  255. package/src/commands/liberica/warehouses/disable.ts +0 -174
  256. package/src/commands/liberica/warehouses/enable.ts +0 -174
  257. package/src/commands/liberica/warehouses/get.ts +0 -101
  258. package/src/commands/liberica/warehouses/index.ts +0 -25
  259. package/src/commands/liberica/warehouses/list.ts +0 -136
  260. package/src/commands/liberica/warehouses/locations/create.ts +0 -209
  261. package/src/commands/liberica/warehouses/locations/delete.ts +0 -116
  262. package/src/commands/liberica/warehouses/locations/disable.ts +0 -174
  263. package/src/commands/liberica/warehouses/locations/enable.ts +0 -174
  264. package/src/commands/liberica/warehouses/locations/get.ts +0 -84
  265. package/src/commands/liberica/warehouses/locations/index.ts +0 -23
  266. package/src/commands/liberica/warehouses/locations/list.ts +0 -140
  267. package/src/commands/liberica/warehouses/locations/update.ts +0 -135
  268. package/src/commands/liberica/warehouses/update.ts +0 -142
  269. package/src/core/api/client.ts +0 -4443
  270. package/src/core/auth/token-manager.ts +0 -183
  271. package/src/core/config/manager.ts +0 -164
  272. package/src/index.ts +0 -35
  273. package/src/types/calendar.ts +0 -36
  274. package/src/types/client-contact.ts +0 -78
  275. package/src/types/client.ts +0 -115
  276. package/src/types/currency.ts +0 -90
  277. package/src/types/dict.ts +0 -121
  278. package/src/types/employee.ts +0 -102
  279. package/src/types/index.ts +0 -93
  280. package/src/types/location.ts +0 -66
  281. package/src/types/material.ts +0 -61
  282. package/src/types/mould-stock-in.ts +0 -82
  283. package/src/types/mould.ts +0 -74
  284. package/src/types/operation.ts +0 -72
  285. package/src/types/org.ts +0 -25
  286. package/src/types/position.ts +0 -24
  287. package/src/types/stock.ts +0 -161
  288. package/src/types/supplier-contact.ts +0 -78
  289. package/src/types/supplier.ts +0 -66
  290. package/src/types/team-issue.ts +0 -94
  291. package/src/types/team-project.ts +0 -74
  292. package/src/types/team-task.ts +0 -98
  293. package/src/types/team-work-log.ts +0 -87
  294. package/src/types/transfer-in-form.ts +0 -265
  295. package/src/types/transfer-out-form.ts +0 -290
  296. package/src/types/uom.ts +0 -60
  297. package/src/types/user.ts +0 -64
  298. package/src/types/warehouse.ts +0 -82
@@ -1,296 +0,0 @@
1
- # arabica auth
2
-
3
- Manage Arabica authentication.
4
-
5
- ## Overview
6
-
7
- The `arabica auth` command group provides authentication management for the Arabica sales platform. Arabica is a single-tenant SaaS platform, which means it does not require tenant context like Liberica. Authentication uses the standard `POST /api/login` endpoint for login and `POST /api/member/user/register` for user registration.
8
-
9
- Key differences from Liberica authentication:
10
-
11
- - **No tenant concept**: Arabica operates as a single-tenant platform
12
- - **Account-based login**: Uses account (username or email) instead of username/tenant pair
13
- - **Registration support**: Includes user registration functionality
14
- - **Remember me option**: Supports persistent login sessions
15
-
16
- ## Commands
17
-
18
- ### login
19
-
20
- Login to Arabica with account credentials.
21
-
22
- **Usage:**
23
- ```
24
- barista arabica auth login [env] [account] [password] [options]
25
- ```
26
-
27
- **Arguments:**
28
-
29
- | Argument | Type | Required | Description |
30
- |----------|------|----------|-------------|
31
- | env | string | No | Target environment (dev\|test\|prod-cn\|prod-jp) |
32
- | account | string | No | Account username or email |
33
- | password | string | No | Account password |
34
-
35
- **Options:**
36
-
37
- | Option | Type | Required | Default | Description |
38
- |--------|------|----------|---------|-------------|
39
- | --env | string | No | Current context | Target environment |
40
- | --account | string | No | Interactive input | Account username or email |
41
- | --password | string | No | Interactive input | Account password |
42
- | --remember | boolean | No | false | Remember login status |
43
-
44
- **Examples:**
45
-
46
- Interactive mode (all fields prompted):
47
- ```bash
48
- barista arabica auth login
49
- ```
50
-
51
- With positional arguments:
52
- ```bash
53
- barista arabica auth login dev user@example.com mypassword
54
- ```
55
-
56
- With options:
57
- ```bash
58
- barista arabica auth login --env dev --account user@example.com --password mypassword --remember
59
- ```
60
-
61
- Mixed (positional + options):
62
- ```bash
63
- barista arabica auth login dev --account user@example.com --password mypassword
64
- ```
65
-
66
- **API Endpoint:**
67
- - **Method**: `POST /api/login`
68
- - **Body**: `{ account: string, password: string, rememberMe: boolean }`
69
- - **Response**: `{ success: boolean, data: { token: string, expiresAt?: string } }`
70
-
71
- **Error Handling:**
72
-
73
- | Error Code | Description | Trigger Condition |
74
- |------------|-------------|-------------------|
75
- | INVALID_CREDENTIALS | Invalid account or password | Wrong account/password combination |
76
- | ACCOUNT_LOCKED | Account is locked | Multiple failed login attempts |
77
- | NETWORK_ERROR | Network connection failed | Cannot reach Arabica server |
78
-
79
- **Implementation Notes:**
80
- - Interactive prompts use `inquirer` for secure password input (masked)
81
- - Successful login stores token via `tokenManager.setToken()` in system keychain
82
- - Token format in keychain: `arabica:{environment}` (no tenant component)
83
- - The `--remember` flag extends token validity on the server side
84
-
85
- ---
86
-
87
- ### register
88
-
89
- Register a new Arabica account.
90
-
91
- **Usage:**
92
- ```
93
- barista arabica auth register [options]
94
- ```
95
-
96
- **Options:**
97
-
98
- | Option | Type | Required | Default | Description |
99
- |--------|------|----------|---------|-------------|
100
- | --env | string | No | Current context | Target environment |
101
- | --email | string | No | Interactive input | Email address |
102
- | --account | string | No | Interactive input | Account username |
103
- | --password | string | No | Interactive input | Account password |
104
- | --phone | string | No | Interactive input | Phone number (optional) |
105
-
106
- **Examples:**
107
-
108
- Interactive mode (all fields prompted):
109
- ```bash
110
- barista arabica auth register
111
- ```
112
-
113
- With all options:
114
- ```bash
115
- barista arabica auth register \
116
- --env dev \
117
- --email newuser@example.com \
118
- --account newuser \
119
- --password mypassword \
120
- --phone "+86 13800138000"
121
- ```
122
-
123
- Minimal registration (prompts for missing fields):
124
- ```bash
125
- barista arabica auth register --email newuser@example.com --account newuser
126
- ```
127
-
128
- **API Endpoint:**
129
- - **Method**: `POST /api/member/user/register`
130
- - **Body**: `{ email: string, account: string, password: string, phone?: string }`
131
- - **Response**: `{ success: boolean, data: { userId?: string } }`
132
-
133
- **Error Handling:**
134
-
135
- | Error Code | Description | Trigger Condition |
136
- |------------|-------------|-------------------|
137
- | EMAIL_EXISTS | Email already registered | Duplicate email address |
138
- | ACCOUNT_EXISTS | Account username taken | Duplicate account name |
139
- | INVALID_EMAIL | Invalid email format | Email format validation failed |
140
- | WEAK_PASSWORD | Password too weak | Password does not meet requirements |
141
-
142
- **Implementation Notes:**
143
- - Email and account are both required and must be unique
144
- - Phone number is optional but recommended for account recovery
145
- - After successful registration, user must login separately to obtain token
146
- - Registration does not automatically authenticate the user
147
-
148
- ---
149
-
150
- ### status
151
-
152
- Check Arabica authentication status across all environments.
153
-
154
- **Usage:**
155
- ```
156
- barista arabica auth status
157
- ```
158
-
159
- **Output:**
160
- ```
161
- 🔐 Arabica Authentication Status
162
-
163
- ✓ arabica (dev): Logged in
164
- ✗ arabica (test): Not logged in
165
- ✗ arabica (prod-cn): Not logged in
166
- ✗ arabica (prod-jp): Not logged in
167
- ```
168
-
169
- **Implementation Notes:**
170
- - Checks all four environments (dev, test, prod-cn, prod-jp)
171
- - Uses `tokenManager.getToken({ service: 'arabica', environment })` for each environment
172
- - No tenant component in token key since Arabica is single-tenant
173
- - Output uses chalk for colored status indicators (green checkmark for logged in, red X for not logged in)
174
-
175
- ---
176
-
177
- ### logout
178
-
179
- Logout from Arabica and clear stored tokens.
180
-
181
- **Usage:**
182
- ```
183
- barista arabica auth logout [options]
184
- ```
185
-
186
- **Options:**
187
-
188
- | Option | Type | Required | Default | Description |
189
- |--------|------|----------|---------|-------------|
190
- | --env | string | No | Current context | Target environment to logout from |
191
- | --all | boolean | No | false | Clear all Arabica tokens across environments |
192
-
193
- **Examples:**
194
-
195
- Logout from current environment:
196
- ```bash
197
- barista arabica auth logout
198
- ```
199
-
200
- Logout from specific environment:
201
- ```bash
202
- barista arabica auth logout --env dev
203
- ```
204
-
205
- Logout from all environments:
206
- ```bash
207
- barista arabica auth logout --all
208
- ```
209
-
210
- **Implementation Notes:**
211
- - Without `--all`, clears token for the specified (or current) environment only
212
- - With `--all`, iterates through all credentials in keychain and deletes those with `arabica:*` prefix
213
- - Uses `tokenManager.deleteToken()` for single environment logout
214
- - Uses `tokenManager.findAllTokens()` and filters by service name for `--all` logout
215
-
216
- ---
217
-
218
- ## Arabica vs Liberica Comparison Table
219
-
220
- | Feature | Arabica Auth | Liberica Auth |
221
- |---------|--------------|---------------|
222
- | **Platform Type** | Single-tenant SaaS | Multi-tenant SaaS |
223
- | **Tenant Required** | No | Yes (required) |
224
- | **Login Identifier** | Account (username/email) | Username + Tenant |
225
- | **Registration** | Supported | Not supported (admin only) |
226
- | **Remember Me** | Supported | Not supported |
227
- | **Token Key Format** | `arabica:{environment}` | `liberica:{environment}:{tenant}` |
228
- | **Login Endpoint** | `POST /api/login` | `POST /api/enterprise/loginApi` |
229
- | **Register Endpoint** | `POST /api/member/user/register` | N/A |
230
-
231
- ## File Structure
232
-
233
- ```
234
- src/commands/arabica/auth/
235
- ├── index.ts # Main auth command with login, register, status, logout implementations
236
- ├── login.ts # Login command factory (stub for future expansion)
237
- ├── register.ts # Register command factory (stub for future expansion)
238
- ├── status.ts # Status command factory (stub for future expansion)
239
- └── logout.ts # Logout command factory (stub for future expansion)
240
- ```
241
-
242
- **Implementation Pattern:**
243
-
244
- All four subcommands are implemented directly in `index.ts` using Commander.js `.command()` chaining. The individual files (`login.ts`, `register.ts`, `status.ts`, `logout.ts`) export factory functions that create empty Command instances for potential future refactoring.
245
-
246
- ```typescript
247
- // index.ts pattern
248
- authCommand
249
- .command('login')
250
- .description('Login to Arabica')
251
- .arguments('<env> [account] [password]')
252
- .option('--env <environment>', 'Environment')
253
- .option('--account <account>', 'Account')
254
- .option('--password <password>', 'Password')
255
- .option('--remember', 'Remember login status')
256
- .action(async (env, account, password, options) => {
257
- // Implementation
258
- });
259
- ```
260
-
261
- ## Unit Tests
262
-
263
- Test file: `tests/unit/commands/arabica/auth.test.ts`
264
-
265
- **Test Coverage:**
266
-
267
- | Test Case | Description |
268
- |-----------|-------------|
269
- | Command creation | Verifies auth command is created with correct name and description |
270
- | Login subcommand | Tests login command existence, description, and all options (--env, --account, --password, --remember) |
271
- | Register subcommand | Tests register command existence, description, and all options (--env, --email, --account, --password, --phone) |
272
- | Status subcommand | Tests status command existence, description, and zero options |
273
- | Logout subcommand | Tests logout command existence, description, and options (--env, --all) |
274
- | No tenant option | Verifies Arabica login does NOT have --tenant option (unlike Liberica) |
275
- | Integration mocks | Verifies apiClient and tokenManager methods are called correctly |
276
-
277
- **Mock Strategy:**
278
-
279
- ```typescript
280
- // Key modules are mocked for unit testing
281
- vi.mock('../../../../src/core/config/manager.js');
282
- vi.mock('../../../../src/core/auth/token-manager.js');
283
- vi.mock('../../../../src/core/api/client.js');
284
- vi.mock('chalk');
285
- vi.mock('inquirer');
286
- ```
287
-
288
- **Running Tests:**
289
-
290
- ```bash
291
- # Run all Arabica auth tests
292
- npm test -- tests/unit/commands/arabica/auth.test.ts
293
-
294
- # Run with coverage
295
- npm run test:coverage -- tests/unit/commands/arabica/auth.test.ts
296
- ```
@@ -1,133 +0,0 @@
1
- # liberica auth
2
-
3
- 管理 Liberica 租户身份认证。
4
-
5
- ## Commands
6
-
7
- ### login
8
-
9
- 登录 Liberica 租户账户。
10
-
11
- **Usage:**
12
- ```
13
- barista liberica auth login [env] [tenant] [username] [password] [options]
14
- ```
15
-
16
- **Arguments:**
17
- | 参数 | 类型 | 必填 | 说明 |
18
- |------|------|------|------|
19
- | env | string | ⬜ | 目标环境 (dev\|test\|prod-cn\|prod-jp) |
20
- | tenant | string | ⬜ | 租户名称 |
21
- | username | string | ⬜ | 用户名 |
22
- | password | string | ⬜ | 密码 |
23
-
24
- **Options:**
25
- | 选项 | 类型 | 必填 | 默认值 | 说明 |
26
- |------|------|------|--------|------|
27
- | --env | string | ⬜ | 当前上下文 | 目标环境 |
28
- | --tenant | string | ⬜ | 当前上下文 | 租户名称 |
29
- | --username | string | ⬜ | 交互输入 | 用户名 |
30
- | --password | string | ⬜ | 交互输入 | 密码 |
31
-
32
- **Examples:**
33
-
34
- Interactive mode (all args prompted):
35
- ```bash
36
- barista liberica auth login
37
- ```
38
-
39
- With positional arguments:
40
- ```bash
41
- barista liberica auth login dev shanghai admin@shanghai.newpeaksh.com 123456
42
- ```
43
-
44
- With options:
45
- ```bash
46
- barista liberica auth login --env dev --tenant shanghai --username admin@shanghai.newpeaksh.com --password 123456
47
- ```
48
-
49
- Mixed (positional + options):
50
- ```bash
51
- barista liberica auth login dev --tenant shanghai --username admin@shanghai.newpeaksh.com --password 123456
52
- ```
53
-
54
- **API:**
55
- - Endpoint: `POST /api/v1/auth/login`
56
- - Body: `{ username, password, tenant, service, environment }`
57
- - Response: `{ success: true, data: { token, expiresAt } }`
58
-
59
- **Error Codes:**
60
- | 错误码 | 错误消息 | 触发条件 |
61
- |--------|----------|----------|
62
- | USER_NOT_EXIST | 用户不存在 | 用户名未注册 |
63
- | PASSWORD_ERROR | 密码错误 | 密码不匹配 |
64
- | NETWORK_ERROR | 网络错误 | 无法连接到服务器 |
65
-
66
- **Implementation Notes:**
67
- - 交互式补全:tenant/username/password 未提供时使用 inquirer 交互输入
68
- - Token存储:成功登录后调用 `tokenManager.setToken()` 存入系统密钥链
69
- - 上下文更新:调用 `configManager.setTenant()` 更新默认租户
70
-
71
- ---
72
-
73
- ### status
74
-
75
- 检查 Liberica 认证状态。
76
-
77
- **Usage:**
78
- ```
79
- barista liberica auth status
80
- ```
81
-
82
- **Output:**
83
- ```
84
- 🔐 Liberica Authentication Status
85
-
86
- ✓ liberica (electionjp) (dev): Logged in
87
- ✗ liberica (electionjp) (test): Not logged in
88
- ✗ liberica (electionjp) (prod-cn): Not logged in
89
- ✗ liberica (electionjp) (prod-jp): Not logged in
90
- ```
91
-
92
- **Implementation Notes:**
93
- - 遍历所有环境检查 Token 状态
94
- - 使用 `tokenManager.getToken()` 检查密钥链
95
-
96
- ---
97
-
98
- ### logout
99
-
100
- 登出并清除 Token。
101
-
102
- **Usage:**
103
- ```
104
- barista liberica auth logout [options]
105
- ```
106
-
107
- **Options:**
108
- | 选项 | 类型 | 必填 | 默认值 | 说明 |
109
- |------|------|------|--------|------|
110
- | --env | string | ⬜ | 当前上下文 | 目标环境 |
111
- | --all | boolean | ⬜ | false | 清除所有 Liberica Token |
112
-
113
- **Examples:**
114
-
115
- Logout current environment:
116
- ```bash
117
- barista liberica auth logout --env dev
118
- ```
119
-
120
- Logout all environments:
121
- ```bash
122
- barista liberica auth logout --all
123
- ```
124
-
125
- **Implementation Notes:**
126
- - 使用 `tokenManager.deleteToken()` 删除指定环境的 Token
127
- - 使用 `tokenManager.findAllTokens()` 遍历所有 Token
128
-
129
- ---
130
-
131
- ## Design Reference
132
-
133
- 完整设计文档见:[命令设计规范](../../COMMAND_DESIGN_SPEC.md#61-示例liberica-auth-login-命令)