BokaMera.API.Host

<back to all web services

AddPaymentSettings

Requires Authentication
Requires any of the roles:bookingsupplier-administrator-write, superadmin
The following routes are available for this service:
POST/payment/settingsAdd payment settingsAdd payment settings for the logged in company
import Foundation
import ServiceStack

// @ValidateRequest(Validator="IsAuthenticated")
public class AddPaymentSettings : ICompany, Codable
{
    /**
    * The company id, if empty will use the company id for the user you are logged in with.
    */
    // @ApiMember(Description="The company id, if empty will use the company id for the user you are logged in with.")
    public var companyId:String?

    /**
    * The payment is enabled
    */
    // @ApiMember(Description="The payment is enabled")
    public var enabled:Bool

    /**
    * Automatically refund customer on canceled booking
    */
    // @ApiMember(Description="Automatically refund customer on canceled booking")
    public var refundOnCancelBooking:Bool

    /**
    * The default option when admin creates a new booking
    */
    // @ApiMember(Description="The default option when admin creates a new booking")
    public var defaultAdminPaymentOptionsId:Int?

    /**
    * What payment provider to use
    */
    // @ApiMember(Description="What payment provider to use")
    public var paymentProviderId:Int

    required public init(){}
}

public class PaymentSettingsQueryResponse : Codable
{
    /**
    * The company id
    */
    // @ApiMember(Description="The company id")
    public var companyId:String

    /**
    * The payment is enabled
    */
    // @ApiMember(Description="The payment is enabled")
    public var enabled:Bool

    /**
    * Automatically refund customer on canceled booking
    */
    // @ApiMember(Description="Automatically refund customer on canceled booking")
    public var refundOnCancelBooking:Bool

    /**
    * The default option when admin creates a new booking
    */
    // @ApiMember(Description="The default option when admin creates a new booking")
    public var defaultPaymentOptionId:Int?

    /**
    * What payment provider to use
    */
    // @ApiMember(Description="What payment provider to use")
    public var paymentProviderId:Int

    /**
    * If you want to include the admin payment options to select from
    */
    // @ApiMember(DataType="boolean", Description="If you want to include the admin payment options to select from", ParameterType="query")
    public var adminPaymentOptions:[AdminPaymentOptionsResponse] = []

    /**
    * If you want to include the payment provider options to select from
    */
    // @ApiMember(DataType="boolean", Description="If you want to include the payment provider options to select from", ParameterType="query")
    public var paymentProviderOptions:[PaymentProviderOptionsResponse] = []

    required public init(){}
}

public class AdminPaymentOptionsResponse : Codable
{
    /**
    * The payment options id
    */
    // @ApiMember(Description="The payment options id")
    public var id:Int

    /**
    * The payment options name
    */
    // @ApiMember(Description="The payment options name")
    public var name:String

    /**
    * The payment options description
    */
    // @ApiMember(Description="The payment options description")
    public var Description:String

    required public init(){}
}

public class PaymentProviderOptionsResponse : Codable
{
    /**
    * The payment provider id
    */
    // @ApiMember(Description="The payment provider id")
    public var id:Int

    /**
    * The payment provider name
    */
    // @ApiMember(Description="The payment provider name")
    public var name:String

    /**
    * The payment provider description
    */
    // @ApiMember(Description="The payment provider description")
    public var Description:String

    required public init(){}
}


Swift AddPaymentSettings DTOs

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

HTTP + JSON

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

POST /payment/settings HTTP/1.1 
Host: api.bokamera.se 
Accept: application/json
Content-Type: application/json
Content-Length: length

{"CompanyId":"00000000-0000-0000-0000-000000000000","Enabled":false,"RefundOnCancelBooking":false,"DefaultAdminPaymentOptionsId":0,"PaymentProviderId":0}
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: length

{"Enabled":false,"RefundOnCancelBooking":false,"DefaultPaymentOptionId":0,"PaymentProviderId":0,"AdminPaymentOptions":[{"Id":0,"Name":"String","Description":"String"}],"PaymentProviderOptions":[{"Id":0,"Name":"String","Description":"String"}]}