| 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>