realtimenetprots/sipfw/SIP/Logging/src/TSIPMessageLogger.cpp
changeset 55 36ea1f90a3d8
parent 0 307788aac0a8
equal deleted inserted replaced
54:e4420734a2a0 55:36ea1f90a3d8
    20 
    20 
    21 #include "SipLogs.h"
    21 #include "SipLogs.h"
    22 
    22 
    23 #ifdef USE_SIP_MESSAGE_LOG
    23 #ifdef USE_SIP_MESSAGE_LOG
    24 
    24 
    25 #include <flogger.h>
       
    26 #include "TSIPMessageLogger.h"
    25 #include "TSIPMessageLogger.h"
    27 #include "TSIPLogLineParser.h"
    26 #include "TSIPLogLineParser.h"
    28 #include "sipmessage.h"
    27 #include "sipmessage.h"
    29 
    28 
    30 _LIT(KSIPMessageLogFileDir, "Sip");
       
    31 _LIT(KSIPMessageLogFileName, "SipLog.txt");
       
    32 //_LIT(KSipLogPath, "C:\\logs\\sip\\");
       
    33 
    29 
    34 _LIT8(KFormatParseError, "    SIP Codec parse error: %d!");
       
    35 _LIT8(KFooter, "-----");
       
    36 
    30 
    37 // Leave some space for date and time:
    31 // Leave some space for date and time:
    38 const TInt KMaxLineLength = KLogBufferSize-50;
    32 const TInt KMaxLineLength = 100;
    39 
    33 
    40 #ifdef WRITE_EXTRA_LOGS
    34 #ifdef WRITE_EXTRA_LOGS
    41 const TInt KSensibleLineLength = 60;
    35 const TInt KSensibleLineLength = 60;
    42 _LIT8(KShortFooter, "---");
    36 _LIT8(KShortFooter, "---");
    43 #endif
    37 #endif
    69 //
    63 //
    70 void TSIPMessageLogger::Write(
    64 void TSIPMessageLogger::Write(
    71     const TDesC8& aSubsystemName,
    65     const TDesC8& aSubsystemName,
    72     const TDesC8& aSIPMessage)
    66     const TDesC8& aSIPMessage)
    73     {
    67     {
    74     TBool exists = LogDirExists( KSipLogPath );
    68 
    75     
    69     __SIP_TXT8_LOG(aSubsystemName)
    76     if ( exists )
    70 
    77         {
       
    78         RFileLogger::Write( KSIPMessageLogFileDir,KSIPMessageLogFileName,
       
    79                             EFileLoggingModeAppend, aSubsystemName);
       
    80         }
       
    81     else
       
    82         {
       
    83         RDebug::RawPrint( aSubsystemName );
       
    84         }
       
    85   
       
    86     WriteSipMessage (aSIPMessage);
    71     WriteSipMessage (aSIPMessage);
    87     
    72 
    88 #ifdef WRITE_EXTRA_LOGS
    73 #ifdef WRITE_EXTRA_LOGS
    89     if ( exists )
    74 
    90         {
    75     __SIP_LOG("---")
    91         RFileLogger::Write( KSIPMessageLogFileDir,KSIPMessageLogFileName,
    76 
    92                             EFileLoggingModeAppend,KShortFooter);
       
    93       }
       
    94     else
       
    95         {
       
    96         RDebug::RawPrint( KShortFooter );
       
    97         }
       
    98     WriteExtraLogs(aSIPMessage);
    77     WriteExtraLogs(aSIPMessage);
    99 #endif
    78 #endif
   100 
    79 
   101     if ( exists )
    80     __SIP_LOG("---")
   102         {
    81 
   103         RFileLogger::Write( KSIPMessageLogFileDir,KSIPMessageLogFileName,
       
   104                             EFileLoggingModeAppend,KFooter);
       
   105         }
       
   106     else
       
   107         {
       
   108         RDebug::RawPrint( KFooter );
       
   109         }
       
   110     }
    82     }
   111 
    83 
   112 // -----------------------------------------------------------------------------
    84 // -----------------------------------------------------------------------------
   113 // TSIPMessageLogger::WriteParseError
    85 // TSIPMessageLogger::WriteParseError
   114 // -----------------------------------------------------------------------------
    86 // -----------------------------------------------------------------------------
   115 //
    87 //
   116 void TSIPMessageLogger::WriteParseError(
    88 void TSIPMessageLogger::WriteParseError(
   117     const TDesC8& aSubsystemName,
    89     const TDesC8& aSubsystemName,
   118     TInt aError)
    90     TInt aError)
   119     {
    91     {
   120     if ( LogDirExists( KSipLogPath ) )
    92     __SIP_TXT8_LOG(aSubsystemName)
   121         {
    93     __SIP_INT_LOG1("    SIP Codec parse error: %d", aError )
   122         RFileLogger::Write( KSIPMessageLogFileDir,KSIPMessageLogFileName,
       
   123                             EFileLoggingModeAppend,
       
   124                             aSubsystemName);
       
   125 
    94 
   126         RFileLogger::WriteFormat( KSIPMessageLogFileDir,KSIPMessageLogFileName,
       
   127                                   EFileLoggingModeAppend,
       
   128                                   KFormatParseError, aError);
       
   129 
    95 
   130         RFileLogger::Write( KSIPMessageLogFileDir,KSIPMessageLogFileName,
    96 
   131                             EFileLoggingModeAppend,KFooter);
       
   132         }
       
   133     else
       
   134         {
       
   135         _LIT8( KFmt, "%d" );
       
   136         TBuf8<32> buf;
       
   137         buf.Format( KFmt, aError );
       
   138         RDebug::RawPrint( aSubsystemName );
       
   139         RDebug::RawPrint( buf );
       
   140         RDebug::RawPrint( KFooter );
       
   141         }
       
   142     }
    97     }
   143 
    98 
   144 // -----------------------------------------------------------------------------
    99 // -----------------------------------------------------------------------------
   145 // TSIPMessageLogger::WriteSipMessage
   100 // TSIPMessageLogger::WriteSipMessage
   146 // -----------------------------------------------------------------------------
   101 // -----------------------------------------------------------------------------
   147 //
   102 //
   148 void TSIPMessageLogger::WriteSipMessage (const TDesC8& aSIPMessage)
   103 void TSIPMessageLogger::WriteSipMessage (const TDesC8& aSIPMessage)
   149     {
   104     {
   150     TSIPLogLineParser lineParser( aSIPMessage, KMaxLineLength );
   105     TSIPLogLineParser lineParser( aSIPMessage, KMaxLineLength );
   151     
   106 
   152     if ( LogDirExists( KSipLogPath ) )
   107     while ( !lineParser.End() )
   153         { 
   108     {
   154         while ( !lineParser.End())
   109         TPtrC8 ptr = lineParser.GetLine();
   155             {
   110         __SIP_DES8_LOG("%s", ptr)
   156             RFileLogger::Write( KSIPMessageLogFileDir,KSIPMessageLogFileName, 
       
   157                                 EFileLoggingModeAppend,
       
   158                                 lineParser.GetLine());
       
   159             }
       
   160         }
       
   161     else
       
   162         {
       
   163         while ( !lineParser.End() )
       
   164             {
       
   165             RDebug::RawPrint( lineParser.GetLine() );
       
   166             }
       
   167         }
       
   168     }
   111     }
   169 
   112 
   170 // -----------------------------------------------------------------------------
       
   171 // TSIPMessageLogger::LogDirExists
       
   172 // -----------------------------------------------------------------------------
       
   173 //
       
   174 TBool TSIPMessageLogger::LogDirExists( const TDesC& aFolderName )
       
   175     {
       
   176     TBool exists( EFalse );
       
   177     RFs fs;
       
   178     if ( KErrNone == fs.Connect() )
       
   179         {
       
   180         TEntry entry;
       
   181         exists = ( fs.Entry( aFolderName, entry ) == KErrNone );
       
   182         fs.Close();        
       
   183         }
       
   184     return exists;
       
   185     }
   113     }
   186     
   114 
       
   115 
       
   116 
   187 // -----------------------------------------------------------------------------
   117 // -----------------------------------------------------------------------------
   188 // TSIPMessageLogger::WriteExtraLogs
   118 // TSIPMessageLogger::WriteExtraLogs
   189 // -----------------------------------------------------------------------------
   119 // -----------------------------------------------------------------------------
   190 //
   120 //
   191 #ifdef WRITE_EXTRA_LOGS
   121 #ifdef WRITE_EXTRA_LOGS
   218                 default:
   148                 default:
   219                     buf.Append(_L8("#"));
   149                     buf.Append(_L8("#"));
   220                 }
   150                 }
   221 
   151 
   222             }
   152             }
   223         
   153 
   224         if (buf.Length() >= KSensibleLineLength)
   154         if (buf.Length() >= KSensibleLineLength)
   225             {
   155             {
   226             //Buffer full, write it to log file
   156             //Buffer full, write it to log file
   227             RFileLogger::Write (KSIPMessageLogFileDir,KSIPMessageLogFileName,
   157             __SIP_TXT8_LOG(buf)
   228                                 EFileLoggingModeAppend, buf);
       
   229             buf.Zero();
   158             buf.Zero();
   230             }
   159             }
   231         }
   160         }
   232 
   161 
   233     if (buf.Length() > 0)
   162     if (buf.Length() > 0)
   234         {
   163         {
   235         if ( LogDirExists( KSipLogPath ) )
   164         __SIP_TXT8_LOG(buf)
   236             {
       
   237             RFileLogger::Write (KSIPMessageLogFileDir,KSIPMessageLogFileName, 
       
   238                             EFileLoggingModeAppend, buf);
       
   239           }
       
   240         else
       
   241             {
       
   242             RDebug::RawPrint( buf );
       
   243             }
       
   244         }
   165         }
   245     }
   166     }
   246 #endif // WRITE_EXTRA_LOGS
   167 #endif // WRITE_EXTRA_LOGS
   247 
   168 
   248 #endif // USE_SIP_MESSAGE_LOG
   169 #endif // USE_SIP_MESSAGE_LOG