GET | /tender/{tenderid} |
---|
import Foundation
import ServiceStack
public class BrowseTender : IGet, Codable
{
public var tenderId:Int
required public init(){}
}
public class BrowseTenderResponse : ResponseBase
{
public var tender:TenderDetails
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case tender
}
required public init(from decoder: Decoder) throws {
try super.init(from: decoder)
let container = try decoder.container(keyedBy: CodingKeys.self)
tender = try container.decodeIfPresent(TenderDetails.self, forKey: .tender)
}
public override func encode(to encoder: Encoder) throws {
try super.encode(to: encoder)
var container = encoder.container(keyedBy: CodingKeys.self)
if tender != nil { try container.encode(tender, forKey: .tender) }
}
}
public class ResponseBase : Codable
{
public var responseStatus:ResponseStatus
required public init(){}
}
public class TenderDetails : TenderBase, IConcurrencyStamp
{
public var id:Int
public var starterTenderRoundId:Int?
public var procedureType:ProcedureType
public var meta:[String:String] = [:]
public var tenderFiles:[TenderFileDetails] = []
public var tenderRounds:[TenderRoundSimple] = []
public var concurrencyStamp:String
public var isProcurementEnabled:Bool
public var isComplianceEnabled:Bool
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case id
case starterTenderRoundId
case procedureType
case meta
case tenderFiles
case tenderRounds
case concurrencyStamp
case isProcurementEnabled
case isComplianceEnabled
}
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)
starterTenderRoundId = try container.decodeIfPresent(Int.self, forKey: .starterTenderRoundId)
procedureType = try container.decodeIfPresent(ProcedureType.self, forKey: .procedureType)
meta = try container.decodeIfPresent([String:String].self, forKey: .meta) ?? [:]
tenderFiles = try container.decodeIfPresent([TenderFileDetails].self, forKey: .tenderFiles) ?? []
tenderRounds = try container.decodeIfPresent([TenderRoundSimple].self, forKey: .tenderRounds) ?? []
concurrencyStamp = try container.decodeIfPresent(String.self, forKey: .concurrencyStamp)
isProcurementEnabled = try container.decodeIfPresent(Bool.self, forKey: .isProcurementEnabled)
isComplianceEnabled = try container.decodeIfPresent(Bool.self, forKey: .isComplianceEnabled)
}
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 starterTenderRoundId != nil { try container.encode(starterTenderRoundId, forKey: .starterTenderRoundId) }
if procedureType != nil { try container.encode(procedureType, forKey: .procedureType) }
if meta.count > 0 { try container.encode(meta, forKey: .meta) }
if tenderFiles.count > 0 { try container.encode(tenderFiles, forKey: .tenderFiles) }
if tenderRounds.count > 0 { try container.encode(tenderRounds, forKey: .tenderRounds) }
if concurrencyStamp != nil { try container.encode(concurrencyStamp, forKey: .concurrencyStamp) }
if isProcurementEnabled != nil { try container.encode(isProcurementEnabled, forKey: .isProcurementEnabled) }
if isComplianceEnabled != nil { try container.encode(isComplianceEnabled, forKey: .isComplianceEnabled) }
}
}
public class TenderBase : Codable
{
public var tenderIdentifier:String
public var tenderType:TenderType
public var subject:String
public var procurementContact:String
public var procurementContactEmail:String
public var procurementContactPhone:String
public var professionalContact:String
public var professionalContactEmail:String
public var professionalContactPhone:String
public var result:String
public var status:TenderStatus
required public init(){}
}
public enum TenderType : Int, Codable
{
case Private = 0
case Public = 1
}
public enum TenderStatus : Int, Codable
{
case FirstRound = 0
case SecondRound = 1
case ThirdRound = 2
case Successful = 3
case UnSuccessful = 4
case Revoked = 5
}
public enum ProcedureType : Int, Codable
{
case Competition = 0
case Simplified = 1
}
public class TenderFileDetails : BrowseFileResponseBase
{
public var tenderId:Int
public var documentType:String
public var isTenderAnnouncement:Bool
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case tenderId
case documentType
case isTenderAnnouncement
}
required public init(from decoder: Decoder) throws {
try super.init(from: decoder)
let container = try decoder.container(keyedBy: CodingKeys.self)
tenderId = try container.decodeIfPresent(Int.self, forKey: .tenderId)
documentType = try container.decodeIfPresent(String.self, forKey: .documentType)
isTenderAnnouncement = try container.decodeIfPresent(Bool.self, forKey: .isTenderAnnouncement)
}
public override func encode(to encoder: Encoder) throws {
try super.encode(to: encoder)
var container = encoder.container(keyedBy: CodingKeys.self)
if tenderId != nil { try container.encode(tenderId, forKey: .tenderId) }
if documentType != nil { try container.encode(documentType, forKey: .documentType) }
if isTenderAnnouncement != nil { try container.encode(isTenderAnnouncement, forKey: .isTenderAnnouncement) }
}
}
public class BrowseFileResponseBase : Codable
{
public var id:Int
public var fileContentId:Int
public var fileName:String
public var size:Int
required public init(){}
}
public class TenderRoundSimple : Codable
{
public var id:Int
public var name:String
public var isQuestionEnabled:Bool
public var questionDeadline:Date?
public var answerDeadline:Date?
public var submissionDeadline:Date
public var isSupplementaryEnabled:Bool
public var supplementaryRequestDeadline:Date?
public var supplementaryDeadline:Date?
public var announcementDateTime:Date
public var status:Int
required public init(){}
}
To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
GET /tender/{tenderid} HTTP/1.1 Host: szallitoiportal-be.veolia.hu Accept: text/jsv
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { "Tender": { "Id": 0, "StarterTenderRoundId": 0, "ProcedureType": 0, "Meta": { "String": "String" }, "TenderFiles": [ { "TenderId": 0, "DocumentType": "String", "IsTenderAnnouncement": false, "Id": 0, "FileContentId": 0, "FileName": "String", "Size": 0 } ], "TenderRounds": [ { "Id": 0, "Name": "String", "IsQuestionEnabled": false, "QuestionDeadline": "0001-01-01T00:00:00.0000000", "AnswerDeadline": "0001-01-01T00:00:00.0000000", "SubmissionDeadline": "0001-01-01T00:00:00.0000000", "IsSupplementaryEnabled": false, "SupplementaryRequestDeadline": "0001-01-01T00:00:00.0000000", "SupplementaryDeadline": "0001-01-01T00:00:00.0000000", "AnnouncementDateTime": "0001-01-01T00:00:00.0000000", "Status": 0 } ], "ConcurrencyStamp": "String", "IsProcurementEnabled": false, "IsComplianceEnabled": false, "TenderIdentifier": "String", "TenderType": 0, "Subject": "String", "ProcurementContact": "String", "ProcurementContactEmail": "String", "ProcurementContactPhone": "String", "ProfessionalContact": "String", "ProfessionalContactEmail": "String", "ProfessionalContactPhone": "String", "Result": "String", "Status": 0 }, "ResponseStatus": { "ErrorCode": "String", "Message": "String", "StackTrace": "String", "Errors": [ { "ErrorCode": "String", "FieldName": "String", "Message": "String", "Meta": { "String": "String" } } ], "Meta": { "String": "String" } } }