source: lab.git/Dev/utvpn/utvpn-unix-v101-7101-public/src/Cedar/Session.h @ a1bae3e

trunk
Last change on this file since a1bae3e 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: 17.1 KB
Line 
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// Session.h
79// Session.c のヘッダ
80
81#ifndef SESSION_H
82#define SESSION_H
83
84
85
86// パケットアダプタ関数
87typedef bool (PA_INIT)(SESSION *s);
88typedef CANCEL *(PA_GETCANCEL)(SESSION *s);
89typedef UINT (PA_GETNEXTPACKET)(SESSION *s, void **data);
90typedef bool (PA_PUTPACKET)(SESSION *s, void *data, UINT size);
91typedef void (PA_FREE)(SESSION *s);
92
93// クライアント関係関数
94typedef void (CLIENT_STATUS_PRINTER)(SESSION *s, wchar_t *status);
95
96// ノード情報
97struct NODE_INFO
98{
99    char ClientProductName[64];     // クライアント製品名
100    UINT ClientProductVer;          // クライアントバージョン
101    UINT ClientProductBuild;        // クライアントビルド番号
102    char ServerProductName[64];     // サーバー製品名
103    UINT ServerProductVer;          // サーバーバージョン
104    UINT ServerProductBuild;        // サーバービルド番号
105    char ClientOsName[64];          // クライアント OS 名
106    char ClientOsVer[128];          // クライアント OS バージョン
107    char ClientOsProductId[64];     // クライアント OS プロダクト ID
108    char ClientHostname[64];        // クライアントホスト名
109    UINT ClientIpAddress;           // クライアント IP アドレス
110    UINT ClientPort;                // クライアントポート番号
111    char ServerHostname[64];        // サーバーホスト名
112    UINT ServerIpAddress;           // サーバー IP アドレス
113    UINT ServerPort;                // サーバーポート番号
114    char ProxyHostname[64];         // プロキシホスト名
115    UINT ProxyIpAddress;            // プロキシ IP アドレス
116    UINT ProxyPort;                 // プロキシポート番号
117    char HubName[64];               // HUB 名
118    UCHAR UniqueId[16];             // ユニーク ID
119    // 以下は IPv6 対応用
120    UCHAR ClientIpAddress6[16];     // クライアント IPv6 アドレス
121    UCHAR ServerIpAddress6[16];     // サーバー IP アドレス
122    UCHAR ProxyIpAddress6[16];      // プロキシ IP アドレス
123    char Padding[304 - (16 * 3)];   // パディング
124};
125
126// パケットアダプタ
127struct PACKET_ADAPTER
128{
129    PA_INIT *Init;
130    PA_GETCANCEL *GetCancel;
131    PA_GETNEXTPACKET *GetNextPacket;
132    PA_PUTPACKET *PutPacket;
133    PA_FREE *Free;
134    void *Param;
135};
136
137// セッション構造体
138struct SESSION
139{
140    LOCK *lock;                     // ロック
141    REF *ref;                       // 参照カウンタ
142    CEDAR *Cedar;                   // Cedar
143    bool LocalHostSession;          // ローカルホストセッション
144    bool ServerMode;                // サーバーモードセッション
145    bool LinkModeClient;            // リンクモードクライアント
146    bool LinkModeServer;            // リンクモードサーバー
147    bool SecureNATMode;             // SecureNAT セッション
148    bool BridgeMode;                // Bridge セッション
149    bool VirtualHost;               // 仮想ホストモード
150    bool L3SwitchMode;              // Layer-3 スイッチモード
151    THREAD *Thread;                 // 管理スレッド
152    CONNECTION *Connection;         // コネクション
153    CLIENT_OPTION *ClientOption;    // クライアント接続オプション
154    CLIENT_AUTH *ClientAuth;        // クライアント認証データ
155    volatile bool Halt;             // 停止フラグ
156    volatile bool CancelConnect;    // 接続のキャンセル
157    EVENT *HaltEvent;               // 停止イベント
158    UINT Err;                       // エラー値
159    HUB *Hub;                       // HUB
160    CANCEL *Cancel1;                // キャンセルオブジェクト 1
161    CANCEL *Cancel2;                // キャンセルオブジェクト 2
162    PACKET_ADAPTER *PacketAdapter;  // パケットアダプタ
163    UCHAR UdpSendKey[16];           // UDP 送信用暗号化鍵
164    UCHAR UdpRecvKey[16];           // UDP 受信用暗号化鍵
165    UINT ClientStatus;              // クライアントステータス
166    bool RetryFlag;                 // リトライフラグ (クライアント)
167    bool ForceStopFlag;             // 強制停止フラグ (クライアント)
168    UINT CurrentRetryCount;         // 現在のリトライカウンタ (クライアント)
169    UINT RetryInterval;             // リトライ間隔 (クライアント)
170    bool ConnectSucceed;            // 接続成功フラグ (クライアント)
171    bool SessionTimeOuted;          // セッションがタイムアウトした
172    UINT Timeout;                   // タイムアウト時間
173    UINT64 NextConnectionTime;      // 次に追加コネクションを張る時刻
174    IP ServerIP;                    // サーバーの IP アドレス
175    bool ClientModeAndUseVLan;      // クライアントモードで仮想 LAN カードを使用
176    bool UseSSLDataEncryption;      // SSL データ暗号化を使用する
177    LOCK *TrafficLock;              // トラフィックデータロック
178    LINK *Link;                     // リンクオブジェクトへの参照
179    SNAT *SecureNAT;                // SecureNAT オブジェクトへの参照
180    BRIDGE *Bridge;                 // Bridge オブジェクトへの参照
181    NODE_INFO NodeInfo;             // ノード情報
182    UINT64 LastIncrementTraffic;    // 最後にユーザーのトラフィックデータを更新した時刻
183    bool AdministratorMode;         // 管理者モード
184    LIST *CancelList;               // キャンセルリスト
185    L3IF *L3If;                     // Layer-3 インターフェイス
186    IP DefaultDns;                  // デフォルトの DNS サーバーの IP アドレス
187    bool IPv6Session;               // IPv6 セッション (物理的な通信が IPv6 である)
188    UINT VLanId;                    // VLAN ID
189
190    UINT64 CreatedTime;             // 作成日時
191    UINT64 LastCommTime;            // 最終通信日時
192    TRAFFIC *Traffic;               // トラフィックデータ
193    TRAFFIC *OldTraffic;            // 古いトラフィックデータ
194    UINT64 TotalSendSize;           // 合計送信データサイズ
195    UINT64 TotalRecvSize;           // 合計受信データサイズ
196    UINT64 TotalSendSizeReal;       // 合計送信データサイズ (無圧縮)
197    UINT64 TotalRecvSizeReal;       // 合計受信データサイズ (無圧縮)
198    char *Name;                     // セッション名
199    char *Username;                 // ユーザー名
200    char UserNameReal[MAX_USERNAME_LEN + 1];    // ユーザー名 (本物)
201    char GroupName[MAX_USERNAME_LEN + 1];   // グループ名
202    POLICY *Policy;                 // ポリシー
203    UCHAR SessionKey[SHA1_SIZE];    // セッションキー
204    UINT SessionKey32;              // 32bit のセッションキー
205    UINT MaxConnection;             // 最大同時接続 TCP コネクション数
206    bool UseEncrypt;                // 暗号化通信を使用
207    bool UseFastRC4;                // 高速 RC4 暗号化を使用
208    bool UseCompress;               // データ圧縮を使用
209    bool HalfConnection;            // ハーフコネクションモード
210    bool QoS;                       // VoIP / QoS
211    bool NoSendSignature;           // シグネチャを送信しない
212    UINT64 FirstConnectionEstablisiedTime;  // 最初のコネクションの接続完了時刻
213    UINT64 CurrentConnectionEstablishTime;  // このコネクションの接続完了時刻
214    UINT NumConnectionsEatablished; // これまでに確立したコネクション数
215
216    ACCOUNT *Account;               // クライアント アカウント
217    UINT VLanDeviceErrorCount;      // 仮想 LAN カードでエラーが発生した回数
218    bool Win32HideConnectWindow;    // 接続ウインドウを非表示にする
219    bool Win32HideNicInfoWindow;    // NIC 情報ウインドウを非表示にする
220    bool UserCanceled;              // ユーザーによってキャンセルされた
221    UINT64 LastTryAddConnectTime;   // 最後にコネクションの追加を試行しようとした時刻
222
223    bool IsMonitorMode;             // モニタモードか否か
224    bool IsBridgeMode;              // ブリッジモードか否か
225    bool UseClientLicense;          // 割り当てられたクライアントライセンス数
226    bool UseBridgeLicense;          // 割り当てられたブリッジライセンス数
227
228    COUNTER *LoggingRecordCount;    // ロギング中のレコード数のカウンタ
229
230    bool Client_NoSavePassword;     // パスワードの保存を禁止
231    wchar_t *Client_Message;        // サーバーから送信されてきたメッセージ
232
233    LIST *DelayedPacketList;        // 遅延パケットリスト
234    UINT Flag1;
235
236    // D-Link バグ対策
237    UINT64 LastDLinkSTPPacketSendTick;  // 最後の D-Link STP パケット送出時刻
238    UCHAR LastDLinkSTPPacketDataHash[MD5_SIZE]; // 最後の D-Link STP パケットハッシュ
239};
240
241// パスワードダイアログ
242struct UI_PASSWORD_DLG
243{
244    UINT Type;                      // パスワードの種類
245    char Username[MAX_USERNAME_LEN + 1];    // ユーザー名
246    char Password[MAX_PASSWORD_LEN + 1];    // パスワード
247    char ServerName[MAX_HOST_NAME_LEN + 1]; // サーバー名
248    UINT RetryIntervalSec;          // リトライまでの時間
249    EVENT *CancelEvent;             // ダイアログ表示をキャンセルするイベント
250    bool ProxyServer;               // プロキシサーバーに関する認証
251    UINT64 StartTick;               // 開始時刻
252    bool AdminMode;                 // 管理モード
253    bool ShowNoSavePassword;        // パスワードを保存しないチェックボックスを表示するかどうか
254    bool NoSavePassword;            // パスワードを保存しないモード
255    SOCK *Sock;                     // ソケット
256};
257
258// メッセージダイアログ
259struct UI_MSG_DLG
260{
261    char ServerName[MAX_HOST_NAME_LEN + 1]; // サーバー名
262    char HubName[MAX_HUBNAME_LEN + 1];  // 仮想 HUB 名
263    wchar_t *Msg;                   // 本文
264    SOCK *Sock;                     // ソケット
265    bool Halt;                      // 閉じるフラグ
266};
267
268// NIC 情報
269struct UI_NICINFO
270{
271    wchar_t AccountName[MAX_SIZE];  // 接続設定名
272    char NicName[MAX_SIZE];         // 仮想 NIC 名
273
274    SOCK *Sock;                     // ソケット
275    bool Halt;                      // 閉じるフラグ
276    ROUTE_CHANGE *RouteChange;      // ルーティングテーブル変更通知
277    UINT CurrentIcon;               // 現在のアイコン
278    UINT64 CloseAfterTime;          // 自動で閉じる
279};
280
281// 接続エラーダイアログ
282struct UI_CONNECTERROR_DLG
283{
284    EVENT *CancelEvent;             // ダイアログ表示をキャンセルするイベント
285    wchar_t AccountName[MAX_ACCOUNT_NAME_LEN + 1];  // アカウント名
286    char ServerName[MAX_HOST_NAME_LEN + 1]; // サーバー名
287    UINT Err;                       // エラーコード
288    UINT CurrentRetryCount;         // 現在のリトライ回数
289    UINT RetryLimit;                // リトライ回数のリミット
290    UINT64 StartTick;               // 開始時刻
291    UINT RetryIntervalSec;          // リトライまでの時間
292    bool HideWindow;                // ウインドウを非表示にする
293    SOCK *Sock;                     // ソケット
294};
295
296// サーバー証明書チェックダイアログ
297struct UI_CHECKCERT
298{
299    wchar_t AccountName[MAX_ACCOUNT_NAME_LEN + 1];  // アカウント名
300    char ServerName[MAX_HOST_NAME_LEN + 1]; // サーバー名
301    X *x;                           // サーバー証明書
302    X *parent_x;                    // 親証明書
303    X *old_x;                       // 前回の証明書
304    bool DiffWarning;               // 証明書変造の警告を表示する
305    bool Ok;                        // 接続許可フラグ
306    bool SaveServerCert;            // サーバー証明書を保存する
307    SESSION *Session;               // セッション
308    volatile bool Halt;             // 停止フラグ
309    SOCK *Sock;                     // ソケット
310};
311
312
313// 関数プロトタイプ
314SESSION *NewClientSessionEx(CEDAR *cedar, CLIENT_OPTION *option, CLIENT_AUTH *auth, PACKET_ADAPTER *pa, struct ACCOUNT *account);
315SESSION *NewClientSession(CEDAR *cedar, CLIENT_OPTION *option, CLIENT_AUTH *auth, PACKET_ADAPTER *pa);
316SESSION *NewRpcSession(CEDAR *cedar, CLIENT_OPTION *option);
317SESSION *NewRpcSessionEx(CEDAR *cedar, CLIENT_OPTION *option, UINT *err, char *client_str);
318SESSION *NewRpcSessionEx2(CEDAR *cedar, CLIENT_OPTION *option, UINT *err, char *client_str, void *hWnd);
319SESSION *NewServerSession(CEDAR *cedar, CONNECTION *c, HUB *h, char *username, POLICY *policy);
320void ClientThread(THREAD *t, void *param);
321void ReleaseSession(SESSION *s);
322void CleanupSession(SESSION *s);
323void StopSession(SESSION *s);
324void StopSessionEx(SESSION *s, bool no_wait);
325bool SessionConnect(SESSION *s);
326bool ClientConnect(CONNECTION *c);
327int CompareSession(void *p1, void *p2);
328PACKET_ADAPTER *NewPacketAdapter(PA_INIT *init, PA_GETCANCEL *getcancel, PA_GETNEXTPACKET *getnext,
329                                 PA_PUTPACKET *put, PA_FREE *free);
330void FreePacketAdapter(PACKET_ADAPTER *pa);
331void SessionMain(SESSION *s);
332void NewSessionKey(CEDAR *cedar, UCHAR *session_key, UINT *session_key_32);
333SESSION *GetSessionFromKey(CEDAR *cedar, UCHAR *session_key);
334SESSION *GetSessionFromKey32(CEDAR *cedar, UINT key32);
335void DebugPrintSessionKey(UCHAR *session_key);
336void ClientAdditionalConnectChance(SESSION *s);
337void SessionAdditionalConnect(SESSION *s);
338void ClientAdditionalThread(THREAD *t, void *param);
339void PrintSessionTotalDataSize(SESSION *s);
340void AddTrafficForSession(SESSION *s, TRAFFIC *t);
341void IncrementUserTraffic(HUB *hub, char *username, SESSION *s);
342void Notify(SESSION *s, UINT code);
343void PrintStatus(SESSION *s, wchar_t *str);
344LIST *NewCancelList();
345void ReleaseCancelList(LIST *o);
346void AddCancelList(LIST *o, CANCEL *c);
347void CancelList(LIST *o);
348bool CompareNodeInfo(NODE_INFO *a, NODE_INFO *b);
349bool IsPriorityHighestPacketForQoS(void *data, UINT size);
350UINT GetNextDelayedPacketTickDiff(SESSION *s);
351
352#endif  // SESSION_H
353
354
355
Note: See TracBrowser for help on using the repository browser.