using System;
using System.IO;
using System.Collections;
using System.Collections.Generic;
using System.Runtime.Serialization;
using ServiceStack;
using ServiceStack.DataAnnotations;
using MyApp.ServiceModel;
namespace MyApp.ServiceModel
{
public partial class Phone
{
public virtual PhoneKind Kind { get; set; }
public virtual string Number { get; set; }
public virtual string Ext { get; set; }
}
public enum PhoneKind
{
Home,
Mobile,
Work,
}
public partial class Player
: AuditBase
{
public virtual int Id { get; set; }
[Required]
public virtual string FirstName { get; set; }
public virtual string LastName { get; set; }
public virtual string Email { get; set; }
public virtual List<Phone> PhoneNumbers { get; set; } = [];
public virtual List<PlayerGameItem> GameItems { get; set; } = [];
public virtual Profile Profile { get; set; }
public virtual int ProfileId { get; set; }
public virtual Guid SavedLevelId { get; set; }
public virtual ulong RowVersion { get; set; }
}
public partial class PlayerGameItem
{
public virtual int Id { get; set; }
[References(typeof(MyApp.ServiceModel.Player))]
public virtual int PlayerId { get; set; }
[References(typeof(MyApp.ServiceModel.GameItem))]
public virtual string GameItemName { get; set; }
}
public enum PlayerRegion
{
Africa = 1,
Americas = 2,
Asia = 3,
Australasia = 4,
Europe = 5,
}
public enum PlayerRole
{
Leader,
Player,
NonPlayer,
}
public partial class Profile
: AuditBase
{
public virtual int Id { get; set; }
public virtual PlayerRole Role { get; set; }
public virtual PlayerRegion Region { get; set; }
public virtual string Username { get; set; }
public virtual long HighScore { get; set; }
public virtual long GamesPlayed { get; set; }
public virtual int Energy { get; set; }
public virtual string ProfileUrl { get; set; }
public virtual string CoverUrl { get; set; }
public virtual Dictionary<string, string> Meta { get; set; }
}
public partial class QueryPlayer
: QueryDb<Player>
{
}
public partial class Todo
{
public virtual long Id { get; set; }
public virtual string Text { get; set; }
public virtual bool IsFinished { 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; }
}
[DataContract]
public partial class QueryBase
{
[DataMember(Order=1)]
public virtual int? Skip { get; set; }
[DataMember(Order=2)]
public virtual int? Take { get; set; }
[DataMember(Order=3)]
public virtual string OrderBy { get; set; }
[DataMember(Order=4)]
public virtual string OrderByDesc { get; set; }
[DataMember(Order=5)]
public virtual string Include { get; set; }
[DataMember(Order=6)]
public virtual string Fields { get; set; }
[DataMember(Order=7)]
public virtual Dictionary<string, string> Meta { get; set; }
}
public partial class QueryDb<T>
: QueryBase
{
}
[DataContract]
public partial class QueryResponse<T>
{
[DataMember(Order=1)]
public virtual int Offset { get; set; }
[DataMember(Order=2)]
public virtual int Total { get; set; }
[DataMember(Order=3)]
public virtual List<Todo> Results { get; set; }
[DataMember(Order=4)]
public virtual Dictionary<string, string> Meta { get; set; }
[DataMember(Order=5)]
public virtual ResponseStatus ResponseStatus { 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/QueryPlayer HTTP/1.1
Host: blazor-gallery.servicestack.net
Accept: text/csv
Content-Type: text/csv
Content-Length: length
{"skip":0,"take":0,"orderBy":"String","orderByDesc":"String","include":"String","fields":"String","meta":{"String":"String"}}
HTTP/1.1 200 OK Content-Type: text/csv Content-Length: length {"offset":0,"total":0,"results":[{"id":0,"firstName":"String","lastName":"String","email":"String","phoneNumbers":[{"kind":"Home","number":"String","ext":"String"}],"gameItems":[{"id":0,"playerId":0,"gameItemName":"String"}],"profile":{"id":0,"role":"Leader","region":"Africa","username":"String","highScore":0,"gamesPlayed":0,"energy":0,"profileUrl":"String","coverUrl":"String","meta":{"String":"String"},"createdDate":"0001-01-01T00:00:00","createdBy":"String","modifiedDate":"0001-01-01T00:00:00","modifiedBy":"String","deletedDate":"0001-01-01T00:00:00","deletedBy":"String"},"profileId":0,"savedLevelId":"00000000-0000-0000-0000-000000000000","rowVersion":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"}],"meta":{"String":"String"},"responseStatus":{"errorCode":"String","message":"String","stackTrace":"String","errors":[{"errorCode":"String","fieldName":"String","message":"String","meta":{"String":"String"}}],"meta":{"String":"String"}}}