/*
* Copyright (c) 2002-2005 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:
*
*/
// INCLUDE FILES
#include "SenCredential.h"
//#include "SenDebug.h"
#include <SenDateUtils.h>
#include <SenXmlElement.h>
#include <SenXmlUtils.h>
#ifdef SYMBIAN_SECURE_ECOM
// for S60 FP3 (2.8) platform or newer (3.0 and above)
#include <xml/attribute.h> // needed for RAttributeArray
//#else // for S60 FP2 platform (2.6) or older
//#include "Attribute.h"
#endif
using namespace Xml;
namespace
{
/* milliseconds before actual notOnOrAfter time
* when credentials are treated
* as expired.
*/
// Identifiers which are accepted (and searched after)
_LIT8(KId, "ID");
_LIT8(Kwsu_ns_plus_Id, "wsu:Id");
_LIT8(KAssertionId, "AssertionID");
_LIT8(KConditions, "Conditions");
_LIT8(KVal_NotOnOrAfter, "NotOnOrAfter");
}
EXPORT_C CSenCredential* CSenCredential::NewL(
const TDesC8& aNsUri,
const TDesC8& aLocalName,
const TDesC8& aQName,
const RAttributeArray& aAttributes
)
{
CSenCredential* pNew = NewLC(aNsUri, aLocalName, aQName, aAttributes);
CleanupStack::Pop(); // pNew;
return pNew;
}
EXPORT_C CSenCredential* CSenCredential::NewLC(
const TDesC8& aNsUri,
const TDesC8& aLocalName,
const TDesC8& aQName,
const RAttributeArray& aAttributes
)
{
CSenCredential* pNew = new (ELeave) CSenCredential;
CleanupStack::PushL(pNew);
pNew->ConstructL(aNsUri, aLocalName, aQName, aAttributes);
return pNew;
}
EXPORT_C CSenCredential* CSenCredential::NewL(
const TDesC8& aNsUri,
const TDesC8& aLocalName,
const TDesC8& aQName,
const RAttributeArray& aAttributes,
CSenElement& aParent
)
{
CSenCredential* pNew = NewLC(aNsUri, aLocalName,
aQName, aAttributes, aParent);
CleanupStack::Pop(); // pNew;
return pNew;
}
EXPORT_C CSenCredential* CSenCredential::NewLC(
const TDesC8& aNsUri,
const TDesC8& aLocalName,
const TDesC8& aQName,
const RAttributeArray& aAttributes,
CSenElement& aParent
)
{
CSenCredential* pNew = new (ELeave) CSenCredential;
CleanupStack::PushL(pNew);
pNew->ConstructL(aNsUri, aLocalName, aQName, aAttributes, aParent);
return pNew;
}
EXPORT_C CSenCredential* CSenCredential::NewL(
const CSenCredential& aCredential)
{
CSenCredential* pNew = NewLC(aCredential);
CleanupStack::Pop(); // pNew;
return pNew;
}
EXPORT_C CSenCredential* CSenCredential::NewLC(
const CSenCredential& aCredential)
{
CSenCredential* pNew = new (ELeave) CSenCredential;
CleanupStack::PushL(pNew);
pNew->ConstructL((CSenCredential&)aCredential);
return pNew;
}
EXPORT_C void CSenCredential::ConstructL(CSenCredential& aCredential)
{
ipElement = CSenXmlElement::NewL(aCredential.ipElement->LocalName());
ipElement->CopyFromL(*(CSenXmlElement*)(aCredential.ipElement));
if (aCredential.ValidUntil() != Time::NullTTime())
{
SetValidUntil(aCredential.ValidUntil());
}
SetIdL(aCredential.Id());
}
EXPORT_C void CSenCredential::ConstructL(
const TDesC8& aNsUri,
const TDesC8& aLocalName,
const TDesC8& aQName,
const RAttributeArray& aAttributes,
CSenElement& aParent
)
{
BaseConstructL(aNsUri, aLocalName, aQName, aAttributes, aParent);
// this ensures we take note of possible namespaces and
// prefixed attributes
CSenBaseFragment::SetAttributesL(aAttributes);
// we want to save its ID and validity
TPtrC8 identifier = SenXmlUtils::AttrValue(aAttributes, KId);
if(identifier.Length()>0)
{
SetIdL(identifier);
}
TPtrC8 identifier2 = SenXmlUtils::AttrValue(aAttributes, Kwsu_ns_plus_Id);
if(identifier2.Length()>0)
{
SetIdL(identifier2);
}
TPtrC8 identifier3 = SenXmlUtils::AttrValue(aAttributes, KAssertionId);
if(identifier3.Length()>0)
{
SetIdL(identifier3);
}
/*
for(int i=0; i<aAttributes.Count(); i++)
{
TPtrC8 attrName = aAttributes[i].Attribute().LocalName().DesC();
if( attrName == KId)
{
SetIdL(aAttributes[i].Value().DesC());
}
else if(attrName == Kwsu_ns_plus_Id)
{
SetIdL(aAttributes[i].Value().DesC());
}
else if(attrName == KAssertionId)
{
SetIdL(aAttributes[i].Value().DesC());
}
}
*/
}
EXPORT_C void CSenCredential::ConstructL(
const TDesC8& aNsUri,
const TDesC8& aLocalName,
const TDesC8& aQName,
const RAttributeArray& aAttributes )
{
BaseConstructL(aNsUri, aLocalName, aQName, aAttributes);
// this ensures we take note of possible namespaces and
// prefixed attributes
CSenBaseFragment::SetAttributesL(aAttributes);
TPtrC8 identifier = SenXmlUtils::AttrValue(aAttributes, KId);
if(identifier.Length()>0)
{
SetIdL(identifier);
}
TPtrC8 identifier2 = SenXmlUtils::AttrValue(aAttributes, Kwsu_ns_plus_Id);
if(identifier2.Length()>0)
{
SetIdL(identifier2);
}
TPtrC8 identifier3 = SenXmlUtils::AttrValue(aAttributes, KAssertionId);
if(identifier3.Length()>0)
{
SetIdL(identifier3);
}
/*
// we want to save its ID and validity
for(int i=0; i<aAttributes.Count(); i++)
{
TPtrC8 attrName = aAttributes[i].Attribute().LocalName().DesC();
if(attrName == KId)
{
SetIdL(aAttributes[i].Value().DesC());
}
if(attrName == Kwsu_ns_plus_Id)
{
SetIdL(aAttributes[i].Value().DesC());
}
if(attrName == KAssertionId)
{
SetIdL(aAttributes[i].Value().DesC());
}
}
*/
}
EXPORT_C CSenCredential::CSenCredential()
:
iId(NULL),
iNotOnOrAfter(Time::NullTTime())
{
}
EXPORT_C CSenCredential::~CSenCredential()
{
delete iId;
}
void CSenCredential::SetIdL(const TDesC8& aNewId)
{
HBufC8* pNew = aNewId.AllocL();
delete iId;
iId = pNew;
}
EXPORT_C const TDesC8& CSenCredential::Id()
{
if(iId)
{
return *iId;
}
else
{
return KNullDesC8();
}
}
EXPORT_C void CSenCredential::StartElementL(
const TDesC8& aNsUri,
const TDesC8& aLocalName,
const TDesC8& aQName,
const RAttributeArray& aAttributes
)
{
if(aLocalName.Compare(KConditions) == 0)
{
// we should save the notOnOrAfter attribute value
TPtrC8 ptr = SenXmlUtils::AttrValue(aAttributes, KVal_NotOnOrAfter );
// Convert dateTime (from XML schema) to Symbian TTime.
// The returned time will be in UTC.
if (ptr.Length() > 0)
{
iNotOnOrAfter = SenDateUtils::FromXmlDateTimeL(ptr);
}
}
CSenBaseFragment::StartElementL(aNsUri,
aLocalName, aQName, aAttributes);
}
EXPORT_C TTime& CSenCredential::ValidUntil()
{
return iNotOnOrAfter;
}
EXPORT_C void CSenCredential::SetValidUntil(TTime& aTime)
{
iNotOnOrAfter = aTime;
}
// END OF FILE