POST | /tender/{tenderid}/user/{userid}/procurement/{procurementid}/file |
---|
import Foundation
import ServiceStack
public class AddProcurementFile : ProcurementBase, IPost
{
public var documentType:ProcurementDocumentType
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case documentType
}
required public init(from decoder: Decoder) throws {
try super.init(from: decoder)
let container = try decoder.container(keyedBy: CodingKeys.self)
documentType = try container.decodeIfPresent(ProcurementDocumentType.self, forKey: .documentType)
}
public override func encode(to encoder: Encoder) throws {
try super.encode(to: encoder)
var container = encoder.container(keyedBy: CodingKeys.self)
if documentType != nil { try container.encode(documentType, forKey: .documentType) }
}
}
public class ProcurementBase : Codable
{
public var tenderId:Int
public var userId:Int
public var procurementId:Int
required public init(){}
}
public enum ProcurementDocumentType : Int, Codable
{
case BankAccountnumber = 0
case EcoVadis = 1
case Csr = 2
case SignedProcurement = 3
}
public class SaveFileEntityResponse : ModifyEntityResponse
{
public var fileContentId:Int
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case fileContentId
}
required public init(from decoder: Decoder) throws {
try super.init(from: decoder)
let container = try decoder.container(keyedBy: CodingKeys.self)
fileContentId = try container.decodeIfPresent(Int.self, forKey: .fileContentId)
}
public override func encode(to encoder: Encoder) throws {
try super.encode(to: encoder)
var container = encoder.container(keyedBy: CodingKeys.self)
if fileContentId != nil { try container.encode(fileContentId, forKey: .fileContentId) }
}
}
public class ModifyEntityResponse : ResponseBase
{
public var id:Int
required public init(){ super.init() }
private enum CodingKeys : String, CodingKey {
case id
}
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)
}
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) }
}
}
public class ResponseBase : Codable
{
public var responseStatus:ResponseStatus
required public init(){}
}
To override the Content-type in your clients, use the HTTP Accept Header, append the .json suffix or ?format=json
To embed the response in a jsonp callback, append ?callback=myCallback
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /tender/{tenderid}/user/{userid}/procurement/{procurementid}/file HTTP/1.1
Host: szallitoiportal-be.veolia.hu
Accept: application/json
Content-Type: application/json
Content-Length: length
{"DocumentType":0,"TenderId":0,"UserId":0,"ProcurementId":0}
HTTP/1.1 200 OK Content-Type: application/json Content-Length: length {"FileContentId":0,"Id":0,"ResponseStatus":{"ErrorCode":"String","Message":"String","StackTrace":"String","Errors":[{"ErrorCode":"String","FieldName":"String","Message":"String","Meta":{"String":"String"}}],"Meta":{"String":"String"}}}