/* ** $Id$ ** ** Copyright 2001 Addison Wesley. All Rights Reserved. */ #include "ace/ACE.h" #include "ace/CDR_Stream.h" #include "ace/INET_Addr.h" #include "ace/Log_Record.h" #include "ace/Message_Block.h" // FUZZ: disable check_for_streams_include #include "ace/streams.h" #include "Logging_Handler.h" #include "ace/os_include/os_netdb.h" #include "ace/OS_NS_string.h" int operator>> (ACE_InputCDR &cdr, ACE_Log_Record &log_record) { ACE_CDR::Long type; ACE_CDR::Long pid; ACE_CDR::Long sec, usec; ACE_CDR::ULong buffer_len; // Extract each field from input CDR stream into . if ((cdr >> type) && (cdr >> pid) && (cdr >> sec) && (cdr >> usec) && (cdr >> buffer_len)) { ACE_TCHAR log_msg[ACE_Log_Record::MAXLOGMSGLEN+1]; log_record.type (type); log_record.pid (pid); log_record.time_stamp (ACE_Time_Value (sec, usec)); cdr.read_char_array (log_msg, buffer_len); log_msg[buffer_len] = '\0'; log_record.msg_data (log_msg); } return cdr.good_bit (); } int Logging_Handler::recv_log_record (ACE_Message_Block *&mblk) { // Put 's hostname in new message block. ACE_INET_Addr peer_addr; logging_peer_.get_remote_addr (peer_addr); mblk = new ACE_Message_Block (MAXHOSTNAMELEN + 1); peer_addr.get_host_name (mblk->wr_ptr (), MAXHOSTNAMELEN); mblk->wr_ptr (ACE_OS::strlen (mblk->wr_ptr ()) + 1); // Go past name // Allocate a message block for the payload; initially at least // large enough to hold the header, but needs some room for // alignment. ACE_Message_Block *payload = new ACE_Message_Block (ACE_DEFAULT_CDR_BUFSIZE); // Align the Message Block for a CDR stream ACE_CDR::mb_align (payload); if (logging_peer_.recv_n (payload->wr_ptr (), 8) == 8) { payload->wr_ptr (8); // Reflect addition of 8 bytes // Create a CDR stream to parse the 8-byte header. ACE_InputCDR cdr (payload); // Extract the byte-order and use helper methods to // disambiguate octet, booleans, and chars. ACE_CDR::Boolean byte_order; cdr >> ACE_InputCDR::to_boolean (byte_order); // Set the byte-order on the stream... cdr.reset_byte_order (byte_order); // Extract the length ACE_CDR::ULong length; cdr >> length; // Ensure there's sufficient room for log record payload. ACE_CDR::grow (payload, 8 + ACE_CDR::MAX_ALIGNMENT + length); // Use to obtain the contents. if (logging_peer_.recv_n (payload->wr_ptr (), length) > 0) { payload->wr_ptr (length); // Reflect additional bytes // Chain the payload to mblk via the contination field. mblk->cont (payload); return length; } } // Error cases end up here, so we need to release the memory to // prevent a leak. payload->release (); payload = 0; mblk->release (); mblk = 0; return -1; } int Logging_Handler::write_log_record (ACE_Message_Block *mblk) { // Peer hostname is in the and the log record data // is in its continuation. if (log_file_->send_n (mblk) == -1) return -1; if (ACE::debug ()) { // Build a CDR stream from the log record data. ACE_InputCDR cdr (mblk->cont ()); ACE_CDR::Boolean byte_order; ACE_CDR::ULong length; // Extract the byte-order and length, ending up at the start // of the log record itself. Use the byte order to properly // set the CDR stream for extracting the contents. cdr >> ACE_InputCDR::to_boolean (byte_order); cdr.reset_byte_order (byte_order); cdr >> length; ACE_Log_Record log_record; cdr >> log_record; // Finally extract the . log_record.print (mblk->rd_ptr (), 1, cerr); } return mblk->total_length (); } int Logging_Handler::log_record () { ACE_Message_Block *mblk = 0; if (recv_log_record (mblk) == -1) return -1; else { int result = write_log_record (mblk); mblk->release (); // Free up the contents. return result == -1 ? -1 : 0; } }