| GET | /posts/{category} |
|---|
export class PagingRequest
{
public page: number;
public limit: number;
public offSet: number;
public constructor(init?: Partial<PagingRequest>) { (Object as any).assign(this, init); }
}
export class CategoryResponse
{
public id: number;
public name: string;
public slug: string;
public constructor(init?: Partial<CategoryResponse>) { (Object as any).assign(this, init); }
}
export class PostResponse
{
public id: number;
public title: string;
public slug: string;
public description: string;
public body: string;
public categoryId: number;
public category: CategoryResponse;
public imageUrl: string;
public viewCount: number;
public isPublished: boolean;
public publishedDate: string;
public createdDate: string;
public updatedDate: string;
public constructor(init?: Partial<PostResponse>) { (Object as any).assign(this, init); }
}
export class GetPostByCategoryRequest extends PagingRequest
{
public category: string;
public constructor(init?: Partial<GetPostByCategoryRequest>) { super(init); (Object as any).assign(this, init); }
}
export class Pagination
{
public total: number;
public pages: number;
public offset: number;
public limit: number;
public currentPage: number;
public constructor(init?: Partial<Pagination>) { (Object as any).assign(this, init); }
}
export class PageResponse<PostResponse> implements IResponseRequest
{
public code: number;
public message: string;
public data: PostResponse[];
public pagination: Pagination;
public constructor(init?: Partial<PageResponse<PostResponse>>) { (Object as any).assign(this, init); }
}
TypeScript GetPostByCategoryRequest DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
GET /posts/{category} HTTP/1.1
Host: tanchinhdo-api-sandbox.adnx.vn
Accept: text/jsv
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length
{
code: 0,
message: String,
data:
[
{
id: 0,
title: String,
slug: String,
description: String,
body: String,
categoryId: 0,
category:
{
id: 0,
name: String,
slug: String
},
imageUrl: String,
viewCount: 0,
isPublished: False
}
]
}