Required role: | Moderator |
// @DataContract
export class AuditBase
{
// @DataMember(Order=1)
public createdDate: string;
// @DataMember(Order=2)
// @Required()
public createdBy: string;
// @DataMember(Order=3)
public modifiedDate: string;
// @DataMember(Order=4)
// @Required()
public modifiedBy: string;
// @DataMember(Order=5)
public deletedDate?: string;
// @DataMember(Order=6)
public deletedBy: string;
public constructor(init?: Partial<AuditBase>) { (Object as any).assign(this, init); }
}
export class Modifier extends AuditBase
{
public id: number;
public name: string;
public category: string;
public description?: string;
public score: number;
public rank: number;
public constructor(init?: Partial<Modifier>) { super(init); (Object as any).assign(this, init); }
}
// @ValidateRequest(Validator="HasRole(`Moderator`)")
export class CreateModifier implements ICreateDb<Modifier>
{
// @Validate(Validator="NotEmpty")
// @Required()
public name: string;
// @Validate(Validator="NotEmpty")
// @Required()
public category: string;
public description?: string;
public constructor(init?: Partial<CreateModifier>) { (Object as any).assign(this, init); }
}
TypeScript CreateModifier 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.
POST /jsv/reply/CreateModifier HTTP/1.1
Host: blazordiffusion.com
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
name: String,
category: String,
description: String
}
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { id: 0, name: String, category: String, description: String, score: 0, rank: 0, createdDate: 0001-01-01, createdBy: String, modifiedDate: 0001-01-01, modifiedBy: String, deletedDate: 0001-01-01, deletedBy: String }