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 .csv suffix or ?format=csv
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: text/csv
HTTP/1.1 200 OK Content-Type: text/csv Content-Length: length {"offset":0,"total":0,"results":[{"id":0,"postId":0,"userId":0,"replyId":0,"content":"String","contentHtml":"String","score":0,"rank":0,"upVotes":0,"downVotes":0,"favorites":0,"wordCount":0,"reportCount":0,"deleted":"0001-01-01T00:00:00.0000000","hidden":"0001-01-01T00:00:00.0000000","modified":"0001-01-01T00:00:00.0000000","created":"0001-01-01T00:00:00.0000000","createdBy":"String","refId":0,"refSource":"String","refUrn":"String"}],"meta":{"String":"String"},"responseStatus":{"errorCode":"String","message":"String","stackTrace":"String","errors":[{"errorCode":"String","fieldName":"String","message":"String","meta":{"String":"String"}}],"meta":{"String":"String"}}}