TicketUserServices

<back to all web services

EventTicketSalesRequest

Requires Authentication
Requires any of the roles:Admin, TeamAdmin, MobileAppRequired permission:Sales.Total
The following routes are available for this service:
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

HTTP + 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
}