/* Options: Date: 2025-12-06 13:09:42 SwiftVersion: 5.0 Version: 6.110 Tip: To override a DTO option, remove "//" prefix before updating BaseUrl: https://etc-api.vsmlab.vn //BaseClass: //AddModelExtensions: True //AddServiceStackTypes: True IncludeTypes: ReportSearch.* //ExcludeTypes: //ExcludeGenericBaseTypes: False //AddResponseStatus: False //AddImplicitVersion: //AddDescriptionAsComments: True //InitializeCollections: True //TreatTypesAsStrings: //DefaultImports: Foundation,ServiceStack */ import Foundation import ServiceStack // @Route("/report/search", "POST") public class ReportSearch : PagingRequest, IReturn { public typealias Return = SearchResponse public var columns:[String] = [] public var title:String public var typeId:Int? public var groupId:Int? public var subjectId:Int? public var isUrgent:Bool? public var documentSearchStage:DocumentSearchStage public var isInternal:Bool? public var fromDate:Date? public var toDate:Date? public var statusId:Int? public var issuingAgencyId:Int? public var orderBy:SearchOrderBy public var isParty:Bool? required public init(){ super.init() } private enum CodingKeys : String, CodingKey { case columns case title case typeId case groupId case subjectId case isUrgent case documentSearchStage case isInternal case fromDate case toDate case statusId case issuingAgencyId case orderBy case isParty } required public init(from decoder: Decoder) throws { try super.init(from: decoder) let container = try decoder.container(keyedBy: CodingKeys.self) columns = try container.decodeIfPresent([String].self, forKey: .columns) ?? [] title = try container.decodeIfPresent(String.self, forKey: .title) typeId = try container.decodeIfPresent(Int.self, forKey: .typeId) groupId = try container.decodeIfPresent(Int.self, forKey: .groupId) subjectId = try container.decodeIfPresent(Int.self, forKey: .subjectId) isUrgent = try container.decodeIfPresent(Bool.self, forKey: .isUrgent) documentSearchStage = try container.decodeIfPresent(DocumentSearchStage.self, forKey: .documentSearchStage) isInternal = try container.decodeIfPresent(Bool.self, forKey: .isInternal) fromDate = try container.decodeIfPresent(Date.self, forKey: .fromDate) toDate = try container.decodeIfPresent(Date.self, forKey: .toDate) statusId = try container.decodeIfPresent(Int.self, forKey: .statusId) issuingAgencyId = try container.decodeIfPresent(Int.self, forKey: .issuingAgencyId) orderBy = try container.decodeIfPresent(SearchOrderBy.self, forKey: .orderBy) isParty = try container.decodeIfPresent(Bool.self, forKey: .isParty) } public override func encode(to encoder: Encoder) throws { try super.encode(to: encoder) var container = encoder.container(keyedBy: CodingKeys.self) if columns.count > 0 { try container.encode(columns, forKey: .columns) } if title != nil { try container.encode(title, forKey: .title) } if typeId != nil { try container.encode(typeId, forKey: .typeId) } if groupId != nil { try container.encode(groupId, forKey: .groupId) } if subjectId != nil { try container.encode(subjectId, forKey: .subjectId) } if isUrgent != nil { try container.encode(isUrgent, forKey: .isUrgent) } if documentSearchStage != nil { try container.encode(documentSearchStage, forKey: .documentSearchStage) } if isInternal != nil { try container.encode(isInternal, forKey: .isInternal) } if fromDate != nil { try container.encode(fromDate, forKey: .fromDate) } if toDate != nil { try container.encode(toDate, forKey: .toDate) } if statusId != nil { try container.encode(statusId, forKey: .statusId) } if issuingAgencyId != nil { try container.encode(issuingAgencyId, forKey: .issuingAgencyId) } if orderBy != nil { try container.encode(orderBy, forKey: .orderBy) } if isParty != nil { try container.encode(isParty, forKey: .isParty) } } } public class SearchResponse : IResponseRequest, Codable { public var totalCount:Int public var code:Int public var data:[DocumentSearchResultItem] = [] public var message:String required public init(){} } public class PagingRequest : Codable { public var page:Int public var limit:Int required public init(){} } public enum DocumentSearchStage : String, Codable { case All case AllProcessing case Draft case PendingApproval case IsRevisionRequested case PendingCompilation case PendingReport case Published case Active case InActive } public enum SearchOrderBy : String, Codable { case UpdatedDateDesc case PublishDateDesc } public protocol IResponseRequest { var code:Int { get set } var message:String { get set } } public class DocumentSearchResultItem : Codable { public var title:String public var Description:String public var owner:String public var documentPolicyId:Int? public var updateDocumentId:Int? public var effectBeginDate:Date? public var effectEndDate:Date? public var issuingAgencyId:Int? public var subjectId:Int? public var signBy:String public var signDate:Date? public var updatedAt:Date? public var statusId:Int? public var isInternal:Bool public var documentNumber:String public var documentCode:String public var isUrgent:Bool? public var id:Int public var reasonReturn:String public var accountId:Int? public var approverId:Int? // @StringLength(500) public var updatedBy:String // @StringLength(500) public var createdBy:String public var isParty:Bool? public var isRevisionRequested:Bool? public var isPrivate:Bool? public var departmentId:Int? public var publicationDate:Date? public var processStatusId:Int public var documentTypeId:Int? public var documentGroupId:Int? public var accountName:String public var acceptAccountName:String public var documentGroupText:String public var processStatusText:String public var documentTypeText:String public var departmentText:String public var statusText:String public var issuingAgencyText:String public var subjectText:String public var comment:String public var submitComment:String public var fullFile:String public var parthFile:String public var isActive:Bool? public var stepOrder:Int? public var stepCount:Int? required public init(){} }