javacommons/gcfprotocols/secureconnection/inc.s60/nativecertificatemanager.h
branchRCL_3
changeset 19 04becd199f91
child 23 98ccebc37403
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/javacommons/gcfprotocols/secureconnection/inc.s60/nativecertificatemanager.h	Tue Apr 27 16:30:29 2010 +0300
@@ -0,0 +1,175 @@
+/*
+* Copyright (c) 2008 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:  Provides functionality for adding certificate ino cert store
+ *
+*/
+
+
+#ifndef NATIVECERTIFICATEMANAGER_H
+#define NATIVECERTIFICATEMANAGER_H
+
+//  INCLUDES
+#include "functionserver.h"
+#include "fs_methodcall.h"
+#include <e32base.h>
+#include <f32file.h>
+#include <ct/rmpointerarray.h>
+#include <cctcertinfo.h>
+#include <ct/tcttokenobjecthandle.h>
+#include <openssl/x509.h>
+#include "s60commonutils.h"
+#include <string>
+
+using namespace java::util;
+// CONSTANTS
+
+// Key usage constants
+const TInt KSTSKeyUsageAuthentication = 0;
+const TInt KSTSKeyUsageNonRepudiation = 1;
+
+// FORWARD DECLARATIONS
+class CUnifiedCertStore;
+class CUnifiedKeyStore;
+class CCTKeyInfo;
+class CX500DistinguishedName;
+class CX520AttributeTypeAndValue;
+class CPKCS10Request;
+class MPKIDialog;
+class CCMSIssuerAndSerialNumber;
+using namespace java::util;
+
+// CLASS DECLARATION
+
+/**
+ *  Provides functionality for adding certificate into CUnified cert store
+ */
+
+NONSHARABLE_CLASS(NativeCertificateManager): public CActive, public FunctionServer
+{
+private: // type definitions
+    enum TCertState
+    {
+        EValidating
+    };
+
+public: // Constructors and destructor
+
+    /**
+     * Two-phased constructor.
+     */
+    static NativeCertificateManager* NewL(X509* aCert);
+
+    /**
+     * Destructor.
+     */
+    virtual ~NativeCertificateManager();
+
+public: // New functions
+
+    int AddCertificate();
+
+    int doValidationL();
+
+    int validation();
+
+    void doClose();
+
+    static int validateX509Certificate(X509 *aCert);
+
+    int doValidateX509Certificate();
+
+    void MyAdd();
+
+    void doAdd();
+
+public: // CActive
+
+    /**
+     * Handles an active object's request completion event.
+     */
+    void RunL();
+
+    /**
+     * Handles a leave occurring in the request completion event handler RunL().
+     */
+    TInt RunError(TInt aError);
+
+    /**
+     * Implements cancellation of an outstanding request.
+     */
+    void DoCancel();
+
+private:
+
+    // From FunctionServer
+    virtual void vmAttached();
+    virtual void doServerSideInit();
+    void AddToScheduler();
+
+    /**
+     * C++ default constructor.
+     */
+    NativeCertificateManager();
+
+    /**
+     * By default Symbian 2nd phase constructor is private.
+     */
+    void ConstructL(X509* aCert);
+
+    /**
+     * Completes current asynchronic operation.
+     * If aError is not KErrNone, sets iError before calling
+     * iWait->AsyncStop().
+     * @param aError return value from the completed operation.
+     */
+    void Complete(TInt aError);
+
+    /**
+     * Waits for the current asynchronic operation to complete.
+     * Leaves with the error code if the asynchronic operation fails.
+     */
+    void WaitForCompletion();
+
+    /**
+     * Retrieves the certificate to be removed, in order to check
+     * the Issuer and SerialNumber of the certificate
+     */
+
+    /**
+     * Adds a certificate
+     */
+    void AddL();
+
+private: // Data
+
+    // internal state
+    TCertState iState;
+
+    // internal error variable
+    TInt iError;
+
+    // Waits for the operation to complete. Owned.
+    CActiveSchedulerWait* iWait;
+
+    // Used by CUnifiedCertStore
+    RFs iFileServer;
+
+    int iCertVerErrCode;
+
+    X509* iCert;
+
+    TInt lab;
+};
+
+#endif // NATIVECERTIFICATEMANAGER_H