Booster.Microservices

<back to all web services

VerifyAuthorizationRequest

Requires Authentication
The following routes are available for this service:
GET/warranty/v1/security/{mnemonicId}
GET/warranty/v1/security/{mnemonicId}/site/{posId}
GET/warranty/v1/security/{mnemonicId}/brand/{brandTrigram}
GET/warranty/v1/security/{mnemonicId}/site/{posId}/brand/{brandTrigram}
import Foundation
import ServiceStack

public class VerifyAuthorizationRequest : BaseRequest<VerifyAuthorizationResponse>
{
    public var mnemonicId:String
    public var posId:Int?
    public var brandTrigram:String

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

    private enum CodingKeys : String, CodingKey {
        case mnemonicId
        case posId
        case brandTrigram
    }

    required public init(from decoder: Decoder) throws {
        try super.init(from: decoder)
        let container = try decoder.container(keyedBy: CodingKeys.self)
        mnemonicId = try container.decodeIfPresent(String.self, forKey: .mnemonicId)
        posId = try container.decodeIfPresent(Int.self, forKey: .posId)
        brandTrigram = try container.decodeIfPresent(String.self, forKey: .brandTrigram)
    }

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

public class BaseRequest<TResponse : Codable> : IRequest, Codable
{
    public var sid:String
    public var app:String
    public var _os:String
    public var _appVersion:String
    public var _searchMethod:String

    required public init(){}
}

public class VerifyAuthorizationResponse : BaseResponse
{
    public var isAllowed:Bool

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

    private enum CodingKeys : String, CodingKey {
        case isAllowed
    }

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

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

public class BaseResponse : IRespose, Codable
{
    public var _xmlns:String
    public var _type:String
    public var _source:String
    public var _tstamp:String
    public var _user:String
    public var _env:String
    public var _uri:String
    public var _query:String

    required public init(){}
}


Swift VerifyAuthorizationRequest DTOs

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

HTTP + OTHER

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

GET /warranty/v1/security/{mnemonicId} HTTP/1.1 
Host: qp-microservices-booster.richemont.com 
Accept: text/jsonl
HTTP/1.1 200 OK
Content-Type: text/jsonl
Content-Length: length

{"isAllowed":false,"_xmlns":"String","_type":"String","_source":"String","_tstamp":"String","_user":"String","_env":"String","_uri":"String","_query":"String"}