All files / src/Batch PipedriveGetAllLeadsBatch.ts

100% Statements 13/13
100% Branches 2/2
100% Functions 2/2
100% Lines 13/13

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 7810x 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 */