-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlist.ts
170 lines (126 loc) · 4.89 KB
/
list.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
import Command, { Flags,/* FLAG_LOAD_PARAMS, FLAG_SAVE_PARAMS, */cliux } from '../../base'
import type { QueryPageSize, CommerceLayerProvisioningClient, QueryParamsList } from '@commercelayer/provisioning-sdk'
import { addRequestReader, isRequestInterrupted } from '../../lang'
// import { mergeCommandParams } from '../../commands'
import { clColor } from '@commercelayer/cli-core'
const OPERATION = 'list'
export default class ProvisioningList extends Command {
static description = 'fetch a collection of resources'
static aliases = ['pl', 'prov:list', 'plist', 'pls']
static examples = [
'$ commercelayer provisioning:list roles -f id,name -i organization -s updated_at',
'$ cl prov:list roles -i organization -f name -f organizations/name -w organization_name_eq="ORG NAME"',
'$ cl prov:list roles -p 5 -n 10 -s -created_at --raw',
]
static flags = {
...Command.flags,
where: Flags.string({
char: 'w',
multiple: true,
description: 'comma separated list of query filters',
}),
page: Flags.integer({
char: 'p',
description: 'page number',
}),
pageSize: Flags.integer({
char: 'n',
description: 'number of elements per page',
}),
sort: Flags.string({
char: 's',
description: 'define results ordering',
multiple: true,
}),
/*
save: Flags.string({
char: 'x',
description: 'save command output to file',
multiple: false,
exclusive: ['save-path'],
}),
'save-path': Flags.string({
char: 'X',
description: 'save command output to file and create missing path directories',
multiple: false,
exclusive: ['save'],
}),
*/
extract: Flags.string({
char: 'e',
description: 'extract subfields from object attributes',
multiple: true,
exclusive: ['raw'],
}),
'force-include': Flags.boolean({
char: 'I',
description: 'force resources inclusion beyond the 3rd level',
dependsOn: ['include'],
hidden: true,
}),
}
static args = {
...Command.args
}
async run(): Promise<any> {
const { args, flags } = await this.parse(ProvisioningList)
const resource = this.checkResource(args.resource)
// const loadParams = flags[FLAG_LOAD_PARAMS]
// const saveCmd = flags[FLAG_SAVE_PARAMS]
// if (saveCmd) this.checkAlias(saveCmd, resource.api, OPERATION, this.config)
const showHeaders = flags.headers || flags['headers-only']
// Include flags
const include: string[] = this.includeFlag(flags.include, undefined, flags['force-include'])
// Fields flags
const fields = this.fieldsFlag(flags.fields, resource.type)
// Where flags
const wheres = this.whereFlag(flags.where)
// Sort flags
const sort = this.sortFlag(flags.sort)
const page = flags.page
const perPage = flags.pageSize as QueryPageSize
const cl = this.initCommerceLayer(flags)
const rawReader = flags.raw ? cl.addRawResponseReader({ headers: showHeaders }) : undefined
const reqReader = flags.doc ? addRequestReader(cl) : undefined
const params: QueryParamsList = {}
try {
const resSdk: any = cl[resource.api as keyof CommerceLayerProvisioningClient]
this.checkOperation(resSdk, OPERATION)
if (include && (include.length > 0)) params.include = include
if (fields && (Object.keys(fields).length > 0)) params.fields = fields
if (wheres && (Object.keys(wheres).length > 0)) params.filters = wheres
if (sort && (Object.keys(sort).length > 0)) params.sort = sort
if (perPage && (perPage > 0)) params.pageSize = perPage
if (page && (page > 0)) params.pageNumber = page
// Load saved command arguments
// if (loadParams) {
// const savedParams = this.loadParams(loadParams, resource.api, OPERATION)
// if (savedParams) mergeCommandParams(params, savedParams)
// }
// if (!flags.doc) cliux.action.start(`Fetching ${resource.api.replace(/_/g, ' ')}`)
const res = await resSdk.list(params)
cliux.action.stop()
const out = (flags.raw && rawReader) ? rawReader.rawResponse : [...res]
const meta = res.meta
if (res && (res.length > 0)) {
if (flags.extract && Array.isArray(out)) {
const ext = this.extractFlag(flags.extract)
out.forEach(o => { this.extractObjectFields(ext, o) })
}
this.printHeaders(rawReader?.headers, flags)
this.printOutput(out, flags)
if (!flags['headers-only']) this.log(`\nRecords: ${clColor.blueBright(res.length)} of ${meta.recordCount} | Page: ${clColor.blueBright(String(flags.page || 1))} of ${meta.pageCount}\n`)
// Save command output
// if (flags.save || flags['save-path']) this.saveOutput(out, flags)
} else this.log(clColor.italic('\nNo records found\n'))
// Save command arguments
// if (saveCmd) this.saveParams(saveCmd, { type: resource.api }, OPERATION, params)
return out
} catch (error) {
if (isRequestInterrupted(error) && reqReader) {
await this.showLiveDocumentation(reqReader.request, params, flags)
cl.removeInterceptor('request', reqReader.id)
} else this.printError(error, flags, args)
}
}
}