-
Notifications
You must be signed in to change notification settings - Fork 9
Expand file tree
/
Copy pathquery-job.ts
More file actions
68 lines (57 loc) · 1.81 KB
/
query-job.ts
File metadata and controls
68 lines (57 loc) · 1.81 KB
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
/**
* Bulk Query Job — full lifecycle example.
*
* Usage:
* export SF_ACCESS_TOKEN="..."
* export SF_INSTANCE_URL="https://yourorg.my.salesforce.com"
* npx ts-node examples/query-job.ts
*/
import { BulkAPI2, BulkAPI2Connection, QueryInput } from 'node-sf-bulk2';
const connection: BulkAPI2Connection = {
accessToken: requireEnv('SF_ACCESS_TOKEN'),
instanceUrl: requireEnv('SF_INSTANCE_URL'),
apiVersion: process.env.SF_API_VERSION ?? '62.0',
};
async function main() {
const bulk = new BulkAPI2(connection);
// Submit a query job
const queryInput: QueryInput = {
query: 'SELECT Id, Name FROM Account LIMIT 10',
operation: 'query',
};
const job = await bulk.submitBulkQueryJob(queryInput);
console.log(`Query job created: ${job.id} (state: ${job.state})`);
// Poll until the job completes
let info = await bulk.getBulkQueryJobInfo(job.id);
while (info.state !== 'JobComplete' && info.state !== 'Failed') {
console.log(` state: ${info.state} — waiting...`);
await sleep(2000);
info = await bulk.getBulkQueryJobInfo(job.id);
}
console.log(`Job finished: ${info.state} (${info.numberRecordsProcessed} records processed)`);
if (info.state === 'Failed') {
process.exit(1);
}
// Retrieve CSV results
const response = await bulk.getBulkQueryResults(job.id);
console.log('\nResults (CSV):');
console.log(response.data);
// Clean up
await bulk.deleteBulkQueryJob(job.id);
console.log('Job deleted.');
}
function requireEnv(name: string): string {
const value = process.env[name];
if (!value) {
console.error(`Error: set the ${name} environment variable.`);
process.exit(1);
}
return value;
}
function sleep(ms: number) {
return new Promise((resolve) => setTimeout(resolve, ms));
}
main().catch((err) => {
console.error(err);
process.exit(1);
});