summaryrefslogtreecommitdiff
path: root/cpp/src/IceSSL/WinRTEngine.cpp
blob: 51cde970937d9068015b0e0237073f7ab564020f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
// **********************************************************************
//
// Copyright (c) 2003-2016 ZeroC, Inc. All rights reserved.
//
// This copy of Ice is licensed to you under the terms described in the
// ICE_LICENSE file included in this distribution.
//
// **********************************************************************

#include <IceSSL/Config.h>

#ifdef ICE_OS_WINRT

#include <IceSSL/SSLEngine.h>
#include <Ice/Communicator.h>
#include <Ice/Properties.h>
#include <IceUtil/Shared.h>

#include <string>

IceUtil::Shared* IceSSL::upCast(IceSSL::WinRTEngine* p) { return p; }

using namespace std;
using namespace IceSSL;

WinRTEngine::WinRTEngine(const Ice::CommunicatorPtr& communicator) : SSLEngine(communicator)
{
}

void
WinRTEngine::initialize()
{
    lock_guard<mutex> lock(_mutex);
    if(_initialized)
    {
        return;
    }

    SSLEngine::initialize();

    const auto properties = communicator()->getProperties();

    //
    // Load CAs
    //
    //string ca = properties->getProperty("IceSSL.CAs");
    //if(!ca.empty())
    //{
    //  _ca = Certificate::load(ca);
    //}

    //
    // Load client certificate
    //
    const int passwordRetryMax = properties->getPropertyAsIntWithDefault("IceSSL.PasswordRetryMax", 3);
    setPassword(properties->getProperty("IceSSL.Password"));

    string certFile = properties->getProperty("IceSSL.CertFile");
    string findCert = properties->getProperty("IceSSL.FindCert");
    if(!certFile.empty())
    {
        _certificate = make_shared<IceSSL::Certificate>(importPersonalCertificate(
            certFile, 
            [this]()
            {
                return password(false);
            }, 
            getPasswordPrompt() != nullptr, 
            passwordRetryMax));
    }
    else if(!findCert.empty())
    {
        auto certs = findCertificates(properties->getPropertyWithDefault("IceSSL.CertStore", "My"), findCert);
        if(certs->Size == 0)
        {
            throw Ice::PluginInitializationException(__FILE__, __LINE__, "IceSSL: no certificates found");
        }
        _certificate = make_shared<IceSSL::Certificate>(certs->GetAt(0));
    }
    _initialized = true;
}

bool
WinRTEngine::initialized() const
{
    return _initialized;
}

//shared_ptr<Certificate>
//WinRTEngine::ca()
//{
//    return _ca;
//}

shared_ptr<Certificate>
WinRTEngine::certificate()
{
    return _certificate;
}

void
WinRTEngine::destroy()
{
}

#endif