OSZZ API

<back to all web services

Search2

The following routes are available for this service:
GET, POST/2/search
import Foundation
import ServiceStack

// @DataContract
public class Search2 : Codable
{
    // @DataMember
    public var q:String?

    // @DataMember
    public var tokenId:String?

    required public init(){}
}

// @DataContract
public class Search2Response : IResponse, Codable
{
    // @DataMember
    public var responseStatus:ResponseStatus?

    // @DataMember
    public var result:[PriceListModel] = []

    required public init(){}
}

// @DataContract
public class PriceListModel : PriceListModel
{
    // @DataMember
    public var isOriginal:Bool?

    // @DataMember
    public var groupId:Int?

    required public init(){ super.init() }

    private enum CodingKeys : String, CodingKey {
        case isOriginal
        case groupId
    }

    required public init(from decoder: Decoder) throws {
        try super.init(from: decoder)
        let container = try decoder.container(keyedBy: CodingKeys.self)
        isOriginal = try container.decodeIfPresent(Bool.self, forKey: .isOriginal)
        groupId = try container.decodeIfPresent(Int.self, forKey: .groupId)
    }

    public override func encode(to encoder: Encoder) throws {
        try super.encode(to: encoder)
        var container = encoder.container(keyedBy: CodingKeys.self)
        if isOriginal != nil { try container.encode(isOriginal, forKey: .isOriginal) }
        if groupId != nil { try container.encode(groupId, forKey: .groupId) }
    }
}

// @DataContract
public class PriceListModel : Codable
{
    // @DataMember
    public var productId:String?

    // @DataMember
    public var manufacturerTitle:String?

    // @DataMember
    public var productNumber:String?

    // @DataMember
    public var productTitle:String?

    // @DataMember
    public var priceListId:String?

    // @DataMember
    public var code:String?

    // @DataMember
    public var delivery:String?

    // @DataMember
    public var location:String?

    // @DataMember
    public var expectedDeliveryDays:Int?

    // @DataMember
    public var guaranteedDeliveryDays:Int?

    // @DataMember
    public var quantity:Int?

    // @DataMember
    public var pack:Int?

    // @DataMember
    public var price:Double?

    // @DataMember
    public var useSchedule:Bool?

    // @DataMember
    public var orderDate:Date?

    // @DataMember
    public var deliveryDate:Date?

    // @DataMember
    public var deliveryChance:Float?

    required public init(){}
}


Swift Search2 DTOs

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

HTTP + CSV

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

POST /2/search HTTP/1.1 
Host: api.oszz.ru 
Accept: text/csv
Content-Type: text/csv
Content-Length: length

{"q":"String","tokenId":"00000000000000000000000000000000"}
HTTP/1.1 200 OK
Content-Type: text/csv
Content-Length: length

{"responseStatus":{"errorCode":"String","message":"String","stackTrace":"String","errors":[{"errorCode":"String","fieldName":"String","message":"String","meta":{"String":"String"}}],"meta":{"String":"String"}},"result":[{"isOriginal":false,"groupId":0,"productId":"00000000000000000000000000000000","manufacturerTitle":"String","productNumber":"String","productTitle":"String","priceListId":"00000000000000000000000000000000","code":"String","delivery":"String","location":"String","expectedDeliveryDays":0,"guaranteedDeliveryDays":0,"quantity":0,"pack":0,"price":0,"useSchedule":false,"orderDate":"0001-01-01 00:00:00","deliveryDate":"0001-01-01 00:00:00","deliveryChance":0}]}