Requires any of the roles: | Admin, TeamAdmin, MobileApp | Required permission: | Sales.Total |
GET POST | /ticketSales | ||
---|---|---|---|
GET POST | /ticketSales/event/{EventId} | ||
GET POST | /ticketSales/team/{EventOwnerId} | ||
GET POST | /ticketSales/event/ksi/{KsiEventId} | ||
GET POST | /ticketSales/team/ksi/{EventOwnerKsiId} |
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 EventTicketDetails:
ticket_price: Optional[Decimal] = None
total_price: Optional[Decimal] = None
count: Optional[int] = None
timestamp_bought: Optional[datetime.datetime] = None
timestamp_activated: Optional[datetime.datetime] = None
payment_method_id: Optional[str] = None
ticket_status: Optional[str] = None
deild: Optional[str] = None
location: Optional[str] = None
event: Optional[str] = None
time_of_event: Optional[datetime.datetime] = None
event_series_owner_ticket_type: Optional[int] = None
event_series_ticket_type: Optional[int] = None
event_id: Optional[int] = None
external_reference: Optional[str] = None
event_owner_id: Optional[int] = None
event_series_id: Optional[int] = None
ksi_competition_id: Optional[str] = None
event_owner_name: Optional[str] = None
event_owner_ksi_i_d: Optional[str] = None
team_pass_id: Optional[int] = None
ticket_name: Optional[str] = None
payment_reference: Optional[str] = None
payment_id: Optional[str] = None
ticket_team_pass_id: Optional[int] = None
ticket_id: Optional[int] = None
phone_verification_number: Optional[str] = None
payment_phone_number: Optional[str] = None
holder_id: Optional[str] = None
holder_name: Optional[str] = None
holder_full_phone_number: Optional[str] = None
seat_name: Optional[str] = None
row_name: Optional[str] = None
section_name: Optional[str] = None
seat_display_string: Optional[str] = None
is_special_ticket: Optional[bool] = None
special_ticket_id: Optional[str] = None
image_url: Optional[str] = None
detailed_description: Optional[str] = None
ticket_token_id: Optional[str] = None
time_of_event_u_t_c: Optional[datetime.datetime] = None
end_of_event: Optional[datetime.datetime] = None
end_of_event_u_t_c: Optional[datetime.datetime] = None
device_id: Optional[str] = None
ticket_has_expired: Optional[bool] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class EventTicketSalesResult:
event_sales: Optional[List[EventTicketDetails]] = None
status_code: Optional[int] = None
message: Optional[str] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class EventTicketSalesRequest:
event_id: Optional[int] = None
ksi_event_id: Optional[str] = None
event_owner_id: Optional[int] = None
event_owner_ksi_id: Optional[str] = None
Python EventTicketSalesRequest DTOs
To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /ticketSales HTTP/1.1
Host: stubbur-autoupdates-live.smartnewapis.com
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
eventId: 0,
ksiEventId: String,
eventOwnerId: 0,
eventOwnerKsiId: String
}
HTTP/1.1 200 OK Content-Type: text/jsv Content-Length: length { eventSales: [ { ticketPrice: 0, totalPrice: 0, count: 0, timestampBought: 0001-01-01, timestampActivated: 0001-01-01, paymentMethodId: String, ticketStatus: String, deild: String, location: String, event: String, timeOfEvent: 0001-01-01, eventSeriesOwnerTicketType: 0, eventSeriesTicketType: 0, eventId: 0, externalReference: String, eventOwnerId: 0, eventSeriesId: 0, ksiCompetitionId: String, eventOwnerName: String, eventOwnerKsiID: String, teamPassId: 0, ticketName: String, paymentReference: String, paymentId: String, ticketTeamPassId: 0, ticketId: 0, phoneVerificationNumber: String, paymentPhoneNumber: String, holderId: String, holderName: String, holderFullPhoneNumber: String, seatName: String, rowName: String, sectionName: String, seatDisplayString: String, isSpecialTicket: False, specialTicketId: String, imageUrl: String, detailedDescription: String, ticketTokenId: String, timeOfEventUTC: 0001-01-01, endOfEvent: 0001-01-01, endOfEventUTC: 0001-01-01, deviceId: String, ticketHasExpired: False } ], statusCode: 0, message: String }