messagingappbase/obexmtms/TObexMTM/SRC/SendAsStates.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 17 Dec 2009 08:44:11 +0200
changeset 0 72b543305e3a
permissions -rw-r--r--
Revision: 200949 Kit: 200951

// 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);
    }