Required role: | Moderator |
using System;
using System.IO;
using System.Collections;
using System.Collections.Generic;
using System.Runtime.Serialization;
using ServiceStack;
using ServiceStack.DataAnnotations;
using BlazorDiffusion.ServiceModel;
namespace BlazorDiffusion.ServiceModel
{
[ValidateRequest("HasRole(`Moderator`)")]
public partial class CreateModifier
: ICreateDb<Modifier>
{
[Validate("NotEmpty")]
[Required]
public virtual string Name { get; set; }
[Validate("NotEmpty")]
[Required]
public virtual string Category { get; set; }
public virtual string Description { get; set; }
}
public partial class Modifier
: AuditBase
{
public virtual int Id { get; set; }
public virtual string Name { get; set; }
public virtual string Category { get; set; }
public virtual string Description { get; set; }
public virtual int Score { get; set; }
public virtual int Rank { get; set; }
}
}
namespace ServiceStack
{
[DataContract]
public partial class AuditBase
{
[DataMember(Order=1)]
public virtual DateTime CreatedDate { get; set; }
[DataMember(Order=2)]
[Required]
public virtual string CreatedBy { get; set; }
[DataMember(Order=3)]
public virtual DateTime ModifiedDate { get; set; }
[DataMember(Order=4)]
[Required]
public virtual string ModifiedBy { get; set; }
[DataMember(Order=5)]
public virtual DateTime? DeletedDate { get; set; }
[DataMember(Order=6)]
public virtual string DeletedBy { get; set; }
}
}
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 /csv/reply/CreateModifier HTTP/1.1
Host: blazordiffusion.com
Accept: text/csv
Content-Type: text/csv
Content-Length: length
{"name":"String","category":"String","description":"String"}
HTTP/1.1 200 OK Content-Type: text/csv Content-Length: length {"id":0,"name":"String","category":"String","description":"String","score":0,"rank":0,"createdDate":"0001-01-01T00:00:00","createdBy":"String","modifiedDate":"0001-01-01T00:00:00","modifiedBy":"String","deletedDate":"0001-01-01T00:00:00","deletedBy":"String"}