All files / src/Connector ProductboardCreateNewFeatureConnector.ts

100% Statements 11/11
100% Branches 0/0
100% Functions 2/2
100% Lines 11/11

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 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 1033x 3x     3x   3x     3x       1x   1x 1x 1x 1x   1x                                                                                                                                                                    
import AConnector from '@orchesty/nodejs-sdk/dist/lib/Connector/AConnector';
import { HttpMethods } from '@orchesty/nodejs-sdk/dist/lib/Transport/HttpMethods';
import ProcessDto from '@orchesty/nodejs-sdk/dist/lib/Utils/ProcessDto';
 
export const NAME = 'productboard-create-new-feature-connector';
 
export default class ProductboardCreateNewFeatureConnector extends AConnector {
 
    public getName(): string {
        return NAME;
    }
 
    public async processAction(dto: ProcessDto<IInput>): Promise<ProcessDto<IOutput>> {
        const body = dto.getJsonData();
 
        const appInstall = await this.getApplicationInstallFromProcess(dto);
        const url = 'features';
        const req = await this.getApplication().getRequestDto(dto, appInstall, HttpMethods.POST, url, body);
        const resp = await this.getSender().send<IOutput>(req, [200]);
 
        return dto.setNewJsonData(resp.getJsonBody());
    }
 
}
 
export interface IInput {
    data: {
        name: string;
        description: string;
        type: 'feature' | 'subfeature';
        status: {
            id: string;
            name: string;
        };
        parent: {
            feature?: {
                id: string;
            };
            product?: {
                id: string;
            };
            component?: {
                id: string;
            };
        };
        archived: boolean;
        timeframe: {
            startDate: string;
            endDate: string;
            granularity: string;
        };
        owner?: {
            email: string;
        };
    };
}
 
export interface IOutput {
    data: {
        id: string;
        name: string;
        description: string;
        type: string;
        archived: boolean;
        status: {
            id: string;
            name: string;
        };
        parent: {
            feature?: {
                id: string;
                links: {
                    self: string;
                };
            };
            product?: {
                id: string;
                links: {
                    self: string;
                };
            };
            component?: {
                id: string;
                links: {
                    self: string;
                };
            };
        };
        links: {
            self: string;
            html: string;
        };
        timeframe: {
            startDate: string;
            endDate: string;
            granularity: string;
        };
        owner?: {
            email: string;
        };
    };
}