source: lab.git/Dev/utvpn/utvpn-unix-v101-7101-public/src/Cedar/UT.c @ 072e48b

trunk
Last change on this file since 072e48b was a1bae3e, checked in by mitty <mitty@…>, 12 years ago
  • copy vendor drop to trunk

git-svn-id: https://lab.mitty.jp/svn/lab/trunk@147 7d2118f6-f56c-43e7-95a2-4bb3031d96e7

  • Property mode set to 100644
File size: 11.7 KB
RevLine 
[a1bae3e]1// SoftEther UT-VPN SourceCode
2//
3// Copyright (C) 2004-2010 SoftEther Corporation.
4// Copyright (C) 2004-2010 University of Tsukuba, Japan.
5// Copyright (C) 2003-2010 Daiyuu Nobori.
6// All Rights Reserved.
7//
8// http://utvpn.tsukuba.ac.jp/
9//
10// This program is free software; you can redistribute it and/or
11// modify it under the terms of the GNU General Public License
12// version 2 as published by the Free Software Foundation.
13//
14// This program is distributed in the hope that it will be useful,
15// but WITHOUT ANY WARRANTY; without even the implied warranty of
16// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17// GNU General Public License for more details.
18//
19// You should have received a copy of the GNU General Public License version 2
20// along with this program; if not, write to the Free Software
21// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
22//
23// このファイルは GPL バージョン 2 ライセンスで公開されています。
24// 誰でもこのファイルの内容を複製、改変したり、改変したバージョンを再配布
25// することができます。ただし、原著作物を改変した場合は、原著作物の著作権表示
26// を除去することはできません。改変した著作物を配布する場合は、改変実施者の
27// 著作権表示を原著作物の著作権表示に付随して記載するようにしてください。
28//
29// この SoftEther UT-VPN オープンソース・プロジェクトは、日本国の
30// ソフトイーサ株式会社 (SoftEther Corporation, http://www.softether.co.jp/ )
31// および筑波大学 (University of Tsukuba, http://www.tsukuba.ac.jp/ ) によって
32// ホストされています。
33// 本プログラムの配布者は、本プログラムを、業としての利用以外のため、
34// および、試験または研究のために利用が行われることを想定して配布
35// しています。
36// SoftEther UT-VPN プロジェクトの Web サイトは http://utvpn.tsukuba.ac.jp/ に
37// あります。
38// 本ソフトウェアの不具合の修正、機能改良、セキュリティホールの修復などのコード
39// の改変を行った場合で、その成果物を SoftEther UT-VPN プロジェクトに提出して
40// いただける場合は、 http://utvpn.tsukuba.ac.jp/ までソースコードを送付して
41// ください。SoftEther UT-VPN プロジェクトの本体リリースまたはブランチリリース
42// に組み込みさせていただきます。
43//
44// GPL に基づいて原著作物が提供される本ソフトウェアの改良版を配布、販売する
45// 場合は、そのソースコードを GPL に基づいて誰にでも開示する義務が生じます。
46//
47// 本ソフトウェアに関連する著作権、特許権、商標権はソフトイーサ株式会社
48// (SoftEther Corporation) およびその他の著作権保持者が保有しています。
49// ソフトイーサ株式会社等はこれらの権利を放棄していません。本ソフトウェアの
50// 二次著作物を配布、販売する場合は、これらの権利を侵害しないようにご注意
51// ください。
52//
53// お願い: どのような通信ソフトウェアにも通常は必ず未発見の
54// セキュリティホールが潜んでいます。本ソースコードをご覧いただいた結果、
55// UT-VPN にセキュリティホールを発見された場合は、当該セキュリティホールの
56// 情報を不特定多数に開示される前に、必ず、ソフトイーサ株式会社
57// および脆弱性情報の届出を受け付ける公的機関まで通報いただき、
58// 公益保護にご協力いただきますようお願い申し上げます。
59//
60// ソフトイーサ株式会社は、当該セキュリティホールについて迅速に対処を
61// 行い、UT-VPN および UT-VPN に関連するソフトウェアのユーザー・顧客
62// を保護するための努力を行います。
63//
64// ソフトイーサへの届出先: http://www.softether.co.jp/jp/contact/
65// 日本国内の脆弱性情報届出受付公的機関:
66//         独立行政法人 情報処理推進機構
67//         http://www.ipa.go.jp/security/vuln/report/
68//
69// 上記各事項について不明な点は、ソフトイーサ株式会社までご連絡ください。
70// 連絡先: http://www.softether.co.jp/jp/contact/
71
72// -----------------------------------------------
73// [ChangeLog]
74// 2010.05.20
75//  新規リリース by SoftEther
76// -----------------------------------------------
77
78// UT.c
79// Win32 用 SoftEther Network Utility
80
81#ifdef  WIN32
82
83#define UT_C
84
85#define _WIN32_WINNT        0x0502
86#define WINVER              0x0502
87#include <winsock2.h>
88#include <windows.h>
89#include <wincrypt.h>
90#include <wininet.h>
91#include <shlobj.h>
92#include <commctrl.h>
93#include <Dbghelp.h>
94#include <stdio.h>
95#include <stdlib.h>
96#include <string.h>
97#include <wchar.h>
98#include <stdarg.h>
99#include <time.h>
100#include <errno.h>
101#include <Mayaqua/Mayaqua.h>
102#include <Cedar/Cedar.h>
103#include "../PenCore/resource.h"
104
105static char *selected_adapter = NULL;
106
107// Q. 「スピードメーター」という関数名になっているがこれはどういう意味か? 警察のオービスなのか?
108// A. もともとこのネットワーク情報表示ユーティリティは、通信速度を測定するために開発
109//    されたのである。しかし、その後「TrafficServer」、「TrafficClient」機能が別途
110//    開発されたため、速度測定機能はこのユーティリティからは削除された。
111//    関数名はその時代の名残である。
112
113// ステータスの更新
114void UtSpeedMeterDlgRefreshStatus(HWND hWnd)
115{
116    char *title;
117    MS_ADAPTER *a;
118    UINT i;
119    // 引数チェック
120    if (hWnd == NULL)
121    {
122        return;
123    }
124
125    title = selected_adapter;
126
127    a = MsGetAdapter(title);
128    if (a == NULL)
129    {
130        LbReset(hWnd, L_STATUS);
131        Disable(hWnd, L_STATUS);
132    }
133    else
134    {
135        LVB *b;
136        wchar_t tmp[MAX_SIZE];
137        wchar_t tmp2[MAX_SIZE];
138        char str[MAX_SIZE];
139        b = LvInsertStart();
140
141        StrToUni(tmp, sizeof(tmp), a->Title);
142        LvInsertAdd(b, 0, NULL, 2, _UU("UT_SM_ST_TITLE"), tmp);
143
144        StrToUni(tmp, sizeof(tmp), a->Guid);
145        LvInsertAdd(b, 0, NULL, 2, _UU("UT_SM_ST_GUID"), tmp);
146
147        LvInsertAdd(b, 0, NULL, 2, _UU("UT_SM_ST_TYPE"), MsGetAdapterTypeStr(a->Type));
148
149        LvInsertAdd(b, 0, NULL, 2, _UU("UT_SM_ST_STATUS"), MsGetAdapterStatusStr(a->Status));
150
151        UniToStr3(tmp, sizeof(tmp), a->Mtu);
152        LvInsertAdd(b, 0, NULL, 2, _UU("UT_SM_ST_MTU"), tmp);
153
154        UniToStr3(tmp, sizeof(tmp), a->Speed);
155        LvInsertAdd(b, 0, NULL, 2, _UU("UT_SM_ST_SPEED"), tmp);
156
157        Zero(str, sizeof(str));
158        BinToStrEx2(str, sizeof(str), a->Address, a->AddressSize, '-');
159        StrToUni(tmp, sizeof(tmp), str);
160        LvInsertAdd(b, 0, NULL, 2, _UU("UT_SM_ST_ADDRESS"), tmp);
161
162        UniToStr3(tmp, sizeof(tmp), a->RecvBytes);
163        LvInsertAdd(b, 0, NULL, 2, _UU("UT_SM_ST_RECV_BYTES"), tmp);
164
165        UniToStr3(tmp, sizeof(tmp), a->RecvPacketsBroadcast);
166        LvInsertAdd(b, 0, NULL, 2, _UU("UT_SM_ST_RECV_BCASTS"), tmp);
167
168        UniToStr3(tmp, sizeof(tmp), a->RecvPacketsUnicast);
169        LvInsertAdd(b, 0, NULL, 2, _UU("UT_SM_ST_RECV_UNICASTS"), tmp);
170
171        UniToStr3(tmp, sizeof(tmp), a->SendBytes);
172        LvInsertAdd(b, 0, NULL, 2, _UU("UT_SM_ST_SEND_BYTES"), tmp);
173
174        UniToStr3(tmp, sizeof(tmp), a->SendPacketsBroadcast);
175        LvInsertAdd(b, 0, NULL, 2, _UU("UT_SM_ST_SEND_BCASTS"), tmp);
176
177        UniToStr3(tmp, sizeof(tmp), a->SendPacketsUnicast);
178        LvInsertAdd(b, 0, NULL, 2, _UU("UT_SM_ST_SEND_UNICASTS"), tmp);
179
180        for (i = 0;i < a->NumIpAddress;i++)
181        {
182            UniFormat(tmp2, sizeof(tmp2), _UU("UT_SM_ST_IP"), i + 1);
183            IPToUniStr(tmp, sizeof(tmp), &a->IpAddresses[i]);
184            LvInsertAdd(b, 0, NULL, 2, tmp2, tmp);
185
186            UniFormat(tmp2, sizeof(tmp2), _UU("UT_SM_ST_SUBNET"), i + 1);
187            IPToUniStr(tmp, sizeof(tmp), &a->SubnetMasks[i]);
188            LvInsertAdd(b, 0, NULL, 2, tmp2, tmp);
189        }
190
191        for (i = 0;i < a->NumGateway;i++)
192        {
193            UniFormat(tmp2, sizeof(tmp2), _UU("UT_SM_ST_GATEWAY"), i + 1);
194            IPToUniStr(tmp, sizeof(tmp), &a->Gateways[i]);
195            LvInsertAdd(b, 0, NULL, 2, tmp2, tmp);
196        }
197
198        if (a->UseDhcp)
199        {
200            IPToUniStr(tmp, sizeof(tmp), &a->DhcpServer);
201            LvInsertAdd(b, 0, NULL, 2, _UU("UT_SM_ST_DHCP"), tmp);
202
203            GetDateTimeStrEx64(tmp, sizeof(tmp), a->DhcpLeaseStart, NULL);
204            LvInsertAdd(b, 0, NULL, 2, _UU("UT_SM_ST_DHCP_1"), tmp);
205
206            GetDateTimeStrEx64(tmp, sizeof(tmp), a->DhcpLeaseExpires, NULL);
207            LvInsertAdd(b, 0, NULL, 2, _UU("UT_SM_ST_DHCP_2"), tmp);
208        }
209
210        if (a->UseWins)
211        {
212            IPToUniStr(tmp, sizeof(tmp), &a->PrimaryWinsServer);
213            LvInsertAdd(b, 0, NULL, 2, _UU("UT_SM_ST_WINS_1"), tmp);
214
215            IPToUniStr(tmp, sizeof(tmp), &a->SecondaryWinsServer);
216            LvInsertAdd(b, 0, NULL, 2, _UU("UT_SM_ST_WINS_2"), tmp);
217        }
218
219        LvInsertEnd(b, hWnd, L_STATUS);
220        Enable(hWnd, L_STATUS);
221
222        MsFreeAdapter(a);
223    }
224
225}
226
227// アダプタリストの更新
228void UtSpeedMeterDlgRefreshList(HWND hWnd)
229{
230    wchar_t *old;
231    MS_ADAPTER_LIST *o;
232    UINT i;
233    // 引数チェック
234    if (hWnd == NULL)
235    {
236        return;
237    }
238
239    // 現在の選択を取得
240    old = GetText(hWnd, E_LIST);
241    if (old != NULL)
242    {
243        if (UniStrLen(old) == 0)
244        {
245            Free(old);
246            old = NULL;
247        }
248    }
249
250    o = MsCreateAdapterList();
251    CbReset(hWnd, E_LIST);
252    CbSetHeight(hWnd, E_LIST, 18);
253
254    for (i = 0;i < o->Num;i++)
255    {
256        wchar_t tmp[MAX_SIZE];
257        MS_ADAPTER *a = o->Adapters[i];
258
259        if (a->Info)
260        {
261            StrToUni(tmp, sizeof(tmp), a->Title);
262            CbAddStr(hWnd, E_LIST, tmp, 0);
263        }
264    }
265
266
267    // 前回の選択を再選択
268    if (old != NULL)
269    {
270        CbSelectIndex(hWnd, E_LIST, CbFindStr(hWnd, E_LIST, old));
271        Free(old);
272    }
273
274    MsFreeAdapterList(o);
275}
276
277// スピードメーターダイアログコントロール更新
278void UtSpeedMeterDlgUpdate(HWND hWnd)
279{
280    // 引数チェック
281    if (hWnd == NULL)
282    {
283        return;
284    }
285}
286
287// スピードメーターダイアログ初期化
288void UtSpeedMeterDlgInit(HWND hWnd)
289{
290    // 引数チェック
291    if (hWnd == NULL)
292    {
293        return;
294    }
295
296    LvInitEx(hWnd, L_STATUS, true);
297    LvInsertColumn(hWnd, L_STATUS, 0, _UU("UT_SM_COLUMN_1"), 150);
298    LvInsertColumn(hWnd, L_STATUS, 1, _UU("UT_SM_COLUMN_2"), 290);
299
300    UtSpeedMeterDlgRefreshList(hWnd);
301    selected_adapter = GetTextA(hWnd, E_LIST);
302    UtSpeedMeterDlgRefreshStatus(hWnd);
303    UtSpeedMeterDlgUpdate(hWnd);
304}
305
306// スピードメーターダイアログ
307UINT UtSpeedMeterDlgProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam, void *param)
308{
309    // 引数チェック
310    if (hWnd == NULL)
311    {
312        return 0;
313    }
314
315    switch (msg)
316    {
317    case WM_INITDIALOG:
318        SetIcon(hWnd, 0, ICO_NIC_ONLINE);
319        UtSpeedMeterDlgInit(hWnd);
320        SetTimer(hWnd, 1, SPEED_METER_REFRESH_INTERVAL, NULL);
321        break;
322
323    case WM_TIMER:
324        switch (wParam)
325        {
326        case 1:
327            KillTimer(hWnd, 1);
328            UtSpeedMeterDlgRefreshStatus(hWnd);
329            UtSpeedMeterDlgUpdate(hWnd);
330            SetTimer(hWnd, 1, SPEED_METER_REFRESH_INTERVAL, NULL);
331            break;
332        }
333        break;
334
335    case WM_COMMAND:
336        if (HIWORD(wParam) == CBN_SELCHANGE) {
337            Free(selected_adapter);
338            selected_adapter = GetTextA(hWnd, E_LIST);
339            UtSpeedMeterDlgUpdate(hWnd);
340        } else {
341            switch (wParam)
342            {
343            case B_REFRESH:
344                UtSpeedMeterDlgRefreshList(hWnd);
345                Free(selected_adapter);
346                selected_adapter = GetTextA(hWnd, E_LIST);
347                UtSpeedMeterDlgUpdate(hWnd);
348                break;
349
350            case IDCANCEL:
351                Close(hWnd);
352                break;
353            }
354        }
355        break;
356
357    case WM_CLOSE:
358        Free(selected_adapter);
359        selected_adapter = NULL;
360        EndDialog(hWnd, 0);
361        break;
362    }
363
364    return 0;
365}
366
367// スピードメーター
368void UtSpeedMeter()
369{
370    UtSpeedMeterEx(NULL);
371}
372void UtSpeedMeterEx(void *hWnd)
373{
374    Dialog((HWND)hWnd, D_SPEEDMETER, UtSpeedMeterDlgProc, NULL);
375}
376
377#endif // WIN32
378
Note: See TracBrowser for help on using the repository browser.