* tar xzf utvpn-src-unix-v101-7101-public-2010.06.27.tar.gz
[lab.git] / utvpn / utvpn-unix-v101-7101-public / src / Cedar / Server.h
diff --git a/utvpn/utvpn-unix-v101-7101-public/src/Cedar/Server.h b/utvpn/utvpn-unix-v101-7101-public/src/Cedar/Server.h
new file mode 100644 (file)
index 0000000..17b12bb
--- /dev/null
@@ -0,0 +1,580 @@
+// SoftEther UT-VPN SourceCode\r
+// \r
+// Copyright (C) 2004-2010 SoftEther Corporation.\r
+// Copyright (C) 2004-2010 University of Tsukuba, Japan.\r
+// Copyright (C) 2003-2010 Daiyuu Nobori.\r
+// All Rights Reserved.\r
+// \r
+// http://utvpn.tsukuba.ac.jp/\r
+// \r
+// This program is free software; you can redistribute it and/or\r
+// modify it under the terms of the GNU General Public License\r
+// version 2 as published by the Free Software Foundation.\r
+// \r
+// This program is distributed in the hope that it will be useful,\r
+// but WITHOUT ANY WARRANTY; without even the implied warranty of\r
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\r
+// GNU General Public License for more details.\r
+// \r
+// You should have received a copy of the GNU General Public License version 2\r
+// along with this program; if not, write to the Free Software\r
+// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\r
+// \r
+// このファイルは GPL バージョン 2 ライセンスで公開されています。\r
+// 誰でもこのファイルの内容を複製、改変したり、改変したバージョンを再配布\r
+// することができます。ただし、原著作物を改変した場合は、原著作物の著作権表示\r
+// を除去することはできません。改変した著作物を配布する場合は、改変実施者の\r
+// 著作権表示を原著作物の著作権表示に付随して記載するようにしてください。\r
+// \r
+// この SoftEther UT-VPN オープンソース・プロジェクトは、日本国の\r
+// ソフトイーサ株式会社 (SoftEther Corporation, http://www.softether.co.jp/ )\r
+// および筑波大学 (University of Tsukuba, http://www.tsukuba.ac.jp/ ) によって\r
+// ホストされています。\r
+// 本プログラムの配布者は、本プログラムを、業としての利用以外のため、\r
+// および、試験または研究のために利用が行われることを想定して配布\r
+// しています。\r
+// SoftEther UT-VPN プロジェクトの Web サイトは http://utvpn.tsukuba.ac.jp/ に\r
+// あります。\r
+// 本ソフトウェアの不具合の修正、機能改良、セキュリティホールの修復などのコード\r
+// の改変を行った場合で、その成果物を SoftEther UT-VPN プロジェクトに提出して\r
+// いただける場合は、 http://utvpn.tsukuba.ac.jp/ までソースコードを送付して\r
+// ください。SoftEther UT-VPN プロジェクトの本体リリースまたはブランチリリース\r
+// に組み込みさせていただきます。\r
+// \r
+// GPL に基づいて原著作物が提供される本ソフトウェアの改良版を配布、販売する\r
+// 場合は、そのソースコードを GPL に基づいて誰にでも開示する義務が生じます。\r
+// \r
+// 本ソフトウェアに関連する著作権、特許権、商標権はソフトイーサ株式会社\r
+// (SoftEther Corporation) およびその他の著作権保持者が保有しています。\r
+// ソフトイーサ株式会社等はこれらの権利を放棄していません。本ソフトウェアの\r
+// 二次著作物を配布、販売する場合は、これらの権利を侵害しないようにご注意\r
+// ください。\r
+// \r
+// お願い: どのような通信ソフトウェアにも通常は必ず未発見の\r
+// セキュリティホールが潜んでいます。本ソースコードをご覧いただいた結果、\r
+// UT-VPN にセキュリティホールを発見された場合は、当該セキュリティホールの\r
+// 情報を不特定多数に開示される前に、必ず、ソフトイーサ株式会社\r
+// および脆弱性情報の届出を受け付ける公的機関まで通報いただき、\r
+// 公益保護にご協力いただきますようお願い申し上げます。\r
+// \r
+// ソフトイーサ株式会社は、当該セキュリティホールについて迅速に対処を\r
+// 行い、UT-VPN および UT-VPN に関連するソフトウェアのユーザー・顧客\r
+// を保護するための努力を行います。\r
+// \r
+// ソフトイーサへの届出先: http://www.softether.co.jp/jp/contact/\r
+// 日本国内の脆弱性情報届出受付公的機関:\r
+//         独立行政法人 情報処理推進機構\r
+//         http://www.ipa.go.jp/security/vuln/report/\r
+// \r
+// 上記各事項について不明な点は、ソフトイーサ株式会社までご連絡ください。\r
+// 連絡先: http://www.softether.co.jp/jp/contact/\r
+\r
+// -----------------------------------------------\r
+// [ChangeLog]\r
+// 2010.05.20\r
+//  新規リリース by SoftEther\r
+// -----------------------------------------------\r
+\r
+// Server.h\r
+// Server.c のヘッダ\r
+\r
+#ifndef        SERVER_H\r
+#define        SERVER_H\r
+\r
+extern char *SERVER_CONFIG_FILE_NAME;\r
+#define        SERVER_DEFAULT_CIPHER_NAME              "RC4-MD5"\r
+#define        SERVER_DEFAULT_CERT_DAYS                (365 * 10)\r
+#define        SERVER_DEFAULT_HUB_NAME                 "DEFAULT"\r
+#define        SERVER_DEFAULT_BRIDGE_NAME              "BRIDGE"\r
+#define        SERVER_CONTROL_TCP_TIMEOUT              (60 * 1000)\r
+#define        SERVER_FARM_CONTROL_INTERVAL    (10 * 1000)\r
+\r
+#define        SERVER_FILE_SAVE_INTERVAL_DEFAULT       (5 * 60 * 1000)\r
+#define        SERVER_FILE_SAVE_INTERVAL_MIN           (5 * 1000)\r
+#define        SERVER_FILE_SAVE_INTERVAL_MAX           (3600 * 1000)\r
+\r
+#define        SERVER_LICENSE_VIOLATION_SPAN   (SERVER_FARM_CONTROL_INTERVAL * 2)\r
+\r
+\r
+#define SERVER_DEADLOCK_CHECK_SPAN             (2 * 60 * 1000)\r
+#define SERVER_DEADLOCK_CHECK_TIMEOUT  (3 * 60 * 1000)\r
+\r
+\r
+#define        RETRY_CONNECT_TO_CONTROLLER_INTERVAL    (1 * 1000)\r
+\r
+#define        MAX_PUBLIC_PORT_NUM                             128\r
+\r
+// 各ファームメンバによってホストされている仮想 HUB リスト\r
+struct HUB_LIST\r
+{\r
+       struct FARM_MEMBER *FarmMember;         // ファームメンバ\r
+       bool DynamicHub;                                        // ダイナミック HUB\r
+       char Name[MAX_HUBNAME_LEN + 1];         // HUB 名\r
+       UINT NumSessions;                                       // セッション数\r
+       UINT NumSessionsClient;                         // クライアントセッション数\r
+       UINT NumSessionsBridge;                         // ブリッジセッション数\r
+       UINT NumMacTables;                                      // MAC テーブル数\r
+       UINT NumIpTables;                                       // IP テーブル数\r
+};\r
+\r
+// タスク\r
+struct FARM_TASK\r
+{\r
+       EVENT *CompleteEvent;                           // 完了通知\r
+       PACK *Request;                                          // 要求\r
+       PACK *Response;                                         // 応答\r
+};\r
+\r
+// ファームメンバ\r
+struct FARM_MEMBER\r
+{\r
+       CEDAR *Cedar;                                           // Cedar\r
+       UINT64 ConnectedTime;                           // 接続日時\r
+       UINT Me;                                                        // 自分自身\r
+       UINT Ip;                                                        // IP アドレス\r
+       UINT NumPort;                                           // ポート番号数\r
+       UINT *Ports;                                            // ポート番号\r
+       char hostname[MAX_HOST_NAME_LEN + 1];   // ホスト名\r
+       X *ServerCert;                                          // サーバー証明書\r
+       LIST *HubList;                                          // 仮想 HUB リスト\r
+       QUEUE *TaskQueue;                                       // タスクキュー\r
+       EVENT *TaskPostEvent;                           // タスク投入イベント\r
+       UINT Point;                                                     // 点数\r
+       volatile bool Halting;                          // 停止中\r
+       UINT NumSessions;                                       // セッション数\r
+       UINT MaxSessions;                                       // 最大セッション数\r
+       UINT NumTcpConnections;                         // TCP コネクション数\r
+       TRAFFIC Traffic;                                        // トラフィック情報\r
+       UINT AssignedClientLicense;                     // 割り当て済みクライアントライセンス数\r
+       UINT AssignedBridgeLicense;                     // 割り当て済みブリッジライセンス数\r
+       UINT Weight;                                            // 性能基準比\r
+       UCHAR RandomKey[SHA1_SIZE];                     // 乱数キー (ライセンスチェック)\r
+       UINT64 SystemId;                                        // システム ID (ライセンスチェック)\r
+};\r
+\r
+// ファームコントローラへの接続\r
+struct FARM_CONTROLLER\r
+{\r
+       LOCK *lock;                                                     // ロック\r
+       struct SERVER *Server;                          // サーバー\r
+       THREAD *Thread;                                         // スレッド\r
+       SOCK *Sock;                                                     // ソケット\r
+       SESSION *Session;                                       // セッション\r
+       volatile bool Halt;                                     // 停止フラグ\r
+       EVENT *HaltEvent;                                       // 停止イベント\r
+       UINT LastError;                                         // 最終エラー\r
+       bool Online;                                            // オンライン フラグ\r
+       UINT64 StartedTime;                                     // 接続開始時刻\r
+       UINT64 CurrentConnectedTime;            // 今回の接続時刻\r
+       UINT64 FirstConnectedTime;                      // 最初の接続時刻\r
+       UINT NumConnected;                                      // 接続回数\r
+       UINT NumTry;                                            // 試行回数\r
+       UINT NumFailed;                                         // 接続失敗回数\r
+};\r
+\r
+// サーバーリスナー\r
+struct SERVER_LISTENER\r
+{\r
+       UINT Port;                                                      // ポート番号\r
+       bool Enabled;                                           // 有効フラグ\r
+       LISTENER *Listener;                                     // リスナーオブジェクト\r
+};\r
+\r
+// syslog 設定\r
+struct SYSLOG_SETTING\r
+{\r
+       UINT SaveType;                                                  // 保存種類\r
+       char Hostname[MAX_HOST_NAME_LEN + 1];   // ホスト名\r
+       UINT Port;                                                              // ポート番号\r
+};\r
+\r
+// サーバー オブジェクト\r
+struct SERVER\r
+{\r
+       UINT ServerType;                                        // サーバーの種類\r
+       UINT UpdatedServerType;                         // 更新されたサーバーの種類\r
+       LIST *ServerListenerList;                       // サーバーリスナーリスト\r
+       UCHAR HashedPassword[SHA1_SIZE];        // パスワード\r
+       char ControllerName[MAX_HOST_NAME_LEN + 1];             // コントローラ名\r
+       UINT ControllerPort;                            // コントローラポート\r
+       UINT Weight;                                            // 性能基準比\r
+       bool ControllerOnly;                            // コントローラ機能のみ\r
+       UCHAR MemberPassword[SHA1_SIZE];        // ファームメンバ用パスワード\r
+       UINT PublicIp;                                          // 公開 IP \r
+       UINT NumPublicPort;                                     // 公開ポート数\r
+       UINT *PublicPorts;                                      // 公開ポート配列\r
+       UINT64 StartTime;                                       // 起動時刻\r
+       UINT AutoSaveConfigSpan;                        // 自動保存間隔\r
+       UINT ConfigRevision;                            // 設定ファイルリビジョン\r
+       UCHAR MyRandomKey[SHA1_SIZE];           // 自分のランダムキー\r
+       bool FarmControllerInited;                      // ファームコントローラの初期化が完了した\r
+       bool DisableDeadLockCheck;                      // デッドロックチェックを無効化する\r
+       bool NoSendSignature;                           // クライアントにシグネチャを送信させない\r
+       bool SaveDebugLog;                                      // デバッグログを保存する\r
+       bool NoLinuxArpFilter;                          // Linux における arp_filter を設定しない\r
+       bool NoHighPriorityProcess;                     // プロセスの優先順位を上げない\r
+       bool NoDebugDump;                                       // デバッグダンプを出力しない\r
+\r
+       volatile bool Halt;                                     // 停止フラグ\r
+       LOCK *lock;                                                     // ロック\r
+       REF *ref;                                                       // 参照カウンタ\r
+       CEDAR *Cedar;                                           // Cedar\r
+       CFG_RW *CfgRw;                                          // 設定ファイル R/W\r
+       LOCK *SaveCfgLock;                                      // 設定保存ロック\r
+       EVENT *SaveHaltEvent;                           // 保存スレッド停止イベント\r
+       THREAD *SaveThread;                                     // 設定保存スレッド\r
+       FARM_CONTROLLER *FarmController;        // ファームコントローラ\r
+       LOCK *TasksFromFarmControllerLock;      // ファームコントローラからのタスクを処理中にかけるロック\r
+       LIST *FarmMemberList;                           // ファームメンバーリスト\r
+       FARM_MEMBER *Me;                                        // 自分自身のファームメンバ登録\r
+       THREAD *FarmControlThread;                      // ファームコントロールスレッド\r
+       EVENT *FarmControlThreadHaltEvent;      // ファームコントロールスレッド停止イベント\r
+       LIST *HubCreateHistoryList;                     // 仮想 HUB 作成履歴リスト\r
+\r
+       KEEP *Keep;                                                     // コネクション維持\r
+       LOG *Logger;                                            // サーバー ロガー\r
+       ERASER *Eraser;                                         // 自動ファイル削除器\r
+\r
+       UINT CurrentTotalNumSessionsOnFarm;     // サーバー ファーム全体での合計のセッション数\r
+       UINT CurrentAssignedClientLicense;      // 現在のクライアントライセンス割り当て数\r
+       UINT CurrentAssignedBridgeLicense;      // 現在のブリッジライセンス割り当て数\r
+       LICENSE_SYSTEM *LicenseSystem;          // ライセンスシステム\r
+\r
+       LOCK *CapsCacheLock;                            // Caps キャッシュ用ロック\r
+       CAPSLIST *CapsListCache;                        // Caps キャッシュ\r
+       UINT LicenseHash;                                       // ライセンスリストのハッシュ値\r
+\r
+       bool SnapshotInited;\r
+       EVENT *SnapshotHaltEvent;                       // スナップショット停止イベント\r
+       volatile bool HaltSnapshot;                     // スナップショット停止フラグ\r
+       THREAD *SnapshotThread;                         // スナップショットスレッド\r
+       LOG *SnapshotLogger;                            // スナップショットロガー\r
+       UINT64 LastSnapshotTime;                        // 最後にスナップショットを作成した時刻\r
+\r
+       THREAD *DeadLockCheckThread;            // デッドロックチェックスレッド\r
+       volatile bool HaltDeadLockThread;       // 停止フラグ\r
+       EVENT *DeadLockWaitEvent;                       // 待機イベント\r
+\r
+       TINY_LOG *DebugLog;                                     // デバッグログ\r
+};\r
+\r
+\r
+// セッションの列挙*\r
+struct RPC_ENUM_SESSION\r
+{\r
+       char HubName[MAX_HUBNAME_LEN + 1];                              // HUB 名\r
+       UINT NumSession;                                                                // セッション数\r
+       struct RPC_ENUM_SESSION_ITEM *Sessions;                 // セッションリスト\r
+};\r
+\r
+// セッション状態*\r
+struct RPC_SESSION_STATUS\r
+{\r
+       char HubName[MAX_HUBNAME_LEN + 1];                              // HUB 名\r
+       char Name[MAX_SESSION_NAME_LEN + 1];                    // セッション名\r
+       char Username[MAX_USERNAME_LEN + 1];                    // ユーザー名\r
+       char RealUsername[MAX_USERNAME_LEN + 1];                // 本当のユーザー名\r
+       char GroupName[MAX_USERNAME_LEN + 1];                   // グループ名\r
+       bool LinkMode;                                                                  // リンクモード\r
+       RPC_CLIENT_GET_CONNECTION_STATUS Status;                // ステータス\r
+       UINT ClientIp;                                                                  // クライアント IP アドレス\r
+       UCHAR ClientIp6[16];                                                    // クライアント IPv6 アドレス\r
+       char ClientHostName[MAX_HOST_NAME_LEN + 1];             // クライアントホスト名\r
+       NODE_INFO NodeInfo;                                                             // ノード情報\r
+};\r
+\r
+\r
+// サーバーの種類\r
+#define        SERVER_TYPE_STANDALONE                  0               // スタンドアロン サーバー\r
+#define        SERVER_TYPE_FARM_CONTROLLER             1               // ファームコントローラ サーバー\r
+#define        SERVER_TYPE_FARM_MEMBER                 2               // ファームメンバ サーバー\r
+\r
+\r
+// Caps 関係\r
+struct CAPS\r
+{\r
+       char *Name;                                                     // 名前\r
+       UINT Value;                                                     // 値\r
+};\r
+struct CAPSLIST\r
+{\r
+       LIST *CapsList;                                         // Caps リスト\r
+};\r
+\r
+// ログファイル\r
+struct LOG_FILE\r
+{\r
+       char Path[MAX_PATH];                            // パス名\r
+       char ServerName[MAX_HOST_NAME_LEN + 1]; // サーバー名\r
+       UINT FileSize;                                          // ファイルサイズ\r
+       UINT64 UpdatedTime;                                     // 更新日時\r
+};\r
+\r
+// 仮想 HUB のスナップショット\r
+struct HUB_SNAPSHOT\r
+{\r
+       char HubName[MAX_HUBNAME_LEN + 1];\r
+       bool HubStatus;\r
+       UINT HubMaxSessionsClient;\r
+       UINT HubMaxSessionsBridge;\r
+};\r
+\r
+// Server のスナップショット\r
+struct SERVER_SNAPSHOT\r
+{\r
+       UINT64 DateTime;\r
+       IP ServerIp;\r
+       char ServerHostname[MAX_HOST_NAME_LEN + 1];\r
+       char ServerProduct[MAX_SIZE];\r
+       char ServerVersion[MAX_SIZE];\r
+       char ServerBuild[MAX_SIZE];\r
+       char ServerOs[MAX_SIZE];\r
+       UINT64 ServerLicenseId;\r
+       UINT64 ServerLicenseExpires;\r
+       UINT ServerType;\r
+       UINT64 ServerStartupDatetime;\r
+       UINT NumClusterNodes;\r
+       LIST *HubList;\r
+};\r
+\r
+// 仮想 HUB 作成履歴\r
+struct SERVER_HUB_CREATE_HISTORY\r
+{\r
+       char HubName[MAX_HUBNAME_LEN + 1];\r
+       UINT64 CreatedTime;\r
+};\r
+\r
+// 関数プロトタイプ宣言\r
+SERVER *SiNewServer(bool bridge);\r
+void SiReleaseServer(SERVER *s);\r
+void SiCleanupServer(SERVER *s);\r
+void StStartServer(bool bridge);\r
+void StStopServer();\r
+void SiInitConfiguration(SERVER *s);\r
+void SiFreeConfiguration(SERVER *s);\r
+UINT SiWriteConfigurationFile(SERVER *s);\r
+void SiLoadInitialConfiguration(SERVER *s);\r
+bool SiLoadConfigurationFile(SERVER *s);\r
+bool SiLoadConfigurationFileMain(SERVER *s, FOLDER *root);\r
+void SiInitDefaultServerCert(SERVER *s);\r
+void SiInitCipherName(SERVER *s);\r
+void SiGenerateDefualtCert(X **server_x, K **server_k);\r
+void SiInitListenerList(SERVER *s);\r
+void SiLockListenerList(SERVER *s);\r
+void SiUnlockListenerList(SERVER *s);\r
+bool SiAddListener(SERVER *s, UINT port, bool enabled);\r
+bool SiEnableListener(SERVER *s, UINT port);\r
+bool SiDisableListener(SERVER *s, UINT port);\r
+bool SiDeleteListener(SERVER *s, UINT port);\r
+SERVER_LISTENER *SiGetListener(SERVER *s, UINT port);\r
+int CompareServerListener(void *p1, void *p2);\r
+void SiStopAllListener(SERVER *s);\r
+void SiInitDefaultHubList(SERVER *s);\r
+void SiInitBridge(SERVER *s);\r
+void SiTest(SERVER *s);\r
+FOLDER *SiWriteConfigurationToCfg(SERVER *s);\r
+bool SiLoadConfigurationCfg(SERVER *s, FOLDER *root);\r
+void SiWriteLocalBridges(FOLDER *f, SERVER *s);\r
+void SiLoadLocalBridges(SERVER *s, FOLDER *f);\r
+void SiWriteLocalBridgeCfg(FOLDER *f, LOCALBRIDGE *br);\r
+void SiLoadLocalBridgeCfg(SERVER *s, FOLDER *f);\r
+void SiWriteListeners(FOLDER *f, SERVER *s);\r
+void SiLoadListeners(SERVER *s, FOLDER *f);\r
+void SiWriteListenerCfg(FOLDER *f, SERVER_LISTENER *r);\r
+void SiLoadListenerCfg(SERVER *s, FOLDER *f);\r
+void SiWriteServerCfg(FOLDER *f, SERVER *s);\r
+void SiLoadServerCfg(SERVER *s, FOLDER *f);\r
+void SiWriteTraffic(FOLDER *parent, char *name, TRAFFIC *t);\r
+void SiWriteTrafficInner(FOLDER *parent, char *name, TRAFFIC_ENTRY *e);\r
+void SiLoadTrafficInner(FOLDER *parent, char *name, TRAFFIC_ENTRY *e);\r
+void SiLoadTraffic(FOLDER *parent, char *name, TRAFFIC *t);\r
+void SiSaverThread(THREAD *thread, void *param);\r
+void SiLoadLicenseManager(SERVER *s, FOLDER *f);\r
+void SiWriteLicenseManager(FOLDER *f, SERVER *s);\r
+void SiLoadL3Switchs(SERVER *s, FOLDER *f);\r
+void SiLoadL3SwitchCfg(L3SW *sw, FOLDER *f);\r
+void SiWriteL3Switchs(FOLDER *f, SERVER *s);\r
+void SiWriteL3SwitchCfg(FOLDER *f, L3SW *sw);\r
+void SiWriteHubs(FOLDER *f, SERVER *s);\r
+void SiLoadHubs(SERVER *s, FOLDER *f);\r
+void SiWriteHubCfg(FOLDER *f, HUB *h);\r
+void SiLoadHubCfg(SERVER *s, FOLDER *f, char *name);\r
+void SiLoadHubLogCfg(HUB_LOG *g, FOLDER *f);\r
+void SiWriteHubOptionCfg(FOLDER *f, HUB_OPTION *o);\r
+void SiWriteHubLogCfg(FOLDER *f, HUB_LOG *g);\r
+void SiWriteHubLogCfgEx(FOLDER *f, HUB_LOG *g, bool el_mode);\r
+void SiLoadHubOptionCfg(FOLDER *f, HUB_OPTION *o);\r
+void SiWriteHubLinks(FOLDER *f, HUB *h);\r
+void SiLoadHubLinks(HUB *h, FOLDER *f);\r
+void SiWriteHubAdminOptions(FOLDER *f, HUB *h);\r
+void SiLoadHubAdminOptions(HUB *h, FOLDER *f);\r
+void SiWriteHubLinkCfg(FOLDER *f, LINK *k);\r
+void SiLoadHubLinkCfg(FOLDER *f, HUB *h);\r
+void SiWriteHubAccessLists(FOLDER *f, HUB *h);\r
+void SiLoadHubAccessLists(HUB *h, FOLDER *f);\r
+void SiWriteHubAccessCfg(FOLDER *f, ACCESS *a);\r
+void SiLoadHubAccessCfg(HUB *h, FOLDER *f);\r
+void SiWriteHubDb(FOLDER *f, HUBDB *db);\r
+void SiLoadHubDb(HUB *h, FOLDER *f);\r
+void SiWriteUserList(FOLDER *f, LIST *o);\r
+void SiLoadUserList(HUB *h, FOLDER *f);\r
+void SiWriteUserCfg(FOLDER *f, USER *u);\r
+void SiLoadUserCfg(HUB *h, FOLDER *f);\r
+void SiWriteGroupList(FOLDER *f, LIST *o);\r
+void SiLoadGroupList(HUB *h, FOLDER *f);\r
+void SiWriteGroupCfg(FOLDER *f, USERGROUP *g);\r
+void SiLoadGroupCfg(HUB *h, FOLDER *f);\r
+void SiWriteCertList(FOLDER *f, LIST *o);\r
+void SiLoadCertList(LIST *o, FOLDER *f);\r
+void SiWriteCrlList(FOLDER *f, LIST *o);\r
+void SiLoadCrlList(LIST *o, FOLDER *f);\r
+void SiWritePolicyCfg(FOLDER *f, POLICY *p, bool cascade_mode);\r
+void SiLoadPolicyCfg(POLICY *p, FOLDER *f);\r
+void SiLoadSecureNAT(HUB *h, FOLDER *f);\r
+void SiWriteSecureNAT(HUB *h, FOLDER *f);\r
+void SiRebootServerEx(bool bridge, bool reset_setting);\r
+void SiRebootServer(bool bridge);\r
+void SiRebootServerThread(THREAD *thread, void *param);\r
+void StInit();\r
+void StFree();\r
+SERVER *StGetServer();\r
+void SiSetServerType(SERVER *s, UINT type,\r
+                                        UINT ip, UINT num_port, UINT *ports,\r
+                                        char *controller_name, UINT controller_port, UCHAR *password, UINT weight, bool controller_only);\r
+FARM_CONTROLLER *SiStartConnectToController(SERVER *s);\r
+void SiStopConnectToController(FARM_CONTROLLER *f);\r
+void SiFarmServ(SERVER *server, SOCK *sock, X *cert, UINT ip, UINT num_port, UINT *ports, char *hostname, UINT point, UINT weight, UINT max_sessions);\r
+int CompareHubList(void *p1, void *p2);\r
+void SiFarmServMain(SERVER *server, SOCK *sock, FARM_MEMBER *f);\r
+FARM_TASK *SiFarmServPostTask(FARM_MEMBER *f, PACK *request);\r
+PACK *SiFarmServWaitTask(FARM_TASK *t);\r
+PACK *SiExecTask(FARM_MEMBER *f, PACK *p);\r
+PACK *SiCallTask(FARM_MEMBER *f, PACK *p, char *taskname);\r
+void SiAcceptTasksFromController(FARM_CONTROLLER *f, SOCK *sock);\r
+void SiAcceptTasksFromControllerMain(FARM_CONTROLLER *f, SOCK *sock);\r
+PACK *SiCalledTask(FARM_CONTROLLER *f, PACK *p, char *taskname);\r
+void SiHubOnlineProc(HUB *h);\r
+void SiHubOfflineProc(HUB *h);\r
+FARM_MEMBER *SiGetNextFarmMember(SERVER *s);\r
+void SiCallCreateHub(SERVER *s, FARM_MEMBER *f, HUB *h);\r
+void SiCallUpdateHub(SERVER *s, FARM_MEMBER *f, HUB *h);\r
+void SiCallDeleteHub(SERVER *s, FARM_MEMBER *f, HUB *h);\r
+void SiCallEnumSession(SERVER *s, FARM_MEMBER *f, char *hubname, RPC_ENUM_SESSION *t);\r
+void SiCallEnumNat(SERVER *s, FARM_MEMBER *f, char *hubname, RPC_ENUM_NAT *t);\r
+void SiCallEnumDhcp(SERVER *s, FARM_MEMBER *f, char *hubname, RPC_ENUM_DHCP *t);\r
+void SiCallGetNatStatus(SERVER *s, FARM_MEMBER *f, char *hubname, RPC_NAT_STATUS *t);\r
+void SiCallEnumMacTable(SERVER *s, FARM_MEMBER *f, char *hubname, RPC_ENUM_MAC_TABLE *t);\r
+void SiCallEnumIpTable(SERVER *s, FARM_MEMBER *f, char *hubname, RPC_ENUM_IP_TABLE *t);\r
+void SiCallDeleteSession(SERVER *s, FARM_MEMBER *f, char *hubname, char *session_name);\r
+void SiCallCreateTicket(SERVER *s, FARM_MEMBER *f, char *hubname, char *username, char *realusername, POLICY *policy, UCHAR *ticket, UINT counter, char *groupname);\r
+void SiCallDeleteMacTable(SERVER *s, FARM_MEMBER *f, char *hubname, UINT key);\r
+void SiCallDeleteIpTable(SERVER *s, FARM_MEMBER *f, char *hubname, UINT key);\r
+void SiCalledCreateHub(SERVER *s, PACK *p);\r
+void SiCalledUpdateHub(SERVER *s, PACK *p);\r
+void SiCalledDeleteHub(SERVER *s, PACK *p);\r
+void SiCalledDeleteSession(SERVER *s, PACK *p);\r
+void SiCalledDeleteMacTable(SERVER *s, PACK *p);\r
+void SiCalledDeleteIpTable(SERVER *s, PACK *p);\r
+PACK *SiCalledCreateTicket(SERVER *s, PACK *p);\r
+PACK *SiCalledEnumSession(SERVER *s, PACK *p);\r
+PACK *SiCalledEnumNat(SERVER *s, PACK *p);\r
+PACK *SiCalledEnumDhcp(SERVER *s, PACK *p);\r
+PACK *SiCalledGetNatStatus(SERVER *s, PACK *p);\r
+PACK *SiCalledEnumMacTable(SERVER *s, PACK *p);\r
+PACK *SiCalledEnumIpTable(SERVER *s, PACK *p);\r
+void SiCalledEnumHub(SERVER *s, PACK *p, PACK *req);\r
+void SiPackAddCreateHub(PACK *p, HUB *h);\r
+FARM_MEMBER *SiGetHubHostingMember(SERVER *s, HUB *h, bool admin_mode);\r
+void SiCallEnumHub(SERVER *s, FARM_MEMBER *f);\r
+void SiStartFarmControl(SERVER *s);\r
+void SiStopFarmControl(SERVER *s);\r
+void SiFarmControlThread(THREAD *thread, void *param);\r
+void SiAccessListToPack(PACK *p, LIST *o);\r
+void SiAccessToPack(PACK *p, ACCESS *a, UINT i, UINT total);\r
+ACCESS *SiPackToAccess(PACK *p, UINT i);\r
+UINT SiNumAccessFromPack(PACK *p);\r
+void SiHubUpdateProc(HUB *h);\r
+bool SiCheckTicket(HUB *h, UCHAR *ticket, char *username, UINT username_size, char *usernamereal, UINT usernamereal_size, POLICY *policy, char *sessionname, UINT sessionname_size, char *groupname, UINT groupname_size);\r
+UINT SiGetPoint(SERVER *s);\r
+UINT SiCalcPoint(SERVER *s, UINT num, UINT weight);\r
+bool SiCallGetSessionStatus(SERVER *s, FARM_MEMBER *f, RPC_SESSION_STATUS *t);\r
+PACK *SiCalledGetSessionStatus(SERVER *s, PACK *p);\r
+bool SiCallEnumLogFileList(SERVER *s, FARM_MEMBER *f, RPC_ENUM_LOG_FILE *t, char *hubname);\r
+PACK *SiCalledEnumLogFileList(SERVER *s, PACK *p);\r
+bool SiCallReadLogFile(SERVER *s, FARM_MEMBER *f, RPC_READ_LOG_FILE *t);\r
+PACK *SiCalledReadLogFile(SERVER *s, PACK *p);\r
+int CmpLogFile(void *p1, void *p2);\r
+LIST *EnumLogFile(char *hubname);\r
+void EnumLogFileDir(LIST *o, char *dirname);\r
+void FreeEnumLogFile(LIST *o);\r
+bool CheckLogFileNameFromEnumList(LIST *o, char *name, char *server_name);\r
+void AdjoinEnumLogFile(LIST *o, LIST *src);\r
+void IncrementServerConfigRevision(SERVER *s);\r
+void GetServerProductName(SERVER *s, char *name, UINT size);\r
+void GetServerProductNameInternal(SERVER *s, char *name, UINT size);\r
+void SiGetServerLicenseStatus(SERVER *s, LICENSE_STATUS *st);\r
+void SiInitDeadLockCheck(SERVER *s);\r
+void SiFreeDeadLockCheck(SERVER *s);\r
+void SiDeadLockCheckThread(THREAD *t, void *param);\r
+void SiCheckDeadLockMain(SERVER *s, UINT timeout);\r
+void SiDebugLog(SERVER *s, char *msg);\r
+UINT SiDebug(SERVER *s, RPC_TEST *ret, UINT i, char *str);\r
+UINT SiDebugProcHelloWorld(SERVER *s, char *in_str, char *ret_str, UINT ret_str_size);\r
+UINT SiDebugProcExit(SERVER *s, char *in_str, char *ret_str, UINT ret_str_size);\r
+UINT SiDebugProcDump(SERVER *s, char *in_str, char *ret_str, UINT ret_str_size);\r
+UINT SiDebugProcRestorePriority(SERVER *s, char *in_str, char *ret_str, UINT ret_str_size);\r
+UINT SiDebugProcSetHighPriority(SERVER *s, char *in_str, char *ret_str, UINT ret_str_size);\r
+UINT SiDebugProcGetExeFileName(SERVER *s, char *in_str, char *ret_str, UINT ret_str_size);\r
+UINT SiDebugProcCrash(SERVER *s, char *in_str, char *ret_str, UINT ret_str_size);\r
+\r
+typedef UINT (SI_DEBUG_PROC)(SERVER *s, char *in_str, char *ret_str, UINT ret_str_size);\r
+\r
+CAPS *NewCaps(char *name, UINT value);\r
+void FreeCaps(CAPS *c);\r
+CAPSLIST *NewCapsList();\r
+int CompareCaps(void *p1, void *p2);\r
+void AddCaps(CAPSLIST *caps, CAPS *c);\r
+CAPS *GetCaps(CAPSLIST *caps, char *name);\r
+void FreeCapsList(CAPSLIST *caps);\r
+bool GetCapsBool(CAPSLIST *caps, char *name);\r
+UINT GetCapsInt(CAPSLIST *caps, char *name);\r
+void AddCapsBool(CAPSLIST *caps, char *name, bool b);\r
+void AddCapsInt(CAPSLIST *caps, char *name, UINT i);\r
+void InRpcCapsList(CAPSLIST *t, PACK *p);\r
+void OutRpcCapsList(PACK *p, CAPSLIST *t);\r
+void FreeRpcCapsList(CAPSLIST *t);\r
+void InitCapsList(CAPSLIST *t);\r
+void InRpcSysLogSetting(SYSLOG_SETTING *t, PACK *p);\r
+void OutRpcSysLogSetting(PACK *p, SYSLOG_SETTING *t);\r
+\r
+void GetServerCaps(SERVER *s, CAPSLIST *t);\r
+bool GetServerCapsBool(SERVER *s, char *name);\r
+UINT GetServerCapsInt(SERVER *s, char *name);\r
+void GetServerCapsMain(SERVER *s, CAPSLIST *t);\r
+void InitServerCapsCache(SERVER *s);\r
+void FreeServerCapsCache(SERVER *s);\r
+void DestroyServerCapsCache(SERVER *s);\r
+\r
+bool MakeServerSnapshot(SERVER *s, UINT64 now, SERVER_SNAPSHOT *t);\r
+void FreeSnapshot(SERVER_SNAPSHOT *t);\r
+void InitServerSnapshot(SERVER *s);\r
+void FreeServerSnapshot(SERVER *s);\r
+void ServerSnapshotThread(THREAD *t, void *param);\r
+void WriteServerSnapshotLog(SERVER *s, SERVER_SNAPSHOT *t);\r
+BUF *ServerSnapshotToBuf(SERVER_SNAPSHOT *t);\r
+bool IsAdminPackSupportedServerProduct(char *name);\r
+\r
+void SiInitHubCreateHistory(SERVER *s);\r
+void SiFreeHubCreateHistory(SERVER *s);\r
+void SiDeleteOldHubCreateHistory(SERVER *s);\r
+void SiAddHubCreateHistory(SERVER *s, char *name);\r
+void SiDelHubCreateHistory(SERVER *s, char *name);\r
+bool SiIsHubRegistedOnCreateHistory(SERVER *s, char *name);\r
+\r
+UINT SiGetServerNumUserObjects(SERVER *s);\r
+bool SiTooManyUserObjectsInServer(SERVER *s, bool oneMore);\r
+\r
+#endif // SERVER_H\r
+\r
+\r
+\r