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 payson payment is enabled
    */
    // @ApiMember(Description="The payson payment is enabled")
    public var enabled:Bool

    /**
    * If there should be any fee added when customer selected invoice payment method
    */
    // @ApiMember(Description="If there should be any fee added when customer selected invoice payment method")
    public var invoiceFee:Int

    /**
    * If allow credit card payment
    */
    // @ApiMember(Description="If allow credit card payment")
    public var allowCreditCardPayment:Bool

    /**
    * If allow invoice payment
    */
    // @ApiMember(Description="If allow invoice payment")
    public var allowInvoicePayment:Bool

    /**
    * If allow bank payment
    */
    // @ApiMember(Description="If allow bank payment")
    public var allowBankPayment: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

    /**
    * If there should be any fee added when customer selected invoice payment method
    */
    // @ApiMember(Description="If there should be any fee added when customer selected invoice payment method")
    public var invoiceFee:Int

    /**
    * If allow credit card payment
    */
    // @ApiMember(Description="If allow credit card payment")
    public var allowCreditCardPayment:Bool

    /**
    * If allow invoice payment
    */
    // @ApiMember(Description="If allow invoice payment")
    public var allowInvoicePayment:Bool

    /**
    * If allow bank payment
    */
    // @ApiMember(Description="If allow bank payment")
    public var allowBankPayment: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] = []

    /**
    * SendPaymentRequestDirectly
    */
    // @ApiMember(Description="SendPaymentRequestDirectly")
    public var sendPaymentRequestDirectly:Bool

    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 .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 /payment/settings HTTP/1.1 
Host: testapi.bokamera.se 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	CompanyId: 00000000-0000-0000-0000-000000000000,
	Enabled: False,
	InvoiceFee: 0,
	AllowCreditCardPayment: False,
	AllowInvoicePayment: False,
	AllowBankPayment: False,
	RefundOnCancelBooking: False,
	DefaultAdminPaymentOptionsId: 0,
	PaymentProviderId: 0
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	Enabled: False,
	InvoiceFee: 0,
	AllowCreditCardPayment: False,
	AllowInvoicePayment: False,
	AllowBankPayment: False,
	RefundOnCancelBooking: False,
	DefaultPaymentOptionId: 0,
	PaymentProviderId: 0,
	AdminPaymentOptions: 
	[
		{
			Id: 0,
			Name: String,
			Description: String
		}
	],
	PaymentProviderOptions: 
	[
		{
			Id: 0,
			Name: String,
			Description: String
		}
	],
	SendPaymentRequestDirectly: False
}