@kitalive/sfdx-plugin 0.1.6 → 0.3.0
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/README.md +264 -31
- package/lib/bulk.d.ts +22 -0
- package/lib/bulk.js +282 -0
- package/lib/bulk.js.map +1 -0
- package/lib/commands/kit/data/bulk/delete.d.ts +18 -0
- package/lib/commands/kit/data/bulk/delete.js +91 -0
- package/lib/commands/kit/data/bulk/delete.js.map +1 -0
- package/lib/commands/kit/data/bulk/insert.d.ts +2 -0
- package/lib/commands/kit/data/bulk/insert.js +5 -0
- package/lib/commands/kit/data/bulk/insert.js.map +1 -0
- package/lib/commands/kit/data/bulk/query.d.ts +15 -0
- package/lib/commands/kit/data/bulk/query.js +57 -0
- package/lib/commands/kit/data/bulk/query.js.map +1 -0
- package/lib/commands/kit/data/bulk/update.d.ts +2 -0
- package/lib/commands/kit/data/bulk/update.js +5 -0
- package/lib/commands/kit/data/bulk/update.js.map +1 -0
- package/lib/commands/kit/data/bulk/upsert.d.ts +2 -49
- package/lib/commands/kit/data/bulk/upsert.js +2 -209
- package/lib/commands/kit/data/bulk/upsert.js.map +1 -1
- package/lib/commands/kit/data/csv/convert.js +53 -21
- package/lib/commands/kit/data/csv/convert.js.map +1 -1
- package/lib/commands/kit/layout/assignments/deploy.js +8 -3
- package/lib/commands/kit/layout/assignments/deploy.js.map +1 -1
- package/lib/commands/kit/layout/assignments/retrieve.d.ts +1 -0
- package/lib/commands/kit/layout/assignments/retrieve.js +51 -16
- package/lib/commands/kit/layout/assignments/retrieve.js.map +1 -1
- package/lib/commands/kit/script/execute.d.ts +1 -1
- package/lib/commands/kit/script/execute.js +19 -8
- package/lib/commands/kit/script/execute.js.map +1 -1
- package/oclif.manifest.json +1 -1
- package/package.json +28 -18
package/lib/bulk.js
ADDED
|
@@ -0,0 +1,282 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createBulkCommand = exports.normalizeDateString = exports.bulkLoad = exports.bulkQuery = void 0;
|
|
4
|
+
const command_1 = require("@salesforce/command");
|
|
5
|
+
const dayjs = require("dayjs");
|
|
6
|
+
const csv = require("fast-csv");
|
|
7
|
+
const fs = require("fs-extra");
|
|
8
|
+
const path = require("path");
|
|
9
|
+
const convert_1 = require("./commands/kit/data/csv/convert");
|
|
10
|
+
const convert_2 = require("./commands/kit/data/csv/convert");
|
|
11
|
+
const utils = require("./utils");
|
|
12
|
+
function bulkQuery(conn, query) {
|
|
13
|
+
return new Promise((resolve, reject) => {
|
|
14
|
+
const records = [];
|
|
15
|
+
conn.bulk
|
|
16
|
+
.query(query)
|
|
17
|
+
.on('error', reject)
|
|
18
|
+
.on('record', (record) => records.push(record))
|
|
19
|
+
.on('end', () => resolve(records));
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
exports.bulkQuery = bulkQuery;
|
|
23
|
+
function bulkLoad(conn, sobject, operation, rows, options) {
|
|
24
|
+
const { batchSize = 10000, wait, ...jobOptions } = options || {};
|
|
25
|
+
const job = conn.bulk.createJob(sobject, operation, jobOptions);
|
|
26
|
+
const fetchResults = async (records) => ({
|
|
27
|
+
job: await job.check(),
|
|
28
|
+
batches: await job.list(),
|
|
29
|
+
records,
|
|
30
|
+
});
|
|
31
|
+
const executeBatch = (batchRows) => new Promise((resolve, reject) => {
|
|
32
|
+
const batch = job.createBatch();
|
|
33
|
+
batch.on('error', (e) => {
|
|
34
|
+
if (e.message.startsWith('Polling time out'))
|
|
35
|
+
job.emit('error', e);
|
|
36
|
+
reject(e);
|
|
37
|
+
});
|
|
38
|
+
batch.on('queue', () => {
|
|
39
|
+
batch
|
|
40
|
+
.check()
|
|
41
|
+
.then((result) => {
|
|
42
|
+
if (result.state === 'Failed') {
|
|
43
|
+
reject(result.stateMessage);
|
|
44
|
+
}
|
|
45
|
+
else if (wait) {
|
|
46
|
+
batch.poll(5000, wait * 60000);
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
fetchResults([]).then(resolve).catch(reject);
|
|
50
|
+
}
|
|
51
|
+
})
|
|
52
|
+
.catch(reject);
|
|
53
|
+
});
|
|
54
|
+
batch.on('response', resolve);
|
|
55
|
+
batch.execute(batchRows, (error) => error && reject(error));
|
|
56
|
+
});
|
|
57
|
+
// eslint-disable-next-line no-async-promise-executor
|
|
58
|
+
return new Promise(async (resolve, reject) => {
|
|
59
|
+
job.on('error', reject);
|
|
60
|
+
try {
|
|
61
|
+
const results = await Promise.all(utils.chunk(rows, batchSize).map(executeBatch));
|
|
62
|
+
resolve(await fetchResults(results.flat()));
|
|
63
|
+
}
|
|
64
|
+
catch (e) {
|
|
65
|
+
reject(e);
|
|
66
|
+
}
|
|
67
|
+
finally {
|
|
68
|
+
await job.close();
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
exports.bulkLoad = bulkLoad;
|
|
73
|
+
function normalizeDateString(str, format) {
|
|
74
|
+
if (!str)
|
|
75
|
+
return str;
|
|
76
|
+
const d = dayjs(str);
|
|
77
|
+
return format ? d.format(format) : d.toISOString();
|
|
78
|
+
}
|
|
79
|
+
exports.normalizeDateString = normalizeDateString;
|
|
80
|
+
const converters = {
|
|
81
|
+
date: (value) => normalizeDateString(value, 'YYYY-MM-DD'),
|
|
82
|
+
datetime: normalizeDateString,
|
|
83
|
+
};
|
|
84
|
+
const csvFlags = convert_1.default['flagsConfig'];
|
|
85
|
+
const createBulkCommand = (operation) => {
|
|
86
|
+
var _a;
|
|
87
|
+
const config = {
|
|
88
|
+
object: command_1.flags.string({
|
|
89
|
+
char: 'o',
|
|
90
|
+
required: true,
|
|
91
|
+
description: `the sObject name to ${operation}`,
|
|
92
|
+
}),
|
|
93
|
+
// csv settings
|
|
94
|
+
csvfile: command_1.flags.filepath({
|
|
95
|
+
char: 'f',
|
|
96
|
+
required: true,
|
|
97
|
+
description: `the CSV file path that defines the records to ${operation}`,
|
|
98
|
+
}),
|
|
99
|
+
resultfile: command_1.flags.filepath({
|
|
100
|
+
char: 'r',
|
|
101
|
+
description: `the CSV file path for writing the ${operation} results`,
|
|
102
|
+
}),
|
|
103
|
+
encoding: csvFlags.encoding,
|
|
104
|
+
delimiter: csvFlags.delimiter,
|
|
105
|
+
quote: csvFlags.quote,
|
|
106
|
+
skiplines: csvFlags.skiplines,
|
|
107
|
+
trim: csvFlags.trim,
|
|
108
|
+
mapping: csvFlags.mapping,
|
|
109
|
+
converter: csvFlags.converter,
|
|
110
|
+
setnull: command_1.flags.boolean({
|
|
111
|
+
description: `set blank values as null values during ${operation} operations (default: empty field values are ignored)`,
|
|
112
|
+
}),
|
|
113
|
+
convertonly: command_1.flags.boolean({
|
|
114
|
+
description: `output converted.csv file and skip ${operation} for debugging`,
|
|
115
|
+
}),
|
|
116
|
+
// job settings
|
|
117
|
+
concurrencymode: command_1.flags.string({
|
|
118
|
+
default: 'Parallel',
|
|
119
|
+
description: 'the concurrency mode (Parallel or Serial) for the job',
|
|
120
|
+
}),
|
|
121
|
+
assignmentruleid: command_1.flags.string({
|
|
122
|
+
description: 'the ID of a specific assignment rule to run for a case or a lead.',
|
|
123
|
+
}),
|
|
124
|
+
batchsize: command_1.flags.integer({
|
|
125
|
+
char: 's',
|
|
126
|
+
min: 1,
|
|
127
|
+
max: 10000,
|
|
128
|
+
default: 10000,
|
|
129
|
+
description: 'the batch size of the job',
|
|
130
|
+
}),
|
|
131
|
+
wait: command_1.flags.integer({
|
|
132
|
+
char: 'w',
|
|
133
|
+
min: 0,
|
|
134
|
+
description: 'the number of minutes to wait for the command to complete before displaying the results',
|
|
135
|
+
}),
|
|
136
|
+
};
|
|
137
|
+
const examples = [
|
|
138
|
+
`$ sfdx kit:data:bulk:${operation} -o Account -f ./path/to/Account.csv -m ./path/to/mapping.json`,
|
|
139
|
+
];
|
|
140
|
+
if (operation === 'upsert') {
|
|
141
|
+
config['externalid'] = command_1.flags.string({
|
|
142
|
+
char: 'i',
|
|
143
|
+
required: true,
|
|
144
|
+
default: 'Id',
|
|
145
|
+
description: 'the column name of the external ID',
|
|
146
|
+
});
|
|
147
|
+
examples.push('$ sfdx kit:data:bulk:upsert -o MyObject__c -f ./path/to/MyObject__c.csv -c ./path/to/convert.js -i MyExternalId__c -w 10');
|
|
148
|
+
}
|
|
149
|
+
else {
|
|
150
|
+
examples.push(`$ sfdx kit:data:bulk:${operation} -o MyObject__c -f ./path/to/MyObject__c.csv -c ./path/to/convert.js -w 10`);
|
|
151
|
+
}
|
|
152
|
+
return _a = class extends command_1.SfdxCommand {
|
|
153
|
+
async run() {
|
|
154
|
+
const { object, csvfile, mapping, converter, encoding, delimiter, quote, skiplines, trim, setnull, } = this.flags;
|
|
155
|
+
const mappingJson = mapping ? await fs.readJson(mapping) : undefined;
|
|
156
|
+
const script = converter ? this.loadScript(converter) : {};
|
|
157
|
+
const fieldTypes = await this.getFieldTypes(object);
|
|
158
|
+
this.ux.startSpinner('Processing csv');
|
|
159
|
+
if (script.start)
|
|
160
|
+
await script.start(this);
|
|
161
|
+
let rows = await this.parseCsv(fs.createReadStream(csvfile), {
|
|
162
|
+
encoding,
|
|
163
|
+
delimiter,
|
|
164
|
+
quote,
|
|
165
|
+
skiplines,
|
|
166
|
+
trim: !!trim,
|
|
167
|
+
setnull,
|
|
168
|
+
mapping: mappingJson,
|
|
169
|
+
convert: script.convert,
|
|
170
|
+
fieldTypes,
|
|
171
|
+
});
|
|
172
|
+
if (script.finish) {
|
|
173
|
+
const result = await script.finish(rows, this);
|
|
174
|
+
if (result)
|
|
175
|
+
rows = result;
|
|
176
|
+
}
|
|
177
|
+
this.ux.stopSpinner();
|
|
178
|
+
if (this.flags.convertonly) {
|
|
179
|
+
const base = path.basename(csvfile, path.extname(csvfile));
|
|
180
|
+
this.saveCsv(path.join(path.dirname(csvfile), base + '.converted.csv'), rows);
|
|
181
|
+
return;
|
|
182
|
+
}
|
|
183
|
+
this.ux.startSpinner(`Bulk ${operation}`);
|
|
184
|
+
try {
|
|
185
|
+
const result = await this.bulkLoad(this.org.getConnection(), object, operation, rows, {
|
|
186
|
+
extIdField: this.flags.externalid,
|
|
187
|
+
concurrencyMode: this.flags.concurrencymode,
|
|
188
|
+
assignmentRuleId: this.flags.assignmentruleid,
|
|
189
|
+
batchSize: this.flags.batchsize,
|
|
190
|
+
wait: this.flags.wait,
|
|
191
|
+
});
|
|
192
|
+
const batchErrors = [];
|
|
193
|
+
if (this.flags.wait) {
|
|
194
|
+
const { numberRecordsProcessed, numberRecordsFailed } = result.job;
|
|
195
|
+
this.ux.stopSpinner(`${numberRecordsProcessed} processed, ${numberRecordsFailed} failed.`);
|
|
196
|
+
rows = rows.map((data, i) => {
|
|
197
|
+
const { id, errors } = result.records[i] || {};
|
|
198
|
+
const message = errors === null || errors === void 0 ? void 0 : errors.join(', ');
|
|
199
|
+
if (message) {
|
|
200
|
+
batchErrors.push({ line: i + 2, message, data });
|
|
201
|
+
}
|
|
202
|
+
return { ...data, Id: id, Errors: message };
|
|
203
|
+
});
|
|
204
|
+
if (batchErrors.length) {
|
|
205
|
+
result.errors = batchErrors;
|
|
206
|
+
this.ux.styledHeader('Error details');
|
|
207
|
+
this.ux.table(batchErrors, ['line', 'message']);
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
else {
|
|
211
|
+
this.ux.stopSpinner();
|
|
212
|
+
this.ux.log('Check bulk job status with the command: ');
|
|
213
|
+
this.ux.log(`sfdx force:org:open -u ${this.flags.targetusername} -p "lightning/setup/AsyncApiJobStatus/page?address=%2F${result.job.id}"`);
|
|
214
|
+
}
|
|
215
|
+
if (this.flags.resultfile)
|
|
216
|
+
this.saveCsv(this.flags.resultfile, rows);
|
|
217
|
+
return result;
|
|
218
|
+
}
|
|
219
|
+
catch (e) {
|
|
220
|
+
this.ux.stopSpinner('error');
|
|
221
|
+
throw e;
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
async parseCsv(input, options) {
|
|
225
|
+
const { encoding, delimiter, quote, skiplines, trim, mapping, convert, setnull, fieldTypes, } = options !== null && options !== void 0 ? options : {};
|
|
226
|
+
return await (0, convert_2.parseCsv)(input, {
|
|
227
|
+
encoding,
|
|
228
|
+
delimiter,
|
|
229
|
+
quote,
|
|
230
|
+
skiplines,
|
|
231
|
+
trim,
|
|
232
|
+
mapping,
|
|
233
|
+
convert: (row) => {
|
|
234
|
+
const result = convert ? convert(row) : row;
|
|
235
|
+
if (!result)
|
|
236
|
+
return;
|
|
237
|
+
if (fieldTypes) {
|
|
238
|
+
for (const key of Object.keys(result)) {
|
|
239
|
+
const converter = converters[fieldTypes[key]];
|
|
240
|
+
if (converter)
|
|
241
|
+
result[key] = converter(result[key]);
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
if (setnull) {
|
|
245
|
+
for (const key of Object.keys(result)) {
|
|
246
|
+
if (key.includes('.'))
|
|
247
|
+
continue; // skip reference
|
|
248
|
+
if (result[key] == null || result[key] === '')
|
|
249
|
+
result[key] = '#N/A';
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
return result;
|
|
253
|
+
},
|
|
254
|
+
});
|
|
255
|
+
}
|
|
256
|
+
bulkLoad(conn, sobject, op, rows, options) {
|
|
257
|
+
return bulkLoad(conn, sobject, op, rows, options);
|
|
258
|
+
}
|
|
259
|
+
saveCsv(file, rows) {
|
|
260
|
+
csv.writeToPath(file, rows, { headers: true, writeBOM: true });
|
|
261
|
+
}
|
|
262
|
+
loadScript(file) {
|
|
263
|
+
return (0, convert_2.loadScript)(file);
|
|
264
|
+
}
|
|
265
|
+
async getFieldTypes(sobject) {
|
|
266
|
+
const conn = this.org.getConnection();
|
|
267
|
+
const objectInfo = await conn.describe(sobject);
|
|
268
|
+
return objectInfo.fields.reduce((info, { name, type }) => Object.assign(info, { [name]: type }), {});
|
|
269
|
+
}
|
|
270
|
+
},
|
|
271
|
+
_a.description = [
|
|
272
|
+
`bulk ${operation} records from a CSV file`,
|
|
273
|
+
'For information about CSV file formats, see [Prepare CSV Files](https://developer.salesforce.com/docs/atlas.en-us.api_asynch.meta/api_asynch/datafiles_csv_preparing.htm) in the Bulk API Developer Guide.',
|
|
274
|
+
].join('\n'),
|
|
275
|
+
_a.examples = examples,
|
|
276
|
+
_a.requiresUsername = true,
|
|
277
|
+
_a.requiresProject = false,
|
|
278
|
+
_a.flagsConfig = config,
|
|
279
|
+
_a;
|
|
280
|
+
};
|
|
281
|
+
exports.createBulkCommand = createBulkCommand;
|
|
282
|
+
//# sourceMappingURL=bulk.js.map
|
package/lib/bulk.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bulk.js","sourceRoot":"","sources":["../src/bulk.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { flags, SfdxCommand } from '@salesforce/command';
|
|
2
|
+
import { BulkResult } from '../../../../bulk';
|
|
3
|
+
export default class DeleteCommand extends SfdxCommand {
|
|
4
|
+
static description: string;
|
|
5
|
+
static examples: string[];
|
|
6
|
+
protected static requiresUsername: boolean;
|
|
7
|
+
protected static requiresProject: boolean;
|
|
8
|
+
protected static flagsConfig: {
|
|
9
|
+
query: flags.Discriminated<flags.String>;
|
|
10
|
+
hard: flags.Discriminated<flags.Boolean<boolean>>;
|
|
11
|
+
concurrencymode: flags.Discriminated<flags.String>;
|
|
12
|
+
batchsize: flags.Discriminated<flags.Number>;
|
|
13
|
+
wait: flags.Discriminated<flags.Number>;
|
|
14
|
+
};
|
|
15
|
+
run(): Promise<BulkResult>;
|
|
16
|
+
private bulkQuery;
|
|
17
|
+
private bulkLoad;
|
|
18
|
+
}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const command_1 = require("@salesforce/command");
|
|
4
|
+
const soql_parser_js_1 = require("soql-parser-js");
|
|
5
|
+
const bulk_1 = require("../../../../bulk");
|
|
6
|
+
class DeleteCommand extends command_1.SfdxCommand {
|
|
7
|
+
async run() {
|
|
8
|
+
var _a;
|
|
9
|
+
const query = (0, soql_parser_js_1.parseQuery)(this.flags.query);
|
|
10
|
+
query.fields = [(0, soql_parser_js_1.getField)('Id')];
|
|
11
|
+
const soql = (0, soql_parser_js_1.composeQuery)(query);
|
|
12
|
+
const conn = this.org.getConnection();
|
|
13
|
+
const { concurrencymode: concurrencyMode, batchsize: batchSize, wait, hard, } = this.flags;
|
|
14
|
+
this.ux.startSpinner(hard ? 'Bulk hard delete' : 'Bulk delete');
|
|
15
|
+
try {
|
|
16
|
+
const rows = await this.bulkQuery(conn, soql);
|
|
17
|
+
if (!rows.length) {
|
|
18
|
+
this.ux.stopSpinner('no records');
|
|
19
|
+
return { records: [] };
|
|
20
|
+
}
|
|
21
|
+
const operation = hard ? 'hardDelete' : 'delete';
|
|
22
|
+
const result = await this.bulkLoad(conn, query.sObject, operation, rows, {
|
|
23
|
+
concurrencyMode,
|
|
24
|
+
batchSize,
|
|
25
|
+
wait,
|
|
26
|
+
});
|
|
27
|
+
if (wait) {
|
|
28
|
+
const { numberRecordsProcessed, numberRecordsFailed } = result.job;
|
|
29
|
+
const errors = result.records
|
|
30
|
+
.filter((r) => !r.success)
|
|
31
|
+
.map((r) => ({ id: r.id, errors: r.errors.join(', ') }));
|
|
32
|
+
this.ux.stopSpinner(`${numberRecordsProcessed} processed, ${numberRecordsFailed} failed.`);
|
|
33
|
+
if (errors.length) {
|
|
34
|
+
this.ux.styledHeader('Error details');
|
|
35
|
+
this.ux.table(errors, ['id', 'errors']);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
this.ux.stopSpinner();
|
|
40
|
+
this.ux.log('Check bulk job status with the command: ');
|
|
41
|
+
this.ux.log(`sfdx force:org:open -u ${this.flags.targetusername} -p "lightning/setup/AsyncApiJobStatus/page?address=%2F${(_a = result.job) === null || _a === void 0 ? void 0 : _a.id}"`);
|
|
42
|
+
}
|
|
43
|
+
return result;
|
|
44
|
+
}
|
|
45
|
+
catch (e) {
|
|
46
|
+
this.ux.stopSpinner('error');
|
|
47
|
+
throw e;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
bulkQuery(conn, query) {
|
|
51
|
+
return (0, bulk_1.bulkQuery)(conn, query);
|
|
52
|
+
}
|
|
53
|
+
bulkLoad(conn, sobject, operation, rows, options) {
|
|
54
|
+
return (0, bulk_1.bulkLoad)(conn, sobject, operation, rows, options);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
exports.default = DeleteCommand;
|
|
58
|
+
DeleteCommand.description = 'bulk delete records by SOQL select query';
|
|
59
|
+
DeleteCommand.examples = [
|
|
60
|
+
"$ sfdx kit:data:bulk:delete -q 'SELECT Id FROM Opportunity WHERE CloseDate < LAST_N_YEARS:5'",
|
|
61
|
+
];
|
|
62
|
+
DeleteCommand.requiresUsername = true;
|
|
63
|
+
DeleteCommand.requiresProject = false;
|
|
64
|
+
DeleteCommand.flagsConfig = {
|
|
65
|
+
query: command_1.flags.string({
|
|
66
|
+
char: 'q',
|
|
67
|
+
required: true,
|
|
68
|
+
description: 'SOQL query to delete',
|
|
69
|
+
}),
|
|
70
|
+
hard: command_1.flags.boolean({
|
|
71
|
+
default: false,
|
|
72
|
+
description: 'perform a hard delete',
|
|
73
|
+
}),
|
|
74
|
+
concurrencymode: command_1.flags.string({
|
|
75
|
+
default: 'Parallel',
|
|
76
|
+
description: 'the concurrency mode (Parallel or Serial) for the job',
|
|
77
|
+
}),
|
|
78
|
+
batchsize: command_1.flags.integer({
|
|
79
|
+
char: 's',
|
|
80
|
+
min: 1,
|
|
81
|
+
max: 10000,
|
|
82
|
+
default: 10000,
|
|
83
|
+
description: 'the batch size of the job',
|
|
84
|
+
}),
|
|
85
|
+
wait: command_1.flags.integer({
|
|
86
|
+
char: 'w',
|
|
87
|
+
min: 0,
|
|
88
|
+
description: 'the number of minutes to wait for the command to complete before displaying the results',
|
|
89
|
+
}),
|
|
90
|
+
};
|
|
91
|
+
//# sourceMappingURL=delete.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delete.js","sourceRoot":"","sources":["../../../../../src/commands/kit/data/bulk/delete.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"insert.js","sourceRoot":"","sources":["../../../../../src/commands/kit/data/bulk/insert.ts"],"names":[],"mappings":";;AAAA,2CAAqD;AAErD,kBAAe,IAAA,wBAAiB,EAAC,QAAQ,CAAC,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { flags, SfdxCommand } from '@salesforce/command';
|
|
2
|
+
import { JsonMap } from '@salesforce/ts-types';
|
|
3
|
+
export default class QueryCommand extends SfdxCommand {
|
|
4
|
+
static description: string;
|
|
5
|
+
static examples: string[];
|
|
6
|
+
protected static requiresUsername: boolean;
|
|
7
|
+
protected static requiresProject: boolean;
|
|
8
|
+
protected static flagsConfig: {
|
|
9
|
+
query: flags.Discriminated<flags.String>;
|
|
10
|
+
csvfile: flags.Discriminated<flags.String>;
|
|
11
|
+
};
|
|
12
|
+
run(): Promise<JsonMap[]>;
|
|
13
|
+
private writeCsv;
|
|
14
|
+
private bulkQuery;
|
|
15
|
+
}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const format_1 = require("@fast-csv/format");
|
|
4
|
+
const command_1 = require("@salesforce/command");
|
|
5
|
+
const fs = require("fs");
|
|
6
|
+
const bulk_1 = require("../../../../bulk");
|
|
7
|
+
class QueryCommand extends command_1.SfdxCommand {
|
|
8
|
+
async run() {
|
|
9
|
+
const conn = this.org.getConnection();
|
|
10
|
+
const file = this.flags.csvfile;
|
|
11
|
+
this.ux.startSpinner('Bulk query');
|
|
12
|
+
try {
|
|
13
|
+
const rows = await this.bulkQuery(conn, this.flags.query);
|
|
14
|
+
if (!rows.length) {
|
|
15
|
+
this.ux.stopSpinner('no records');
|
|
16
|
+
return rows;
|
|
17
|
+
}
|
|
18
|
+
this.ux.stopSpinner(`${rows.length} records`);
|
|
19
|
+
if (file) {
|
|
20
|
+
this.writeCsv(rows, fs.createWriteStream(file));
|
|
21
|
+
}
|
|
22
|
+
else if (!this.flags.json) {
|
|
23
|
+
this.writeCsv(rows, process.stdout);
|
|
24
|
+
}
|
|
25
|
+
return rows;
|
|
26
|
+
}
|
|
27
|
+
catch (e) {
|
|
28
|
+
this.ux.stopSpinner('error');
|
|
29
|
+
throw e;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
writeCsv(rows, stream) {
|
|
33
|
+
(0, format_1.write)(rows, { headers: true, writeBOM: true }).pipe(stream);
|
|
34
|
+
}
|
|
35
|
+
bulkQuery(conn, query) {
|
|
36
|
+
return (0, bulk_1.bulkQuery)(conn, query);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
exports.default = QueryCommand;
|
|
40
|
+
QueryCommand.description = 'bulk query records';
|
|
41
|
+
QueryCommand.examples = [
|
|
42
|
+
"$ sfdx kit:data:bulk:query -q 'SELECT Id, Name FROM Account' -f ./path/to/Account.csv",
|
|
43
|
+
];
|
|
44
|
+
QueryCommand.requiresUsername = true;
|
|
45
|
+
QueryCommand.requiresProject = false;
|
|
46
|
+
QueryCommand.flagsConfig = {
|
|
47
|
+
query: command_1.flags.string({
|
|
48
|
+
char: 'q',
|
|
49
|
+
required: true,
|
|
50
|
+
description: 'SOQL query to export',
|
|
51
|
+
}),
|
|
52
|
+
csvfile: command_1.flags.string({
|
|
53
|
+
char: 'f',
|
|
54
|
+
description: 'output csv file (default: standard output)',
|
|
55
|
+
}),
|
|
56
|
+
};
|
|
57
|
+
//# sourceMappingURL=query.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"query.js","sourceRoot":"","sources":["../../../../../src/commands/kit/data/bulk/query.ts"],"names":[],"mappings":";;AAAA,6CAAyC;AACzC,iDAAyD;AAEzD,yBAAyB;AACzB,2CAA6C;AAE7C,MAAqB,YAAa,SAAQ,qBAAW;IAsB5C,KAAK,CAAC,GAAG;QACd,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QACtC,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC;QAEhC,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC;QACnC,IAAI;YACF,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YAC1D,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;gBAChB,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;gBAClC,OAAO,IAAI,CAAC;aACb;YAED,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,MAAM,UAAU,CAAC,CAAC;YAE9C,IAAI,IAAI,EAAE;gBACR,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,EAAE,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC;aACjD;iBAAM,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE;gBAC3B,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;aACrC;YAED,OAAO,IAAI,CAAC;SACb;QAAC,OAAO,CAAC,EAAE;YACV,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YAC7B,MAAM,CAAC,CAAC;SACT;IACH,CAAC;IAEO,QAAQ,CAAC,IAAI,EAAE,MAAM;QAC3B,IAAA,cAAK,EAAC,IAAI,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC9D,CAAC;IAEO,SAAS,CAAC,IAAI,EAAE,KAAK;QAC3B,OAAO,IAAA,gBAAS,EAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IAChC,CAAC;;AAvDH,+BAwDC;AAvDe,wBAAW,GAAG,oBAAoB,CAAC;AAEnC,qBAAQ,GAAG;IACvB,uFAAuF;CACxF,CAAC;AAEe,6BAAgB,GAAG,IAAI,CAAC;AACxB,4BAAe,GAAG,KAAK,CAAC;AAExB,wBAAW,GAAG;IAC7B,KAAK,EAAE,eAAK,CAAC,MAAM,CAAC;QAClB,IAAI,EAAE,GAAG;QACT,QAAQ,EAAE,IAAI;QACd,WAAW,EAAE,sBAAsB;KACpC,CAAC;IACF,OAAO,EAAE,eAAK,CAAC,MAAM,CAAC;QACpB,IAAI,EAAE,GAAG;QACT,WAAW,EAAE,4CAA4C;KAC1D,CAAC;CACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"update.js","sourceRoot":"","sources":["../../../../../src/commands/kit/data/bulk/update.ts"],"names":[],"mappings":";;AAAA,2CAAqD;AAErD,kBAAe,IAAA,wBAAiB,EAAC,QAAQ,CAAC,CAAC"}
|
|
@@ -1,49 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
import { JsonMap } from '@salesforce/ts-types';
|
|
4
|
-
import { Readable } from 'stream';
|
|
5
|
-
export default class UpsertCommand extends SfdxCommand {
|
|
6
|
-
static description: string;
|
|
7
|
-
static examples: string[];
|
|
8
|
-
protected static requiresUsername: boolean;
|
|
9
|
-
protected static requiresProject: boolean;
|
|
10
|
-
protected static flagsConfig: {
|
|
11
|
-
object: flags.Discriminated<flags.String>;
|
|
12
|
-
externalid: flags.Discriminated<flags.String>;
|
|
13
|
-
csvfile: flags.Discriminated<flags.String>;
|
|
14
|
-
resultfile: flags.Discriminated<flags.String>;
|
|
15
|
-
encoding: flags.Discriminated<flags.String>;
|
|
16
|
-
delimiter: flags.Discriminated<flags.String>;
|
|
17
|
-
quote: flags.Discriminated<flags.String>;
|
|
18
|
-
skiplines: flags.Discriminated<flags.Number>;
|
|
19
|
-
trim: flags.Discriminated<flags.Boolean<boolean>>;
|
|
20
|
-
mapping: flags.Discriminated<flags.String>;
|
|
21
|
-
converter: flags.Discriminated<flags.String>;
|
|
22
|
-
setnull: flags.Discriminated<flags.Boolean<boolean>>;
|
|
23
|
-
convertonly: flags.Discriminated<flags.Boolean<boolean>>;
|
|
24
|
-
concurrencymode: flags.Discriminated<flags.String>;
|
|
25
|
-
assignmentruleid: flags.Discriminated<flags.String>;
|
|
26
|
-
batchsize: flags.Discriminated<flags.Number>;
|
|
27
|
-
wait: flags.Discriminated<flags.Number>;
|
|
28
|
-
};
|
|
29
|
-
run(): Promise<JsonMap>;
|
|
30
|
-
parseCsv(input: Readable, options?: {
|
|
31
|
-
encoding?: string;
|
|
32
|
-
delimiter?: string;
|
|
33
|
-
quote?: string;
|
|
34
|
-
skiplines?: number;
|
|
35
|
-
trim?: boolean;
|
|
36
|
-
setnull?: boolean;
|
|
37
|
-
mapping?: JsonMap;
|
|
38
|
-
convert?: (row: JsonMap) => JsonMap | null | undefined;
|
|
39
|
-
fieldTypes?: {
|
|
40
|
-
[field: string]: string;
|
|
41
|
-
};
|
|
42
|
-
}): Promise<JsonMap[]>;
|
|
43
|
-
private executeBatches;
|
|
44
|
-
private executeBatch;
|
|
45
|
-
private saveCsv;
|
|
46
|
-
private loadScript;
|
|
47
|
-
private getFieldTypes;
|
|
48
|
-
private createJob;
|
|
49
|
-
}
|
|
1
|
+
declare const _default: new (...args: any[]) => import("@salesforce/command").SfdxCommand;
|
|
2
|
+
export default _default;
|