rtsecuritymanager/inc/rtsecmgrmsg.h
author Pat Downey <patd@symbian.org>
Mon, 26 Oct 2009 17:47:04 +0000
changeset 15 93c869ba5d1f
parent 10 a7062f7f0b79
permissions -rw-r--r--
Merge tags.

/*
* Copyright (c) 2007-2008 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of the License "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:      
*
*/







#ifndef _RTSECMGRMSG_H
#define _RTSECMGRMSG_H

// INCLUDES
#include <e32std.h>
#include <e32base.h>
#include <s32strm.h>
#include <s32mem.h>
#include <rtsecmgrcommondef.h>

// Maximum size expected for iHashMarker in CRTSecMgrRegisterScriptMsg
const TInt KMaxHashValueDesLen = 255;

// Maximum total size expected for a CRTSecMgrRegisterScriptMsg object
const TInt KMaxMsgLength = 520;

// CLASS DECLARATION

/**
 *  Message type to pass script object across
 *  client server boundary
 * 
 */
NONSHARABLE_CLASS(CRTSecMgrRegisterScriptMsg) : public CBase
	{
public:

	/**
	 * Destructor.
	 */
	IMPORT_C ~CRTSecMgrRegisterScriptMsg();

	/**
	 * Two-phased constructor.
	 * 
	 * Creates an instance of CRTSecMgrRegisterScriptMsg.
	 * 
	 * 
	 * @param aPolicyID policy identifier of script
	 * @param aHashValue hash value of script
	 * 
	 * @return CRTSecMgrRegisterScriptMsg* created instance of CRTSecMgrRegisterScriptMsg
	 * 
	 */
	IMPORT_C static CRTSecMgrRegisterScriptMsg* NewL(TPolicyID aPolicyID, const TDesC& aHashValue);

	/**
	 * Two-phased constructor. 
	 * 
	 * Creates an instance of CRTSecMgrRegisterScriptMsg
	 * and leaves it on cleanupstack
	 * 
	 * @param aPolicyID policy identifier of script
	 * @param aHashValue hash value of script
	 * 
	 * @return CRTSecMgrRegisterScriptMsg* created instance of CRTSecMgrRegisterScriptMsg
	 * 
	 */
	IMPORT_C static CRTSecMgrRegisterScriptMsg* NewLC(TPolicyID aPolicyID, const TDesC& aHashValue);

	/**
	 * Two-phased constructor. 
	 * 
	 * Creates an instance of CRTSecMgrRegisterScriptMsg
	 * from the input source
	 * 
	 * @param aStreamData input source data
	 * 
	 * @return CRTSecMgrRegisterScriptMsg* created instance of CRTSecMgrRegisterScriptMsg 
	 * 
	 */
	IMPORT_C static CRTSecMgrRegisterScriptMsg* NewLC(const TDesC8& aStreamData);

	/*
	 * Creates an HBufC8 representation of CRTSecMgrRegisterScriptMsg
	 * 
	 * @return HBufC8* buffer representation of CRTSecMgrRegisterScriptMsg
	 */
	IMPORT_C HBufC8* PackMsgL() const;

	/*
	 * Gets the hash value of the script
	 * 
	 * @return const TDesC8& hash value of script
	 */
	inline const TDesC& HashValue() const
		{
		if(iHashMarker)
		return *iHashMarker;
		else
		return KNullDesC;
		}

	/*
	 * Gets the policy identifier
	 * 
	 * @return TPolicyID policy identifier
	 */
	inline TPolicyID PolicyID() const
		{
		return iPolicyID;
		}

protected:
	// Writes ’this’ to the stream
	void ExternalizeL(RWriteStream& aStream) const;
	// Initializes ’this’ from stream
	void InternalizeL(RReadStream& aStream);

private:

	/**
	 * Constructor for performing 1st stage construction
	 */
	CRTSecMgrRegisterScriptMsg()
		{}

	/**
	 * Constructor for performing 1st stage construction
	 */
	CRTSecMgrRegisterScriptMsg(TPolicyID aPolicyID);

	/**
	 * Second stage construction
	 */
	void ConstructL(const TDesC& aHashValue);

private:
	/*
	 * Policy identifier
	 * 
	 */
	TPolicyID iPolicyID;

	/*
	 * Hash value of the script
	 * 
	 */
	HBufC* iHashMarker;
	};

NONSHARABLE_CLASS(CRTPermGrantMessage) : public CBase
    {
    public:
        /**
         * Destructor.
         */
        IMPORT_C virtual ~CRTPermGrantMessage();
        
        /**
         * Two-phased constructor.
         * 
         * Creates an instance of CRTPermGrantMessage.
         */
        IMPORT_C static CRTPermGrantMessage* NewL();
        
        /**
         * Two-phased constructor. 
         * 
         * Creates an instance of CRTPermGrantMessage
         * and leaves it on cleanupstack
         */
        IMPORT_C static CRTPermGrantMessage* NewLC();
                
        /**
         * Two-phased constructor. 
         * 
         * Creates an instance of CRTPermGrantMessage
         * from the input source
         * 
         * @param aBuf input source data
         * 
         * @return CRTPermGrantMessage* created instance of CRTPermGrantMessage 
         * 
         */
        IMPORT_C static CRTPermGrantMessage* NewL(const TDesC8& aBuf);
        
        /**
         * Two-phased constructor. 
         * 
         * Creates an instance of CRTPermGrantMessage
         * from the input source and leaves it on cleanup stack
         * 
         * @param aBuf input source data
         * 
         * @return CRTPermGrantMessage* created instance of CRTPermGrantMessage 
         * 
         */
        IMPORT_C static CRTPermGrantMessage* NewLC(const TDesC8& aBuf);
        
        /**
         * Two-phased constructor. 
         * 
         * Creates an instance of CRTPermGrantMessage
         * 
         * @param aAllowedProviders RProviderArray Allowed service providers
         * @param aDeniedProviders RProviderArray Denied service providers
         * @param aScriptId TExecutableID script identifier
         * @return CRTPermGrantMessage* created instance of CRTPermGrantMessage 
         * 
         */
        IMPORT_C static CRTPermGrantMessage* NewL(RProviderArray aAllowedProviders, RProviderArray aDeniedProviders,TExecutableID aScriptId);
        
        /**
         * Two-phased constructor. 
         * 
         * Creates an instance of CRTPermGrantMessage and leaves it on the cleanup stack
         * 
         * @param aAllowedProviders RProviderArray Allowed service providers
         * @param aDeniedProviders RProviderArray Denied service providers
         * @param aScriptId TExecutableID script identifier
         * @return CRTPermGrantMessage* created instance of CRTPermGrantMessage 
         * 
         */
        IMPORT_C static CRTPermGrantMessage* NewLC(RProviderArray aAllowedProviders, RProviderArray aDeniedProviders,TExecutableID aScriptId);
        
        /**
         * Get Method.
         * 
         * Gets the list of Allowed providers
         * 
         * @param aAllowedProviders RProviderArray In/Out parameter which will contain the list of allowed providers
         */
        IMPORT_C void AllowedProviders(RProviderArray& aAllowedProviders);
        
        /**
         * Get Method.
         * 
         * Gets the list of Allowed providers
         * 
         * @param aDeniedProviders RProviderArray In/Out parameter which will contain the list of denied providers
         */
        IMPORT_C void DeniedProviders(RProviderArray& aDeniedProviders);
        
        /**
         * Get Method
         * 
         * Gets the script Identifier.
         * 
         * @return TExecutableID the script identifier
         */
        IMPORT_C TExecutableID ScriptID();
        
        /**
         * Set Method.
         * 
         * Sets the list of Allowed providers
         * 
         * @param aAllowedProviders RProviderArray input parameter which contains the list of allowed providers
         */
        IMPORT_C void setAllowedProviders(RProviderArray aAllowedProviders);
        
        /**
         * Set Method.
         * 
         * Sets the list of Denied providers
         * 
         * @param aDeniedProviders RProviderArray input parameter which contains the list of denied providers
         */
        IMPORT_C void setDeniedProviders(RProviderArray aDeniedProviders);
        
        /**
         * Set Method
         * 
         * Sets the script Identifier.
         * 
         * @param TExecutableID the script identifier
         */
        IMPORT_C void setScriptID(TExecutableID aScriptId);
        
        /*
         * Creates an HBufC8 representation of CRTPermGrantMessage
         * 
         * @return HBufC8* buffer representation of CRTPermGrantMessage
         */
        IMPORT_C HBufC8* PackMessageL();
        
    private:
        CRTPermGrantMessage();
        CRTPermGrantMessage(RProviderArray aAllowedProviders,RProviderArray aDeniedProviders,TExecutableID aScriptId);
        void ConstructL(const TDesC8& aBuf);
        void InternalizeL(RReadStream& aSink);
        void ExternalizeL(RWriteStream& aSource);
    private:
        RProviderArray iAllowedProviders;
        RProviderArray iDeniedProviders;
        TExecutableID iScriptId;
    };

#endif // RTSECMGRMSG_H