| Requires any of the roles: | Admin, TeamAdmin | Requires the permission: | ReadData |
| POST | /transferTicket/quote | Read-only price-diff lookup for a prospective ticket transfer |
|---|
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 TransferQuoteEventSide:
event_id: Optional[int] = None
event_name: Optional[str] = None
time_of_event: Optional[datetime.datetime] = None
ticket_price: Optional[Decimal] = None
payment_method_id: Optional[str] = None
payment_reference: Optional[str] = None
available_seats: Optional[int] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class TransferTicketQuoteResult:
ok: Optional[bool] = None
status_code: Optional[int] = None
code: Optional[str] = None
message: Optional[str] = None
from_: Optional[TransferQuoteEventSide] = field(metadata=config(field_name='from'), default=None)
to: Optional[TransferQuoteEventSide] = None
price_difference: Optional[Decimal] = None
direction: Optional[str] = None
refundable_via_borgun: Optional[bool] = None
after_payout: Optional[bool] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class TransferTicketQuoteRequest:
ticket_token_id: Optional[str] = None
to_event_id: Optional[int] = None
user_id: Optional[int] = None
to_owner_ticket_type_id: Optional[int] = None
to_series_ticket_type_id: Optional[int] = None
Python TransferTicketQuoteRequest 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 /transferTicket/quote HTTP/1.1
Host: stubbur-app.azurewebsites.net
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
ticketTokenId: String,
toEventId: 0,
userId: 0,
toOwnerTicketTypeId: 0,
toSeriesTicketTypeId: 0
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length
{
ok: False,
statusCode: 0,
code: String,
message: String,
from:
{
eventId: 0,
eventName: String,
timeOfEvent: 0001-01-01,
ticketPrice: 0,
paymentMethodId: String,
paymentReference: String,
availableSeats: 0
},
to:
{
eventId: 0,
eventName: String,
timeOfEvent: 0001-01-01,
ticketPrice: 0,
paymentMethodId: String,
paymentReference: String,
availableSeats: 0
},
priceDifference: 0,
direction: String,
refundableViaBorgun: False,
afterPayout: False
}