Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 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 | 10x 10x 10x 10x 10x 2x 2x 2x 2x 2x 2x 1x 2x | import ABatchNode from '@orchesty/nodejs-sdk/dist/lib/Batch/ABatchNode';
import { HttpMethods } from '@orchesty/nodejs-sdk/dist/lib/Transport/HttpMethods';
import BatchProcessDto from '@orchesty/nodejs-sdk/dist/lib/Utils/BatchProcessDto';
export const NAME = 'pipedrive-get-all-leads-batch';
export default class PipedriveGetAllLeadsBatch extends ABatchNode {
public getName(): string {
return NAME;
}
public async processAction(dto: BatchProcessDto): Promise<BatchProcessDto> {
const params = new URLSearchParams();
params.set('start', dto.getBatchCursor('0'));
params.set('limit', '100');
const response = (
await this.getSender().send<IResponse>(
await this.getApplication().getRequestDto(
dto,
await this.getApplicationInstallFromProcess(dto),
HttpMethods.GET,
`/leads?${params}`,
),
[200],
)
).getJsonBody();
dto.setItemList(response.data);
if (response.additional_data.pagination.more_items_in_collection) {
dto.setBatchCursor(
response.additional_data.pagination.next_start.toString(),
);
}
return dto;
}
}
/* eslint-disable @typescript-eslint/naming-convention */
export interface IOutput {
id: string;
title: string;
owner_id: number;
creator_id: number;
label_ids: string[];
value: unknown;
expected_close_date: Date;
person_id: number;
organization_id: number;
is_archived: boolean;
source_name: string;
was_seen: boolean;
next_activity_id: number;
add_time: Date;
update_time: Date;
visible_to: string;
cc_email: string;
}
interface IResponse {
success: boolean;
data: IOutput[];
additional_data: {
pagination: {
start: number;
limit: number;
next_start: number;
more_items_in_collection: boolean;
};
};
}
/* eslint-enable @typescript-eslint/naming-convention */
|