| Requires any of the roles: | Admin, TeamAdmin | Required permission: | Sales.Total |
| POST | /sales/overview |
|---|
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 SalesKpis:
gross_net: Optional[Decimal] = None
refunded: Optional[Decimal] = None
tickets_all_real: Optional[int] = None
tickets_paid: Optional[int] = None
orders: Optional[int] = None
aov: Optional[Decimal] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class KpiDelta:
abs: Optional[Decimal] = None
pct: Optional[float] = None
dir: Optional[str] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class SalesDeltas:
gross_net: Optional[KpiDelta] = None
refunded: Optional[KpiDelta] = None
tickets_all_real: Optional[KpiDelta] = None
tickets_paid: Optional[KpiDelta] = None
orders: Optional[KpiDelta] = None
aov: Optional[KpiDelta] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class SalesTrendBucket:
bucket: Optional[datetime.datetime] = None
revenue: Optional[Decimal] = None
tickets: Optional[int] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class SalesTopEvent:
event_id: Optional[int] = None
event_name: Optional[str] = None
event_date: Optional[datetime.datetime] = None
gross_net: Optional[Decimal] = None
paid_tickets: Optional[int] = None
real_tickets: Optional[int] = None
orders: Optional[int] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class SalesRecentOrder:
ticket_id: Optional[int] = None
created_at: Optional[datetime.datetime] = None
event_name: Optional[str] = None
amount: Optional[Decimal] = None
ticket_count: Optional[int] = None
buyer_name: Optional[str] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class SalesHourBucket:
hour: Optional[int] = None
revenue: Optional[Decimal] = None
orders: Optional[int] = None
tickets: Optional[int] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class SalesDowBucket:
dow: Optional[int] = None
revenue: Optional[Decimal] = None
orders: Optional[int] = None
tickets: Optional[int] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class SalesProduct:
ticket_name: Optional[str] = None
tickets: Optional[int] = None
revenue: Optional[Decimal] = None
orders: Optional[int] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class SalesOverviewResult:
current: Optional[SalesKpis] = None
previous: Optional[SalesKpis] = None
delta: Optional[SalesDeltas] = None
trend: Optional[List[SalesTrendBucket]] = None
previous_trend: Optional[List[SalesTrendBucket]] = None
top_events: Optional[List[SalesTopEvent]] = None
recent_orders: Optional[List[SalesRecentOrder]] = None
by_hour_of_day: Optional[List[SalesHourBucket]] = None
by_day_of_week: Optional[List[SalesDowBucket]] = None
top_products: Optional[List[SalesProduct]] = None
has_any_data_ever: Optional[bool] = None
owners: Optional[List[int]] = None
bucket: Optional[str] = None
freshness_utc: Optional[datetime.datetime] = None
status_code: Optional[int] = None
message: Optional[str] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class SalesOverviewRequest:
event_owner_id: Optional[int] = None
additional_owner_ids: Optional[List[int]] = None
event_id: Optional[int] = None
from_utc: Optional[datetime.datetime] = None
to_utc: Optional[datetime.datetime] = None
compare_from_utc: Optional[datetime.datetime] = None
compare_to_utc: Optional[datetime.datetime] = None
bucket: Optional[str] = None
top_events_limit: Optional[int] = None
recent_orders_limit: Optional[int] = None
Python SalesOverviewRequest DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .xml suffix or ?format=xml
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /sales/overview HTTP/1.1
Host: stubbur-app.azurewebsites.net
Accept: application/xml
Content-Type: application/xml
Content-Length: length
<SalesOverviewRequest xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/TicketUserServices.ServiceModel">
<AdditionalOwnerIds xmlns:d2p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
<d2p1:int>0</d2p1:int>
</AdditionalOwnerIds>
<Bucket>String</Bucket>
<CompareFromUtc>0001-01-01T00:00:00</CompareFromUtc>
<CompareToUtc>0001-01-01T00:00:00</CompareToUtc>
<EventId>0</EventId>
<EventOwnerId>0</EventOwnerId>
<FromUtc>0001-01-01T00:00:00</FromUtc>
<RecentOrdersLimit>0</RecentOrdersLimit>
<ToUtc>0001-01-01T00:00:00</ToUtc>
<TopEventsLimit>0</TopEventsLimit>
</SalesOverviewRequest>
HTTP/1.1 200 OK
Content-Type: application/xml
Content-Length: length
<SalesOverviewResult xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/TicketUserServices.ServiceModel">
<Bucket>String</Bucket>
<ByDayOfWeek>
<SalesDowBucket>
<Dow>0</Dow>
<Orders>0</Orders>
<Revenue>0</Revenue>
<Tickets>0</Tickets>
</SalesDowBucket>
</ByDayOfWeek>
<ByHourOfDay>
<SalesHourBucket>
<Hour>0</Hour>
<Orders>0</Orders>
<Revenue>0</Revenue>
<Tickets>0</Tickets>
</SalesHourBucket>
</ByHourOfDay>
<Current>
<Aov>0</Aov>
<GrossNet>0</GrossNet>
<Orders>0</Orders>
<Refunded>0</Refunded>
<TicketsAllReal>0</TicketsAllReal>
<TicketsPaid>0</TicketsPaid>
</Current>
<Delta>
<Aov>
<Abs>0</Abs>
<Dir>String</Dir>
<Pct>0</Pct>
</Aov>
<GrossNet>
<Abs>0</Abs>
<Dir>String</Dir>
<Pct>0</Pct>
</GrossNet>
<Orders>
<Abs>0</Abs>
<Dir>String</Dir>
<Pct>0</Pct>
</Orders>
<Refunded>
<Abs>0</Abs>
<Dir>String</Dir>
<Pct>0</Pct>
</Refunded>
<TicketsAllReal>
<Abs>0</Abs>
<Dir>String</Dir>
<Pct>0</Pct>
</TicketsAllReal>
<TicketsPaid>
<Abs>0</Abs>
<Dir>String</Dir>
<Pct>0</Pct>
</TicketsPaid>
</Delta>
<FreshnessUtc>0001-01-01T00:00:00</FreshnessUtc>
<HasAnyDataEver>false</HasAnyDataEver>
<Message>String</Message>
<Owners xmlns:d2p1="http://schemas.microsoft.com/2003/10/Serialization/Arrays">
<d2p1:int>0</d2p1:int>
</Owners>
<Previous>
<Aov>0</Aov>
<GrossNet>0</GrossNet>
<Orders>0</Orders>
<Refunded>0</Refunded>
<TicketsAllReal>0</TicketsAllReal>
<TicketsPaid>0</TicketsPaid>
</Previous>
<PreviousTrend>
<SalesTrendBucket>
<Bucket>0001-01-01T00:00:00</Bucket>
<Revenue>0</Revenue>
<Tickets>0</Tickets>
</SalesTrendBucket>
</PreviousTrend>
<RecentOrders>
<SalesRecentOrder>
<Amount>0</Amount>
<BuyerName>String</BuyerName>
<CreatedAt>0001-01-01T00:00:00</CreatedAt>
<EventName>String</EventName>
<TicketCount>0</TicketCount>
<TicketId>0</TicketId>
</SalesRecentOrder>
</RecentOrders>
<StatusCode>0</StatusCode>
<TopEvents>
<SalesTopEvent>
<EventDate>0001-01-01T00:00:00</EventDate>
<EventId>0</EventId>
<EventName>String</EventName>
<GrossNet>0</GrossNet>
<Orders>0</Orders>
<PaidTickets>0</PaidTickets>
<RealTickets>0</RealTickets>
</SalesTopEvent>
</TopEvents>
<TopProducts>
<SalesProduct>
<Orders>0</Orders>
<Revenue>0</Revenue>
<TicketName>String</TicketName>
<Tickets>0</Tickets>
</SalesProduct>
</TopProducts>
<Trend>
<SalesTrendBucket>
<Bucket>0001-01-01T00:00:00</Bucket>
<Revenue>0</Revenue>
<Tickets>0</Tickets>
</SalesTrendBucket>
</Trend>
</SalesOverviewResult>