| Requires any of the roles: | Admin, TeamAdmin | Requires the permission: | ReadData |
| POST | /TransferTicketToEvent | Transfer a ticket to a different event with automatic price reconciliation |
|---|
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 TransferRefundInstruction:
amount_isk: Optional[Decimal] = None
payment_reference: Optional[str] = None
instruction: Optional[str] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class TransferTopupInstruction:
amount_isk: Optional[Decimal] = None
payment_link_url: Optional[str] = None
session_token: Optional[str] = None
expires_at: Optional[datetime.datetime] = None
@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 TransferTicketToEventResult:
ok: Optional[bool] = None
status_code: Optional[int] = None
code: Optional[str] = None
message: Optional[str] = None
transfer_log_id: Optional[int] = None
new_ticket_token_id: Optional[str] = None
direction: Optional[str] = None
price_difference: Optional[Decimal] = None
original_ticket_price: Optional[Decimal] = None
target_ticket_price: Optional[Decimal] = None
source_event_paid_out: Optional[bool] = None
outstanding_cost_handled_by_server: Optional[bool] = None
refund: Optional[TransferRefundInstruction] = None
topup: Optional[TransferTopupInstruction] = None
quote: Optional[TransferTicketQuoteResult] = None
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class TransferTicketToEventRequest:
ticket_token_id: Optional[str] = None
to_event_id: Optional[int] = None
user_id: Optional[int] = None
reason: Optional[str] = None
idempotency_key: Optional[str] = None
expected_price_difference: Optional[Decimal] = None
to_owner_ticket_type_id: Optional[int] = None
to_series_ticket_type_id: Optional[int] = None
to_seat_id: Optional[int] = None
Python TransferTicketToEventRequest 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 /TransferTicketToEvent HTTP/1.1
Host: stubbur-app.azurewebsites.net
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
ticketTokenId: String,
toEventId: 0,
userId: 0,
reason: String,
idempotencyKey: String,
expectedPriceDifference: 0,
toOwnerTicketTypeId: 0,
toSeriesTicketTypeId: 0,
toSeatId: 0
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length
{
ok: False,
statusCode: 0,
code: String,
message: String,
transferLogId: 0,
newTicketTokenId: String,
direction: String,
priceDifference: 0,
originalTicketPrice: 0,
targetTicketPrice: 0,
sourceEventPaidOut: False,
outstandingCostHandledByServer: False,
refund:
{
amountIsk: 0,
paymentReference: String,
instruction: String
},
topup:
{
amountIsk: 0,
paymentLinkUrl: String,
sessionToken: String,
expiresAt: 0001-01-01
},
quote:
{
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
}
}