@kitalive/sfdx-plugin 1.0.0-rc.2 → 1.0.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 +127 -127
- package/messages/data.bulk.md +7 -7
- package/messages/data.bulk.query.md +1 -1
- package/messages/data.bulk.upsert.md +1 -1
- package/messages/data.csv.convert.md +2 -2
- package/oclif.lock +4166 -2872
- package/oclif.manifest.json +2 -1750
- package/package.json +17 -18
- package/public/graphql/index.html +67 -53
- package/lib/bulk.js +0 -273
- package/lib/bulk.js.map +0 -1
- package/lib/commands/kit/data/bulk/delete.js +0 -100
- package/lib/commands/kit/data/bulk/delete.js.map +0 -1
- package/lib/commands/kit/data/bulk/insert.js +0 -7
- package/lib/commands/kit/data/bulk/insert.js.map +0 -1
- package/lib/commands/kit/data/bulk/query.js +0 -68
- package/lib/commands/kit/data/bulk/query.js.map +0 -1
- package/lib/commands/kit/data/bulk/update.js +0 -7
- package/lib/commands/kit/data/bulk/update.js.map +0 -1
- package/lib/commands/kit/data/bulk/upsert.js +0 -20
- package/lib/commands/kit/data/bulk/upsert.js.map +0 -1
- package/lib/commands/kit/data/csv/convert.js +0 -80
- package/lib/commands/kit/data/csv/convert.js.map +0 -1
- package/lib/commands/kit/graphql/editor.js +0 -27
- package/lib/commands/kit/graphql/editor.js.map +0 -1
- package/lib/commands/kit/layout/assignments/deploy.js +0 -35
- package/lib/commands/kit/layout/assignments/deploy.js.map +0 -1
- package/lib/commands/kit/layout/assignments/retrieve.js +0 -124
- package/lib/commands/kit/layout/assignments/retrieve.js.map +0 -1
- package/lib/commands/kit/metadata/dependencies.js +0 -182
- package/lib/commands/kit/metadata/dependencies.js.map +0 -1
- package/lib/commands/kit/object/fields/describe.js +0 -84
- package/lib/commands/kit/object/fields/describe.js.map +0 -1
- package/lib/commands/kit/object/fields/setup.js +0 -260
- package/lib/commands/kit/object/fields/setup.js.map +0 -1
- package/lib/commands/kit/script/execute.js +0 -55
- package/lib/commands/kit/script/execute.js.map +0 -1
- package/lib/index.js +0 -2
- package/lib/index.js.map +0 -1
- package/lib/metadata.js +0 -82
- package/lib/metadata.js.map +0 -1
- package/lib/server.js +0 -44
- package/lib/server.js.map +0 -1
- package/lib/types.js +0 -2
- package/lib/types.js.map +0 -1
- package/lib/utils.js +0 -87
- package/lib/utils.js.map +0 -1
package/package.json
CHANGED
|
@@ -1,37 +1,36 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@kitalive/sfdx-plugin",
|
|
3
3
|
"description": "Kitalive SFDX plugin",
|
|
4
|
-
"version": "1.0.0
|
|
4
|
+
"version": "1.0.0",
|
|
5
5
|
"author": "Akihiro Ono",
|
|
6
6
|
"bugs": "https://github.com/Kitalive-Inc/sfdx-plugin/issues",
|
|
7
7
|
"dependencies": {
|
|
8
|
-
"@jetstreamapp/soql-parser-js": "^6.1
|
|
8
|
+
"@jetstreamapp/soql-parser-js": "^6.3.1",
|
|
9
9
|
"@oclif/core": "^4",
|
|
10
10
|
"@salesforce/core": "^8",
|
|
11
11
|
"@salesforce/kit": "^3",
|
|
12
12
|
"@salesforce/sf-plugins-core": "^12",
|
|
13
|
-
"dayjs": "^1.11.
|
|
14
|
-
"express": "^
|
|
15
|
-
"
|
|
16
|
-
"
|
|
17
|
-
"fs-extra": "^11.3.0",
|
|
13
|
+
"dayjs": "^1.11.19",
|
|
14
|
+
"express": "^5.2.1",
|
|
15
|
+
"fast-csv": "^5.0.5",
|
|
16
|
+
"fs-extra": "^11.3.3",
|
|
18
17
|
"iconv-lite": "^0.6.3",
|
|
19
|
-
"open": "^
|
|
18
|
+
"open": "^11",
|
|
20
19
|
"tslib": "^2",
|
|
21
|
-
"yargs": "^
|
|
20
|
+
"yargs": "^18.0.0"
|
|
22
21
|
},
|
|
23
22
|
"devDependencies": {
|
|
24
|
-
"@oclif/plugin-command-snapshot": "^5.
|
|
25
|
-
"@salesforce/cli-plugins-testkit": "^5.3.
|
|
26
|
-
"@salesforce/dev-scripts": "^
|
|
27
|
-
"@types/express": "^5.0.
|
|
23
|
+
"@oclif/plugin-command-snapshot": "^5.3.8",
|
|
24
|
+
"@salesforce/cli-plugins-testkit": "^5.3.41",
|
|
25
|
+
"@salesforce/dev-scripts": "^11",
|
|
26
|
+
"@types/express": "^5.0.6",
|
|
28
27
|
"@types/fs-extra": "^11.0.4",
|
|
29
|
-
"@types/yargs": "^17.0.
|
|
30
|
-
"eslint-plugin-sf-plugin": "^1.20.
|
|
31
|
-
"esmock": "^2.7.
|
|
32
|
-
"oclif": "^4.
|
|
28
|
+
"@types/yargs": "^17.0.35",
|
|
29
|
+
"eslint-plugin-sf-plugin": "^1.20.33",
|
|
30
|
+
"esmock": "^2.7.3",
|
|
31
|
+
"oclif": "^4.22.59",
|
|
33
32
|
"ts-node": "^10.9.2",
|
|
34
|
-
"typescript": "^5.
|
|
33
|
+
"typescript": "^5.9.3"
|
|
35
34
|
},
|
|
36
35
|
"engines": {
|
|
37
36
|
"node": ">=18.0.0"
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
<!--
|
|
2
|
-
* Copyright (c)
|
|
2
|
+
* Copyright (c) 2025 GraphQL Contributors
|
|
3
3
|
* All rights reserved.
|
|
4
4
|
*
|
|
5
5
|
* This source code is licensed under the license found in the
|
|
@@ -8,75 +8,89 @@
|
|
|
8
8
|
<!DOCTYPE html>
|
|
9
9
|
<html lang="en">
|
|
10
10
|
<head>
|
|
11
|
-
<
|
|
11
|
+
<meta charset="UTF-8" />
|
|
12
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
13
|
+
<title>GraphiQL 5 with React 19 and GraphiQL Explorer</title>
|
|
12
14
|
<style>
|
|
13
15
|
body {
|
|
14
|
-
height: 100%;
|
|
15
16
|
margin: 0;
|
|
16
|
-
width: 100%;
|
|
17
|
-
overflow: hidden;
|
|
18
17
|
}
|
|
19
18
|
|
|
20
19
|
#graphiql {
|
|
21
|
-
height:
|
|
20
|
+
height: 100dvh;
|
|
22
21
|
}
|
|
23
|
-
</style>
|
|
24
|
-
<!--
|
|
25
|
-
This GraphiQL example depends on Promise and fetch, which are available in
|
|
26
|
-
modern browsers, but can be "polyfilled" for older browsers.
|
|
27
|
-
GraphiQL itself depends on React DOM.
|
|
28
|
-
If you do not want to rely on a CDN, you can host these files locally or
|
|
29
|
-
include them directly in your favored resource bundler.
|
|
30
|
-
-->
|
|
31
|
-
<script
|
|
32
|
-
crossorigin
|
|
33
|
-
src="https://unpkg.com/react@18/umd/react.development.js"
|
|
34
|
-
></script>
|
|
35
|
-
<script
|
|
36
|
-
crossorigin
|
|
37
|
-
src="https://unpkg.com/react-dom@18/umd/react-dom.development.js"
|
|
38
|
-
></script>
|
|
39
|
-
<!--
|
|
40
|
-
These two files can be found in the npm module, however you may wish to
|
|
41
|
-
copy them directly into your environment, or perhaps include them in your
|
|
42
|
-
favored resource bundler.
|
|
43
|
-
-->
|
|
44
|
-
<script
|
|
45
|
-
src="https://unpkg.com/graphiql/graphiql.min.js"
|
|
46
|
-
type="application/javascript"
|
|
47
|
-
></script>
|
|
48
|
-
<link rel="stylesheet" href="https://unpkg.com/graphiql/graphiql.min.css" />
|
|
49
|
-
<!--
|
|
50
|
-
These are imports for the GraphIQL Explorer plugin.
|
|
51
|
-
-->
|
|
52
|
-
<script
|
|
53
|
-
src="https://unpkg.com/@graphiql/plugin-explorer/dist/index.umd.js"
|
|
54
|
-
crossorigin
|
|
55
|
-
></script>
|
|
56
22
|
|
|
23
|
+
.loading {
|
|
24
|
+
height: 100%;
|
|
25
|
+
display: flex;
|
|
26
|
+
align-items: center;
|
|
27
|
+
justify-content: center;
|
|
28
|
+
font-size: 4rem;
|
|
29
|
+
}
|
|
30
|
+
</style>
|
|
31
|
+
<link rel="stylesheet" href="https://esm.sh/graphiql/dist/style.css" />
|
|
57
32
|
<link
|
|
58
33
|
rel="stylesheet"
|
|
59
|
-
href="https://
|
|
34
|
+
href="https://esm.sh/@graphiql/plugin-explorer/dist/style.css"
|
|
60
35
|
/>
|
|
61
|
-
|
|
36
|
+
<!--
|
|
37
|
+
* Note:
|
|
38
|
+
* The ?standalone flag bundles the module along with all of its `dependencies`, excluding `peerDependencies`, into a single JavaScript file.
|
|
39
|
+
* `@emotion/is-prop-valid` is a shim to remove the console error ` module "@emotion /is-prop-valid" not found`. Upstream issue: https://github.com/motiondivision/motion/issues/3126
|
|
40
|
+
-->
|
|
41
|
+
<script type="importmap">
|
|
42
|
+
{
|
|
43
|
+
"imports": {
|
|
44
|
+
"react": "https://esm.sh/react@19.1.0",
|
|
45
|
+
"react/": "https://esm.sh/react@19.1.0/",
|
|
62
46
|
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
47
|
+
"react-dom": "https://esm.sh/react-dom@19.1.0",
|
|
48
|
+
"react-dom/": "https://esm.sh/react-dom@19.1.0/",
|
|
49
|
+
|
|
50
|
+
"graphiql": "https://esm.sh/graphiql?standalone&external=react,react-dom,@graphiql/react,graphql",
|
|
51
|
+
"graphiql/": "https://esm.sh/graphiql/",
|
|
52
|
+
"@graphiql/plugin-explorer": "https://esm.sh/@graphiql/plugin-explorer?standalone&external=react,@graphiql/react,graphql",
|
|
53
|
+
"@graphiql/react": "https://esm.sh/@graphiql/react?standalone&external=react,react-dom,graphql,@graphiql/toolkit,@emotion/is-prop-valid",
|
|
54
|
+
|
|
55
|
+
"@graphiql/toolkit": "https://esm.sh/@graphiql/toolkit?standalone&external=graphql",
|
|
56
|
+
"graphql": "https://esm.sh/graphql@16.11.0",
|
|
57
|
+
"@emotion/is-prop-valid": "data:text/javascript,"
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
</script>
|
|
61
|
+
<script type="module">
|
|
62
|
+
import React from 'react';
|
|
63
|
+
import ReactDOM from 'react-dom/client';
|
|
64
|
+
import { GraphiQL, HISTORY_PLUGIN } from 'graphiql';
|
|
65
|
+
import { createGraphiQLFetcher } from '@graphiql/toolkit';
|
|
66
|
+
import { explorerPlugin } from '@graphiql/plugin-explorer';
|
|
67
|
+
import 'graphiql/setup-workers/esm.sh';
|
|
68
|
+
|
|
69
|
+
const fetcher = createGraphiQLFetcher({
|
|
70
|
+
url: '/api/graphql',
|
|
71
|
+
});
|
|
72
|
+
const plugins = [HISTORY_PLUGIN, explorerPlugin()];
|
|
73
|
+
|
|
74
|
+
function App() {
|
|
75
|
+
return React.createElement(GraphiQL, {
|
|
71
76
|
fetcher,
|
|
72
|
-
|
|
77
|
+
plugins,
|
|
73
78
|
defaultEditorToolsVisibility: true,
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
const container = document.getElementById('graphiql');
|
|
83
|
+
const root = ReactDOM.createRoot(container);
|
|
84
|
+
root.render(React.createElement(App));
|
|
85
|
+
|
|
77
86
|
window.addEventListener('beforeunload', () =>
|
|
78
87
|
navigator.sendBeacon('/quit')
|
|
79
88
|
);
|
|
80
89
|
</script>
|
|
90
|
+
</head>
|
|
91
|
+
<body>
|
|
92
|
+
<div id="graphiql">
|
|
93
|
+
<div class="loading">Loading…</div>
|
|
94
|
+
</div>
|
|
81
95
|
</body>
|
|
82
96
|
</html>
|
package/lib/bulk.js
DELETED
|
@@ -1,273 +0,0 @@
|
|
|
1
|
-
/* eslint-disable */
|
|
2
|
-
import path from 'path';
|
|
3
|
-
import { Messages } from '@salesforce/core';
|
|
4
|
-
import { Duration } from '@salesforce/kit';
|
|
5
|
-
import { Flags, SfCommand } from '@salesforce/sf-plugins-core';
|
|
6
|
-
import dayjs from 'dayjs';
|
|
7
|
-
import * as csv from 'fast-csv';
|
|
8
|
-
// @ts-ignore
|
|
9
|
-
import fs from 'fs-extra';
|
|
10
|
-
import CsvConvertCommand from './commands/kit/data/csv/convert.js';
|
|
11
|
-
import * as utils from './utils.js';
|
|
12
|
-
Messages.importMessagesDirectoryFromMetaUrl(import.meta.url);
|
|
13
|
-
export const messages = Messages.loadMessages('@kitalive/sfdx-plugin', 'data.bulk');
|
|
14
|
-
export async function bulkQuery(conn, query, options) {
|
|
15
|
-
const wait = options?.wait ?? 5;
|
|
16
|
-
conn.bulk2.pollTimeout = Duration.minutes(wait).milliseconds;
|
|
17
|
-
const result = await conn.bulk2.query(query, options?.all ? { scanAll: true } : {});
|
|
18
|
-
return result.toArray();
|
|
19
|
-
}
|
|
20
|
-
export function bulkLoad(conn, sobject, operation, rows, options) {
|
|
21
|
-
const { batchSize = 10000, wait, ...jobOptions } = options || {};
|
|
22
|
-
const job = conn.bulk.createJob(sobject, operation, jobOptions);
|
|
23
|
-
const fetchResults = async (records) => ({
|
|
24
|
-
job: await job.check(),
|
|
25
|
-
batches: await job.list(),
|
|
26
|
-
records,
|
|
27
|
-
});
|
|
28
|
-
const executeBatch = (batchRows) => new Promise((resolve, reject) => {
|
|
29
|
-
const batch = job.createBatch();
|
|
30
|
-
batch.on('error', (e) => {
|
|
31
|
-
if (e.message.startsWith('Polling time out'))
|
|
32
|
-
job.emit('error', e);
|
|
33
|
-
reject(e);
|
|
34
|
-
});
|
|
35
|
-
batch.on('queue', () => {
|
|
36
|
-
batch
|
|
37
|
-
.check()
|
|
38
|
-
.then((result) => {
|
|
39
|
-
if (result.state === 'Failed') {
|
|
40
|
-
reject(result.stateMessage);
|
|
41
|
-
}
|
|
42
|
-
else if (wait) {
|
|
43
|
-
batch.poll(5000, wait * 60000);
|
|
44
|
-
}
|
|
45
|
-
else {
|
|
46
|
-
fetchResults([]).then(resolve).catch(reject);
|
|
47
|
-
}
|
|
48
|
-
})
|
|
49
|
-
.catch(reject);
|
|
50
|
-
});
|
|
51
|
-
batch.on('response', resolve);
|
|
52
|
-
batch.execute(batchRows);
|
|
53
|
-
});
|
|
54
|
-
// eslint-disable-next-line no-async-promise-executor
|
|
55
|
-
return new Promise(async (resolve, reject) => {
|
|
56
|
-
job.on('error', reject);
|
|
57
|
-
try {
|
|
58
|
-
const results = await Promise.all(utils.chunk(rows, batchSize).map(executeBatch));
|
|
59
|
-
resolve(await fetchResults(results.flat()));
|
|
60
|
-
}
|
|
61
|
-
catch (e) {
|
|
62
|
-
reject(e);
|
|
63
|
-
}
|
|
64
|
-
finally {
|
|
65
|
-
await job.close();
|
|
66
|
-
}
|
|
67
|
-
});
|
|
68
|
-
}
|
|
69
|
-
export function normalizeDateString(str, format) {
|
|
70
|
-
if (!str)
|
|
71
|
-
return str;
|
|
72
|
-
const d = dayjs(str);
|
|
73
|
-
return format ? d.format(format) : d.toISOString();
|
|
74
|
-
}
|
|
75
|
-
const converters = {
|
|
76
|
-
date: (value) => normalizeDateString(value, 'YYYY-MM-DD'),
|
|
77
|
-
datetime: normalizeDateString,
|
|
78
|
-
};
|
|
79
|
-
const csvFlags = CsvConvertCommand.flags;
|
|
80
|
-
export function commonFlags(operation) {
|
|
81
|
-
return {
|
|
82
|
-
sobject: Flags.string({
|
|
83
|
-
char: 's',
|
|
84
|
-
required: true,
|
|
85
|
-
summary: messages.getMessage('flags.sobject.summary', [operation]),
|
|
86
|
-
}),
|
|
87
|
-
// csv settings
|
|
88
|
-
csvfile: Flags.string({
|
|
89
|
-
char: 'f',
|
|
90
|
-
required: true,
|
|
91
|
-
summary: messages.getMessage('flags.csvfile.summary', [operation]),
|
|
92
|
-
}),
|
|
93
|
-
resultfile: Flags.string({
|
|
94
|
-
char: 'r',
|
|
95
|
-
summary: messages.getMessage('flags.resultfile.summary', [operation]),
|
|
96
|
-
}),
|
|
97
|
-
encoding: csvFlags.encoding,
|
|
98
|
-
delimiter: csvFlags.delimiter,
|
|
99
|
-
quote: csvFlags.quote,
|
|
100
|
-
skiplines: csvFlags.skiplines,
|
|
101
|
-
trim: csvFlags.trim,
|
|
102
|
-
mapping: csvFlags.mapping,
|
|
103
|
-
converter: csvFlags.converter,
|
|
104
|
-
setnull: Flags.boolean({
|
|
105
|
-
summary: messages.getMessage('flags.setnull.summary', [operation]),
|
|
106
|
-
}),
|
|
107
|
-
convertonly: Flags.boolean({
|
|
108
|
-
summary: messages.getMessage('flags.convertonly.summary', [operation]),
|
|
109
|
-
}),
|
|
110
|
-
// job settings
|
|
111
|
-
concurrencymode: Flags.string({
|
|
112
|
-
default: 'Parallel',
|
|
113
|
-
summary: messages.getMessage('flags.concurrencymode.summary'),
|
|
114
|
-
}),
|
|
115
|
-
assignmentruleid: Flags.string({
|
|
116
|
-
summary: messages.getMessage('flags.assignmentruleid.summary'),
|
|
117
|
-
}),
|
|
118
|
-
batchsize: Flags.integer({
|
|
119
|
-
min: 1,
|
|
120
|
-
max: 10000,
|
|
121
|
-
default: 10000,
|
|
122
|
-
summary: messages.getMessage('flags.batchsize.summary'),
|
|
123
|
-
}),
|
|
124
|
-
wait: Flags.integer({
|
|
125
|
-
char: 'w',
|
|
126
|
-
min: 0,
|
|
127
|
-
summary: messages.getMessage('flags.wait.summary'),
|
|
128
|
-
}),
|
|
129
|
-
'target-org': Flags.requiredOrg(),
|
|
130
|
-
'api-version': Flags.orgApiVersion(),
|
|
131
|
-
};
|
|
132
|
-
}
|
|
133
|
-
export class BulkCommand extends SfCommand {
|
|
134
|
-
static description = messages.getMessage('description');
|
|
135
|
-
static requiresProject = false;
|
|
136
|
-
async run() {
|
|
137
|
-
const { flags } = await this.parse();
|
|
138
|
-
const org = flags['target-org'];
|
|
139
|
-
const conn = org.getConnection(flags['api-version']);
|
|
140
|
-
Object.defineProperties(this, {
|
|
141
|
-
org: { value: org },
|
|
142
|
-
conn: { value: conn },
|
|
143
|
-
});
|
|
144
|
-
const { sobject, csvfile, mapping, converter, encoding, delimiter, quote, skiplines, trim, setnull, } = flags;
|
|
145
|
-
const mappingJson = mapping ? await fs.readJson(mapping) : undefined;
|
|
146
|
-
const script = converter
|
|
147
|
-
? await utils.loadScript(converter)
|
|
148
|
-
: {};
|
|
149
|
-
const fieldTypes = await this.getFieldTypes(conn, sobject);
|
|
150
|
-
this.spinner.start('Processing csv');
|
|
151
|
-
try {
|
|
152
|
-
if (script.start)
|
|
153
|
-
await script.start(this);
|
|
154
|
-
let rows = await this.parseCsv(fs.createReadStream(csvfile), {
|
|
155
|
-
encoding,
|
|
156
|
-
delimiter,
|
|
157
|
-
quote,
|
|
158
|
-
skiplines,
|
|
159
|
-
trim: !!trim,
|
|
160
|
-
setnull,
|
|
161
|
-
mapping: mappingJson,
|
|
162
|
-
convert: script.convert,
|
|
163
|
-
fieldTypes,
|
|
164
|
-
});
|
|
165
|
-
if (script.finish) {
|
|
166
|
-
const result = await script.finish(rows, this);
|
|
167
|
-
if (result)
|
|
168
|
-
rows = result;
|
|
169
|
-
}
|
|
170
|
-
this.spinner.stop();
|
|
171
|
-
if (flags.convertonly) {
|
|
172
|
-
const base = path.basename(csvfile, path.extname(csvfile));
|
|
173
|
-
await this.saveCsv(path.join(path.dirname(csvfile), base + '.converted.csv'), rows);
|
|
174
|
-
return;
|
|
175
|
-
}
|
|
176
|
-
this.spinner.start(`Bulk ${this.operation}`);
|
|
177
|
-
const result = await this.bulkLoad(conn, sobject, this.operation, rows, {
|
|
178
|
-
extIdField: flags.externalid,
|
|
179
|
-
concurrencyMode: flags.concurrencymode,
|
|
180
|
-
assignmentRuleId: flags.assignmentruleid,
|
|
181
|
-
batchSize: flags.batchsize,
|
|
182
|
-
wait: flags.wait,
|
|
183
|
-
});
|
|
184
|
-
if (!result)
|
|
185
|
-
return;
|
|
186
|
-
const batchErrors = [];
|
|
187
|
-
if (flags.wait) {
|
|
188
|
-
const { numberRecordsProcessed, numberRecordsFailed } = result.job;
|
|
189
|
-
this.spinner.stop(`${numberRecordsProcessed} processed, ${numberRecordsFailed} failed.`);
|
|
190
|
-
rows = rows.map((data, i) => {
|
|
191
|
-
const { id, errors } = result.records[i] || {};
|
|
192
|
-
const message = errors?.join(', ');
|
|
193
|
-
if (message) {
|
|
194
|
-
batchErrors.push({ line: i + 2, message, data });
|
|
195
|
-
}
|
|
196
|
-
return { ...data, Id: id, Errors: message };
|
|
197
|
-
});
|
|
198
|
-
if (batchErrors.length) {
|
|
199
|
-
result.errors = batchErrors;
|
|
200
|
-
this.styledHeader('Error details');
|
|
201
|
-
this.table({
|
|
202
|
-
data: batchErrors,
|
|
203
|
-
columns: ['line', 'message'],
|
|
204
|
-
});
|
|
205
|
-
}
|
|
206
|
-
}
|
|
207
|
-
else {
|
|
208
|
-
this.spinner.stop();
|
|
209
|
-
this.log(messages.getMessage('asyncJob', [
|
|
210
|
-
this.config.bin,
|
|
211
|
-
conn.username,
|
|
212
|
-
result.job?.id,
|
|
213
|
-
]));
|
|
214
|
-
}
|
|
215
|
-
if (flags.resultfile)
|
|
216
|
-
await this.saveCsv(flags.resultfile, rows);
|
|
217
|
-
return result;
|
|
218
|
-
}
|
|
219
|
-
catch (e) {
|
|
220
|
-
this.spinner.stop('error');
|
|
221
|
-
throw e;
|
|
222
|
-
}
|
|
223
|
-
}
|
|
224
|
-
async parseCsv(input, options) {
|
|
225
|
-
const { encoding, delimiter, quote, skiplines, trim, mapping, convert, setnull, fieldTypes, } = options ?? {};
|
|
226
|
-
return utils.parseCsv(typeof input === 'string' ? fs.createReadStream(input) : 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
|
-
// @ts-ignore
|
|
240
|
-
const converter = converters[fieldTypes[key]];
|
|
241
|
-
if (converter)
|
|
242
|
-
result[key] = converter(result[key]);
|
|
243
|
-
}
|
|
244
|
-
}
|
|
245
|
-
if (setnull) {
|
|
246
|
-
for (const key of Object.keys(result)) {
|
|
247
|
-
if (key.includes('.'))
|
|
248
|
-
continue; // skip reference
|
|
249
|
-
if (result[key] == null || result[key] === '')
|
|
250
|
-
result[key] = '#N/A';
|
|
251
|
-
}
|
|
252
|
-
}
|
|
253
|
-
return result;
|
|
254
|
-
},
|
|
255
|
-
});
|
|
256
|
-
}
|
|
257
|
-
async saveCsv(file, rows) {
|
|
258
|
-
return new Promise((resolve, reject) => {
|
|
259
|
-
csv
|
|
260
|
-
.writeToPath(file, rows, { headers: true, writeBOM: true })
|
|
261
|
-
.on('error', reject)
|
|
262
|
-
.on('finish', resolve);
|
|
263
|
-
});
|
|
264
|
-
}
|
|
265
|
-
bulkLoad(conn, sobject, op, rows, options) {
|
|
266
|
-
return bulkLoad(conn, sobject, op, rows, options);
|
|
267
|
-
}
|
|
268
|
-
async getFieldTypes(conn, sobject) {
|
|
269
|
-
const objectInfo = await conn.describe(sobject);
|
|
270
|
-
return objectInfo.fields.reduce((info, { name, type }) => Object.assign(info, { [name]: type }), {});
|
|
271
|
-
}
|
|
272
|
-
}
|
|
273
|
-
//# sourceMappingURL=bulk.js.map
|
package/lib/bulk.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"bulk.js","sourceRoot":"","sources":["../src/bulk.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,100 +0,0 @@
|
|
|
1
|
-
import { Messages } from '@salesforce/core';
|
|
2
|
-
import { Flags, SfCommand } from '@salesforce/sf-plugins-core';
|
|
3
|
-
import soqlParser from '@jetstreamapp/soql-parser-js';
|
|
4
|
-
import { bulkLoad, bulkQuery, } from '../../../../bulk.js';
|
|
5
|
-
const { composeQuery, getField, parseQuery } = soqlParser;
|
|
6
|
-
Messages.importMessagesDirectoryFromMetaUrl(import.meta.url);
|
|
7
|
-
const bulkMessages = Messages.loadMessages('@kitalive/sfdx-plugin', 'data.bulk');
|
|
8
|
-
const messages = Messages.loadMessages('@kitalive/sfdx-plugin', 'data.bulk.delete');
|
|
9
|
-
export default class DeleteCommand extends SfCommand {
|
|
10
|
-
static summary = messages.getMessage('summary');
|
|
11
|
-
static examples = messages.getMessages('examples');
|
|
12
|
-
static flags = {
|
|
13
|
-
query: Flags.string({
|
|
14
|
-
char: 'q',
|
|
15
|
-
required: true,
|
|
16
|
-
summary: messages.getMessage('flags.query.summary'),
|
|
17
|
-
}),
|
|
18
|
-
hard: Flags.boolean({
|
|
19
|
-
default: false,
|
|
20
|
-
summary: messages.getMessage('flags.hard.summary'),
|
|
21
|
-
}),
|
|
22
|
-
concurrencymode: Flags.string({
|
|
23
|
-
default: 'Parallel',
|
|
24
|
-
summary: bulkMessages.getMessage('flags.concurrencymode.summary'),
|
|
25
|
-
}),
|
|
26
|
-
batchsize: Flags.integer({
|
|
27
|
-
char: 's',
|
|
28
|
-
min: 1,
|
|
29
|
-
max: 10_000,
|
|
30
|
-
default: 10_000,
|
|
31
|
-
summary: bulkMessages.getMessage('flags.batchsize.summary'),
|
|
32
|
-
}),
|
|
33
|
-
wait: Flags.integer({
|
|
34
|
-
char: 'w',
|
|
35
|
-
default: 0,
|
|
36
|
-
min: 0,
|
|
37
|
-
summary: bulkMessages.getMessage('flags.wait.summary'),
|
|
38
|
-
}),
|
|
39
|
-
'target-org': Flags.requiredOrg(),
|
|
40
|
-
'api-version': Flags.orgApiVersion(),
|
|
41
|
-
};
|
|
42
|
-
async run() {
|
|
43
|
-
const { flags } = await this.parse();
|
|
44
|
-
const org = flags['target-org'];
|
|
45
|
-
const conn = org.getConnection(flags['api-version']);
|
|
46
|
-
const query = parseQuery(flags.query);
|
|
47
|
-
query.fields = [getField('Id')];
|
|
48
|
-
const soql = composeQuery(query);
|
|
49
|
-
this.spinner.start(flags.hard ? 'Bulk hard delete' : 'Bulk delete');
|
|
50
|
-
try {
|
|
51
|
-
const rows = await this.bulkQuery(conn, soql);
|
|
52
|
-
if (!rows.length) {
|
|
53
|
-
this.spinner.stop('no records');
|
|
54
|
-
return { records: [] };
|
|
55
|
-
}
|
|
56
|
-
const operation = flags.hard ? 'hardDelete' : 'delete';
|
|
57
|
-
const result = await this.bulkLoad(conn, query.sObject, operation, rows, {
|
|
58
|
-
concurrencyMode: flags.concurrencymode,
|
|
59
|
-
batchSize: flags.batchsize,
|
|
60
|
-
wait: flags.wait,
|
|
61
|
-
});
|
|
62
|
-
if (!result)
|
|
63
|
-
return;
|
|
64
|
-
if (flags.wait) {
|
|
65
|
-
const { numberRecordsProcessed, numberRecordsFailed } = result.job;
|
|
66
|
-
const errors = result.records
|
|
67
|
-
.filter((r) => !r.success)
|
|
68
|
-
.map((r) => ({ id: r.id, errors: r.errors.join(', ') }));
|
|
69
|
-
this.spinner.stop(`${numberRecordsProcessed} processed, ${numberRecordsFailed} failed.`);
|
|
70
|
-
if (errors.length) {
|
|
71
|
-
this.styledHeader('Error details');
|
|
72
|
-
this.table({
|
|
73
|
-
data: errors,
|
|
74
|
-
columns: ['id', 'errors'],
|
|
75
|
-
});
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
else {
|
|
79
|
-
this.spinner.stop();
|
|
80
|
-
this.log(bulkMessages.getMessage('asyncJob', [
|
|
81
|
-
this.config.bin,
|
|
82
|
-
org.getUsername(),
|
|
83
|
-
result.job?.id,
|
|
84
|
-
]));
|
|
85
|
-
}
|
|
86
|
-
return result;
|
|
87
|
-
}
|
|
88
|
-
catch (e) {
|
|
89
|
-
this.spinner.stop('error');
|
|
90
|
-
throw e;
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
bulkQuery(conn, query) {
|
|
94
|
-
return bulkQuery(conn, query);
|
|
95
|
-
}
|
|
96
|
-
bulkLoad(conn, sobject, operation, rows, options) {
|
|
97
|
-
return bulkLoad(conn, sobject, operation, rows, options);
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
//# sourceMappingURL=delete.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"delete.js","sourceRoot":"","sources":["../../../../../src/commands/kit/data/bulk/delete.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { BulkCommand, messages, commonFlags } from '../../../../bulk.js';
|
|
2
|
-
export default class InsertCommand extends BulkCommand {
|
|
3
|
-
static examples = messages.getMessages('examples', ['Insert']);
|
|
4
|
-
static flags = commonFlags('insert');
|
|
5
|
-
operation = 'insert';
|
|
6
|
-
}
|
|
7
|
-
//# sourceMappingURL=insert.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"insert.js","sourceRoot":"","sources":["../../../../../src/commands/kit/data/bulk/insert.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAEzE,MAAM,CAAC,OAAO,OAAO,aAAc,SAAQ,WAAW;IAC7C,MAAM,CAAC,QAAQ,GAAG,QAAQ,CAAC,WAAW,CAAC,UAAU,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;IAE/D,MAAM,CAAC,KAAK,GAAG,WAAW,CAAC,QAAQ,CAAC,CAAC;IAElC,SAAS,GAAoB,QAAQ,CAAC"}
|