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 .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 /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
	}
}