source: lab.git/Dev/utvpn/utvpn-unix-v101-7101-public/src/Mayaqua/Cfg.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: 10.2 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// Cfg.h
79// Cfg.c のヘッダ
80
81#ifndef CFG_H
82#define CFG_H
83
84// マクロ
85//#define   CHECK_CFG_NAME_EXISTS           // 既存の名前との重複チェックを行う
86
87#define SAVE_BINARY_FILE_NAME_SWITCH    L"@save_binary"
88
89// 定数
90#define TAG_DECLARE         "declare"
91#define TAG_STRING          "string"
92#define TAG_INT             "uint"
93#define TAG_INT64           "uint64"
94#define TAG_BOOL            "bool"
95#define TAG_BYTE            "byte"
96#define TAG_TRUE            "true"
97#define TAG_FALSE           "false"
98#define TAG_END             "end"
99#define TAG_ROOT            "root"
100
101#define TAG_CPYRIGHT        "\xef\xbb\xbf# SoftEther UT-VPN Software Configuration File\r\n# \r\n# You can edit this file when the program is not working.\r\n# \r\n"
102#define TAG_BINARY          "SEVPN_DB"
103
104// データ型
105#define ITEM_TYPE_INT       1       // int
106#define ITEM_TYPE_INT64     2       // int64
107#define ITEM_TYPE_BYTE      3       // byte
108#define ITEM_TYPE_STRING    4       // string
109#define ITEM_TYPE_BOOL      5       // bool
110
111// フォルダ
112struct FOLDER
113{
114    char *Name;             // フォルダ名
115    LIST *Items;            // アイテムのリスト
116    LIST *Folders;          // サブフォルダ
117    struct FOLDER *Parent;  // 親フォルダ
118};
119
120// アイテム
121struct ITEM
122{
123    char *Name;             // アイテム名
124    UINT Type;              // データ型
125    void *Buf;              // データ
126    UINT size;              // データサイズ
127    FOLDER *Parent;         // 親フォルダ
128};
129
130// 設定ファイルリーダライタ
131struct CFG_RW
132{
133    LOCK *lock;             // ロック
134    char *FileName;         // ファイル名 (ANSI)
135    wchar_t *FileNameW;     // ファイル名 (Unicode)
136    IO *Io;                 // IO
137    UCHAR LashHash[SHA1_SIZE];  // 最後に書き込んだハッシュ値
138    bool DontBackup;        // バックアップを使用しない
139};
140
141typedef bool (*ENUM_FOLDER)(FOLDER *f, void *param);
142typedef bool (*ENUM_ITEM)(ITEM *t, void *param);
143
144// 列挙用のパラメータ
145struct CFG_ENUM_PARAM
146{
147    BUF *b;
148    FOLDER *f;
149    UINT depth;
150};
151
152int CmpItemName(void *p1, void *p2);
153int CmpFolderName(void *p1, void *p2);
154ITEM *CfgCreateItem(FOLDER *parent, char *name, UINT type, void *buf, UINT size);
155void CfgDeleteFolder(FOLDER *f);
156FOLDER *CfgCreateFolder(FOLDER *parent, char *name);
157void CfgEnumFolder(FOLDER *f, ENUM_FOLDER proc, void *param);
158TOKEN_LIST *CfgEnumFolderToTokenList(FOLDER *f);
159TOKEN_LIST *CfgEnumItemToTokenList(FOLDER *f);
160void CfgEnumItem(FOLDER *f, ENUM_ITEM proc, void *param);
161FOLDER *CfgFindFolder(FOLDER *parent, char *name);
162ITEM *CfgFindItem(FOLDER *parent, char *name);
163ITEM *CfgAddInt(FOLDER *f, char *name, UINT i);
164ITEM *CfgAddBool(FOLDER *f, char *name, bool b);
165ITEM *CfgAddInt64(FOLDER *f, char *name, UINT64 i);
166ITEM *CfgAddByte(FOLDER *f, char *name, void *buf, UINT size);
167ITEM *CfgAddBuf(FOLDER *f, char *name, BUF *b);
168ITEM *CfgAddStr(FOLDER *f, char *name, char *str);
169ITEM *CfgAddUniStr(FOLDER *f, char *name, wchar_t *str);
170FOLDER *CfgGetFolder(FOLDER *parent, char *name);
171UINT CfgGetInt(FOLDER *f, char *name);
172bool CfgGetBool(FOLDER *f, char *name);
173UINT64 CfgGetInt64(FOLDER *f, char *name);
174UINT CfgGetByte(FOLDER *f, char *name, void *buf, UINT size);
175BUF *CfgGetBuf(FOLDER *f, char *name);
176bool CfgGetStr(FOLDER *f, char *name, char *str, UINT size);
177bool CfgGetUniStr(FOLDER *f, char *name, wchar_t *str, UINT size);
178bool CfgIsItem(FOLDER *f, char *name);
179bool CfgIsFolder(FOLDER *f, char *name);
180void CfgTest();
181void CfgTest2(FOLDER *f, UINT n);
182char *CfgEscape(char *name);
183bool CfgCheckCharForName(char c);
184char *CfgUnescape(char *str);
185BUF *CfgFolderToBuf(FOLDER *f, bool textmode);
186BUF *CfgFolderToBufEx(FOLDER *f, bool textmode, bool no_banner);
187BUF *CfgFolderToBufText(FOLDER *f);
188BUF *CfgFolderToBufTextEx(FOLDER *f, bool no_banner);
189BUF *CfgFolderToBufBin(FOLDER *f);
190void CfgOutputFolderText(BUF *b, FOLDER *f, UINT depth);
191void CfgOutputFolderBin(BUF *b, FOLDER *f);
192void CfgAddLine(BUF *b, char *str, UINT depth);
193void CfgAddDeclare(BUF *b, char *name, UINT depth);
194void CfgAddEnd(BUF *b, UINT depth);
195void CfgAddData(BUF *b, UINT type, char *name, char *data, char *sub, UINT depth);
196UINT CfgStrToType(char *str);
197char *CfgTypeToStr(UINT type);
198void CfgAddItemText(BUF *b, ITEM *t, UINT depth);
199bool CfgEnumFolderProc(FOLDER *f, void *param);
200bool CfgEnumItemProc(ITEM *t, void *param);
201FOLDER *CfgBufTextToFolder(BUF *b);
202FOLDER *CfgBufBinToFolder(BUF *b);
203void CfgReadNextFolderBin(BUF *b, FOLDER *parent);
204char *CfgReadNextLine(BUF *b);
205bool CfgReadNextTextBuf(BUF *b, FOLDER *current);
206void CfgSave(FOLDER *f, char *name);
207void CfgSaveW(FOLDER *f, wchar_t *name);
208bool CfgSaveEx(CFG_RW *rw, FOLDER *f, char *name);
209bool CfgSaveExW(CFG_RW *rw, FOLDER *f, wchar_t *name);
210bool CfgSaveExW2(CFG_RW *rw, FOLDER *f, wchar_t *name, UINT *written_size);
211FOLDER *CfgRead(char *name);
212FOLDER *CfgReadW(wchar_t *name);
213FOLDER *CfgCreateRoot();
214void CfgTest();
215void CfgTest2(FOLDER *f, UINT n);
216CFG_RW *NewCfgRw(FOLDER **root, char *cfg_name);
217CFG_RW *NewCfgRwW(FOLDER **root, wchar_t *cfg_name);
218CFG_RW *NewCfgRwEx(FOLDER **root, char *cfg_name, bool dont_backup);
219CFG_RW *NewCfgRwExW(FOLDER **root, wchar_t *cfg_name, bool dont_backup);
220UINT SaveCfgRw(CFG_RW *rw, FOLDER *f);
221void FreeCfgRw(CFG_RW *rw);
222ITEM *CfgAddIp32(FOLDER *f, char *name, UINT ip);
223UINT CfgGetIp32(FOLDER *f, char *name);
224bool CfgGetIp6Addr(FOLDER *f, char *name, IPV6_ADDR *addr);
225ITEM *CfgAddIp6Addr(FOLDER *f, char *name, IPV6_ADDR *addr);
226bool FileCopy(char *src, char *dst);
227bool FileCopyW(wchar_t *src, wchar_t *dst);
228void BackupCfg(FOLDER *f, char *original);
229void BackupCfgW(FOLDER *f, wchar_t *original);
230
231#if (!defined(CFG_C)) || (!defined(OS_UNIX))
232bool CfgGetIp(FOLDER *f, char *name, struct IP *ip);
233ITEM *CfgAddIp(FOLDER *f, char *name, struct IP *ip);
234#endif
235
236#endif  // CFG_H
237
238
239
Note: See TracBrowser for help on using the repository browser.