| GET,POST,PUT,DELETE,OPTIONS | /v1/Project/Invoice/{ProjectID}/{InvoiceStartDate}/{InvoiceEndDate} |
|---|
export class ProjectInvoice
{
public CostType: string;
public CostName: string;
public CostToDate: number;
public JobID: number;
public Rate: number;
public Hours: number;
public constructor(init?: Partial<ProjectInvoice>) { (Object as any).assign(this, init); }
}
export class ProjectInvoiceResponse
{
public ResponseStatus: ResponseStatus;
public ProjectInvoice: ProjectInvoice[] = [];
public constructor(init?: Partial<ProjectInvoiceResponse>) { (Object as any).assign(this, init); }
}
export class ProjectInvoiceRequest
{
public ProjectID: number;
public InvoiceStartDate: string;
public InvoiceEndDate: string;
public constructor(init?: Partial<ProjectInvoiceRequest>) { (Object as any).assign(this, init); }
}
TypeScript ProjectInvoiceRequest DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .csv suffix or ?format=csv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /v1/Project/Invoice/{ProjectID}/{InvoiceStartDate}/{InvoiceEndDate} HTTP/1.1
Host: api.dev.dynamics.trendsic.com
Accept: text/csv
Content-Type: text/csv
Content-Length: length
{"ProjectID":0,"InvoiceStartDate":"0001-01-01T00:00:00.0000000","InvoiceEndDate":"0001-01-01T00:00:00.0000000"}
HTTP/1.1 200 OK
Content-Type: text/csv
Content-Length: length
{"ResponseStatus":{"ErrorCode":"String","Message":"String","StackTrace":"String","Errors":[{"ErrorCode":"String","FieldName":"String","Message":"String","Meta":{"String":"String"}}],"Meta":{"String":"String"}},"ProjectInvoice":[{"CostType":"String","CostName":"String","CostToDate":0,"JobID":0,"Rate":0,"Hours":0}]}