use crate::contracts::*;
use crate::messages::{IncomingMessages, OutgoingMessages, RequestMessage, ResponseMessage};
use crate::subscriptions::{DecoderContext, StreamDecoder};
use crate::Error;
use super::decoders;
use super::encoders;
impl StreamDecoder<OptionComputation> for OptionComputation {
const RESPONSE_MESSAGE_IDS: &'static [IncomingMessages] = &[IncomingMessages::TickOptionComputation];
fn decode(context: &DecoderContext, message: &mut ResponseMessage) -> Result<Self, Error> {
match message.message_type() {
IncomingMessages::TickOptionComputation => Ok(decoders::decode_option_computation(context.server_version, message)?),
message => Err(Error::Simple(format!("unexpected message: {message:?}"))),
}
}
fn cancel_message(_server_version: i32, request_id: Option<i32>, context: Option<&DecoderContext>) -> Result<RequestMessage, Error> {
let request_id = request_id.expect("request id required to cancel option calculations");
match context.and_then(|c| c.request_type) {
Some(OutgoingMessages::ReqCalcImpliedVolat) => {
encoders::encode_cancel_option_computation(OutgoingMessages::CancelImpliedVolatility, request_id)
}
Some(OutgoingMessages::ReqCalcOptionPrice) => encoders::encode_cancel_option_computation(OutgoingMessages::CancelOptionPrice, request_id),
_ => panic!(
"Unsupported request message type option computation cancel: {:?}",
context.and_then(|c| c.request_type)
),
}
}
}
impl StreamDecoder<OptionChain> for OptionChain {
fn decode(_context: &DecoderContext, message: &mut ResponseMessage) -> Result<OptionChain, Error> {
match message.message_type() {
IncomingMessages::SecurityDefinitionOptionParameter => Ok(decoders::decode_option_chain(message)?),
IncomingMessages::SecurityDefinitionOptionParameterEnd => Err(Error::EndOfStream),
_ => Err(Error::UnexpectedResponse(message.clone())),
}
}
}