kerneltest/f32test/shostmassstorage/testclient/usbtestmsclient/inc/usbmsserversecuritypolicy.h
author Mike Kinghan <mikek@symbian.org>
Thu, 25 Nov 2010 14:35:45 +0000
branchGCC_SURGE
changeset 305 1ba12ef4ef89
parent 0 a41df078684a
permissions -rw-r--r--
Enhance the base/rom extension to generate the symbol file of the rom built. The symbol file is placed in epoc32/rom/<baseport_name>, along with the rom log and final oby file.

// Copyright (c) 2009 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:
// USB mass storage Server Security Policy definitions for Platform security.
// 
//



/**
 @file
 @internalComponent
*/

#ifndef USBMSSERVERSECURITYPOLICY_H
#define USBMSSERVERSECURITYPOLICY_H

//#include <usbmsshared.h>

// USB masss storage Server Security Policy Definition

const TUint KUsbMsServerRangeCount = 3;

const TInt KUsbMsServerRanges[KUsbMsServerRangeCount] =
	{
	EUsbMsStart,                // NetworkControl	[Start/Stop]
	EUsbMsShutdown,				// DiskAdmin		[Shutdown]
    EUsbMsShutdown + 1,         // fail (to KMaxInt)
	};

// Index numbers into KUsbMsServerElements[]
const TInt KPolicyNetworkControl = 0;
const TInt KPolicyDiskAdmin = 1;

// Mapping IPCs to poicy element
const TUint8 KUsbMsServerElementsIndex[KUsbMsServerRangeCount] =
	{
	KPolicyNetworkControl,          // EUsbMsStart & EUsbMsStop
	KPolicyDiskAdmin,			 	// EUsbMsShutdown
	CPolicyServer::ENotSupported,   // EUsbMsShutdown + 1 to KMaxTInt
	};

// Individual policy elements
const CPolicyServer::TPolicyElement KUsbMsServerElements[] =
	{
  		{ _INIT_SECURITY_POLICY_C1(ECapabilityNetworkControl), CPolicyServer::EFailClient },
		{ _INIT_SECURITY_POLICY_C1(ECapabilityDiskAdmin), CPolicyServer::EFailClient},
		// the EFailClient means that if the check fails
        // the CheckFailed method with return KErrPermissionDenied
	};

// Main policy
const CPolicyServer::TPolicy KUsbMsServerPolicy =
	{
	CPolicyServer::EAlwaysPass, // all connect attempts should pass
	KUsbMsServerRangeCount,
	KUsbMsServerRanges,
	KUsbMsServerElementsIndex,
	KUsbMsServerElements,
	};
#endif //__USBMSSERVERSECURITYPOLICY_H__