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 .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.

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

{
	q: String,
	tokenId: 00000000000000000000000000000000
}
HTTP/1.1 200 OK
Content-Type: text/jsv
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,
			deliveryDate: 0001-01-01,
			deliveryChance: 0
		}
	]
}