TechStacks!

<back to all web services

QueryPostComments

AutoQueryPosts
The following routes are available for this service:
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
}


Swift QueryPostComments DTOs

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

HTTP + JSV

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/jsv
HTTP/1.1 200 OK
Content-Type: text/jsv
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-01,
			hidden: 0001-01-01,
			modified: 0001-01-01,
			created: 0001-01-01,
			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
		}
	}
}