MyApp

<back to all web services

QueryPlayer

Game
using System;
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 Player()
        {
            PhoneNumbers = new List<Phone>{};
            GameItems = new List<PlayerGameItem>{};
        }

        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 Profile()
        {
            Meta = new Dictionary<string, string>{};
        }

        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
    {
        public QueryBase()
        {
            Meta = new Dictionary<string, string>{};
        }

        [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<Todo>
    {
        public QueryResponse()
        {
            Results = new List<Todo>{};
            Meta = new Dictionary<string, string>{};
        }

        [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; }
    }

}

C# QueryPlayer DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .csv suffix or ?format=csv

HTTP + 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"}}}