/* Copyright 2015-2016 Amebis Copyright 2016 GÉANT This file is part of GÉANTLink. GÉANTLink is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. GÉANTLink is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with GÉANTLink. If not, see . */ #include "EAPMethods.h" #include "../res/wxEAPMethods.h" #include "../res/wxpass.h" #include #include namespace eap { template class peer_ui; } template class wxEAPConfig; class wxPasswordCredentials; inline int wxShowModal(wxDialog *dlg); #pragma once namespace eap { /// /// EAP UI peer base abstract class template /// /// A group of methods all EAP UI peers must or should implement. /// template class peer_ui : public module { public: /// /// Configuration data type /// typedef config_providers > config_type; /// /// Identity data type /// typedef _Tid identity_type; /// /// Interactive request data type /// typedef _Tint interactive_request_type; /// /// Interactive response data type /// typedef _Tintres interactive_response_type; public: /// /// Constructor /// peer_ui() : module() {} /// /// Raises the EAP method's specific connection configuration user interface dialog on the client. /// /// \sa [EapPeerInvokeConfigUI function](https://msdn.microsoft.com/en-us/library/windows/desktop/aa363614.aspx) /// /// \param[in] hwndParent Parent window /// \param[in] dwFlags Flags passed to `EapPeerInvokeConfigUI()` call /// \param[inout] cfg Configuration to edit /// \param[out] ppEapError Pointer to error descriptor in case of failure. Free using `module::free_error_memory()`. /// /// \returns /// - \c ERROR_SUCCESS if succeeded /// - error code otherwise /// virtual DWORD invoke_config_ui( _In_ HWND hwndParent, _In_ DWORD dwFlags, _Inout_ config_type &cfg, _Out_ EAP_ERROR **ppEapError) = 0; /// /// Raises a custom interactive user interface dialog to obtain user identity information for the EAP method on the client. /// /// \sa [EapPeerInvokeIdentityUI function](https://msdn.microsoft.com/en-us/library/windows/desktop/aa363615.aspx) /// /// \param[in] hwndParent Parent window /// \param[in] dwFlags Flags passed to `EapPeerInvokeIdentityUI()` call /// \param[inout] cfg Configuration /// \param[inout] usr User data to edit /// \param[out] ppwszIdentity Pointer to user identity. Free using `module::free_memory()`. /// \param[out] ppEapError Pointer to error descriptor in case of failure. Free using `module::free_error_memory()`. /// /// \returns /// - \c ERROR_SUCCESS if succeeded /// - error code otherwise /// virtual DWORD invoke_identity_ui( _In_ HWND hwndParent, _In_ DWORD dwFlags, _Inout_ config_type &cfg, _Inout_ identity_type &usr, _Out_ LPWSTR *ppwszIdentity, _Out_ EAP_ERROR **ppEapError) = 0; /// /// Raises a custom interactive user interface dialog for the EAP method on the client. /// /// \sa [EapPeerInvokeInteractiveUI function](https://msdn.microsoft.com/en-us/library/windows/desktop/aa363616.aspx) /// /// \param[in] hwndParent Parent window /// \param[in] req Interactive request /// \param[out] res Interactive response /// \param[out] ppEapError Pointer to error descriptor in case of failure. Free using `module::free_error_memory()`. /// /// \returns /// - \c ERROR_SUCCESS if succeeded /// - error code otherwise /// virtual DWORD invoke_interactive_ui( _In_ HWND hwndParent, _In_ const interactive_request_type &req, _Out_ interactive_response_type &res, _Out_ EAP_ERROR **ppEapError) = 0; }; } /// /// EAP configuration dialog /// template class wxEAPConfig : public wxEAPConfigBase { public: /// /// Configuration provider data type /// typedef eap::config_provider<_Tcfg> _Tprov; /// /// Configuration data type /// typedef eap::config_providers<_Tprov> config_type; public: /// /// Constructs a config panel /// wxEAPConfig(config_type &cfg, wxWindow* parent) : m_cfg(cfg), wxEAPConfigBase(parent) { m_banner->SetBitmap(wxBitmap(wxT("banner.bmp"), wxBITMAP_TYPE_BMP_RESOURCE)); for (std::list<_Tprov>::iterator provider = m_cfg.m_providers.begin(), provider_end = m_cfg.m_providers.end(); provider != provider_end; ++provider) { // TODO: Add multiple method support. assert(!provider->m_methods.empty()); m_providers->AddPage(new _wxT(provider->m_methods.front(), m_providers), provider->m_id); } Layout(); } protected: config_type &m_cfg; ///< EAP providers configuration }; /// /// Password credentials panel /// class wxPasswordCredentials : public wxPasswordCredentialsBase { public: wxPasswordCredentials(wxWindow* parent); protected: winstd::library m_shell32; ///< shell32.dll resource library reference wxIcon m_icon; ///< Panel icon }; /// /// Helper function to launch modal dialogs with parent disabled /// /// \param[in] dlg Dialog to launch modal /// /// \returns Dialog result code /// inline int wxShowModal(wxDialog *dlg) { // Temporary disable the parent for true native modal experience, then launch the dialog. wxWindow *parent = dlg->GetParent(); parent->Enable(false); int result; __try { result = dlg->ShowModal(); } __finally { parent->Enable(true); } return result; }