@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.
- 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,153 +0,0 @@
|
|
|
1
|
-
# barista liberica employees get
|
|
2
|
-
|
|
3
|
-
获取单个员工详情。
|
|
4
|
-
|
|
5
|
-
## 2.1 命令元数据
|
|
6
|
-
|
|
7
|
-
| 字段 | 值 |
|
|
8
|
-
|------|-----|
|
|
9
|
-
| 完整命令 | `barista liberica employees get <id>` |
|
|
10
|
-
| 功能描述 | 获取单个员工详情 |
|
|
11
|
-
| HTTP方法 | GET |
|
|
12
|
-
| 是否需要认证 | ✅ 是 |
|
|
13
|
-
| 是否支持dry-run | ⬜ 否 |
|
|
14
|
-
|
|
15
|
-
## 2.2 后端接口引用
|
|
16
|
-
|
|
17
|
-
### Controller位置
|
|
18
|
-
```
|
|
19
|
-
coffee-liberica-end/
|
|
20
|
-
└── facade/liberica-facade-enterprise/
|
|
21
|
-
└── src/main/java/com/newpeak/liberica/facade/enterprise/controller/master/
|
|
22
|
-
└── EnterpriseEmployeeController.java
|
|
23
|
-
└── detail(@GetResource(path = "/detail"))
|
|
24
|
-
└── public ResponseData<MasterEmployeeResponse> detail(
|
|
25
|
-
@RequestHeader("X-TENANT-ID") Long tenantId,
|
|
26
|
-
@RequestParam("employeeId") Long employeeId
|
|
27
|
-
)
|
|
28
|
-
```
|
|
29
|
-
|
|
30
|
-
### Request DTO位置
|
|
31
|
-
```
|
|
32
|
-
coffee-liberica-end/
|
|
33
|
-
└── business/liberica-business-master/master-api/
|
|
34
|
-
└── src/main/java/com/newpeak/liberica/master/api/pojo/request/
|
|
35
|
-
└── MasterEmployeeRequest.java
|
|
36
|
-
└── employeeId: Long (@NotNull on detail)
|
|
37
|
-
```
|
|
38
|
-
|
|
39
|
-
### Response DTO位置
|
|
40
|
-
```
|
|
41
|
-
coffee-liberica-end/
|
|
42
|
-
└── business/liberica-business-master/master-api/
|
|
43
|
-
└── src/main/java/com/newpeak/liberica/master/api/pojo/response/
|
|
44
|
-
└── MasterEmployeeResponse.java
|
|
45
|
-
├── employeeId: Long
|
|
46
|
-
├── employeeCode: String
|
|
47
|
-
├── employeeName: String
|
|
48
|
-
├── employeeNo: String
|
|
49
|
-
├── employeePhone: String
|
|
50
|
-
├── employeeEmail: String
|
|
51
|
-
├── employeeSex: SexEnum
|
|
52
|
-
├── employeeIdType: String
|
|
53
|
-
├── employeeIdNo: String
|
|
54
|
-
├── employeeJoinedDate: Date
|
|
55
|
-
├── employeeLeaveDate: Date
|
|
56
|
-
├── employeeBirthday: Date
|
|
57
|
-
├── organizationId: Long
|
|
58
|
-
├── orgCode: String
|
|
59
|
-
├── orgName: String
|
|
60
|
-
├── organizationManagerFlag: String
|
|
61
|
-
├── positionId: String
|
|
62
|
-
├── positionName: String
|
|
63
|
-
├── jobType: String
|
|
64
|
-
├── jobLevelNo: String
|
|
65
|
-
├── evaluator1: String (员工编码)
|
|
66
|
-
├── evaluator2: String (员工编码)
|
|
67
|
-
├── coach: String (员工编码)
|
|
68
|
-
├── employeeStatus: String
|
|
69
|
-
├── statusFlag: Integer (1=enable, 2=disable)
|
|
70
|
-
├── employeeBankAccount: String
|
|
71
|
-
├── employeeDepositBank: String
|
|
72
|
-
├── account: String
|
|
73
|
-
├── encryptPassword: String
|
|
74
|
-
├── showQrCode: boolean
|
|
75
|
-
├── qrCode: String (SVG)
|
|
76
|
-
├── createTime: String
|
|
77
|
-
└── updateTime: String
|
|
78
|
-
```
|
|
79
|
-
|
|
80
|
-
## 2.3 CLI参数设计
|
|
81
|
-
|
|
82
|
-
### 命令结构
|
|
83
|
-
```
|
|
84
|
-
barista liberica employees get <id> [options]
|
|
85
|
-
```
|
|
86
|
-
|
|
87
|
-
### 位置参数
|
|
88
|
-
| 参数 | 类型 | 必填 | 说明 |
|
|
89
|
-
|------|------|------|------|
|
|
90
|
-
| id | number | ✅ | 员工ID (employeeId) |
|
|
91
|
-
|
|
92
|
-
### 全局选项
|
|
93
|
-
| 选项 | 类型 | 说明 |
|
|
94
|
-
|------|------|------|
|
|
95
|
-
| `--env` | string | 目标环境(dev\|test\|prod-cn\|prod-jp) |
|
|
96
|
-
| `--tenant` | string | 租户代码 |
|
|
97
|
-
| `--json` | boolean | JSON输出 |
|
|
98
|
-
|
|
99
|
-
### 命令选项
|
|
100
|
-
| 选项 | 短选项 | 类型 | 必填 | 默认值 | 说明 |
|
|
101
|
-
|------|--------|------|------|--------|------|
|
|
102
|
-
| — | — | — | — | — | 此命令无额外选项,ID 通过位置参数传入 |
|
|
103
|
-
|
|
104
|
-
## 2.4 字段映射表
|
|
105
|
-
|
|
106
|
-
| CLI参数 | DTO字段 | 类型转换 | 验证规则 |
|
|
107
|
-
|---------|---------|----------|----------|
|
|
108
|
-
| <id> (位置参数) | employeeId | string→Long | @NotNull, 必须为正整数 |
|
|
109
|
-
|
|
110
|
-
## 2.5 错误码引用
|
|
111
|
-
|
|
112
|
-
### ExceptionEnum位置
|
|
113
|
-
```
|
|
114
|
-
coffee-liberica-end/
|
|
115
|
-
└── business/liberica-business-master/master-api/
|
|
116
|
-
└── src/main/java/com/newpeak/liberica/master/api/exception/enums/
|
|
117
|
-
└── EmployeeExceptionEnum.java
|
|
118
|
-
├── MASTER_EMPLOYEE_NOT_EXISTED("01001150001", "查询结果不存在")
|
|
119
|
-
├── MASTER_EMPLOYEE_CODE_VALIDATE_NOT_EXIST_ERROR("01001150007", "指定{}不存在")
|
|
120
|
-
└── MASTER_EMPLOYEE_NAME_VALIDATE_NOT_EXIST_ERROR("01001150009", "指定{}不存在")
|
|
121
|
-
```
|
|
122
|
-
|
|
123
|
-
### 已知错误码
|
|
124
|
-
| 错误码 | 错误消息 | 触发条件 |
|
|
125
|
-
|--------|----------|----------|
|
|
126
|
-
| 01001150001 | 查询结果不存在 | employeeId 不存在或不属于当前租户 |
|
|
127
|
-
|
|
128
|
-
## 2.6 权限检查
|
|
129
|
-
|
|
130
|
-
| 检查项 | 位置 | 说明 |
|
|
131
|
-
|--------|------|------|
|
|
132
|
-
| 注解 | `@GetResource(path = "/detail")` | 无 requiredPermission |
|
|
133
|
-
|
|
134
|
-
## 2.7 实现要点
|
|
135
|
-
|
|
136
|
-
1. **位置参数**:`get` 命令使用 `<id>` 位置参数指定员工ID
|
|
137
|
-
2. **错误处理**:员工不存在时抛出 `MASTER_EMPLOYEE_NOT_EXISTED`,CLI 显示友好错误信息
|
|
138
|
-
3. **tenantId来源**:来自 X-TENANT-ID header,后端自动按租户隔离数据
|
|
139
|
-
4. **QR Code**:响应中包含 qrCode (SVG),可在需要时通过 --json 输出展示
|
|
140
|
-
|
|
141
|
-
## 2.8 示例用法
|
|
142
|
-
|
|
143
|
-
```bash
|
|
144
|
-
# 获取员工详情
|
|
145
|
-
barista liberica employees get 12345
|
|
146
|
-
|
|
147
|
-
# JSON 输出
|
|
148
|
-
barista liberica employees get 12345 --json
|
|
149
|
-
|
|
150
|
-
# 员工不存在
|
|
151
|
-
barista liberica employees get 99999
|
|
152
|
-
# 输出: Error: 员工不存在 (01001150001)
|
|
153
|
-
```
|
|
@@ -1,168 +0,0 @@
|
|
|
1
|
-
# barista liberica employees list
|
|
2
|
-
|
|
3
|
-
分页查询员工列表。
|
|
4
|
-
|
|
5
|
-
## 2.1 命令元数据
|
|
6
|
-
|
|
7
|
-
| 字段 | 值 |
|
|
8
|
-
|------|-----|
|
|
9
|
-
| 完整命令 | `barista liberica employees list` |
|
|
10
|
-
| 功能描述 | 分页查询员工列表 |
|
|
11
|
-
| HTTP方法 | GET |
|
|
12
|
-
| 是否需要认证 | ✅ 是 |
|
|
13
|
-
| 是否支持dry-run | ⬜ 否 |
|
|
14
|
-
|
|
15
|
-
## 2.2 后端接口引用
|
|
16
|
-
|
|
17
|
-
### Controller位置
|
|
18
|
-
```
|
|
19
|
-
coffee-liberica-end/
|
|
20
|
-
└── facade/liberica-facade-enterprise/
|
|
21
|
-
└── src/main/java/com/newpeak/liberica/facade/enterprise/controller/master/
|
|
22
|
-
└── EnterpriseEmployeeController.java
|
|
23
|
-
└── page(@GetResource(path = "/page"))
|
|
24
|
-
└── public ResponseData<PageResult<MasterEmployeeResponse>> page(
|
|
25
|
-
@RequestHeader("X-TENANT-ID") Long tenantId,
|
|
26
|
-
MasterEmployeeRequest request
|
|
27
|
-
)
|
|
28
|
-
```
|
|
29
|
-
|
|
30
|
-
### Request DTO位置
|
|
31
|
-
```
|
|
32
|
-
coffee-liberica-end/
|
|
33
|
-
└── business/liberica-business-master/master-api/
|
|
34
|
-
└── src/main/java/com/newpeak/liberica/master/api/pojo/request/
|
|
35
|
-
└── MasterEmployeeRequest.java
|
|
36
|
-
├── current: Long (分页当前页)
|
|
37
|
-
├── size: Long (分页大小)
|
|
38
|
-
├── searchText: String (搜索: 姓名/编码)
|
|
39
|
-
├── employeeStatus: String (在职状态)
|
|
40
|
-
├── organizationId: Long (部门ID)
|
|
41
|
-
├── excludeEmployeeCodeList: Set<String>
|
|
42
|
-
├── excludeEmployeeIdList: Set<Long>
|
|
43
|
-
├── searchBeginTime: String
|
|
44
|
-
└── searchEndTime: String
|
|
45
|
-
```
|
|
46
|
-
|
|
47
|
-
### Response DTO位置
|
|
48
|
-
```
|
|
49
|
-
coffee-liberica-end/
|
|
50
|
-
└── business/liberica-business-master/master-api/
|
|
51
|
-
└── src/main/java/com/newpeak/liberica/master/api/pojo/response/
|
|
52
|
-
└── MasterEmployeeResponse.java
|
|
53
|
-
├── employeeId: Long
|
|
54
|
-
├── employeeCode: String
|
|
55
|
-
├── employeeName: String
|
|
56
|
-
├── employeeNo: String
|
|
57
|
-
├── employeePhone: String
|
|
58
|
-
├── employeeEmail: String
|
|
59
|
-
├── employeeSex: SexEnum
|
|
60
|
-
├── organizationId: Long
|
|
61
|
-
├── orgName: String
|
|
62
|
-
├── positionId: String
|
|
63
|
-
├── positionName: String
|
|
64
|
-
├── statusFlag: Integer (1=enable, 2=disable)
|
|
65
|
-
├── createTime: String
|
|
66
|
-
└── updateTime: String
|
|
67
|
-
```
|
|
68
|
-
|
|
69
|
-
### 分页包装器
|
|
70
|
-
```
|
|
71
|
-
cn.stylefeng.roses.kernel.db.api.pojo.page.PageResult
|
|
72
|
-
├── total: long
|
|
73
|
-
├── size: long
|
|
74
|
-
├── current: long
|
|
75
|
-
└── records: List<MasterEmployeeResponse>
|
|
76
|
-
```
|
|
77
|
-
|
|
78
|
-
## 2.3 CLI参数设计
|
|
79
|
-
|
|
80
|
-
### 命令结构
|
|
81
|
-
```
|
|
82
|
-
barista liberica employees list [options]
|
|
83
|
-
```
|
|
84
|
-
|
|
85
|
-
### 全局选项
|
|
86
|
-
| 选项 | 类型 | 说明 |
|
|
87
|
-
|------|------|------|
|
|
88
|
-
| `--env` | string | 目标环境(dev\|test\|prod-cn\|prod-jp) |
|
|
89
|
-
| `--tenant` | string | 租户代码 |
|
|
90
|
-
| `--json` | boolean | JSON输出 |
|
|
91
|
-
|
|
92
|
-
### 命令选项
|
|
93
|
-
| 选项 | 短选项 | 类型 | 必填 | 默认值 | 说明 | 对应DTO字段 |
|
|
94
|
-
|------|--------|------|------|--------|------|-------------|
|
|
95
|
-
| --page | -p | number | ⬜ | 1 | 页码 | current |
|
|
96
|
-
| --size | -s | number | ⬜ | 20 | 每页条数 | size |
|
|
97
|
-
| --status | — | string | ⬜ | - | 在职状态 | employeeStatus |
|
|
98
|
-
| --org-id | — | number | ⬜ | - | 部门ID | organizationId |
|
|
99
|
-
| --search | — | string | ⬜ | - | 搜索关键词(姓名/编码) | searchText |
|
|
100
|
-
|
|
101
|
-
## 2.4 字段映射表
|
|
102
|
-
|
|
103
|
-
| CLI参数 | DTO字段 | 类型转换 | 验证规则 |
|
|
104
|
-
|---------|---------|----------|----------|
|
|
105
|
-
| --page / -p | current | number→Long | >= 1 |
|
|
106
|
-
| --size / -s | size | number→Long | 1-100 |
|
|
107
|
-
| --status | employeeStatus | 直接传递 | 枚举验证 |
|
|
108
|
-
| --org-id | organizationId | string→Long | - |
|
|
109
|
-
| --search | searchText | 直接传递 | - |
|
|
110
|
-
|
|
111
|
-
## 2.5 错误码引用
|
|
112
|
-
|
|
113
|
-
### ExceptionEnum位置
|
|
114
|
-
```
|
|
115
|
-
coffee-liberica-end/
|
|
116
|
-
└── business/liberica-business-master/master-api/
|
|
117
|
-
└── src/main/java/com/newpeak/liberica/master/api/exception/enums/
|
|
118
|
-
└── EmployeeExceptionEnum.java
|
|
119
|
-
├── MASTER_EMPLOYEE_NOT_EXISTED("01001150001", "查询结果不存在")
|
|
120
|
-
├── MASTER_EMPLOYEE_NAME_VALIDATE_NOT_EXIST_ERROR("01001150009", "指定{}不存在")
|
|
121
|
-
└── MASTER_EMPLOYEE_IMPORT_DATA_EMPTY("01001150010", "职员导入数据为空")
|
|
122
|
-
```
|
|
123
|
-
|
|
124
|
-
### 已知错误码
|
|
125
|
-
| 错误码 | 错误消息 | 触发条件 |
|
|
126
|
-
|--------|----------|----------|
|
|
127
|
-
| 01001150001 | 查询结果不存在 | 条件查询无匹配结果(通常返回空列表而非报错) |
|
|
128
|
-
|
|
129
|
-
## 2.6 权限检查
|
|
130
|
-
|
|
131
|
-
| 检查项 | 位置 | 说明 |
|
|
132
|
-
|--------|------|------|
|
|
133
|
-
| 注解 | `@GetResource(path = "/page")` | 无 requiredPermission(无需权限码) |
|
|
134
|
-
|
|
135
|
-
**注意**:list 和 page 接口在 Controller 层无需权限校验,数据范围通过 tenantId 隔离。
|
|
136
|
-
|
|
137
|
-
## 2.7 实现要点
|
|
138
|
-
|
|
139
|
-
1. **分页默认值**:page=1, size=20
|
|
140
|
-
2. **搜索行为**:searchText 同时匹配 employeeName 和 employeeCode(模糊查询)
|
|
141
|
-
3. **无结果处理**:返回空列表,不抛出异常
|
|
142
|
-
4. **tenantId来源**:来自 X-TENANT-ID header
|
|
143
|
-
5. **输出格式**:表格形式展示,分页信息在底部显示
|
|
144
|
-
|
|
145
|
-
## 2.8 示例用法
|
|
146
|
-
|
|
147
|
-
```bash
|
|
148
|
-
# 默认分页
|
|
149
|
-
barista liberica employees list
|
|
150
|
-
|
|
151
|
-
# 指定页码和每页条数
|
|
152
|
-
barista liberica employees list --page 2 --size 50
|
|
153
|
-
|
|
154
|
-
# 按部门筛选
|
|
155
|
-
barista liberica employees list --org-id 1001
|
|
156
|
-
|
|
157
|
-
# 按在职状态筛选
|
|
158
|
-
barista liberica employees list --status IN_SERVICE
|
|
159
|
-
|
|
160
|
-
# 关键词搜索
|
|
161
|
-
barista liberica employees list --search "张三"
|
|
162
|
-
|
|
163
|
-
# 组合筛选
|
|
164
|
-
barista liberica employees list --page 1 --size 10 --org-id 1001 --status IN_SERVICE
|
|
165
|
-
|
|
166
|
-
# JSON 输出(便于脚本处理)
|
|
167
|
-
barista liberica employees list --page 1 --size 20 --json
|
|
168
|
-
```
|
|
@@ -1,180 +0,0 @@
|
|
|
1
|
-
# barista liberica employees update
|
|
2
|
-
|
|
3
|
-
更新员工信息。
|
|
4
|
-
|
|
5
|
-
## 2.1 命令元数据
|
|
6
|
-
|
|
7
|
-
| 字段 | 值 |
|
|
8
|
-
|------|-----|
|
|
9
|
-
| 完整命令 | `barista liberica employees update <id>` |
|
|
10
|
-
| 功能描述 | 更新员工信息 |
|
|
11
|
-
| HTTP方法 | POST |
|
|
12
|
-
| 是否需要认证 | ✅ 是 |
|
|
13
|
-
| 是否支持dry-run | ✅ 是 |
|
|
14
|
-
|
|
15
|
-
## 2.2 后端接口引用
|
|
16
|
-
|
|
17
|
-
### Controller位置
|
|
18
|
-
```
|
|
19
|
-
coffee-liberica-end/
|
|
20
|
-
└── facade/liberica-facade-enterprise/
|
|
21
|
-
└── src/main/java/com/newpeak/liberica/facade/enterprise/controller/master/
|
|
22
|
-
└── EnterpriseEmployeeController.java
|
|
23
|
-
└── edit(@PostResource(path = "/edit", requiredPermission = true, requirePermissionCode = "EDIT_EMPLOYEE"))
|
|
24
|
-
└── public ResponseData<MasterEmployeeResponse> edit(
|
|
25
|
-
@RequestHeader("X-TENANT-ID") Long tenantId,
|
|
26
|
-
@RequestBody @Validated(BaseRequest.edit.class) MasterEmployeeRequest request
|
|
27
|
-
)
|
|
28
|
-
```
|
|
29
|
-
|
|
30
|
-
### Request DTO位置
|
|
31
|
-
```
|
|
32
|
-
coffee-liberica-end/
|
|
33
|
-
└── business/liberica-business-master/master-api/
|
|
34
|
-
└── src/main/java/com/newpeak/liberica/master/api/pojo/request/
|
|
35
|
-
└── MasterEmployeeRequest.java
|
|
36
|
-
├── employeeId: Long (@NotNull on edit) — 必须提供
|
|
37
|
-
├── employeeCode: String (@NotBlank on edit)
|
|
38
|
-
├── employeeName: String
|
|
39
|
-
├── employeePhone: String
|
|
40
|
-
├── employeeEmail: String
|
|
41
|
-
├── employeeSex: SexEnum
|
|
42
|
-
├── employeeIdType: String
|
|
43
|
-
├── employeeIdNo: String
|
|
44
|
-
├── employeeJoinedDate: Date
|
|
45
|
-
├── employeeBirthday: Date
|
|
46
|
-
├── organizationId: Long
|
|
47
|
-
├── organizationManagerFlag: String
|
|
48
|
-
├── positionId: String
|
|
49
|
-
├── jobType: String
|
|
50
|
-
├── jobLevelNo: Integer
|
|
51
|
-
├── evaluator1: String
|
|
52
|
-
├── evaluator2: String
|
|
53
|
-
├── coach: String
|
|
54
|
-
├── employeeBankAccount: String
|
|
55
|
-
└── employeeDepositBank: String
|
|
56
|
-
```
|
|
57
|
-
|
|
58
|
-
### Response DTO位置
|
|
59
|
-
```
|
|
60
|
-
coffee-liberica-end/
|
|
61
|
-
└── business/liberica-business-master/master-api/
|
|
62
|
-
└── src/main/java/com/newpeak/liberica/master/api/pojo/response/
|
|
63
|
-
└── MasterEmployeeResponse.java
|
|
64
|
-
├── employeeId: Long
|
|
65
|
-
├── employeeCode: String
|
|
66
|
-
├── employeeName: String
|
|
67
|
-
├── employeeNo: String
|
|
68
|
-
├── employeePhone: String
|
|
69
|
-
├── employeeEmail: String
|
|
70
|
-
├── employeeSex: SexEnum
|
|
71
|
-
├── organizationId: Long
|
|
72
|
-
├── orgName: String
|
|
73
|
-
├── positionId: String
|
|
74
|
-
├── positionName: String
|
|
75
|
-
├── statusFlag: Integer (1=enable, 2=disable)
|
|
76
|
-
├── createTime: String
|
|
77
|
-
└── updateTime: String
|
|
78
|
-
```
|
|
79
|
-
|
|
80
|
-
## 2.3 CLI参数设计
|
|
81
|
-
|
|
82
|
-
### 命令结构
|
|
83
|
-
```
|
|
84
|
-
barista liberica employees update <id> [options]
|
|
85
|
-
```
|
|
86
|
-
|
|
87
|
-
### 位置参数
|
|
88
|
-
| 参数 | 类型 | 必填 | 说明 |
|
|
89
|
-
|------|------|------|------|
|
|
90
|
-
| id | number | ✅ | 员工ID (employeeId) |
|
|
91
|
-
|
|
92
|
-
### 全局选项
|
|
93
|
-
| 选项 | 类型 | 说明 |
|
|
94
|
-
|------|------|------|
|
|
95
|
-
| `--env` | string | 目标环境(dev\|test\|prod-cn\|prod-jp) |
|
|
96
|
-
| `--tenant` | string | 租户代码 |
|
|
97
|
-
| `--dry-run` | boolean | 预览模式(不实际调用API) |
|
|
98
|
-
| `--json` | boolean | JSON输出 |
|
|
99
|
-
|
|
100
|
-
### 命令选项
|
|
101
|
-
| 选项 | 短选项 | 类型 | 必填 | 默认值 | 说明 | 对应DTO字段 |
|
|
102
|
-
|------|--------|------|------|--------|------|-------------|
|
|
103
|
-
| --name | -n | string | ⬜ | - | 员工姓名 | employeeName |
|
|
104
|
-
| --phone | -p | string | ⬜ | - | 手机号码 | employeePhone |
|
|
105
|
-
| --email | -e | string | ⬜ | - | 电子邮箱 | employeeEmail |
|
|
106
|
-
| --sex | -s | string | ⬜ | - | 性别 (M/F) | employeeSex |
|
|
107
|
-
| --position-id | — | string | ⬜ | - | 岗位ID | positionId |
|
|
108
|
-
| --joined-date | -d | string | ⬜ | - | 入职日期 (YYYY-MM-DD) | employeeJoinedDate |
|
|
109
|
-
| --org-id | — | number | ⬜ | - | 部门ID | organizationId |
|
|
110
|
-
|
|
111
|
-
**注意**:员工ID(employeeId)为必填,通过位置参数 `<id>` 传入。更新操作只发送变更的字段(部分更新)。
|
|
112
|
-
|
|
113
|
-
## 2.4 字段映射表
|
|
114
|
-
|
|
115
|
-
| CLI参数 | DTO字段 | 类型转换 | 验证规则 |
|
|
116
|
-
|---------|---------|----------|----------|
|
|
117
|
-
| <id> (位置参数) | employeeId | string→Long | @NotNull |
|
|
118
|
-
| --name / -n | employeeName | 直接传递 | max=255 |
|
|
119
|
-
| --phone / -p | employeePhone | 直接传递 | 手机号格式 |
|
|
120
|
-
| --email / -e | employeeEmail | 直接传递 | 邮箱格式 |
|
|
121
|
-
| --sex / -s | employeeSex | 直接传递 | M 或 F |
|
|
122
|
-
| --position-id | positionId | 直接传递 | - |
|
|
123
|
-
| --joined-date / -d | employeeJoinedDate | string→Date | yyyy-MM-dd |
|
|
124
|
-
| --org-id | organizationId | string→Long | - |
|
|
125
|
-
|
|
126
|
-
## 2.5 错误码引用
|
|
127
|
-
|
|
128
|
-
### ExceptionEnum位置
|
|
129
|
-
```
|
|
130
|
-
coffee-liberica-end/
|
|
131
|
-
└── business/liberica-business-master/master-api/
|
|
132
|
-
└── src/main/java/com/newpeak/liberica/master/api/exception/enums/
|
|
133
|
-
└── EmployeeExceptionEnum.java
|
|
134
|
-
├── MASTER_EMPLOYEE_NOT_EXISTED("01001150001", "查询结果不存在")
|
|
135
|
-
├── MASTER_EMPLOYEE_CODE_VALIDATE_NOT_EXIST_ERROR("01001150007", "指定{}不存在")
|
|
136
|
-
└── MASTER_EMPLOYEE_NAME_VALIDATE_NOT_EXIST_ERROR("01001150009", "指定{}不存在")
|
|
137
|
-
```
|
|
138
|
-
|
|
139
|
-
### 已知错误码
|
|
140
|
-
| 错误码 | 错误消息 | 触发条件 |
|
|
141
|
-
|--------|----------|----------|
|
|
142
|
-
| 01001150001 | 查询结果不存在 | employeeId 不存在或不属于当前租户 |
|
|
143
|
-
| 01001150007 | 指定xxx不存在 | 指定关联的员工编码不存在 |
|
|
144
|
-
|
|
145
|
-
## 2.6 权限检查
|
|
146
|
-
|
|
147
|
-
| 检查项 | 位置 | 说明 |
|
|
148
|
-
|--------|------|------|
|
|
149
|
-
| PermissionConstants | `LibericaPermissionCodeConstants.EDIT_EMPLOYEE` | Controller层 `@PostResource(requirePermissionCode = "EDIT_EMPLOYEE")` |
|
|
150
|
-
|
|
151
|
-
## 2.7 实现要点
|
|
152
|
-
|
|
153
|
-
1. **部分更新**:只发送需要更新的字段,未提供的字段保持原值
|
|
154
|
-
2. **必填位置参数**:`<id>` 必须指定,后端根据此ID定位记录
|
|
155
|
-
3. **Dry-run支持**:使用 --dry-run 时构造请求体但不发送,显示预览信息
|
|
156
|
-
4. **后端无预检**:edit() 方法直接调用 `updateById()`,不检查员工是否存在(由DB约束保证)
|
|
157
|
-
|
|
158
|
-
## 2.8 示例用法
|
|
159
|
-
|
|
160
|
-
```bash
|
|
161
|
-
# 更新员工姓名
|
|
162
|
-
barista liberica employees update 12345 --name "李四"
|
|
163
|
-
|
|
164
|
-
# 更新多个字段
|
|
165
|
-
barista liberica employees update 12345 \
|
|
166
|
-
--name "李四" \
|
|
167
|
-
--phone "13900139000" \
|
|
168
|
-
--email "lisi@example.com" \
|
|
169
|
-
--position-id "SENIOR_ENGINEER"
|
|
170
|
-
|
|
171
|
-
# Dry-run 预览
|
|
172
|
-
barista liberica employees update 12345 --name "李四" --dry-run
|
|
173
|
-
|
|
174
|
-
# JSON 输出
|
|
175
|
-
barista liberica employees update 12345 --name "李四" --json
|
|
176
|
-
|
|
177
|
-
# 员工不存在
|
|
178
|
-
barista liberica employees update 99999 --name "测试"
|
|
179
|
-
# 输出: Error: 员工不存在 (01001150001)
|
|
180
|
-
```
|
|
@@ -1,195 +0,0 @@
|
|
|
1
|
-
# barista liberica locations create
|
|
2
|
-
|
|
3
|
-
Create a new warehouse location.
|
|
4
|
-
|
|
5
|
-
## 2.1 Command Metadata
|
|
6
|
-
|
|
7
|
-
| Field | Value |
|
|
8
|
-
|------|-----|
|
|
9
|
-
| Full Command | `barista liberica locations create` |
|
|
10
|
-
| Description | Create a new warehouse location |
|
|
11
|
-
| HTTP Method | POST |
|
|
12
|
-
| Requires Authentication | Yes |
|
|
13
|
-
| Supports Dry-Run | Yes |
|
|
14
|
-
|
|
15
|
-
## 2.2 Backend API Reference
|
|
16
|
-
|
|
17
|
-
### Controller Location
|
|
18
|
-
```
|
|
19
|
-
coffee-liberica-end/
|
|
20
|
-
└── facade/liberica-facade-enterprise/
|
|
21
|
-
└── src/main/java/com/newpeak/liberica/facade/enterprise/controller/stock/
|
|
22
|
-
└── EnterpriseWarehouseLocationController.java
|
|
23
|
-
└── add(@PostResource(path = "/add", requiredPermission = true, requirePermissionCode = MasterWarehouseLocationPermissionConstants.ADD_MASTER_WAREHOUSE_LOCATION))
|
|
24
|
-
└── public ResponseData<MasterWarehouseLocationResponse> add(
|
|
25
|
-
@RequestHeader("X-TENANT-ID") Long tenantId,
|
|
26
|
-
@RequestBody @Validated(BaseRequest.add.class) MasterWarehouseLocationRequest masterWarehouseLocationRequest
|
|
27
|
-
)
|
|
28
|
-
```
|
|
29
|
-
|
|
30
|
-
### Request DTO Location
|
|
31
|
-
```
|
|
32
|
-
coffee-liberica-end/
|
|
33
|
-
└── business/liberica-business-master/master-api/
|
|
34
|
-
└── src/main/java/com/newpeak/liberica/master/api/pojo/request/
|
|
35
|
-
└── MasterWarehouseLocationRequest.java
|
|
36
|
-
├── warehouseId: Long (@NotNull on add)
|
|
37
|
-
├── warehouseLocationCode: String (@NotBlank on add, max=255)
|
|
38
|
-
├── warehouseLocationName: String (max=255)
|
|
39
|
-
├── statusFlag: Integer
|
|
40
|
-
└── remark: String (max=255)
|
|
41
|
-
```
|
|
42
|
-
|
|
43
|
-
### Response DTO Location
|
|
44
|
-
```
|
|
45
|
-
coffee-liberica-end/
|
|
46
|
-
└── business/liberica-business-master/master-api/
|
|
47
|
-
└── src/main/java/com/newpeak/liberica/master/api/pojo/response/
|
|
48
|
-
└── MasterWarehouseLocationResponse.java
|
|
49
|
-
├── warehouseLocationId: Long
|
|
50
|
-
├── warehouseId: Long
|
|
51
|
-
├── warehouseLocationCode: String
|
|
52
|
-
├── warehouseLocationName: String
|
|
53
|
-
├── statusFlag: Integer (1=enable, 2=disable)
|
|
54
|
-
└── remark: String
|
|
55
|
-
```
|
|
56
|
-
|
|
57
|
-
## 2.3 CLI Parameter Design
|
|
58
|
-
|
|
59
|
-
### Command Structure
|
|
60
|
-
```
|
|
61
|
-
barista liberica locations create [options]
|
|
62
|
-
```
|
|
63
|
-
|
|
64
|
-
### Global Options
|
|
65
|
-
| Option | Type | Description |
|
|
66
|
-
|------|------|------|
|
|
67
|
-
| `--env` | string | Target environment (dev\|test\|prod-cn\|prod-jp) |
|
|
68
|
-
| `--tenant` | string | Tenant code |
|
|
69
|
-
| `--dry-run` | boolean | Preview mode (no actual API call) |
|
|
70
|
-
| `--json` | boolean | JSON output |
|
|
71
|
-
|
|
72
|
-
### Command Options
|
|
73
|
-
| Option | Short | Type | Required | Default | Description | Maps to DTO Field |
|
|
74
|
-
|------|--------|------|------|--------|------|-------------|
|
|
75
|
-
| --warehouse-id | -w | string | Yes | - | Parent warehouse ID | warehouseId |
|
|
76
|
-
| --code | -c | string | Yes | - | Location code | warehouseLocationCode |
|
|
77
|
-
| --name | -n | string | Yes | - | Location name | warehouseLocationName |
|
|
78
|
-
| --status | -s | number | No | 1 | Status (1=enable, 2=disable) | statusFlag |
|
|
79
|
-
| --remark | -r | string | No | - | Remarks | remark |
|
|
80
|
-
|
|
81
|
-
## 2.4 Field Mapping Table
|
|
82
|
-
|
|
83
|
-
| CLI Parameter | DTO Field | Type Conversion | Validation Rule |
|
|
84
|
-
|---------|---------|----------|----------|
|
|
85
|
-
| --warehouse-id / -w | warehouseId | string | @NotNull, max=255 |
|
|
86
|
-
| --code / -c | warehouseLocationCode | Direct | @NotBlank, max=255, unique per warehouse |
|
|
87
|
-
| --name / -n | warehouseLocationName | Direct | max=255 |
|
|
88
|
-
| --status / -s | statusFlag | number | 1 or 2 |
|
|
89
|
-
| --remark / -r | remark | Direct | max=255 |
|
|
90
|
-
|
|
91
|
-
**Auto-Generated Fields:**
|
|
92
|
-
| Field | Value |
|
|
93
|
-
|------|-----|
|
|
94
|
-
| tenantId | From JWT token (do NOT pass X-TENANT-ID header) |
|
|
95
|
-
| statusFlag | Default 1 (enabled) when not provided |
|
|
96
|
-
|
|
97
|
-
## 2.5 Error Code Reference
|
|
98
|
-
|
|
99
|
-
### ExceptionEnum Location
|
|
100
|
-
```
|
|
101
|
-
coffee-liberica-end/
|
|
102
|
-
└── business/liberica-business-master/master-api/
|
|
103
|
-
└── src/main/java/com/newpeak/liberica/master/api/exception/enums/
|
|
104
|
-
└── MasterWarehouseLocationExceptionEnum.java
|
|
105
|
-
├── MASTER_WAREHOUSE_LOCATION_NOT_EXIST("01001380001", "租户仓位不存在")
|
|
106
|
-
├── MASTER_WAREHOUSE_LOCATION_CODE_FORMAT_CANNOT_EMPTY("01001380002", "仓位编码规则不能为空")
|
|
107
|
-
└── MASTER_WAREHOUSE_LOCATION_CODE_FORMAT_NOT_CORRECT("01001380003", "仓位编码规则格式不正确")
|
|
108
|
-
```
|
|
109
|
-
|
|
110
|
-
### Known Error Codes
|
|
111
|
-
| Error Code | Error Message | Trigger Condition |
|
|
112
|
-
|--------|----------|----------|
|
|
113
|
-
| 01001380001 | Location does not exist | Edit/detail with non-existent ID |
|
|
114
|
-
| 01001380002 | Location code format cannot be empty | Auto-generation rule not configured |
|
|
115
|
-
| 01001380003 | Location code format incorrect | Invalid code format pattern |
|
|
116
|
-
|
|
117
|
-
## 2.6 Permission Check
|
|
118
|
-
|
|
119
|
-
| Check Item | Location | Description |
|
|
120
|
-
|--------|------|------|
|
|
121
|
-
| PermissionConstants | `MasterWarehouseLocationPermissionConstants.ADD_MASTER_WAREHOUSE_LOCATION` | Controller layer `@PostResource(requirePermissionCode = "ADD_MASTER_WAREHOUSE_LOCATION")` |
|
|
122
|
-
|
|
123
|
-
## 2.7 Implementation Notes
|
|
124
|
-
|
|
125
|
-
1. **Required Fields**: `--warehouse-id`, `--code`, and `--name` must be provided.
|
|
126
|
-
2. **Manual Code**: `warehouseLocationCode` is NOT auto-generated. Must be unique within the warehouse.
|
|
127
|
-
3. **Dry-Run Support**: Use `--dry-run` to preview request without calling API.
|
|
128
|
-
4. **Status Default**: `--status` defaults to 1 (enabled).
|
|
129
|
-
5. **No Batch Create**: This command does NOT support batch creation (one location per call). Use `barista liberica locations batch-create` for bulk operations if implemented separately.
|
|
130
|
-
6. **BigInteger IDs**: `warehouseLocationId` and `warehouseId` in response must be parsed as `string` in TypeScript to avoid precision loss.
|
|
131
|
-
|
|
132
|
-
## 2.8 Example Usage
|
|
133
|
-
|
|
134
|
-
```bash
|
|
135
|
-
# Create with minimal required fields
|
|
136
|
-
barista liberica locations create \
|
|
137
|
-
--warehouse-id "1234567890123456789" \
|
|
138
|
-
--code "A-01-01" \
|
|
139
|
-
--name "Shelf A-01-01"
|
|
140
|
-
|
|
141
|
-
# Create with all options
|
|
142
|
-
barista liberica locations create \
|
|
143
|
-
--warehouse-id "1234567890123456789" \
|
|
144
|
-
--code "B-02-03" \
|
|
145
|
-
--name "Bin B-02-03" \
|
|
146
|
-
--status 1 \
|
|
147
|
-
--remark "High-priority picking zone"
|
|
148
|
-
|
|
149
|
-
# Create disabled location
|
|
150
|
-
barista liberica locations create \
|
|
151
|
-
--warehouse-id "1234567890123456789" \
|
|
152
|
-
--code "C-99-99" \
|
|
153
|
-
--name "Reserved" \
|
|
154
|
-
--status 2
|
|
155
|
-
|
|
156
|
-
# Dry-run to preview
|
|
157
|
-
barista liberica locations create \
|
|
158
|
-
--warehouse-id "1234567890123456789" \
|
|
159
|
-
--code "TEST-01" \
|
|
160
|
-
--name "Test Location" \
|
|
161
|
-
--dry-run
|
|
162
|
-
|
|
163
|
-
# JSON output
|
|
164
|
-
barista liberica locations create \
|
|
165
|
-
--warehouse-id "1234567890123456789" \
|
|
166
|
-
--code "D-04-01" \
|
|
167
|
-
--name "Dock D-04-01" \
|
|
168
|
-
--json
|
|
169
|
-
```
|
|
170
|
-
|
|
171
|
-
## 2.9 Request Body Structure
|
|
172
|
-
|
|
173
|
-
```json
|
|
174
|
-
{
|
|
175
|
-
"warehouseId": "1234567890123456789",
|
|
176
|
-
"warehouseLocationCode": "A-01-01",
|
|
177
|
-
"warehouseLocationName": "Shelf A-01-01",
|
|
178
|
-
"statusFlag": 1,
|
|
179
|
-
"remark": "High-priority picking zone"
|
|
180
|
-
}
|
|
181
|
-
```
|
|
182
|
-
|
|
183
|
-
## 2.10 API Path
|
|
184
|
-
|
|
185
|
-
```
|
|
186
|
-
POST /api/enterprise/purchases/warehouse/location/add
|
|
187
|
-
```
|
|
188
|
-
|
|
189
|
-
**Headers:**
|
|
190
|
-
```
|
|
191
|
-
Authorization: <token> (No "Bearer " prefix)
|
|
192
|
-
Content-Type: application/json
|
|
193
|
-
```
|
|
194
|
-
|
|
195
|
-
**Note**: Do NOT include `X-TENANT-ID` header. Tenant is extracted from JWT token.
|