TicketUserServices

<back to all web services

TransferTicketToEventRequest

Requires Authentication
Requires any of the roles:Admin, TeamAdminRequires the permission:ReadData
The following routes are available for this service:
POST/TransferTicketToEventTransfer 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 .json suffix or ?format=json

To embed the response in a jsonp callback, append ?callback=myCallback

HTTP + JSON

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: application/json
Content-Type: application/json
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: application/json
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-01T00:00:00.0000000"},"quote":{"ok":false,"statusCode":0,"code":"String","message":"String","from":{"eventId":0,"eventName":"String","timeOfEvent":"0001-01-01T00:00:00.0000000","ticketPrice":0,"paymentMethodId":"String","paymentReference":"String","availableSeats":0},"to":{"eventId":0,"eventName":"String","timeOfEvent":"0001-01-01T00:00:00.0000000","ticketPrice":0,"paymentMethodId":"String","paymentReference":"String","availableSeats":0},"priceDifference":0,"direction":"String","refundableViaBorgun":false,"afterPayout":false}}