@newpeak/barista-cli 0.1.11 → 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.
- package/dist/index.js +1 -1
- package/package.json +7 -3
- package/docs/ARCHITECTURE.md +0 -184
- package/docs/COMMANDS.md +0 -352
- package/docs/COMMAND_DESIGN_SPEC.md +0 -840
- package/docs/INTEGRATION_NOTES.md +0 -270
- package/docs/commands/REFERENCE.md +0 -323
- package/docs/commands/arabica/auth/index.md +0 -296
- package/docs/commands/liberica/auth/index.md +0 -133
- package/docs/commands/liberica/calendar/DESIGN.md +0 -333
- package/docs/commands/liberica/client-contacts/create.md +0 -152
- package/docs/commands/liberica/client-contacts/delete.md +0 -123
- package/docs/commands/liberica/client-contacts/get.md +0 -133
- package/docs/commands/liberica/client-contacts/list.md +0 -143
- package/docs/commands/liberica/client-contacts/update.md +0 -158
- package/docs/commands/liberica/context/index.md +0 -60
- package/docs/commands/liberica/currency/create.md +0 -145
- package/docs/commands/liberica/currency/delete.md +0 -121
- package/docs/commands/liberica/currency/disable.md +0 -119
- package/docs/commands/liberica/currency/enable.md +0 -115
- package/docs/commands/liberica/currency/get.md +0 -118
- package/docs/commands/liberica/currency/list.md +0 -149
- package/docs/commands/liberica/currency/update.md +0 -141
- package/docs/commands/liberica/employees/create.md +0 -185
- package/docs/commands/liberica/employees/disable.md +0 -138
- package/docs/commands/liberica/employees/enable.md +0 -137
- package/docs/commands/liberica/employees/get.md +0 -153
- package/docs/commands/liberica/employees/list.md +0 -168
- package/docs/commands/liberica/employees/update.md +0 -180
- package/docs/commands/liberica/locations/create.md +0 -195
- package/docs/commands/liberica/locations/list.md +0 -171
- package/docs/commands/liberica/materials/create.md +0 -293
- package/docs/commands/liberica/materials/delete.md +0 -240
- package/docs/commands/liberica/materials/disable.md +0 -150
- package/docs/commands/liberica/materials/enable.md +0 -146
- package/docs/commands/liberica/materials/get.md +0 -188
- package/docs/commands/liberica/materials/list.md +0 -198
- package/docs/commands/liberica/materials/update.md +0 -250
- package/docs/commands/liberica/orgs/list.md +0 -62
- package/docs/commands/liberica/positions/list.md +0 -61
- package/docs/commands/liberica/roles/list.md +0 -67
- package/docs/commands/liberica/stock/ledger.md +0 -209
- package/docs/commands/liberica/stock/list.md +0 -165
- package/docs/commands/liberica/supplier-contacts/create.md +0 -152
- package/docs/commands/liberica/supplier-contacts/delete.md +0 -123
- package/docs/commands/liberica/supplier-contacts/get.md +0 -133
- package/docs/commands/liberica/supplier-contacts/list.md +0 -143
- package/docs/commands/liberica/supplier-contacts/update.md +0 -158
- package/docs/commands/liberica/teams/issues/close.md +0 -161
- package/docs/commands/liberica/teams/issues/create.md +0 -212
- package/docs/commands/liberica/teams/issues/delete.md +0 -179
- package/docs/commands/liberica/teams/issues/get.md +0 -167
- package/docs/commands/liberica/teams/issues/list.md +0 -182
- package/docs/commands/liberica/teams/issues/tests-design.md +0 -341
- package/docs/commands/liberica/teams/issues/update.md +0 -202
- package/docs/commands/liberica/teams/projects/create.md +0 -174
- package/docs/commands/liberica/teams/projects/delete.md +0 -180
- package/docs/commands/liberica/teams/projects/get.md +0 -150
- package/docs/commands/liberica/teams/projects/list.md +0 -179
- package/docs/commands/liberica/teams/projects/update.md +0 -175
- package/docs/commands/liberica/teams/tasks/create.md +0 -163
- package/docs/commands/liberica/teams/tasks/delete.md +0 -109
- package/docs/commands/liberica/teams/tasks/get.md +0 -121
- package/docs/commands/liberica/teams/tasks/list.md +0 -148
- package/docs/commands/liberica/teams/tasks/update.md +0 -158
- package/docs/commands/liberica/teams/work-logs/create.md +0 -151
- package/docs/commands/liberica/teams/work-logs/delete.md +0 -130
- package/docs/commands/liberica/teams/work-logs/get.md +0 -131
- package/docs/commands/liberica/teams/work-logs/list.md +0 -153
- package/docs/commands/liberica/teams/work-logs/update.md +0 -150
- package/docs/commands/liberica/transfer-in-forms/batch-delete.md +0 -157
- package/docs/commands/liberica/transfer-in-forms/batch-review.md +0 -157
- package/docs/commands/liberica/transfer-in-forms/batch-unreview.md +0 -157
- package/docs/commands/liberica/transfer-in-forms/create.md +0 -220
- package/docs/commands/liberica/transfer-in-forms/get.md +0 -221
- package/docs/commands/liberica/transfer-in-forms/list.md +0 -242
- package/docs/commands/liberica/transfer-in-forms/update.md +0 -185
- package/docs/commands/liberica/transfer-out-forms/batch-delete.md +0 -187
- package/docs/commands/liberica/transfer-out-forms/batch-review.md +0 -157
- package/docs/commands/liberica/transfer-out-forms/batch-unreview.md +0 -157
- package/docs/commands/liberica/transfer-out-forms/create.md +0 -280
- package/docs/commands/liberica/transfer-out-forms/get.md +0 -211
- package/docs/commands/liberica/transfer-out-forms/list.md +0 -233
- package/docs/commands/liberica/transfer-out-forms/update.md +0 -286
- package/docs/commands/liberica/uoms/create.md +0 -136
- package/docs/commands/liberica/uoms/delete.md +0 -119
- package/docs/commands/liberica/uoms/disable.md +0 -117
- package/docs/commands/liberica/uoms/enable.md +0 -115
- package/docs/commands/liberica/uoms/get.md +0 -119
- package/docs/commands/liberica/uoms/list.md +0 -155
- package/docs/commands/liberica/uoms/update.md +0 -148
- package/docs/commands/liberica/users/create.md +0 -170
- package/docs/commands/liberica/users/get.md +0 -151
- package/docs/commands/liberica/users/list.md +0 -175
- package/docs/commands/liberica/warehouses/create.md +0 -222
- package/docs/commands/liberica/warehouses/list.md +0 -184
- package/src/commands/arabica/auth/index.ts +0 -277
- package/src/commands/arabica/auth/login.ts +0 -5
- package/src/commands/arabica/auth/logout.ts +0 -5
- package/src/commands/arabica/auth/register.ts +0 -5
- package/src/commands/arabica/auth/status.ts +0 -5
- package/src/commands/arabica/index.ts +0 -23
- package/src/commands/auth.ts +0 -107
- package/src/commands/context.ts +0 -60
- package/src/commands/liberica/auth/index.ts +0 -176
- package/src/commands/liberica/calendar/index.ts +0 -13
- package/src/commands/liberica/calendar/list.ts +0 -214
- package/src/commands/liberica/calendar/set.ts +0 -130
- package/src/commands/liberica/client-contacts/create.ts +0 -115
- package/src/commands/liberica/client-contacts/delete.ts +0 -140
- package/src/commands/liberica/client-contacts/get.ts +0 -103
- package/src/commands/liberica/client-contacts/index.ts +0 -19
- package/src/commands/liberica/client-contacts/list.ts +0 -118
- package/src/commands/liberica/client-contacts/update.ts +0 -137
- package/src/commands/liberica/clients/create.ts +0 -122
- package/src/commands/liberica/clients/delete.ts +0 -125
- package/src/commands/liberica/clients/get.ts +0 -88
- package/src/commands/liberica/clients/index.ts +0 -19
- package/src/commands/liberica/clients/list.ts +0 -123
- package/src/commands/liberica/clients/update.ts +0 -103
- package/src/commands/liberica/context/index.ts +0 -43
- package/src/commands/liberica/currency/create.ts +0 -183
- package/src/commands/liberica/currency/delete.ts +0 -124
- package/src/commands/liberica/currency/disable.ts +0 -147
- package/src/commands/liberica/currency/enable.ts +0 -128
- package/src/commands/liberica/currency/get.ts +0 -91
- package/src/commands/liberica/currency/index.ts +0 -23
- package/src/commands/liberica/currency/list.ts +0 -140
- package/src/commands/liberica/currency/update.ts +0 -129
- package/src/commands/liberica/dict-types/get.ts +0 -74
- package/src/commands/liberica/dict-types/index.ts +0 -15
- package/src/commands/liberica/dict-types/list.ts +0 -118
- package/src/commands/liberica/dict-types/update.ts +0 -134
- package/src/commands/liberica/dicts/create.ts +0 -175
- package/src/commands/liberica/dicts/delete.ts +0 -107
- package/src/commands/liberica/dicts/get.ts +0 -80
- package/src/commands/liberica/dicts/index.ts +0 -19
- package/src/commands/liberica/dicts/list.ts +0 -114
- package/src/commands/liberica/dicts/update.ts +0 -116
- package/src/commands/liberica/employees/create.ts +0 -275
- package/src/commands/liberica/employees/delete.ts +0 -122
- package/src/commands/liberica/employees/disable.ts +0 -97
- package/src/commands/liberica/employees/enable.ts +0 -97
- package/src/commands/liberica/employees/get.ts +0 -115
- package/src/commands/liberica/employees/index.ts +0 -23
- package/src/commands/liberica/employees/list.ts +0 -131
- package/src/commands/liberica/employees/update.ts +0 -157
- package/src/commands/liberica/index.ts +0 -81
- package/src/commands/liberica/materials/create.ts +0 -199
- package/src/commands/liberica/materials/delete.ts +0 -105
- package/src/commands/liberica/materials/disable.ts +0 -148
- package/src/commands/liberica/materials/enable.ts +0 -129
- package/src/commands/liberica/materials/get.ts +0 -83
- package/src/commands/liberica/materials/index.ts +0 -23
- package/src/commands/liberica/materials/list.ts +0 -142
- package/src/commands/liberica/materials/update.ts +0 -125
- package/src/commands/liberica/mould/get.ts +0 -111
- package/src/commands/liberica/mould/index.ts +0 -17
- package/src/commands/liberica/mould/list.ts +0 -157
- package/src/commands/liberica/mould/set-status.ts +0 -99
- package/src/commands/liberica/mould/stock-in.ts +0 -165
- package/src/commands/liberica/operations/active.ts +0 -153
- package/src/commands/liberica/operations/batch-delete.ts +0 -131
- package/src/commands/liberica/operations/copy.ts +0 -138
- package/src/commands/liberica/operations/create.ts +0 -223
- package/src/commands/liberica/operations/deactive.ts +0 -152
- package/src/commands/liberica/operations/delete.ts +0 -128
- package/src/commands/liberica/operations/design.md +0 -587
- package/src/commands/liberica/operations/get.ts +0 -112
- package/src/commands/liberica/operations/index.ts +0 -27
- package/src/commands/liberica/operations/list.ts +0 -180
- package/src/commands/liberica/operations/update.ts +0 -218
- package/src/commands/liberica/orgs/index.ts +0 -34
- package/src/commands/liberica/positions/index.ts +0 -30
- package/src/commands/liberica/roles/index.ts +0 -59
- package/src/commands/liberica/stock/index.ts +0 -13
- package/src/commands/liberica/stock/ledger.ts +0 -159
- package/src/commands/liberica/stock/list.ts +0 -128
- package/src/commands/liberica/supplier-contacts/create.ts +0 -120
- package/src/commands/liberica/supplier-contacts/delete.ts +0 -88
- package/src/commands/liberica/supplier-contacts/get.ts +0 -94
- package/src/commands/liberica/supplier-contacts/index.ts +0 -19
- package/src/commands/liberica/supplier-contacts/list.ts +0 -130
- package/src/commands/liberica/supplier-contacts/update.ts +0 -127
- package/src/commands/liberica/suppliers/create.ts +0 -149
- package/src/commands/liberica/suppliers/delete.ts +0 -102
- package/src/commands/liberica/suppliers/disable.ts +0 -145
- package/src/commands/liberica/suppliers/enable.ts +0 -126
- package/src/commands/liberica/suppliers/get.ts +0 -86
- package/src/commands/liberica/suppliers/index.ts +0 -23
- package/src/commands/liberica/suppliers/list.ts +0 -134
- package/src/commands/liberica/suppliers/update.ts +0 -128
- package/src/commands/liberica/teams/index.ts +0 -17
- package/src/commands/liberica/teams/issues/close.ts +0 -104
- package/src/commands/liberica/teams/issues/create.ts +0 -254
- package/src/commands/liberica/teams/issues/delete.ts +0 -58
- package/src/commands/liberica/teams/issues/get.ts +0 -78
- package/src/commands/liberica/teams/issues/index.ts +0 -21
- package/src/commands/liberica/teams/issues/list.ts +0 -144
- package/src/commands/liberica/teams/issues/update.ts +0 -141
- package/src/commands/liberica/teams/projects/create.ts +0 -159
- package/src/commands/liberica/teams/projects/delete.ts +0 -58
- package/src/commands/liberica/teams/projects/get.ts +0 -87
- package/src/commands/liberica/teams/projects/index.ts +0 -19
- package/src/commands/liberica/teams/projects/list.ts +0 -147
- package/src/commands/liberica/teams/projects/update.ts +0 -117
- package/src/commands/liberica/teams/tasks/create.ts +0 -102
- package/src/commands/liberica/teams/tasks/delete.ts +0 -92
- package/src/commands/liberica/teams/tasks/get.ts +0 -64
- package/src/commands/liberica/teams/tasks/index.ts +0 -19
- package/src/commands/liberica/teams/tasks/list.ts +0 -102
- package/src/commands/liberica/teams/tasks/update.ts +0 -122
- package/src/commands/liberica/teams/work-logs/create.ts +0 -204
- package/src/commands/liberica/teams/work-logs/delete.ts +0 -58
- package/src/commands/liberica/teams/work-logs/get.ts +0 -87
- package/src/commands/liberica/teams/work-logs/index.ts +0 -19
- package/src/commands/liberica/teams/work-logs/list.ts +0 -141
- package/src/commands/liberica/teams/work-logs/update.ts +0 -120
- package/src/commands/liberica/transfer-in-forms/batch-delete.ts +0 -152
- package/src/commands/liberica/transfer-in-forms/batch-review.ts +0 -151
- package/src/commands/liberica/transfer-in-forms/batch-unreview.ts +0 -152
- package/src/commands/liberica/transfer-in-forms/create.ts +0 -179
- package/src/commands/liberica/transfer-in-forms/get.ts +0 -107
- package/src/commands/liberica/transfer-in-forms/index.ts +0 -23
- package/src/commands/liberica/transfer-in-forms/list.ts +0 -97
- package/src/commands/liberica/transfer-in-forms/update.ts +0 -213
- package/src/commands/liberica/transfer-out-forms/batch-delete.ts +0 -83
- package/src/commands/liberica/transfer-out-forms/batch-review.ts +0 -148
- package/src/commands/liberica/transfer-out-forms/batch-unreview.ts +0 -56
- package/src/commands/liberica/transfer-out-forms/create.ts +0 -194
- package/src/commands/liberica/transfer-out-forms/get.ts +0 -114
- package/src/commands/liberica/transfer-out-forms/index.ts +0 -23
- package/src/commands/liberica/transfer-out-forms/list.ts +0 -125
- package/src/commands/liberica/transfer-out-forms/update.ts +0 -197
- package/src/commands/liberica/uoms/create.ts +0 -134
- package/src/commands/liberica/uoms/delete.ts +0 -105
- package/src/commands/liberica/uoms/disable.ts +0 -148
- package/src/commands/liberica/uoms/enable.ts +0 -129
- package/src/commands/liberica/uoms/get.ts +0 -83
- package/src/commands/liberica/uoms/index.ts +0 -23
- package/src/commands/liberica/uoms/list.ts +0 -129
- package/src/commands/liberica/uoms/update.ts +0 -124
- package/src/commands/liberica/users/create.ts +0 -133
- package/src/commands/liberica/users/delete.ts +0 -49
- package/src/commands/liberica/users/disable.ts +0 -41
- package/src/commands/liberica/users/enable.ts +0 -30
- package/src/commands/liberica/users/get.ts +0 -46
- package/src/commands/liberica/users/index.ts +0 -27
- package/src/commands/liberica/users/list.ts +0 -68
- package/src/commands/liberica/users/me.ts +0 -42
- package/src/commands/liberica/users/reset-password.ts +0 -42
- package/src/commands/liberica/users/update.ts +0 -48
- package/src/commands/liberica/warehouses/create.ts +0 -204
- package/src/commands/liberica/warehouses/delete.ts +0 -112
- package/src/commands/liberica/warehouses/disable.ts +0 -174
- package/src/commands/liberica/warehouses/enable.ts +0 -174
- package/src/commands/liberica/warehouses/get.ts +0 -101
- package/src/commands/liberica/warehouses/index.ts +0 -25
- package/src/commands/liberica/warehouses/list.ts +0 -136
- package/src/commands/liberica/warehouses/locations/create.ts +0 -209
- package/src/commands/liberica/warehouses/locations/delete.ts +0 -116
- package/src/commands/liberica/warehouses/locations/disable.ts +0 -174
- package/src/commands/liberica/warehouses/locations/enable.ts +0 -174
- package/src/commands/liberica/warehouses/locations/get.ts +0 -84
- package/src/commands/liberica/warehouses/locations/index.ts +0 -23
- package/src/commands/liberica/warehouses/locations/list.ts +0 -140
- package/src/commands/liberica/warehouses/locations/update.ts +0 -135
- package/src/commands/liberica/warehouses/update.ts +0 -142
- package/src/core/api/client.ts +0 -4443
- package/src/core/auth/token-manager.ts +0 -183
- package/src/core/config/manager.ts +0 -164
- package/src/index.ts +0 -35
- package/src/types/calendar.ts +0 -36
- package/src/types/client-contact.ts +0 -78
- package/src/types/client.ts +0 -115
- package/src/types/currency.ts +0 -90
- package/src/types/dict.ts +0 -121
- package/src/types/employee.ts +0 -102
- package/src/types/index.ts +0 -93
- package/src/types/location.ts +0 -66
- package/src/types/material.ts +0 -61
- package/src/types/mould-stock-in.ts +0 -82
- package/src/types/mould.ts +0 -74
- package/src/types/operation.ts +0 -72
- package/src/types/org.ts +0 -25
- package/src/types/position.ts +0 -24
- package/src/types/stock.ts +0 -161
- package/src/types/supplier-contact.ts +0 -78
- package/src/types/supplier.ts +0 -66
- package/src/types/team-issue.ts +0 -94
- package/src/types/team-project.ts +0 -74
- package/src/types/team-task.ts +0 -98
- package/src/types/team-work-log.ts +0 -87
- package/src/types/transfer-in-form.ts +0 -265
- package/src/types/transfer-out-form.ts +0 -290
- package/src/types/uom.ts +0 -60
- package/src/types/user.ts +0 -64
- 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-命令)
|