Bridge

<back to all web services

ETSPlaceOrderSubmit

ETS
The following routes are available for this service:
POST/ETS/Place-Order
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 ETSLinkedVesselsViewModel:
    deleted: bool = False
    vessel_id: int = 0
    quantity: Optional[int] = None
    moha_account: Optional[str] = None
    is_quote: bool = False


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class GetETSRegistrationStatusViewModel:
    status: Optional[str] = None
    applied_by: Optional[str] = None


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class ETSPlaceOrderSubmit:
    order_type: Optional[str] = None
    quote_guid: Optional[str] = None
    unit_price: float = 0.0
    price: float = 0.0
    financing_price: float = 0.0
    financing_status: Optional[str] = None
    arrangement_fee: float = 0.0
    arrangement_fee_description: Optional[str] = None
    ets_order_info_text_non_financed: Optional[str] = None
    ets_order_info_text_financed: Optional[str] = None
    payment_type: Optional[str] = None
    quantity: Optional[int] = None
    original_quantity: Optional[int] = None
    company_name: Optional[str] = None
    full_name: Optional[str] = None
    email_address: Optional[str] = None
    can_purchase_e_u_a: bool = False
    external_fee_per_ticket: float = 0.0
    our_commission_for_order: float = 0.0
    eua_price: float = 0.0
    unit_cost_price: float = 0.0
    third_party: bool = False
    third_party_name: Optional[str] = None
    api_to_use: Optional[str] = None
    io_i_id: Optional[str] = None
    offer_ioi: Optional[str] = None
    spot_additional_margin: Optional[float] = None
    aither_settlement_u_u_i_d: Optional[str] = None
    linked_vessels: Optional[List[ETSLinkedVesselsViewModel]] = None
    get_e_t_s_registration_status: Optional[GetETSRegistrationStatusViewModel] = None


class SavingResultStatus(str, Enum):
    SUCCESS = 'Success'
    ERROR = 'Error'


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class SavingResultErrors:
    error: Optional[str] = None


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class SavingResult:
    id: Optional[int] = None
    guid_id: Optional[str] = None
    status: Optional[SavingResultStatus] = None
    errors: Optional[List[SavingResultErrors]] = None

Python ETSPlaceOrderSubmit 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 /ETS/Place-Order HTTP/1.1 
Host: internal.thebunkerbridge.com 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	OrderType: String,
	QuoteGuid: 00000000000000000000000000000000,
	UnitPrice: 0,
	Price: 0,
	FinancingPrice: 0,
	FinancingStatus: String,
	ArrangementFee: 0,
	ArrangementFeeDescription: String,
	ETSOrderInfoTextNonFinanced: String,
	ETSOrderInfoTextFinanced: String,
	PaymentType: String,
	Quantity: 0,
	OriginalQuantity: 0,
	CompanyName: String,
	FullName: String,
	EmailAddress: String,
	CanPurchaseEUA: False,
	ExternalFeePerTicket: 0,
	OurCommissionForOrder: 0,
	EUAPrice: 0,
	UnitCostPrice: 0,
	ThirdParty: False,
	ThirdPartyName: String,
	APIToUse: String,
	IoIId: String,
	OfferIoi: String,
	SpotAdditionalMargin: 0,
	AitherSettlementUUID: String,
	LinkedVessels: 
	[
		{
			Deleted: False,
			VesselId: 0,
			Quantity: 0,
			MohaAccount: String,
			IsQuote: False
		}
	],
	GetETSRegistrationStatus: 
	{
		Status: String,
		AppliedBy: String
	}
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	Id: 0,
	GuidId: 00000000000000000000000000000000,
	Status: Success,
	Errors: 
	[
		{
			Error: String
		}
	]
}