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 Artist extends AuditBase
{
public id: number;
public firstName?: string;
public lastName: string;
public yearDied?: number;
public type?: string[];
public score: number;
public rank: number;
public constructor(init?: Partial<Artist>) { super(init); (Object as any).assign(this, init); }
}
// @ValidateRequest(Validator="HasRole(`Moderator`)")
export class UpdateArtist implements IPatchDb<Artist>
{
public id: number;
public firstName?: string;
public lastName?: string;
public yearDied?: number;
public type?: string[];
public constructor(init?: Partial<UpdateArtist>) { (Object as any).assign(this, init); }
}
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/UpdateArtist HTTP/1.1
Host: blazordiffusion.com
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
id: 0,
firstName: String,
lastName: String,
yearDied: 0,
type:
[
String
]
}
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { id: 0, firstName: String, lastName: String, yearDied: 0, type: [ String ], score: 0, rank: 0, createdDate: 0001-01-01, createdBy: String, modifiedDate: 0001-01-01, modifiedBy: String, deletedDate: 0001-01-01, deletedBy: String }