/* tslint:disable */
/* eslint-disable */
/**
 * Paystack
 * The OpenAPI specification of the Paystack API that merchants and developers can harness to build financial solutions in Africa.
 *
 * The version of the Paystack Node library: 1.0.0
 * Contact: techsupport@paystack.com
 *
 * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
 * https://openapi-generator.tech
 * Do not edit the class manually.
 */

import { exists, mapValues } from '../runtime';
/**
 * 
 * @export
 * @interface TransactionChargeAuthorization
 */
export interface TransactionChargeAuthorization {
    /**
     * Customer's email address
     * @type {string}
     * @memberof TransactionChargeAuthorization
     */
    email: string;
    /**
     * Amount should be in kobo if currency is NGN, pesewas, if currency is GHS, and cents, if currency is ZAR
     * @type {number}
     * @memberof TransactionChargeAuthorization
     */
    amount: number;
    /**
     * Valid authorization code to charge
     * @type {string}
     * @memberof TransactionChargeAuthorization
     */
    authorizationCode: string;
    /**
     * Unique transaction reference. Only -, ., = and alphanumeric characters allowed.
     * @type {string}
     * @memberof TransactionChargeAuthorization
     */
    reference?: string;
    /**
     * The transaction currency
     * @type {string}
     * @memberof TransactionChargeAuthorization
     */
    currency?: string;
    /**
     * Stringified JSON object of custom data
     * @type {string}
     * @memberof TransactionChargeAuthorization
     */
    metadata?: string;
    /**
     * The split code of the transaction split
     * @type {string}
     * @memberof TransactionChargeAuthorization
     */
    splitCode?: string;
    /**
     * The code for the subaccount that owns the payment
     * @type {string}
     * @memberof TransactionChargeAuthorization
     */
    subaccount?: string;
    /**
     * A flat fee to charge the subaccount for a transaction. 
     * This overrides the split percentage set when the subaccount was created
     * @type {string}
     * @memberof TransactionChargeAuthorization
     */
    transactionCharge?: string;
    /**
     * The beare of the transaction charge
     * @type {string}
     * @memberof TransactionChargeAuthorization
     */
    bearer?: string;
    /**
     * If you are making a scheduled charge call, it is a good idea to queue them so the processing system does not get overloaded causing transaction processing errors.
     * @type {boolean}
     * @memberof TransactionChargeAuthorization
     */
    queue?: boolean;
}

export function TransactionChargeAuthorizationFromJSON(json: any): TransactionChargeAuthorization {
    return TransactionChargeAuthorizationFromJSONTyped(json, false);
}

export function TransactionChargeAuthorizationFromJSONTyped(json: any, ignoreDiscriminator: boolean): TransactionChargeAuthorization {
    if ((json === undefined) || (json === null)) {
        return json;
    }
    return {
        
        'email': json['email'],
        'amount': json['amount'],
        'authorizationCode': json['authorization_code'],
        'reference': !exists(json, 'reference') ? undefined : json['reference'],
        'currency': !exists(json, 'currency') ? undefined : json['currency'],
        'metadata': !exists(json, 'metadata') ? undefined : json['metadata'],
        'splitCode': !exists(json, 'split_code') ? undefined : json['split_code'],
        'subaccount': !exists(json, 'subaccount') ? undefined : json['subaccount'],
        'transactionCharge': !exists(json, 'transaction_charge') ? undefined : json['transaction_charge'],
        'bearer': !exists(json, 'bearer') ? undefined : json['bearer'],
        'queue': !exists(json, 'queue') ? undefined : json['queue'],
    };
}

export function TransactionChargeAuthorizationToJSON(value?: TransactionChargeAuthorization | null): any {
    if (value === undefined) {
        return undefined;
    }
    if (value === null) {
        return null;
    }
    return {
        
        'email': value.email,
        'amount': value.amount,
        'authorization_code': value.authorizationCode,
        'reference': value.reference,
        'currency': value.currency,
        'metadata': value.metadata,
        'split_code': value.splitCode,
        'subaccount': value.subaccount,
        'transaction_charge': value.transactionCharge,
        'bearer': value.bearer,
        'queue': value.queue,
    };
}


