GET | /financial-transactions/{BeeNumberCustomer}/{TransactionSequence} |
---|
import datetime
import decimal
from marshmallow.fields import *
from servicestack import *
from typing import *
from dataclasses import dataclass, field
from dataclasses_json import dataclass_json, LetterCase, Undefined, config
from enum import Enum, IntEnum
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class FinancialTransactionsGetViewModel:
bee_number_customer: Optional[Decimal] = None
transaction_time: Optional[datetime.datetime] = None
transaction_id: Optional[str] = None
campaign: Optional[str] = None
transaction_code: Optional[str] = None
transaction_b_i_d_s_code: Optional[str] = None
order_number: Optional[str] = None
invoice_number: Optional[str] = None
retail_sales_amount: Optional[Decimal] = None
federal_tax_amount1: Optional[Decimal] = None
federal_tax_amount2: Optional[Decimal] = None
local_tax_amount: Optional[Decimal] = None
transaction_amount: Optional[Decimal] = None
payment_amount: Optional[Decimal] = None
transaction_balance_amount: Optional[Decimal] = None
customer_price: Optional[Decimal] = None
free_amount: Optional[Decimal] = None
bonus_amount: Optional[Decimal] = None
discount_percentage: Optional[Decimal] = None
customer_count: Optional[Decimal] = None
prc_promotion_code: Optional[str] = None
account_type: Optional[str] = None
state: Optional[str] = None
tax_area: Optional[str] = None
tax_rate: Optional[Decimal] = None
tax_indicator: Optional[str] = None
net_sales_amount: Optional[Decimal] = None
current_balance: Optional[Decimal] = None
operator_id: Optional[str] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class FinancialTransactionsGetResponse(GetResponse[FinancialTransactionsGetViewModel]):
pass
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class FinancialTransactionsGet(IGet):
bee_number_customer: Optional[Decimal] = None
transaction_sequence: Optional[int] = None
TEntity = TypeVar('TEntity')
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class GetResponse(Generic[TEntity]):
item: Optional[TEntity] = None
response_status: Optional[ResponseStatus] = None
Python FinancialTransactionsGet DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .csv suffix or ?format=csv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
GET /financial-transactions/{BeeNumberCustomer}/{TransactionSequence} HTTP/1.1 Host: extensions.avon.ca Accept: text/csv
HTTP/1.1 200 OK Content-Type: text/csv Content-Length: length {"item":{"beeNumberCustomer":0,"transactionTime":"0001-01-01T00:00:00.0000000","transactionId":"String","campaign":"String","transactionCode":"String","transactionBIDSCode":"String","orderNumber":"String","invoiceNumber":"String","retailSalesAmount":0,"federalTaxAmount1":0,"federalTaxAmount2":0,"localTaxAmount":0,"transactionAmount":0,"paymentAmount":0,"transactionBalanceAmount":0,"customerPrice":0,"freeAmount":0,"bonusAmount":0,"discountPercentage":0,"customerCount":0,"prcPromotionCode":"String","accountType":"String","state":"String","taxArea":"String","taxRate":0,"taxIndicator":"String","netSalesAmount":0,"currentBalance":0,"operatorId":"String"},"responseStatus":{"errorCode":"String","message":"String","stackTrace":"String","errors":[{"errorCode":"String","fieldName":"String","message":"String","meta":{"String":"String"}}],"meta":{"String":"String"}}}