AIM Web Services

<back to all web services

C2BGetInstrumentDetailRequest

C2BGetInstrumentDetail
Requires active-e Contracts Service.

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

/**
* C2BGetInstrumentDetailRequires active-e Contracts Service.
*/
// @DataContract
public class C2BGetInstrumentDetailRequest : BaseSecureRequest
{
    /**
    * ID of the Teacher/Instrument record. Either this *or* TeacherId + InstrumentId must be sent.
    */
    // @DataMember
    // @ApiMember(DataType="integer", Description="ID of the Teacher/Instrument record. Either this *or* TeacherId + InstrumentId must be sent.", Format="int64", Name="RsiPk", ParameterType="query")
    public var rsiPk:Int?

    /**
    * ID of the Teacher record. Either this+InstrumentID *or* RsiPk must be sent.
    */
    // @DataMember
    // @ApiMember(DataType="integer", Description="ID of the Teacher record. Either this+InstrumentID *or* RsiPk must be sent.", Format="int64", Name="TeacherId", ParameterType="query")
    public var teacherId:Int?

    /**
    * ID of the Instrument record. Either this+TeacherID *or* RsiPk must be sent.
    */
    // @DataMember
    // @ApiMember(DataType="integer", Description="ID of the Instrument record. Either this+TeacherID *or* RsiPk must be sent.", Format="int64", Name="InstrumentId", ParameterType="query")
    public var instrumentId:Int?

    /**
    * ID of the Rate to be used. This is required.
    */
    // @DataMember
    // @ApiMember(DataType="integer", Description="ID of the Rate to be used. This is required.", Format="int64", IsRequired=true, Name="RateId", ParameterType="query")
    public var rateId:Int?

    /**
    * If 'Y', then Mobile Layout will be returned.
    */
    // @DataMember
    // @ApiMember(DataType="string", Description="If 'Y', then Mobile Layout will be returned.", Name="IncludeMobileLayout", ParameterType="query")
    public var includeMobileLayout:String

    /**
    * ID of the Delivery option to be used.
    */
    // @DataMember
    // @ApiMember(DataType="integer", Description="ID of the Delivery option to be used.", Format="int64", IsRequired=true, Name="DeliveryId", ParameterType="query")
    public var deliveryId:Int?

    /**
    * ID of the Location. Used for Location required Delivery options.
    */
    // @DataMember
    // @ApiMember(DataType="integer", Description="ID of the Location. Used for Location required Delivery options.", Format="int64", IsRequired=true, Name="LocationId", ParameterType="query")
    public var locationId:Int?

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

    private enum CodingKeys : String, CodingKey {
        case rsiPk
        case teacherId
        case instrumentId
        case rateId
        case includeMobileLayout
        case deliveryId
        case locationId
    }

    required public init(from decoder: Decoder) throws {
        try super.init(from: decoder)
        let container = try decoder.container(keyedBy: CodingKeys.self)
        rsiPk = try container.decodeIfPresent(Int.self, forKey: .rsiPk)
        teacherId = try container.decodeIfPresent(Int.self, forKey: .teacherId)
        instrumentId = try container.decodeIfPresent(Int.self, forKey: .instrumentId)
        rateId = try container.decodeIfPresent(Int.self, forKey: .rateId)
        includeMobileLayout = try container.decodeIfPresent(String.self, forKey: .includeMobileLayout)
        deliveryId = try container.decodeIfPresent(Int.self, forKey: .deliveryId)
        locationId = try container.decodeIfPresent(Int.self, forKey: .locationId)
    }

    public override func encode(to encoder: Encoder) throws {
        try super.encode(to: encoder)
        var container = encoder.container(keyedBy: CodingKeys.self)
        if rsiPk != nil { try container.encode(rsiPk, forKey: .rsiPk) }
        if teacherId != nil { try container.encode(teacherId, forKey: .teacherId) }
        if instrumentId != nil { try container.encode(instrumentId, forKey: .instrumentId) }
        if rateId != nil { try container.encode(rateId, forKey: .rateId) }
        if includeMobileLayout != nil { try container.encode(includeMobileLayout, forKey: .includeMobileLayout) }
        if deliveryId != nil { try container.encode(deliveryId, forKey: .deliveryId) }
        if locationId != nil { try container.encode(locationId, forKey: .locationId) }
    }
}

// @DataContract
public class BaseSecureRequest : BaseRequest
{
    /**
    * 
    */
    // @DataMember
    // @ApiMember(DataType="string", Description="", Name="Token", ParameterType="Header")
    public var token:String

    /**
    * 
    */
    // @DataMember
    // @ApiMember(DataType="string", Description="", Name="DeviceId", ParameterType="Header")
    public var deviceId:String

    /**
    * 
    */
    // @DataMember
    // @ApiMember(DataType="string", Description="", IsRequired=true, Name="AppId", ParameterType="Header")
    public var appId:String

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

    private enum CodingKeys : String, CodingKey {
        case token
        case deviceId
        case appId
    }

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

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

// @DataContract
public class BaseRequest : Codable
{
    /**
    * This is your AIM API Key provided by Tri-Tech
    */
    // @DataMember
    // @ApiMember(DataType="string", Description="This is your AIM API Key provided by Tri-Tech", IsRequired=true, Name="ApiKey", ParameterType="header")
    public var apiKey:String

    // @DataMember
    // @ApiMember(DataType="string", Name="OAuthToken", ParameterType="header")
    public var oAuthToken:String

    required public init(){}
}

// @DataContract
public class C2BGetInstrumentDetailResponse : BaseResponse
{
    // @DataMember
    public var instrumentDetails:C2BInstrumentDetailGeneric

    // @DataMember
    public var mobileLayout:MobileLayout

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

    private enum CodingKeys : String, CodingKey {
        case instrumentDetails
        case mobileLayout
    }

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

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

// @DataContract
public class BaseResponse : Codable
{
    /**
    * 
    */
    // @DataMember
    // @ApiMember(DataType="BaseResponseResult", Description="", Name="Status", ParameterType="body")
    public var status:BaseResponseResult

    required public init(){}
}

// @DataContract
public class BaseResponseResult : Codable
{
    /**
    * 
    */
    // @DataMember
    // @ApiMember(DataType="string", Description="", Name="StatusCode", ParameterType="body")
    public var statusCode:String

    /**
    * 
    */
    // @DataMember
    // @ApiMember(DataType="string", Description="", Name="Login", ParameterType="body")
    public var login:String

    /**
    * 
    */
    // @DataMember
    // @ApiMember(DataType="string", Description="", Name="ErrorCode", ParameterType="body")
    public var errorCode:String

    /**
    * 
    */
    // @DataMember
    // @ApiMember(DataType="string", Description="", Name="ErrorDisplayText", ParameterType="body")
    public var errorDisplayText:String

    /**
    * 
    */
    // @DataMember
    // @ApiMember(DataType="string", Description="", Name="ErrorMessage", ParameterType="body")
    public var errorMessage:String

    /**
    * 
    */
    // @DataMember
    // @ApiMember(DataType="string", Description="", ExcludeInSchema=true, Name="DomainName", ParameterType="body")
    public var domainName:String

    /**
    * 
    */
    // @DataMember
    // @ApiMember(DataType="string", Description="", ExcludeInSchema=true, Name="IPAddress", ParameterType="body")
    public var ipAddress:String

    required public init(){}
}

// @DataContract
public class C2BInstrumentDetailGeneric : Codable
{
    // @DataMember
    public var planCode:C2BPlanCodeGeneric

    // @DataMember
    public var teacher:C2BTeacherGeneric

    // @DataMember
    public var school:C2BSchoolGeneric

    // @DataMember
    public var deliveryDate:String

    // @DataMember
    public var salesPerson:String

    // @DataMember
    public var district:C2BDistrictGeneric

    // @DataMember
    public var instrument:C2BInstrumentGeneric

    // @DataMember
    public var grade:C2BGradeGeneric

    // @DataMember
    public var accessoryList:[C2BAccessoryGeneric] = []

    // @DataMember
    public var deliveryList:[C2BAccessoryGeneric] = []

    // @DataMember
    public var maintenanceList:[C2BAccessoryGeneric] = []

    required public init(){}
}

// @DataContract
public class C2BPlanCodeGeneric : Codable
{
    // @DataMember
    public var code:String

    // @DataMember
    public var name:String

    // @DataMember
    public var months:Int

    // @DataMember
    public var topic:String

    // @DataMember
    public var url:String

    // @DataMember
    public var finalTopic:String

    required public init(){}
}

// @DataContract
public class C2BTeacherGeneric : Codable
{
    // @DataMember
    public var teacherName:String

    // @DataMember
    public var schoolName:String

    // @DataMember
    public var districtName:String

    // @DataMember
    public var topic:String

    // @DataMember
    public var id:Int

    // @DataMember
    public var deliveryInfo:C2BDeliveryInfo

    // @DataMember
    public var aimSchoolId:Int?

    required public init(){}
}

// @DataContract
public class C2BDeliveryInfo : Codable
{
    // @DataMember
    public var firstDelivery:Date

    // @DataMember
    public var deliveryTime:Date

    // @DataMember
    public var deliveryThreshold:Int

    // @DataMember
    public var sundayDelivery:Bool

    // @DataMember
    public var mondayDelivery:Bool

    // @DataMember
    public var tuesdayDelivery:Bool

    // @DataMember
    public var wednesdayDelivery:Bool

    // @DataMember
    public var thursdayDelivery:Bool

    // @DataMember
    public var fridayDelivery:Bool

    // @DataMember
    public var saturdayDelivery:Bool

    required public init(){}
}

// @DataContract
public class C2BSchoolGeneric : Codable
{
    // @DataMember
    public var schoolName:String

    // @DataMember
    public var districtName:String

    // @DataMember
    public var teacherCount:Int

    // @DataMember
    public var topic:String

    // @DataMember
    public var id:Int

    // @DataMember
    public var deliveryInfo:C2BDeliveryInfo

    // @DataMember
    public var aimSchoolId:Int?

    required public init(){}
}

// @DataContract
public class C2BDistrictGeneric : Codable
{
    // @DataMember
    public var districtName:String

    // @DataMember
    public var schoolCount:Int

    // @DataMember
    public var teacherCount:Int

    // @DataMember
    public var topic:String

    // @DataMember
    public var id:Int

    required public init(){}
}

// @DataContract
public class C2BInstrumentGeneric : Codable
{
    // @DataMember
    public var instrumentName:String

    // @DataMember
    public var sku:String

    // @DataMember
    public var topic:String

    // @DataMember
    public var image:String

    // @DataMember
    public var level:Int

    // @DataMember
    public var rentPrice:Double?

    // @DataMember
    public var cashPrice:Double?

    // @DataMember
    public var token:String

    // @DataMember
    public var instrumentId:Int

    // @DataMember
    public var instrumentTeacherId:Int

    // @DataMember
    public var gradeList:[C2BGradeGeneric] = []

    // @DataMember
    public var hasGrades:Bool

    // @DataMember
    public var displayOrder:Int

    // @DataMember
    public var accessoryList:[C2BAccessoryGeneric] = []

    // @DataMember
    public var deliveryList:[C2BAccessoryGeneric] = []

    // @DataMember
    public var maintenanceList:[C2BAccessoryGeneric] = []

    required public init(){}
}

// @DataContract
public class C2BGradeGeneric : Codable
{
    // @DataMember
    public var level:Int

    // @DataMember
    public var grade:String

    // @DataMember
    public var downPay:Double

    // @DataMember
    public var downMaint:Double

    // @DataMember
    public var moPay:Double

    // @DataMember
    public var moMaint:Double

    // @DataMember
    public var id:Int

    // @DataMember
    public var outOfStock:Bool

    // @DataMember
    public var rentPrice:Double

    // @DataMember
    public var cashPrice:Double

    // @DataMember
    public var downPayTax:Double?

    // @DataMember
    public var downMaintTax:Double?

    // @DataMember
    public var moPayTax:Double?

    // @DataMember
    public var moMaintTax:Double?

    // @DataMember
    public var rentPricePlusTax:Double

    // @DataMember
    public var rentPricePlusTaxLessDownpay:Double

    // @DataMember
    public var months:Int

    required public init(){}
}

// @DataContract
public class C2BAccessoryGeneric : Codable
{
    // @DataMember
    public var accessoryDesc:String

    // @DataMember
    public var price:Double

    // @DataMember
    public var required:Bool

    // @DataMember
    public var `default`:Bool

    // @DataMember
    public var requiresLocation:Bool

    // @DataMember
    public var type:String

    // @DataMember
    public var topic:String

    // @DataMember
    public var id:Int

    // @DataMember
    public var displayOrder:Int

    // @DataMember
    public var sku:String

    // @DataMember
    public var taxAmount:Double?

    // @DataMember
    public var catNum:Int?

    required public init(){}
}

// @DataContract
public class MobileLayout : Codable
{
    // @DataMember
    public var title:String

    // @DataMember
    public var returnurl:String

    // @DataMember
    public var sections:[Section] = []

    required public init(){}
}

// @DataContract
public class Section : Codable
{
    // @DataMember
    public var header:String

    // @DataMember
    public var id:String

    // @DataMember
    public var margin:String

    // @DataMember
    public var elements:[Element] = []

    required public init(){}
}

// @DataContract
public class Element : Codable
{
    // @DataMember
    public var type:String

    // @DataMember
    public var label:String

    // @DataMember
    public var id:String

    // @DataMember
    public var fontsize:String

    // @DataMember
    public var margin:String

    // @DataMember
    public var backgroundcolor:String

    // @DataMember
    public var textcolor:String

    // @DataMember
    public var height:String

    // @DataMember
    public var width:String

    // @DataMember
    public var value:String

    // @DataMember
    public var addvalue:Bool

    // @DataMember
    public var values:[String] = []

    // @DataMember
    public var textalign:String

    // @DataMember
    public var required:Bool?

    // @DataMember
    public var placeholder:String

    // @DataMember
    public var fontbold:Bool?

    // @DataMember
    public var selected:Bool?

    // @DataMember
    public var disabled:Bool?

    // @DataMember
    public var totalamount:Bool?

    // @DataMember
    public var elements:[Element] = []

    // @DataMember
    public var map:[LicenseMap] = []

    required public init(){}
}

// @DataContract
public class LicenseMap : Codable
{
    // @DataMember
    public var name:String

    // @DataMember
    public var value:String

    required public init(){}
}


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

POST /api/C2BGetInstrumentDetail HTTP/1.1 
Host: active-ewebservice.biz 
Accept: text/jsonl
Content-Type: text/jsonl
Content-Length: length

{"RsiPk":0,"TeacherId":0,"InstrumentId":0,"RateId":0,"IncludeMobileLayout":"String","DeliveryId":0,"LocationId":0,"Token":"String","DeviceId":"String","AppId":"String","ApiKey":"String","OAuthToken":"String"}
HTTP/1.1 200 OK
Content-Type: text/jsonl
Content-Length: length

{"MobileLayout":{"title":"String","returnurl":"String","sections":[{"header":"String","id":"String","margin":"String","elements":[{"type":"String","label":"String","id":"String","fontsize":"String","margin":"String","backgroundcolor":"String","textcolor":"String","height":"String","width":"String","value":"String","addvalue":false,"values":["String"],"textalign":"String","required":false,"placeholder":"String","fontbold":false,"selected":false,"disabled":false,"totalamount":false}]}]},"Status":{"StatusCode":"String","Login":"String","ErrorCode":"String","ErrorDisplayText":"String","ErrorMessage":"String","DomainName":"String","IpAddress":"String"}}