generated from salesforcecli/lerna-template
-
Notifications
You must be signed in to change notification settings - Fork 14
/
record.ts
106 lines (99 loc) · 3.8 KB
/
record.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
/*
* Copyright (c) 2020, salesforce.com, inc.
* All rights reserved.
* Licensed under the BSD 3-Clause license.
* For full license text, see LICENSE.txt file in the repo root or https://opensource.org/licenses/BSD-3-Clause
*/
import { Messages, SfError } from '@salesforce/core';
import type { SaveError, SaveResult } from '@jsforce/jsforce-node';
import { SfCommand, Flags } from '@salesforce/sf-plugins-core';
import { orgFlags } from '../../../flags.js';
import { collectErrorMessages, query, stringToDictionary } from '../../../dataUtils.js';
Messages.importMessagesDirectoryFromMetaUrl(import.meta.url);
const messages = Messages.loadMessages('@salesforce/plugin-data', 'record.update');
const commonMessages = Messages.loadMessages('@salesforce/plugin-data', 'messages');
export default class Update extends SfCommand<SaveResult> {
public static readonly summary = messages.getMessage('summary');
public static readonly description = messages.getMessage('description');
public static readonly examples = messages.getMessages('examples');
public static readonly aliases = ['force:data:record:update'];
public static readonly deprecateAliases = true;
public static readonly flags = {
...orgFlags,
sobject: Flags.string({
char: 's',
required: true,
summary: messages.getMessage('flags.sobject.summary'),
aliases: ['sobjecttype'],
deprecateAliases: true,
}),
// eslint-disable-next-line sf-plugin/id-flag-suggestions
'record-id': Flags.salesforceId({
char: 'i',
length: 'both',
summary: messages.getMessage('flags.record-id.summary'),
exactlyOne: ['where', 'record-id'],
aliases: ['sobjectid'],
deprecateAliases: true,
}),
where: Flags.string({
char: 'w',
summary: messages.getMessage('flags.where.summary'),
exactlyOne: ['where', 'record-id'],
}),
values: Flags.string({
char: 'v',
required: true,
summary: messages.getMessage('flags.values.summary'),
}),
'use-tooling-api': Flags.boolean({
char: 't',
summary: messages.getMessage('flags.use-tooling-api.summary'),
aliases: ['usetoolingapi'],
deprecateAliases: true,
}),
perflog: Flags.boolean({
summary: commonMessages.getMessage('perfLogLevelOption'),
hidden: true,
deprecated: {
version: '57',
},
}),
};
public async run(): Promise<SaveResult> {
const { flags } = await this.parse(Update);
this.spinner.start('Updating Record');
let status = 'Success';
const conn = flags['use-tooling-api']
? flags['target-org'].getConnection(flags['api-version']).tooling
: flags['target-org'].getConnection(flags['api-version']);
// oclif isn't smart of enough to know that if record-id is not set, then where is set
const sObjectId = flags['record-id'] ?? ((await query(conn, flags.sobject, flags.where as string)).Id as string);
try {
const updateObject = { ...stringToDictionary(flags.values), Id: sObjectId };
const result = await conn.sobject(flags.sobject).update(updateObject);
if (result.success) {
this.log(messages.getMessage('updateSuccess', [sObjectId]));
} else {
const errors = collectErrorMessages(result);
this.error(messages.getMessage('updateFailure', [errors]));
}
this.spinner.stop(status);
return result;
} catch (err) {
status = 'Failed';
this.spinner.stop(status);
if (isSaveResult(err)) {
throw new SfError(
messages.getMessage('updateFailureWithFields', [err.errorCode, err.message, (err.fields ?? []).join(',')])
);
} else {
throw err;
}
}
}
}
const isSaveResult = (error: unknown): error is SaveError => {
const se = error as SaveError;
return Boolean(se.fields && se.errorCode && se.message);
};