GET | /posts/comment |
---|
import Foundation
import ServiceStack
public class QueryPostComments : QueryDb<PostComment>
{
public var id:Int?
public var userId:Int?
public var postId:Int?
public var contentContains:String
public var upVotesAbove:Int?
public var upVotesBelow:Int?
public var downVotesAbove:Int?
public var downVotes:Int?
public var favoritesAbove:Int?
public var favoritesBelow:Int?
public var wordCountAbove:Int?
public var wordCountBelow:Int?
public var reportCountAbove:Int?
public var reportCountBelow:Int?
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case id
case userId
case postId
case contentContains
case upVotesAbove
case upVotesBelow
case downVotesAbove
case downVotes
case favoritesAbove
case favoritesBelow
case wordCountAbove
case wordCountBelow
case reportCountAbove
case reportCountBelow
}
required public init(from decoder: Decoder) throws {
try super.init(from: decoder)
let container = try decoder.container(keyedBy: CodingKeys.self)
id = try container.decodeIfPresent(Int.self, forKey: .id)
userId = try container.decodeIfPresent(Int.self, forKey: .userId)
postId = try container.decodeIfPresent(Int.self, forKey: .postId)
contentContains = try container.decodeIfPresent(String.self, forKey: .contentContains)
upVotesAbove = try container.decodeIfPresent(Int.self, forKey: .upVotesAbove)
upVotesBelow = try container.decodeIfPresent(Int.self, forKey: .upVotesBelow)
downVotesAbove = try container.decodeIfPresent(Int.self, forKey: .downVotesAbove)
downVotes = try container.decodeIfPresent(Int.self, forKey: .downVotes)
favoritesAbove = try container.decodeIfPresent(Int.self, forKey: .favoritesAbove)
favoritesBelow = try container.decodeIfPresent(Int.self, forKey: .favoritesBelow)
wordCountAbove = try container.decodeIfPresent(Int.self, forKey: .wordCountAbove)
wordCountBelow = try container.decodeIfPresent(Int.self, forKey: .wordCountBelow)
reportCountAbove = try container.decodeIfPresent(Int.self, forKey: .reportCountAbove)
reportCountBelow = try container.decodeIfPresent(Int.self, forKey: .reportCountBelow)
}
public override func encode(to encoder: Encoder) throws {
try super.encode(to: encoder)
var container = encoder.container(keyedBy: CodingKeys.self)
if id != nil { try container.encode(id, forKey: .id) }
if userId != nil { try container.encode(userId, forKey: .userId) }
if postId != nil { try container.encode(postId, forKey: .postId) }
if contentContains != nil { try container.encode(contentContains, forKey: .contentContains) }
if upVotesAbove != nil { try container.encode(upVotesAbove, forKey: .upVotesAbove) }
if upVotesBelow != nil { try container.encode(upVotesBelow, forKey: .upVotesBelow) }
if downVotesAbove != nil { try container.encode(downVotesAbove, forKey: .downVotesAbove) }
if downVotes != nil { try container.encode(downVotes, forKey: .downVotes) }
if favoritesAbove != nil { try container.encode(favoritesAbove, forKey: .favoritesAbove) }
if favoritesBelow != nil { try container.encode(favoritesBelow, forKey: .favoritesBelow) }
if wordCountAbove != nil { try container.encode(wordCountAbove, forKey: .wordCountAbove) }
if wordCountBelow != nil { try container.encode(wordCountBelow, forKey: .wordCountBelow) }
if reportCountAbove != nil { try container.encode(reportCountAbove, forKey: .reportCountAbove) }
if reportCountBelow != nil { try container.encode(reportCountBelow, forKey: .reportCountBelow) }
}
}
public class PostComment : Codable
{
public var id:Int
public var postId:Int
public var userId:Int
public var replyId:Int?
// @StringLength(Int32.max)
public var content:String
// @StringLength(Int32.max)
public var contentHtml:String
public var score:Int
public var rank:Int
public var upVotes:Int
public var downVotes:Int
public var favorites:Int
public var wordCount:Int
public var reportCount:Int
public var deleted:Date?
public var hidden:Date?
public var modified:Date
public var created:Date
public var createdBy:String
public var refId:Int?
public var refSource:String
public var refUrn:String
required public init(){}
}
public class Post : Codable
{
public var id:Int
public var organizationId:Int
public var userId:Int
public var type:PostType
public var categoryId:Int
public var title:String
public var slug:String
public var url:String
public var imageUrl:String
// @StringLength(Int32.max)
public var content:String
// @StringLength(Int32.max)
public var contentHtml:String
public var pinCommentId:Int?
public var technologyIds:[Int]
public var fromDate:Date?
public var toDate:Date?
public var location:String
public var metaType:String
public var meta:String
public var approved:Bool
public var upVotes:Int
public var downVotes:Int
public var points:Int
public var views:Int
public var favorites:Int
public var subscribers:Int
public var replyCount:Int
public var commentsCount:Int
public var wordCount:Int
public var reportCount:Int
public var linksCount:Int
public var linkedToCount:Int
public var score:Int
public var rank:Int
public var labels:[String]
public var refUserIds:[Int]
public var refLinks:[String]
public var muteUserIds:[Int]
public var lastCommentDate:Date?
public var lastCommentId:Int?
public var lastCommentUserId:Int?
public var deleted:Date?
public var deletedBy:String
public var locked:Date?
public var lockedBy:String
public var hidden:Date?
public var hiddenBy:String
public var status:String
public var statusDate:Date?
public var statusBy:String
public var archived:Bool
public var bumped:Date?
public var created:Date
public var createdBy:String
public var modified:Date
public var modifiedBy:String
public var refId:Int?
public var refSource:String
public var refUrn:String
required public init(){}
}
public enum PostType : String, Codable
{
case Announcement
case Post
case Showcase
case Question
case Request
}
To override the Content-type in your clients, use the HTTP Accept Header, append the .xml suffix or ?format=xml
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
GET /posts/comment HTTP/1.1 Host: techstacks.io Accept: application/xml
HTTP/1.1 200 OK Content-Type: application/xml Content-Length: length <QueryResponseOfPostCommentclPpLQp2 xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.servicestack.net/types"> <Offset>0</Offset> <Total>0</Total> <Results xmlns:d2p1="http://schemas.datacontract.org/2004/07/TechStacks.ServiceModel.Types"> <d2p1:PostComment> <d2p1:Content>String</d2p1:Content> <d2p1:ContentHtml>String</d2p1:ContentHtml> <d2p1:Created>0001-01-01T00:00:00</d2p1:Created> <d2p1:CreatedBy>String</d2p1:CreatedBy> <d2p1:Deleted>0001-01-01T00:00:00</d2p1:Deleted> <d2p1:DownVotes>0</d2p1:DownVotes> <d2p1:Favorites>0</d2p1:Favorites> <d2p1:Hidden>0001-01-01T00:00:00</d2p1:Hidden> <d2p1:Id>0</d2p1:Id> <d2p1:Modified>0001-01-01T00:00:00</d2p1:Modified> <d2p1:PostId>0</d2p1:PostId> <d2p1:Rank>0</d2p1:Rank> <d2p1:RefId>0</d2p1:RefId> <d2p1:RefSource>String</d2p1:RefSource> <d2p1:RefUrn>String</d2p1:RefUrn> <d2p1:ReplyId>0</d2p1:ReplyId> <d2p1:ReportCount>0</d2p1:ReportCount> <d2p1:Score>0</d2p1:Score> <d2p1:UpVotes>0</d2p1:UpVotes> <d2p1:UserId>0</d2p1:UserId> <d2p1:WordCount>0</d2p1:WordCount> </d2p1:PostComment> </Results> <Meta xmlns:d2p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays"> <d2p1:KeyValueOfstringstring> <d2p1:Key>String</d2p1:Key> <d2p1:Value>String</d2p1:Value> </d2p1:KeyValueOfstringstring> </Meta> <ResponseStatus> <ErrorCode>String</ErrorCode> <Message>String</Message> <StackTrace>String</StackTrace> <Errors> <ResponseError> <ErrorCode>String</ErrorCode> <FieldName>String</FieldName> <Message>String</Message> <Meta xmlns:d5p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays"> <d5p1:KeyValueOfstringstring> <d5p1:Key>String</d5p1:Key> <d5p1:Value>String</d5p1:Value> </d5p1:KeyValueOfstringstring> </Meta> </ResponseError> </Errors> <Meta xmlns:d3p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays"> <d3p1:KeyValueOfstringstring> <d3p1:Key>String</d3p1:Key> <d3p1:Value>String</d3p1:Value> </d3p1:KeyValueOfstringstring> </Meta> </ResponseStatus> </QueryResponseOfPostCommentclPpLQp2>