--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/messagingappbase/obexmtms/TObexMTM/SRC/SendAsStates.cpp Thu Dec 17 08:44:11 2009 +0200
@@ -0,0 +1,292 @@
+// Copyright (c) 2002-2009 Nokia Corporation and/or its subsidiary(-ies).
+// All rights reserved.
+// This component and the accompanying materials are made available
+// under the terms of "Eclipse Public License v1.0"
+// which accompanies this distribution, and is available
+// at the URL "http://www.eclipse.org/legal/epl-v10.html".
+//
+// Initial Contributors:
+// Nokia Corporation - initial contribution.
+//
+// Contributors:
+//
+// Description:
+// $Workfile: SendAsStates.cpp $
+// $Author: Stevep $
+// $Revision: 2 $
+// $Date: 27/03/02 10:44 $
+//
+//
+
+#include "sendasstates.h"
+
+// System includes
+#include <sendas.h> // CSendAs
+#include <mtmdef.h> // Message part constant bitmasks for a TMsvPartList value.
+
+
+// User includes
+#include "obexharness.h" // CObexClientTest
+#include "obextestutils.h" // CObexTestUtils
+
+_LIT(KObexSendAsPanicLiteral, "Obex SendAs States"); // literal for panic
+
+//
+// CObexSendAsCreateState
+//
+
+CObexSendAsCreateState::CObexSendAsCreateState(CObexClientTest& aClientTest) :
+ iClientTest(aClientTest)
+ {
+ }
+
+void CObexSendAsCreateState::StartL(TRequestStatus& aStatus)
+ {
+ if(!iClientTest.SendAs())
+ iClientTest.CreateSendAsL();
+
+ TRequestStatus* status = &aStatus;
+ User::RequestComplete(status, KErrNone);
+ }
+
+
+//
+// CObexSendAsAddRecipientState
+//
+
+CObexSendAsAddRecipientState::CObexSendAsAddRecipientState(const TDesC& aRecipient, CObexClientTest& aClientTest) :
+ iClientTest(aClientTest),
+ iRecipient(aRecipient)
+ {
+ }
+
+void CObexSendAsAddRecipientState::StartL(TRequestStatus& aStatus)
+ {
+ __ASSERT_ALWAYS( iClientTest.SendAs(), User::Panic(KObexSendAsPanicLiteral, KErrNotReady));
+
+ iClientTest.SendAs()->AddRecipientL(iRecipient);
+
+ TRequestStatus* status = &aStatus;
+ User::RequestComplete(status, KErrNone);
+ }
+
+//
+// CObexSendAsAddBTRecipientState
+//
+
+TUint8 CObexSendAsAddBTRecipientState::GetByteFromUnicodeHexTextChar(const TUint16 *input)
+ {
+ TUint8 result = (TUint8)*input;
+
+ if(result >='0' && result <='9')
+ result = (TUint8)(result - '0');
+ else if(result >='a' && result <='f')
+ result = (TUint8)(result - 'a' + 10);
+ else if(result >='A' && result <='F')
+ result = (TUint8)(result - 'A' + 10);
+ else
+ result = 0;
+
+ return result;
+ }
+
+CObexSendAsAddBTRecipientState::CObexSendAsAddBTRecipientState(const TDesC& aRecipient, CObexClientTest& aClientTest) :
+ iClientTest(aClientTest)
+ {
+ // convert the incoming string from 12 unicode chars to 3 by
+ // converting 4 chars into 1 thus:
+
+ // first 4 input chars: '0' '0' '0' '2'
+ // output char 0x0002
+
+ // Convert first addresse from 16bit descriptor to 8bit descriptor containing 48bit BT device address
+ TPtrC16 ptr16 = aRecipient;
+ int ii;
+
+ for(ii=0;ii<12;ii+=4)
+ {
+ // do 4 characters to get one out. We're going to force the compiler to do the character endianness.
+ TUint8 byte1 = GetByteFromUnicodeHexTextChar(&ptr16[ii]);
+ TUint8 byte2 = GetByteFromUnicodeHexTextChar(&ptr16[ii+1]);
+ TUint8 byte3 = GetByteFromUnicodeHexTextChar(&ptr16[ii+2]);
+ TUint8 byte4 = GetByteFromUnicodeHexTextChar(&ptr16[ii+3]);
+
+ byte1 = (TUint8) ( ((byte1 & 0x0F) << 4) | (byte2 & 0x0f) );
+ byte3 = (TUint8) ( ((byte3 & 0x0F) << 4) | (byte4 & 0x0f) );
+
+ // make sure this is put together in network endianness
+ TUint16 result = (TUint16)( (TUint16)(byte3 << 8) | byte1 );
+
+ iRecipient.Append( result );
+ }
+
+ }
+
+void CObexSendAsAddBTRecipientState::StartL(TRequestStatus& aStatus)
+ {
+ __ASSERT_ALWAYS( iClientTest.SendAs(), User::Panic(KObexSendAsPanicLiteral, KErrNotReady));
+
+ iClientTest.SendAs()->AddRecipientL(iRecipient);
+
+ TRequestStatus* status = &aStatus;
+ User::RequestComplete(status, KErrNone);
+ }
+
+//
+// CObexSendAsSetSubjectState
+//
+
+CObexSendAsSetSubjectState::CObexSendAsSetSubjectState(const TDesC& aSubject, CObexClientTest& aClientTest) :
+ iClientTest(aClientTest),
+ iSubject(aSubject)
+ {
+ }
+
+void CObexSendAsSetSubjectState::StartL(TRequestStatus& aStatus)
+ {
+ __ASSERT_ALWAYS( iClientTest.SendAs(), User::Panic(KObexSendAsPanicLiteral, KErrNotReady));
+
+ iClientTest.SendAs()->SetSubjectL(iSubject);
+
+ TRequestStatus* status = &aStatus;
+ User::RequestComplete(status, KErrNone);
+ }
+
+
+//
+// CObexSendAsAddAttachmentState
+//
+
+CObexSendAsAddAttachmentState::CObexSendAsAddAttachmentState(const TDesC& aFileName, CObexClientTest& aClientTest) :
+ iClientTest(aClientTest),
+ iFileName(aFileName)
+ {
+ }
+
+void CObexSendAsAddAttachmentState::StartL(TRequestStatus& aStatus)
+ {
+ __ASSERT_ALWAYS( iClientTest.SendAs(), User::Panic(KObexSendAsPanicLiteral, KErrNotReady));
+
+ TMsvId id;
+ TFileName filename;
+
+ iClientTest.SendAs()->CreateAttachmentL(id, filename);
+
+ CFileMan* fileMan = CFileMan::NewL(iClientTest.ObexTestUtils().iMsvSession->FileSession());
+ CleanupStack::PushL(fileMan); // PUSH
+ User::LeaveIfError(fileMan->Copy(iFileName, filename));
+ CleanupStack::PopAndDestroy(); // fileMan // POP(1)
+
+ TRequestStatus* status = &aStatus;
+ User::RequestComplete(status, KErrNone);
+ }
+
+
+//
+// CObexSendAsAbandonState
+//
+
+CObexSendAsAbandonState::CObexSendAsAbandonState(CObexClientTest& aClientTest) :
+ iClientTest(aClientTest)
+ {
+ }
+
+void CObexSendAsAbandonState::StartL(TRequestStatus& aStatus)
+ {
+ __ASSERT_ALWAYS( iClientTest.SendAs(), User::Panic(KObexSendAsPanicLiteral, KErrNotReady));
+
+ iClientTest.SendAs()->AbandonMessage();
+
+ TRequestStatus* status = &aStatus;
+ User::RequestComplete(status, KErrNone);
+ }
+
+
+//
+// CObexSendAsSaveState
+//
+
+CObexSendAsSaveState::CObexSendAsSaveState(CObexClientTest& aClientTest) :
+ iClientTest(aClientTest)
+ {
+ }
+
+void CObexSendAsSaveState::StartL(TRequestStatus& aStatus)
+ {
+ __ASSERT_ALWAYS( iClientTest.SendAs(), User::Panic(KObexSendAsPanicLiteral, KErrNotReady));
+
+ iClientTest.SendAs()->SaveMessageL(); //no real benefit in using the async version of this function
+
+ TRequestStatus* status = &aStatus;
+ User::RequestComplete(status, KErrNone);
+ }
+
+
+//
+// CObexSendAsValidateState
+//
+
+CObexSendAsValidateState::CObexSendAsValidateState(CObexClientTest& aClientTest) :
+ iClientTest(aClientTest)
+ {
+ }
+
+void CObexSendAsValidateState::StartL(TRequestStatus& aStatus)
+ {
+//CBaseMtm::ValidateMessage currently only validates the recipient part of the message but, hey, that may change.
+ __ASSERT_ALWAYS( iClientTest.SendAs(), User::Panic(KObexSendAsPanicLiteral, KErrNotReady));
+
+ TMsvPartList partlist = iClientTest.SendAs()->ValidateMessage();
+
+ if(partlist != 0)
+ {
+ _LIT(KOpeningMessage, "\nThe following parts of the SendAs message are invalid:");
+ iClientTest.LogCommentL(KOpeningMessage);
+
+ if(partlist & KMsvMessagePartAttachments)
+ {
+ _LIT(KAttachments, "KMsvMessagePartAttachments.");
+ iClientTest.LogCommentL(KAttachments);
+ }
+
+ if(partlist & KMsvMessagePartBody)
+ {
+ _LIT(KBody, "KMsvMessagePartBody.");
+ iClientTest.LogCommentL(KBody);
+ }
+
+ if(partlist & KMsvMessagePartDate)
+ {
+ _LIT(KDate, "KMsvMessagePartDate.");
+ iClientTest.LogCommentL(KDate);
+ }
+
+ if(partlist & KMsvMessagePartDescription)
+ {
+ _LIT(KDescription, "KMsvMessagePartDescription.");
+ iClientTest.LogCommentL(KDescription);
+ }
+
+ if(partlist & KMsvMessagePartOriginator)
+ {
+ _LIT(KOriginator, "KMsvMessagePartOriginator.");
+ iClientTest.LogCommentL(KOriginator);
+ }
+
+ if(partlist & KMsvMessagePartRecipient)
+ {
+ _LIT(KRecipient, "KMsvMessagePartRecipient.");
+ iClientTest.LogCommentL(KRecipient);
+ }
+
+ }
+ else
+ {
+ _LIT(KMessageValid, "\nThe SendAs message is valid.");
+ iClientTest.LogCommentL(KMessageValid);
+ }
+
+ TRequestStatus* status = &aStatus;
+ User::RequestComplete(status, KErrNone);
+ }
+