/* * OpenVPN-GUI -- A Windows GUI for OpenVPN. * * Copyright (C) 2004 Mathias Sundman * 2010 Heiko Hund * * This program 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 2 of the License, or * (at your option) any later version. * * This program 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 this program (see the file COPYING included with this * distribution); if not, write to the Free Software Foundation, Inc., * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #ifndef OPENVPN_H #define OPENVPN_H #include "options.h" #define TRY_SETPROP(hwnd, name, p) \ do { if (SetPropW(hwnd, name, p)) break; \ MsgToEventLog(EVENTLOG_ERROR_TYPE, L"%hs:%d GetProp returned null", \ __func__, __LINE__); \ EndDialog(hwnd, IDABORT); \ return false; \ } while(0) BOOL StartOpenVPN(connection_t *); void StopOpenVPN(connection_t *); void DetachOpenVPN(connection_t *); void SuspendOpenVPN(int config); void RestartOpenVPN(connection_t *); void ReleaseOpenVPN(connection_t *); BOOL CheckVersion(); void SetStatusWinIcon(HWND hwndDlg, int IconID); void OnReady(connection_t *, char *); void OnHold(connection_t *, char *); void OnLogLine(connection_t *, char *); void OnStateChange(connection_t *, char *); void OnPassword(connection_t *, char *); void OnStop(connection_t *, char *); void OnNeedOk(connection_t *, char *); void OnNeedStr(connection_t *, char *); void OnEcho(connection_t *, char *); void OnByteCount(connection_t *, char *); void OnInfoMsg(connection_t *, char *); void OnTimeout(connection_t *, char *); void ResetSavePasswords(connection_t *); extern const TCHAR *cfgProp; /* These error codes are from openvpn service sources */ #define ERROR_OPENVPN_STARTUP 0x20000000 #define ERROR_STARTUP_DATA 0x20000001 #define ERROR_MESSAGE_DATA 0x20000002 #define ERROR_MESSAGE_TYPE 0x20000003 /* Write a line to status window and optionally to the log file */ void WriteStatusLog(connection_t *c, const WCHAR *prefix, const WCHAR *line, BOOL fileio); #define FLAG_CR_TYPE_SCRV1 0x1 /* static challenege */ #define FLAG_CR_TYPE_CRV1 0x2 /* dynamic challenege */ #define FLAG_CR_ECHO 0x4 /* echo the response */ #define FLAG_CR_RESPONSE 0x8 /* response needed */ #define FLAG_PASS_TOKEN 0x10 /* PKCS11 token password needed */ #define FLAG_STRING_PKCS11 0x20 /* PKCS11 id needed */ #define FLAG_PASS_PKEY 0x40 /* Private key password needed */ #define FLAG_CR_TYPE_CRTEXT 0x80 /* crtext */ #define FLAG_CR_TYPE_CONCAT 0x100 /* concatenate otp with password */ typedef struct { connection_t *c; unsigned int flags; char *str; char *id; char *user; char *cr_response; } auth_param_t; /* * Parse dynamic challenge string received from the server. Returns * true on success. The caller must free param->str and param->id * even on error. */ BOOL parse_dynamic_cr(const char *str, auth_param_t *param); void free_auth_param(auth_param_t *param); /* * Given an OpenVPN state as reported by the management interface * return the correspnding resource id for translation. */ int daemon_state_resid(const char *name); #endif /* ifndef OPENVPN_H */