1 /*=============================================================================
\r
2 *
\83\8c\83W
\83X
\83g
\83\8a\8aÖ
\8cW
\r
5 ===============================================================================
\r
6 / Copyright (C) 1997-2007 Sota. All rights reserved.
\r
8 / Redistribution and use in source and binary forms, with or without
\r
9 / modification, are permitted provided that the following conditions
\r
12 / 1. Redistributions of source code must retain the above copyright
\r
13 / notice, this list of conditions and the following disclaimer.
\r
14 / 2. Redistributions in binary form must reproduce the above copyright
\r
15 / notice, this list of conditions and the following disclaimer in the
\r
16 / documentation and/or other materials provided with the distribution.
\r
18 / THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
\r
19 / IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
\r
20 / OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
\r
21 / IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
\r
22 / INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
\r
23 / BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
\r
24 / USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
\r
25 / ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
\r
26 / (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
\r
27 / THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
\r
28 /============================================================================*/
\r
30 // VC 8.0(2005)
\88È
\8fã
\82Å
\82Ì
\82Ý rand_s
\82ð
\97\98\97p
\89Â
\94\
\r
31 #if 1400 <= _MSC_VER
\r
32 //#define _CRT_RAND_S
\r
36 #include <windows.h>
\r
41 #include <windowsx.h>
\r
42 #include <process.h>
\r
46 #include "resource.h"
\r
52 /*=====
\83v
\83\8d\83g
\83^
\83C
\83v =====*/
\r
54 static void SaveStr(HKEY hKey, char *Key, char *Str, char *DefaultStr);
\r
55 static void SaveIntNum(HKEY hKey, char *Key, int Num, int DefaultNum);
\r
56 static void MakeFontData(LOGFONT Font, HFONT hFont, char *Buf);
\r
57 static int RestoreFontData(char *Str, LOGFONT *Font);
\r
59 static void EncodePassword(char *Str, char *Buf);
\r
60 static void EncodePasswordOriginal(char *Str, char *Buf);
\r
61 static void EncodePassword2(char *Str, char *Buf, const char *Key);
\r
62 static void EncodePassword3(char *Str, char *Buf, const char *Key);
\r
64 static void DecodePassword(char *Str, char *Buf);
\r
65 static void DecodePasswordOriginal(char *Str, char *Buf);
\r
66 static void DecodePassword2(char *Str, char *Buf, const char *Key);
\r
67 static void DecodePassword3(char *Str, char *Buf, const char *Key);
\r
68 static int CreateAesKey(unsigned char *AesKey, const char* Key);
\r
70 static void SetRegType(int Type);
\r
71 static int OpenReg(char *Name, void **Handle);
\r
72 static int CreateReg(char *Name, void **Handle);
\r
73 static int CloseReg(void *Handle);
\r
74 static int OpenSubKey(void *Parent, char *Name, void **Handle);
\r
75 static int CreateSubKey(void *Parent, char *Name, void **Handle);
\r
76 static int CloseSubKey(void *Handle);
\r
77 static int DeleteSubKey(void *Handle, char *Name);
\r
78 static int DeleteValue(void *Handle, char *Name);
\r
79 static int ReadIntValueFromReg(void *Handle, char *Name, int *Value);
\r
80 static int WriteIntValueToReg(void *Handle, char *Name, int Value);
\r
81 static int ReadStringFromReg(void *Handle, char *Name, char *Str, DWORD Size);
\r
82 static int WriteStringToReg(void *Handle, char *Name, char *Str);
\r
83 static int ReadMultiStringFromReg(void *Handle, char *Name, char *Str, DWORD Size);
\r
84 static int WriteMultiStringToReg(void *Handle, char *Name, char *Str);
\r
85 static int ReadBinaryFromReg(void *Handle, char *Name, void *Bin, DWORD Size);
\r
86 static int WriteBinaryToReg(void *Handle, char *Name, void *Bin, int Len);
\r
88 int CheckPasswordValidity( char* Password, int length, const char* HashStr );
\r
89 void CreatePasswordHash( char* Password, int length, char* HashStr );
\r
90 void SetHashSalt( DWORD salt );
\r
92 DWORD GetRandamDWRODValue(void);
\r
94 /* 2010.01.30 genta
\92Ç
\89Á */
\r
95 static char SecretKey[FMAX_PATH+1];
\r
96 static int SecretKeyLength;
\r
97 static int IsMasterPasswordError = PASSWORD_OK;
\r
99 static int IsRndSourceInit = 0;
\r
100 static ulong RndSource[9];
\r
102 /*=====
\8aO
\95\94\8eQ
\8fÆ =====*/
\r
105 extern int WinPosX;
\r
106 extern int WinPosY;
\r
107 extern int WinWidth;
\r
108 extern int WinHeight;
\r
109 extern int LocalWidth;
\r
110 extern int TaskHeight;
\r
111 extern int LocalTabWidth[4];
\r
112 extern int RemoteTabWidth[6];
\r
113 extern char UserMailAdrs[USER_MAIL_LEN+1];
\r
114 extern char ViewerName[VIEWERS][FMAX_PATH+1];
\r
115 extern HFONT ListFont;
\r
116 extern LOGFONT ListLogFont;
\r
117 extern int LocalFileSort;
\r
118 extern int LocalDirSort;
\r
119 extern int RemoteFileSort;
\r
120 extern int RemoteDirSort;
\r
121 extern int TransMode;
\r
122 extern int ConnectOnStart;
\r
123 extern int DebugConsole;
\r
124 extern int SaveWinPos;
\r
125 extern char AsciiExt[ASCII_EXT_LEN+1];
\r
126 extern int RecvMode;
\r
127 extern int SendMode;
\r
128 extern int MoveMode;
\r
129 extern int ListType;
\r
130 extern int CacheEntry;
\r
131 extern int CacheSave;
\r
132 extern char DefaultLocalPath[FMAX_PATH+1];
\r
133 extern int SaveTimeStamp;
\r
134 extern int FindMode;
\r
135 extern int DotFile;
\r
136 extern int DclickOpen;
\r
137 extern SOUNDFILE Sound[SOUND_TYPES];
\r
138 extern int FnameCnv;
\r
139 extern int ConnectAndSet;
\r
140 extern int TimeOut;
\r
142 extern int RegType;
\r
143 extern char FwallHost[HOST_ADRS_LEN+1];
\r
144 extern char FwallUser[USER_NAME_LEN+1];
\r
145 extern char FwallPass[PASSWORD_LEN+1];
\r
146 extern int FwallPort;
\r
147 extern int FwallType;
\r
148 extern int FwallDefault;
\r
149 extern int FwallSecurity;
\r
150 extern int FwallResolv;
\r
151 extern int FwallLower;
\r
152 extern int FwallDelimiter;
\r
153 extern int PasvDefault;
\r
154 extern char MirrorNoTrn[MIRROR_LEN+1];
\r
155 extern char MirrorNoDel[MIRROR_LEN+1];
\r
156 extern int MirrorFnameCnv;
\r
157 //extern int MirrorFolderCnv;
\r
158 extern int RasClose;
\r
159 extern int RasCloseNotify;
\r
160 extern int FileHist;
\r
161 extern char DefAttrList[DEFATTRLIST_LEN+1];
\r
162 extern SIZE HostDlgSize;
\r
163 extern SIZE BmarkDlgSize;
\r
164 extern SIZE MirrorDlgSize;
\r
166 extern int SortSave;
\r
167 extern char TmpPath[FMAX_PATH+1];
\r
168 extern int QuickAnonymous;
\r
169 extern int PassToHist;
\r
170 extern int VaxSemicolon;
\r
171 extern int SendQuit;
\r
172 extern int NoRasControl;
\r
173 extern int SuppressSave;
\r
175 extern int UpExistMode;
\r
176 extern int ExistMode;
\r
177 extern int DispIgnoreHide;
\r
178 extern int DispDrives;
\r
179 extern int MirUpDelNotify;
\r
180 extern int MirDownDelNotify;
\r
182 extern int FolderAttr;
\r
183 extern int FolderAttrNum;
\r
185 /*-----
\83}
\83X
\83^
\83p
\83X
\83\8f\81[
\83h
\82Ì
\90Ý
\92è ----------------------------------------------
\r
188 * const char* Password :
\83}
\83X
\83^
\81[
\83p
\83X
\83\8f\81[
\83h
\r
192 *----------------------------------------------------------------------------*/
\r
193 void SetMasterPassword( const char* Password )
\r
195 ZeroMemory( SecretKey, MAX_PASSWORD_LEN + 12 );
\r
196 if( Password != NULL ){
\r
197 strncpy( SecretKey, Password, MAX_PASSWORD_LEN );
\r
200 strcpy( SecretKey, DEFAULT_PASSWORD );
\r
202 SecretKeyLength = strlen( SecretKey );
\r
204 /*
\96¢
\8c\9f\8fØ
\82È
\82Ì
\82Å
\81C
\8f\89\8aú
\8fó
\91Ô
\82ÍOK
\82É
\82·
\82é (
\8b
\90§
\8dÄ
\90Ý
\92è
\81¨
\95Û
\91¶
\82É
\82ð
\89Â
\94\
\82É
\82·
\82é)*/
\r
205 IsMasterPasswordError = PASSWORD_OK;
\r
208 /*-----
\83}
\83X
\83^
\83p
\83X
\83\8f\81[
\83h
\82Ì
\8fó
\91Ô
\8eæ
\93¾ ----------------------------------------------
\r
215 * PASSWORD_UNMATCH :
\83p
\83X
\83\8f\81[
\83h
\95s
\88ê
\92v
\r
216 * BAD_PASSWORD_HASH :
\83p
\83X
\83\8f\81[
\83h
\8am
\94F
\8e¸
\94s
\r
217 *----------------------------------------------------------------------------*/
\r
218 int GetMasterPasswordStatus(void)
\r
220 return IsMasterPasswordError;
\r
223 /*-----
\83\8c\83W
\83X
\83g
\83\8a\81^INI
\83t
\83@
\83C
\83\8b\82Ì
\83}
\83X
\83^
\81[
\83p
\83X
\83\8f\81[
\83h
\82Ì
\8c\9f\8fØ
\82ð
\8ds
\82¤ ------------
\r
230 *----------------------------------------------------------------------------*/
\r
232 int ValidateMasterPassword(void)
\r
237 SetRegType(REGTYPE_INI);
\r
238 if((i = OpenReg("FFFTP", &hKey3)) != SUCCESS)
\r
240 if(AskForceIni() == NO)
\r
242 SetRegType(REGTYPE_REG);
\r
243 i = OpenReg("FFFTP", &hKey3);
\r
250 if( ReadIntValueFromReg(hKey3, "CredentialSalt", &salt)){
\r
251 SetHashSalt( salt );
\r
253 if( ReadStringFromReg(hKey3, "CredentialCheck", checkbuf, sizeof( checkbuf )) == SUCCESS ){
\r
254 switch( CheckPasswordValidity( SecretKey, SecretKeyLength, checkbuf ) ){
\r
255 case 0: /* not match */
\r
256 IsMasterPasswordError = PASSWORD_UNMATCH;
\r
258 case 1: /* match */
\r
259 IsMasterPasswordError = PASSWORD_OK;
\r
261 case 2: /* invalid hash */
\r
263 IsMasterPasswordError = BAD_PASSWORD_HASH;
\r
273 /*-----
\83\8c\83W
\83X
\83g
\83\8a\81^INI
\83t
\83@
\83C
\83\8b\82É
\90Ý
\92è
\92l
\82ð
\95Û
\91¶ ---------------------------------
\r
280 *----------------------------------------------------------------------------*/
\r
282 void SaveRegistory(void)
\r
287 char Str[FMAX_PATH+1];
\r
290 HOSTDATA DefaultHost;
\r
293 HISTORYDATA DefaultHist;
\r
295 if( GetMasterPasswordStatus() == PASSWORD_UNMATCH ){
\r
296 /* 2010.01.30 genta:
\83}
\83X
\83^
\81[
\83p
\83X
\83\8f\81[
\83h
\82ª
\95s
\88ê
\92v
\82Ì
\8fê
\8d\87\82Í
\95s
\97p
\88Ó
\82É
\8fã
\8f\91\82«
\82µ
\82È
\82¢ */
\r
300 SetRegType(RegType);
\r
301 if(CreateReg("FFFTP", &hKey3) == SUCCESS)
\r
304 int salt = GetTickCount();
\r
306 WriteIntValueToReg(hKey3, "Version", VER_NUM);
\r
307 WriteIntValueToReg(hKey3, "CredentialSalt", salt);
\r
309 SetHashSalt( salt );
\r
310 /* save password hash */
\r
311 CreatePasswordHash( SecretKey, SecretKeyLength, buf );
\r
312 WriteStringToReg(hKey3, "CredentialCheck", buf);
\r
314 if(CreateSubKey(hKey3, "Options", &hKey4) == SUCCESS)
\r
316 WriteIntValueToReg(hKey4, "NoSave", SuppressSave);
\r
318 if(SuppressSave != YES)
\r
320 WriteIntValueToReg(hKey4, "WinPosX", WinPosX);
\r
321 WriteIntValueToReg(hKey4, "WinPosY", WinPosY);
\r
322 WriteIntValueToReg(hKey4, "WinWidth", WinWidth);
\r
323 WriteIntValueToReg(hKey4, "WinHeight", WinHeight);
\r
324 WriteIntValueToReg(hKey4, "LocalWidth", LocalWidth);
\r
325 WriteIntValueToReg(hKey4, "TaskHeight", TaskHeight);
\r
326 WriteBinaryToReg(hKey4, "LocalColm", LocalTabWidth, sizeof(LocalTabWidth));
\r
327 WriteBinaryToReg(hKey4, "RemoteColm", RemoteTabWidth, sizeof(RemoteTabWidth));
\r
328 WriteIntValueToReg(hKey4, "SwCmd", Sizing);
\r
330 WriteStringToReg(hKey4, "UserMail", UserMailAdrs);
\r
331 WriteStringToReg(hKey4, "Viewer", ViewerName[0]);
\r
332 WriteStringToReg(hKey4, "Viewer2", ViewerName[1]);
\r
333 WriteStringToReg(hKey4, "Viewer3", ViewerName[2]);
\r
335 WriteIntValueToReg(hKey4, "TrType", TransMode);
\r
336 WriteIntValueToReg(hKey4, "Recv", RecvMode);
\r
337 WriteIntValueToReg(hKey4, "Send", SendMode);
\r
338 WriteIntValueToReg(hKey4, "Move", MoveMode);
\r
339 WriteStringToReg(hKey4, "Path", DefaultLocalPath);
\r
340 WriteIntValueToReg(hKey4, "Time", SaveTimeStamp);
\r
341 WriteIntValueToReg(hKey4, "EOF", RmEOF);
\r
342 WriteIntValueToReg(hKey4, "Scolon", VaxSemicolon);
\r
344 WriteIntValueToReg(hKey4, "RecvEx", ExistMode);
\r
345 WriteIntValueToReg(hKey4, "SendEx", UpExistMode);
\r
347 WriteIntValueToReg(hKey4, "LFsort", LocalFileSort);
\r
348 WriteIntValueToReg(hKey4, "LDsort", LocalDirSort);
\r
349 WriteIntValueToReg(hKey4, "RFsort", RemoteFileSort);
\r
350 WriteIntValueToReg(hKey4, "RDsort", RemoteDirSort);
\r
351 WriteIntValueToReg(hKey4, "SortSave", SortSave);
\r
353 WriteIntValueToReg(hKey4, "ListType", ListType);
\r
354 WriteIntValueToReg(hKey4, "Cache", CacheEntry);
\r
355 WriteIntValueToReg(hKey4, "CacheSave", CacheSave);
\r
356 WriteIntValueToReg(hKey4, "DotFile", DotFile);
\r
357 WriteIntValueToReg(hKey4, "Dclick", DclickOpen);
\r
359 WriteIntValueToReg(hKey4, "ConS", ConnectOnStart);
\r
360 WriteIntValueToReg(hKey4, "OldDlg", ConnectAndSet);
\r
361 WriteIntValueToReg(hKey4, "RasClose", RasClose);
\r
362 WriteIntValueToReg(hKey4, "RasNotify", RasCloseNotify);
\r
363 WriteIntValueToReg(hKey4, "Qanony", QuickAnonymous);
\r
364 WriteIntValueToReg(hKey4, "PassHist", PassToHist);
\r
365 WriteIntValueToReg(hKey4, "SendQuit", SendQuit);
\r
366 WriteIntValueToReg(hKey4, "NoRas", NoRasControl);
\r
368 WriteIntValueToReg(hKey4, "Debug", DebugConsole);
\r
369 WriteIntValueToReg(hKey4, "WinPos", SaveWinPos);
\r
370 WriteIntValueToReg(hKey4, "RegExp", FindMode);
\r
371 WriteIntValueToReg(hKey4, "Reg", RegType);
\r
373 WriteMultiStringToReg(hKey4, "AsciiFile", AsciiExt);
\r
374 WriteIntValueToReg(hKey4, "LowUp", FnameCnv);
\r
375 WriteIntValueToReg(hKey4, "Tout", TimeOut);
\r
377 WriteMultiStringToReg(hKey4, "NoTrn", MirrorNoTrn);
\r
378 WriteMultiStringToReg(hKey4, "NoDel", MirrorNoDel);
\r
379 WriteIntValueToReg(hKey4, "MirFile", MirrorFnameCnv);
\r
380 WriteIntValueToReg(hKey4, "MirUNot", MirUpDelNotify);
\r
381 WriteIntValueToReg(hKey4, "MirDNot", MirDownDelNotify);
\r
383 MakeFontData(ListLogFont, ListFont, Str);
\r
384 WriteStringToReg(hKey4, "ListFont", Str);
\r
385 WriteIntValueToReg(hKey4, "ListHide", DispIgnoreHide);
\r
386 WriteIntValueToReg(hKey4, "ListDrv", DispDrives);
\r
388 WriteStringToReg(hKey4, "FwallHost", FwallHost);
\r
389 WriteStringToReg(hKey4, "FwallUser", FwallUser);
\r
390 EncodePassword(FwallPass, Str);
\r
391 WriteStringToReg(hKey4, "FwallPass", Str);
\r
392 WriteIntValueToReg(hKey4, "FwallPort", FwallPort);
\r
393 WriteIntValueToReg(hKey4, "FwallType", FwallType);
\r
394 WriteIntValueToReg(hKey4, "FwallDef", FwallDefault);
\r
395 WriteIntValueToReg(hKey4, "FwallSec", FwallSecurity);
\r
396 WriteIntValueToReg(hKey4, "PasvDef", PasvDefault);
\r
397 WriteIntValueToReg(hKey4, "FwallRes", FwallResolv);
\r
398 WriteIntValueToReg(hKey4, "FwallLow", FwallLower);
\r
399 WriteIntValueToReg(hKey4, "FwallDel", FwallDelimiter);
\r
401 WriteIntValueToReg(hKey4, "SndConSw", Sound[SND_CONNECT].On);
\r
402 WriteIntValueToReg(hKey4, "SndTrnSw", Sound[SND_TRANS].On);
\r
403 WriteIntValueToReg(hKey4, "SndErrSw", Sound[SND_ERROR].On);
\r
404 WriteStringToReg(hKey4, "SndCon", Sound[SND_CONNECT].Fname);
\r
405 WriteStringToReg(hKey4, "SndTrn", Sound[SND_TRANS].Fname);
\r
406 WriteStringToReg(hKey4, "SndErr", Sound[SND_ERROR].Fname);
\r
408 WriteMultiStringToReg(hKey4, "DefAttr", DefAttrList);
\r
410 GetTempPath(FMAX_PATH, Str);
\r
411 SaveStr(hKey4, "Tmp", TmpPath, Str);
\r
413 WriteBinaryToReg(hKey4, "Hdlg", &HostDlgSize, sizeof(SIZE));
\r
414 WriteBinaryToReg(hKey4, "Bdlg", &BmarkDlgSize, sizeof(SIZE));
\r
415 WriteBinaryToReg(hKey4, "Mdlg", &MirrorDlgSize, sizeof(SIZE));
\r
417 WriteIntValueToReg(hKey4, "FAttrSw", FolderAttr);
\r
418 WriteIntValueToReg(hKey4, "FAttr", FolderAttrNum);
\r
420 WriteIntValueToReg(hKey4, "HistNum", FileHist);
\r
422 /* Ver1.54a
\88È
\91O
\82Ì
\8c`
\8e®
\82Ì
\83q
\83X
\83g
\83\8a\83f
\81[
\83^
\82Í
\8dí
\8f\9c */
\r
423 DeleteValue(hKey4, "Hist");
\r
425 /*
\83q
\83X
\83g
\83\8a\82Ì
\90Ý
\92è
\82ð
\95Û
\91¶ */
\r
426 CopyDefaultHistory(&DefaultHist);
\r
428 for(i = AskHistoryNum(); i > 0; i--)
\r
430 if(GetHistoryByNum(i-1, &Hist) == SUCCESS)
\r
432 sprintf(Str, "History%d", n);
\r
433 if(CreateSubKey(hKey4, Str, &hKey5) == SUCCESS)
\r
435 SaveStr(hKey5, "HostAdrs", Hist.HostAdrs, DefaultHist.HostAdrs);
\r
436 SaveStr(hKey5, "UserName", Hist.UserName, DefaultHist.UserName);
\r
437 SaveStr(hKey5, "Account", Hist.Account, DefaultHist.Account);
\r
438 SaveStr(hKey5, "LocalDir", Hist.LocalInitDir, NULL);
\r
439 SaveStr(hKey5, "RemoteDir", Hist.RemoteInitDir, DefaultHist.RemoteInitDir);
\r
440 SaveStr(hKey5, "Chmod", Hist.ChmodCmd, DefaultHist.ChmodCmd);
\r
441 SaveStr(hKey5, "Nlst", Hist.LsName, DefaultHist.LsName);
\r
442 SaveStr(hKey5, "Init", Hist.InitCmd, DefaultHist.InitCmd);
\r
443 EncodePassword(Hist.PassWord, Str);
\r
444 SaveStr(hKey5, "Password", Str, DefaultHist.PassWord);
\r
445 SaveIntNum(hKey5, "Port", Hist.Port, DefaultHist.Port);
\r
446 SaveIntNum(hKey5, "Kanji", Hist.KanjiCode, DefaultHist.KanjiCode);
\r
447 SaveIntNum(hKey5, "KanaCnv", Hist.KanaCnv, DefaultHist.KanaCnv);
\r
448 SaveIntNum(hKey5, "NameKanji", Hist.NameKanjiCode, DefaultHist.NameKanjiCode);
\r
449 SaveIntNum(hKey5, "NameKana", Hist.NameKanaCnv, DefaultHist.NameKanaCnv);
\r
450 SaveIntNum(hKey5, "Pasv", Hist.Pasv, DefaultHist.Pasv);
\r
451 SaveIntNum(hKey5, "Fwall", Hist.FireWall, DefaultHist.FireWall);
\r
452 SaveIntNum(hKey5, "List", Hist.ListCmdOnly, DefaultHist.ListCmdOnly);
\r
453 SaveIntNum(hKey5, "NLST-R", Hist.UseNLST_R, DefaultHist.UseNLST_R);
\r
454 SaveIntNum(hKey5, "Tzone", Hist.TimeZone, DefaultHist.TimeZone);
\r
455 SaveIntNum(hKey5, "Type", Hist.HostType, DefaultHist.HostType);
\r
456 SaveIntNum(hKey5, "Sync", Hist.SyncMove, DefaultHist.SyncMove);
\r
457 SaveIntNum(hKey5, "Fpath", Hist.NoFullPath, DefaultHist.NoFullPath);
\r
458 WriteBinaryToReg(hKey5, "Sort", &Hist.Sort, sizeof(Hist.Sort));
\r
459 SaveIntNum(hKey5, "Secu", Hist.Security, DefaultHist.Security);
\r
460 WriteIntValueToReg(hKey5, "TrType", Hist.Type);
\r
461 SaveIntNum(hKey5, "Dial", Hist.Dialup, DefaultHist.Dialup);
\r
462 SaveIntNum(hKey5, "UseIt", Hist.DialupAlways, DefaultHist.DialupAlways);
\r
463 SaveIntNum(hKey5, "Notify", Hist.DialupNotify, DefaultHist.DialupNotify);
\r
464 SaveStr(hKey5, "DialTo", Hist.DialEntry, DefaultHist.DialEntry);
\r
466 CloseSubKey(hKey5);
\r
471 WriteIntValueToReg(hKey4, "SavedHist", n);
\r
473 /*
\97]
\95ª
\82È
\83q
\83X
\83g
\83\8a\82ª
\82 \82Á
\82½
\82ç
\8dí
\8f\9c */
\r
474 for(; n < 999; n++)
\r
476 sprintf(Str, "History%d", n);
\r
477 if(DeleteSubKey(hKey4, Str) != SUCCESS)
\r
481 /*
\83z
\83X
\83g
\82Ì
\90Ý
\92è
\82ð
\95Û
\91¶ */
\r
482 CopyDefaultHost(&DefaultHost);
\r
484 while(CopyHostFromList(i, &Host) == SUCCESS)
\r
486 sprintf(Str, "Host%d", i);
\r
487 if(CreateSubKey(hKey4, Str, &hKey5) == SUCCESS)
\r
489 // SaveIntNum(hKey5, "Set", Host.Level, DefaultHost.Level);
\r
490 WriteIntValueToReg(hKey5, "Set", Host.Level);
\r
491 SaveStr(hKey5, "HostName", Host.HostName, DefaultHost.HostName);
\r
492 if((Host.Level & SET_LEVEL_GROUP) == 0)
\r
494 SaveStr(hKey5, "HostAdrs", Host.HostAdrs, DefaultHost.HostAdrs);
\r
495 SaveStr(hKey5, "UserName", Host.UserName, DefaultHost.UserName);
\r
496 SaveStr(hKey5, "Account", Host.Account, DefaultHost.Account);
\r
497 SaveStr(hKey5, "LocalDir", Host.LocalInitDir, NULL);
\r
498 SaveStr(hKey5, "RemoteDir", Host.RemoteInitDir, DefaultHost.RemoteInitDir);
\r
499 SaveStr(hKey5, "Chmod", Host.ChmodCmd, DefaultHost.ChmodCmd);
\r
500 SaveStr(hKey5, "Nlst", Host.LsName, DefaultHost.LsName);
\r
501 SaveStr(hKey5, "Init", Host.InitCmd, DefaultHost.InitCmd);
\r
503 if(Host.Anonymous == NO)
\r
504 EncodePassword(Host.PassWord, Str);
\r
506 strcpy(Str, DefaultHost.PassWord);
\r
507 SaveStr(hKey5, "Password", Str, DefaultHost.PassWord);
\r
509 SaveIntNum(hKey5, "Port", Host.Port, DefaultHost.Port);
\r
510 SaveIntNum(hKey5, "Anonymous", Host.Anonymous, DefaultHost.Anonymous);
\r
511 SaveIntNum(hKey5, "Kanji", Host.KanjiCode, DefaultHost.KanjiCode);
\r
512 SaveIntNum(hKey5, "KanaCnv", Host.KanaCnv, DefaultHost.KanaCnv);
\r
513 SaveIntNum(hKey5, "NameKanji", Host.NameKanjiCode, DefaultHost.NameKanjiCode);
\r
514 SaveIntNum(hKey5, "NameKana", Host.NameKanaCnv, DefaultHost.NameKanaCnv);
\r
515 SaveIntNum(hKey5, "Pasv", Host.Pasv, DefaultHost.Pasv);
\r
516 SaveIntNum(hKey5, "Fwall", Host.FireWall, DefaultHost.FireWall);
\r
517 SaveIntNum(hKey5, "List", Host.ListCmdOnly, DefaultHost.ListCmdOnly);
\r
518 SaveIntNum(hKey5, "NLST-R", Host.UseNLST_R, DefaultHost.UseNLST_R);
\r
519 SaveIntNum(hKey5, "Last", Host.LastDir, DefaultHost.LastDir);
\r
520 SaveIntNum(hKey5, "Tzone", Host.TimeZone, DefaultHost.TimeZone);
\r
521 SaveIntNum(hKey5, "Type", Host.HostType, DefaultHost.HostType);
\r
522 SaveIntNum(hKey5, "Sync", Host.SyncMove, DefaultHost.SyncMove);
\r
523 SaveIntNum(hKey5, "Fpath", Host.NoFullPath, DefaultHost.NoFullPath);
\r
524 WriteBinaryToReg(hKey5, "Sort", &Host.Sort, sizeof(Host.Sort));
\r
525 SaveIntNum(hKey5, "Secu", Host.Security, DefaultHost.Security);
\r
527 WriteMultiStringToReg(hKey5, "Bmarks", Host.BookMark);
\r
529 SaveIntNum(hKey5, "Dial", Host.Dialup, DefaultHost.Dialup);
\r
530 SaveIntNum(hKey5, "UseIt", Host.DialupAlways, DefaultHost.DialupAlways);
\r
531 SaveIntNum(hKey5, "Notify", Host.DialupNotify, DefaultHost.DialupNotify);
\r
532 SaveStr(hKey5, "DialTo", Host.DialEntry, DefaultHost.DialEntry);
\r
534 CloseSubKey(hKey5);
\r
538 WriteIntValueToReg(hKey4, "SetNum", i);
\r
540 /*
\97]
\95ª
\82È
\83z
\83X
\83g
\82Ì
\90Ý
\92è
\82ª
\82 \82Á
\82½
\82ç
\8dí
\8f\9c */
\r
541 for(; i < 998; i++)
\r
543 sprintf(Str, "Host%d", i);
\r
544 if(DeleteSubKey(hKey4, Str) != SUCCESS)
\r
548 if((i = AskCurrentHost()) == HOSTNUM_NOENTRY)
\r
550 WriteIntValueToReg(hKey4, "CurSet", i);
\r
552 CloseSubKey(hKey4);
\r
559 /*-----
\83\8c\83W
\83X
\83g
\83\8a\81^INI
\83t
\83@
\83C
\83\8b\82©
\82ç
\90Ý
\92è
\92l
\82ð
\8cÄ
\82Ñ
\8fo
\82· ---------------------------
\r
561 *
\82±
\82Ì
\8aÖ
\90\94\82ð
\95¡
\90\94\89ñ
\8cÄ
\82Ñ
\8fo
\82·
\82Æ
\81C
\83z
\83X
\83g
\90Ý
\92è
\82ª
\92Ç
\89Á
\82³
\82ê
\82é
\81D
\r
567 * YES:
\93Ç
\82Ý
\8fo
\82µ
\90¬
\8c÷
\r
568 * NO:
\93Ç
\82Ý
\8fo
\82µ
\8e¸
\94s(
\90Ý
\92è
\96³
\82µ)
\r
569 *----------------------------------------------------------------------------*/
\r
571 int LoadRegistory(void)
\r
578 char Str[256]; /* ASCII_EXT_LEN
\82æ
\82è
\91å
\82«
\82¢
\8e\96 */
\r
588 SetRegType(REGTYPE_INI);
\r
589 if((i = OpenReg("FFFTP", &hKey3)) != SUCCESS)
\r
591 if(AskForceIni() == NO)
\r
593 SetRegType(REGTYPE_REG);
\r
594 i = OpenReg("FFFTP", &hKey3);
\r
604 ReadIntValueFromReg(hKey3, "Version", &Version);
\r
606 if(OpenSubKey(hKey3, "Options", &hKey4) == SUCCESS)
\r
608 ReadIntValueFromReg(hKey4, "WinPosX", &WinPosX);
\r
609 ReadIntValueFromReg(hKey4, "WinPosY", &WinPosY);
\r
610 ReadIntValueFromReg(hKey4, "WinWidth", &WinWidth);
\r
611 ReadIntValueFromReg(hKey4, "WinHeight", &WinHeight);
\r
612 ReadIntValueFromReg(hKey4, "LocalWidth", &LocalWidth);
\r
613 /*
\81«
\8b\8c\83o
\81[
\83W
\83\87\83\93\82Ì
\83o
\83O
\91Î
\8dô */
\r
614 LocalWidth = max1(0, LocalWidth);
\r
615 ReadIntValueFromReg(hKey4, "TaskHeight", &TaskHeight);
\r
616 /*
\81«
\8b\8c\83o
\81[
\83W
\83\87\83\93\82Ì
\83o
\83O
\91Î
\8dô */
\r
617 TaskHeight = max1(0, TaskHeight);
\r
618 ReadBinaryFromReg(hKey4, "LocalColm", &LocalTabWidth, sizeof(LocalTabWidth));
\r
619 ReadBinaryFromReg(hKey4, "RemoteColm", &RemoteTabWidth, sizeof(RemoteTabWidth));
\r
620 ReadIntValueFromReg(hKey4, "SwCmd", &Sizing);
\r
622 ReadStringFromReg(hKey4, "UserMail", UserMailAdrs, USER_MAIL_LEN+1);
\r
623 ReadStringFromReg(hKey4, "Viewer", ViewerName[0], FMAX_PATH+1);
\r
624 ReadStringFromReg(hKey4, "Viewer2", ViewerName[1], FMAX_PATH+1);
\r
625 ReadStringFromReg(hKey4, "Viewer3", ViewerName[2], FMAX_PATH+1);
\r
627 ReadIntValueFromReg(hKey4, "TrType", &TransMode);
\r
628 ReadIntValueFromReg(hKey4, "Recv", &RecvMode);
\r
629 ReadIntValueFromReg(hKey4, "Send", &SendMode);
\r
630 ReadIntValueFromReg(hKey4, "Move", &MoveMode);
\r
631 ReadStringFromReg(hKey4, "Path", DefaultLocalPath, FMAX_PATH+1);
\r
632 ReadIntValueFromReg(hKey4, "Time", &SaveTimeStamp);
\r
633 ReadIntValueFromReg(hKey4, "EOF", &RmEOF);
\r
634 ReadIntValueFromReg(hKey4, "Scolon", &VaxSemicolon);
\r
636 ReadIntValueFromReg(hKey4, "RecvEx", &ExistMode);
\r
637 ReadIntValueFromReg(hKey4, "SendEx", &UpExistMode);
\r
639 ReadIntValueFromReg(hKey4, "LFsort", &LocalFileSort);
\r
640 ReadIntValueFromReg(hKey4, "LDsort", &LocalDirSort);
\r
641 ReadIntValueFromReg(hKey4, "RFsort", &RemoteFileSort);
\r
642 ReadIntValueFromReg(hKey4, "RDsort", &RemoteDirSort);
\r
643 ReadIntValueFromReg(hKey4, "SortSave", &SortSave);
\r
645 ReadIntValueFromReg(hKey4, "ListType", &ListType);
\r
646 ReadIntValueFromReg(hKey4, "Cache", &CacheEntry);
\r
647 ReadIntValueFromReg(hKey4, "CacheSave", &CacheSave);
\r
648 ReadIntValueFromReg(hKey4, "DotFile", &DotFile);
\r
649 ReadIntValueFromReg(hKey4, "Dclick", &DclickOpen);
\r
651 ReadIntValueFromReg(hKey4, "ConS", &ConnectOnStart);
\r
652 ReadIntValueFromReg(hKey4, "OldDlg", &ConnectAndSet);
\r
653 ReadIntValueFromReg(hKey4, "RasClose", &RasClose);
\r
654 ReadIntValueFromReg(hKey4, "RasNotify", &RasCloseNotify);
\r
655 ReadIntValueFromReg(hKey4, "Qanony", &QuickAnonymous);
\r
656 ReadIntValueFromReg(hKey4, "PassHist", &PassToHist);
\r
657 ReadIntValueFromReg(hKey4, "SendQuit", &SendQuit);
\r
658 ReadIntValueFromReg(hKey4, "NoRas", &NoRasControl);
\r
660 ReadIntValueFromReg(hKey4, "Debug", &DebugConsole);
\r
661 ReadIntValueFromReg(hKey4, "WinPos", &SaveWinPos);
\r
662 ReadIntValueFromReg(hKey4, "RegExp", &FindMode);
\r
663 ReadIntValueFromReg(hKey4, "Reg", &RegType);
\r
665 if(ReadMultiStringFromReg(hKey4, "AsciiFile", AsciiExt, ASCII_EXT_LEN+1) == FAIL)
\r
667 /*
\8b\8cASCII
\83\82\81[
\83h
\82Ì
\8ag
\92£
\8eq
\82Ì
\90Ý
\92è
\82ð
\90V
\82µ
\82¢
\82à
\82Ì
\82É
\95Ï
\8a· */
\r
668 ReadStringFromReg(hKey4, "Ascii", Str, ASCII_EXT_LEN+1);
\r
669 memset(AsciiExt, NUL, ASCII_EXT_LEN+1);
\r
673 if((Pos2 = strchr(Pos, ';')) == NULL)
\r
674 Pos2 = strchr(Pos, NUL);
\r
675 if((Pos2 - Pos) > 0)
\r
677 if((StrMultiLen(AsciiExt) + (Pos2 - Pos) + 2) >= ASCII_EXT_LEN)
\r
679 strcpy(AsciiExt + StrMultiLen(AsciiExt), "*.");
\r
680 strncpy(AsciiExt + StrMultiLen(AsciiExt) - 1, Pos, (Pos2 - Pos));
\r
688 ReadIntValueFromReg(hKey4, "LowUp", &FnameCnv);
\r
689 ReadIntValueFromReg(hKey4, "Tout", &TimeOut);
\r
691 ReadMultiStringFromReg(hKey4, "NoTrn", MirrorNoTrn, MIRROR_LEN+1);
\r
692 ReadMultiStringFromReg(hKey4, "NoDel", MirrorNoDel, MIRROR_LEN+1);
\r
693 ReadIntValueFromReg(hKey4, "MirFile", &MirrorFnameCnv);
\r
694 ReadIntValueFromReg(hKey4, "MirUNot", &MirUpDelNotify);
\r
695 ReadIntValueFromReg(hKey4, "MirDNot", &MirDownDelNotify);
\r
697 if(ReadStringFromReg(hKey4, "ListFont", Str, 256) == SUCCESS)
\r
699 if(RestoreFontData(Str, &ListLogFont) == SUCCESS)
\r
700 ListFont = CreateFontIndirect(&ListLogFont);
\r
702 ReadIntValueFromReg(hKey4, "ListHide", &DispIgnoreHide);
\r
703 ReadIntValueFromReg(hKey4, "ListDrv", &DispDrives);
\r
705 ReadStringFromReg(hKey4, "FwallHost", FwallHost, HOST_ADRS_LEN+1);
\r
706 ReadStringFromReg(hKey4, "FwallUser", FwallUser, USER_NAME_LEN+1);
\r
707 ReadStringFromReg(hKey4, "FwallPass", Str, 255);
\r
708 DecodePassword(Str, FwallPass);
\r
709 ReadIntValueFromReg(hKey4, "FwallPort", &FwallPort);
\r
710 ReadIntValueFromReg(hKey4, "FwallType", &FwallType);
\r
711 ReadIntValueFromReg(hKey4, "FwallDef", &FwallDefault);
\r
712 ReadIntValueFromReg(hKey4, "FwallSec", &FwallSecurity);
\r
713 ReadIntValueFromReg(hKey4, "PasvDef", &PasvDefault);
\r
714 ReadIntValueFromReg(hKey4, "FwallRes", &FwallResolv);
\r
715 ReadIntValueFromReg(hKey4, "FwallLow", &FwallLower);
\r
716 ReadIntValueFromReg(hKey4, "FwallDel", &FwallDelimiter);
\r
718 ReadIntValueFromReg(hKey4, "SndConSw", &Sound[SND_CONNECT].On);
\r
719 ReadIntValueFromReg(hKey4, "SndTrnSw", &Sound[SND_TRANS].On);
\r
720 ReadIntValueFromReg(hKey4, "SndErrSw", &Sound[SND_ERROR].On);
\r
721 ReadStringFromReg(hKey4, "SndCon", Sound[SND_CONNECT].Fname, FMAX_PATH+1);
\r
722 ReadStringFromReg(hKey4, "SndTrn", Sound[SND_TRANS].Fname, FMAX_PATH+1);
\r
723 ReadStringFromReg(hKey4, "SndErr", Sound[SND_ERROR].Fname, FMAX_PATH+1);
\r
725 ReadMultiStringFromReg(hKey4, "DefAttr", DefAttrList, DEFATTRLIST_LEN+1);
\r
727 ReadStringFromReg(hKey4, "Tmp", TmpPath, FMAX_PATH+1);
\r
729 ReadBinaryFromReg(hKey4, "Hdlg", &HostDlgSize, sizeof(SIZE));
\r
730 ReadBinaryFromReg(hKey4, "Bdlg", &BmarkDlgSize, sizeof(SIZE));
\r
731 ReadBinaryFromReg(hKey4, "Mdlg", &MirrorDlgSize, sizeof(SIZE));
\r
733 ReadIntValueFromReg(hKey4, "FAttrSw", &FolderAttr);
\r
734 ReadIntValueFromReg(hKey4, "FAttr", &FolderAttrNum);
\r
736 ReadIntValueFromReg(hKey4, "NoSave", &SuppressSave);
\r
738 ReadIntValueFromReg(hKey4, "HistNum", &FileHist);
\r
739 // ReadMultiStringFromReg(hKey4, "Hist", Hist, (FMAX_PATH+1)*HISTORY_MAX+1);
\r
741 /*
\83q
\83X
\83g
\83\8a\82Ì
\90Ý
\92è
\82ð
\93Ç
\82Ý
\8d\9e\82Þ */
\r
743 ReadIntValueFromReg(hKey4, "SavedHist", &Sets);
\r
745 for(i = 0; i < Sets; i++)
\r
747 sprintf(Str, "History%d", i);
\r
748 if(OpenSubKey(hKey4, Str, &hKey5) == SUCCESS)
\r
750 CopyDefaultHistory(&Hist);
\r
752 ReadStringFromReg(hKey5, "HostAdrs", Hist.HostAdrs, HOST_ADRS_LEN+1);
\r
753 ReadStringFromReg(hKey5, "UserName", Hist.UserName, USER_NAME_LEN+1);
\r
754 ReadStringFromReg(hKey5, "Account", Hist.Account, ACCOUNT_LEN+1);
\r
755 ReadStringFromReg(hKey5, "LocalDir", Hist.LocalInitDir, INIT_DIR_LEN+1);
\r
756 ReadStringFromReg(hKey5, "RemoteDir", Hist.RemoteInitDir, INIT_DIR_LEN+1);
\r
757 ReadStringFromReg(hKey5, "Chmod", Hist.ChmodCmd, CHMOD_CMD_LEN+1);
\r
758 ReadStringFromReg(hKey5, "Nlst", Hist.LsName, NLST_NAME_LEN+1);
\r
759 ReadStringFromReg(hKey5, "Init", Hist.InitCmd, INITCMD_LEN+1);
\r
760 ReadIntValueFromReg(hKey5, "Port", &Hist.Port);
\r
761 ReadIntValueFromReg(hKey5, "Kanji", &Hist.KanjiCode);
\r
762 ReadIntValueFromReg(hKey5, "KanaCnv", &Hist.KanaCnv);
\r
763 ReadIntValueFromReg(hKey5, "NameKanji", &Hist.NameKanjiCode);
\r
764 ReadIntValueFromReg(hKey5, "NameKana", &Hist.NameKanaCnv);
\r
765 ReadIntValueFromReg(hKey5, "Pasv", &Hist.Pasv);
\r
766 ReadIntValueFromReg(hKey5, "Fwall", &Hist.FireWall);
\r
767 ReadIntValueFromReg(hKey5, "List", &Hist.ListCmdOnly);
\r
768 ReadIntValueFromReg(hKey5, "NLST-R", &Hist.UseNLST_R);
\r
769 ReadIntValueFromReg(hKey5, "Tzone", &Hist.TimeZone);
\r
770 ReadIntValueFromReg(hKey5, "Type", &Hist.HostType);
\r
771 ReadIntValueFromReg(hKey5, "Sync", &Hist.SyncMove);
\r
772 ReadIntValueFromReg(hKey5, "Fpath", &Hist.NoFullPath);
\r
773 ReadBinaryFromReg(hKey5, "Sort", &Hist.Sort, sizeof(Hist.Sort));
\r
774 ReadIntValueFromReg(hKey5, "Secu", &Hist.Security);
\r
775 ReadIntValueFromReg(hKey5, "TrType", &Hist.Type);
\r
777 ReadStringFromReg(hKey5, "Password", Str, 255);
\r
778 DecodePassword(Str, Hist.PassWord);
\r
779 ReadIntValueFromReg(hKey5, "Dial", &Hist.Dialup);
\r
780 ReadIntValueFromReg(hKey5, "UseIt", &Hist.DialupAlways);
\r
781 ReadIntValueFromReg(hKey5, "Notify", &Hist.DialupNotify);
\r
782 ReadStringFromReg(hKey5, "DialTo", Hist.DialEntry, RAS_NAME_LEN+1);
\r
784 CloseSubKey(hKey5);
\r
785 AddHistoryToHistory(&Hist);
\r
789 /*
\83z
\83X
\83g
\82Ì
\90Ý
\92è
\82ð
\93Ç
\82Ý
\8d\9e\82Þ */
\r
791 ReadIntValueFromReg(hKey4, "SetNum", &Sets);
\r
793 for(i = 0; i < Sets; i++)
\r
795 sprintf(Str, "Host%d", i);
\r
796 if(OpenSubKey(hKey4, Str, &hKey5) == SUCCESS)
\r
798 CopyDefaultHost(&Host);
\r
799 /*
\89º
\88Ê
\8cÝ
\8a·
\90«
\82Ì
\82½
\82ß */
\r
800 if(Version < VER_NUM)
\r
803 Host.ListCmdOnly = NO;
\r
805 ReadIntValueFromReg(hKey5, "Set", &Host.Level);
\r
807 ReadStringFromReg(hKey5, "HostName", Host.HostName, HOST_NAME_LEN+1);
\r
808 ReadStringFromReg(hKey5, "HostAdrs", Host.HostAdrs, HOST_ADRS_LEN+1);
\r
809 ReadStringFromReg(hKey5, "UserName", Host.UserName, USER_NAME_LEN+1);
\r
810 ReadStringFromReg(hKey5, "Account", Host.Account, ACCOUNT_LEN+1);
\r
811 ReadStringFromReg(hKey5, "LocalDir", Host.LocalInitDir, INIT_DIR_LEN+1);
\r
812 ReadStringFromReg(hKey5, "RemoteDir", Host.RemoteInitDir, INIT_DIR_LEN+1);
\r
813 ReadStringFromReg(hKey5, "Chmod", Host.ChmodCmd, CHMOD_CMD_LEN+1);
\r
814 ReadStringFromReg(hKey5, "Nlst", Host.LsName, NLST_NAME_LEN+1);
\r
815 ReadStringFromReg(hKey5, "Init", Host.InitCmd, INITCMD_LEN+1);
\r
816 ReadIntValueFromReg(hKey5, "Port", &Host.Port);
\r
817 ReadIntValueFromReg(hKey5, "Anonymous", &Host.Anonymous);
\r
818 ReadIntValueFromReg(hKey5, "Kanji", &Host.KanjiCode);
\r
819 ReadIntValueFromReg(hKey5, "KanaCnv", &Host.KanaCnv);
\r
820 ReadIntValueFromReg(hKey5, "NameKanji", &Host.NameKanjiCode);
\r
821 ReadIntValueFromReg(hKey5, "NameKana", &Host.NameKanaCnv);
\r
822 ReadIntValueFromReg(hKey5, "Pasv", &Host.Pasv);
\r
823 ReadIntValueFromReg(hKey5, "Fwall", &Host.FireWall);
\r
824 ReadIntValueFromReg(hKey5, "List", &Host.ListCmdOnly);
\r
825 ReadIntValueFromReg(hKey5, "NLST-R", &Host.UseNLST_R);
\r
826 ReadIntValueFromReg(hKey5, "Last", &Host.LastDir);
\r
827 ReadIntValueFromReg(hKey5, "Tzone", &Host.TimeZone);
\r
828 ReadIntValueFromReg(hKey5, "Type", &Host.HostType);
\r
829 ReadIntValueFromReg(hKey5, "Sync", &Host.SyncMove);
\r
830 ReadIntValueFromReg(hKey5, "Fpath", &Host.NoFullPath);
\r
831 ReadBinaryFromReg(hKey5, "Sort", &Host.Sort, sizeof(Host.Sort));
\r
832 ReadIntValueFromReg(hKey5, "Secu", &Host.Security);
\r
833 if(Host.Anonymous != YES)
\r
836 ReadStringFromReg(hKey5, "Password", Str, 255);
\r
837 DecodePassword(Str, Host.PassWord);
\r
840 strcpy(Host.PassWord, UserMailAdrs);
\r
842 ReadMultiStringFromReg(hKey5, "Bmarks", Host.BookMark, BOOKMARK_SIZE);
\r
844 ReadIntValueFromReg(hKey5, "Dial", &Host.Dialup);
\r
845 ReadIntValueFromReg(hKey5, "UseIt", &Host.DialupAlways);
\r
846 ReadIntValueFromReg(hKey5, "Notify", &Host.DialupNotify);
\r
847 ReadStringFromReg(hKey5, "DialTo", Host.DialEntry, RAS_NAME_LEN+1);
\r
849 CloseSubKey(hKey5);
\r
851 AddHostToList(&Host, -1, Host.Level);
\r
855 ReadIntValueFromReg(hKey4, "CurSet", &Sets);
\r
856 SetCurrentHost(Sets);
\r
858 CloseSubKey(hKey4);
\r
864 /*=====
\8dÅ
\8f\89\82Ì
\8bN
\93®
\8e\9e\81i
\90Ý
\92è
\82ª
\96³
\82¢) =====*/
\r
867 strcpy(UserMailAdrs, "");
\r
869 if(InputDialogBox(mailadrs_dlg, HWND_DESKTOP, NULL, Str, USER_MAIL_LEN+1, &i, IDH_HELP_TOPIC_0000001) == YES)
\r
870 strcpy(UserMailAdrs, Str);
\r
872 for(i = 0; i < SAMPLE_HOSTS; i++)
\r
874 CopyDefaultHost(&Host);
\r
875 Host.Level = Sample[i].Level;
\r
876 strcpy(Host.PassWord, UserMailAdrs);
\r
877 strcpy(Host.HostName, Sample[i].HostName);
\r
878 strcpy(Host.HostAdrs, Sample[i].HostAdrs);
\r
879 strcpy(Host.UserName, "anonymous");
\r
880 AddHostToList(&Host, -1, Host.Level);
\r
888 /*-----
\89B
\82µ
\83h
\83\89\83C
\83u
\8fî
\95ñ
\82ð
\8eæ
\93¾ ------------------------------------------------
\r
895 * YES/NO=
\90Ý
\92è
\96³
\82µ
\r
896 *----------------------------------------------------------------------------*/
\r
898 DWORD LoadHideDriveListRegistory(void)
\r
911 if(RegOpenKeyEx(HKEY_CURRENT_USER, "Software", 0, KEY_READ, &hKey1) == ERROR_SUCCESS)
\r
913 if(RegOpenKeyEx(hKey1, "Microsoft", 0, KEY_READ, &hKey2) == ERROR_SUCCESS)
\r
915 if(RegOpenKeyEx(hKey2, "Windows", 0, KEY_READ, &hKey3) == ERROR_SUCCESS)
\r
917 if(RegOpenKeyEx(hKey3, "CurrentVersion", 0, KEY_READ, &hKey4) == ERROR_SUCCESS)
\r
919 if(RegOpenKeyEx(hKey4, "Policies", 0, KEY_READ, &hKey5) == ERROR_SUCCESS)
\r
921 if(RegOpenKeyEx(hKey5, "Explorer", 0, KEY_READ, &hKey6) == ERROR_SUCCESS)
\r
923 Size = sizeof(DWORD);
\r
924 RegQueryValueEx(hKey6, "NoDrives", NULL, &Type, (BYTE *)&Ret, &Size);
\r
925 RegCloseKey(hKey6);
\r
927 RegCloseKey(hKey5);
\r
929 RegCloseKey(hKey4);
\r
931 RegCloseKey(hKey3);
\r
933 RegCloseKey(hKey2);
\r
935 RegCloseKey(hKey1);
\r
941 /*-----
\83\8c\83W
\83X
\83g
\83\8a\82Ì
\90Ý
\92è
\92l
\82ð
\83N
\83\8a\83A --------------------------------------------
\r
948 *----------------------------------------------------------------------------*/
\r
950 void ClearRegistory(void)
\r
959 if(RegCreateKeyEx(HKEY_CURRENT_USER, "Software\\Sota", 0, "", REG_OPTION_NON_VOLATILE, KEY_CREATE_SUB_KEY, NULL, &hKey2, &Dispos) == ERROR_SUCCESS)
\r
961 if(RegCreateKeyEx(hKey2, "FFFTP", 0, "", REG_OPTION_NON_VOLATILE, KEY_WRITE, NULL, &hKey3, &Dispos) == ERROR_SUCCESS)
\r
963 if(RegCreateKeyEx(hKey3, "Options", 0, "", REG_OPTION_NON_VOLATILE, KEY_WRITE, NULL, &hKey4, &Dispos) == ERROR_SUCCESS)
\r
967 sprintf(Str, "Host%d", i);
\r
968 if(RegDeleteKey(hKey4, Str) != ERROR_SUCCESS)
\r
973 sprintf(Str, "History%d", i);
\r
974 if(RegDeleteKey(hKey4, Str) != ERROR_SUCCESS)
\r
977 RegCloseKey(hKey4);
\r
979 RegDeleteKey(hKey3, "Options");
\r
980 RegCloseKey(hKey3);
\r
982 RegDeleteKey(hKey2, "FFFTP");
\r
983 RegCloseKey(hKey2);
\r
989 /*-----
\90Ý
\92è
\82ð
\83t
\83@
\83C
\83\8b\82É
\95Û
\91¶ --------------------------------------------------
\r
996 *----------------------------------------------------------------------------*/
\r
998 void SaveSettingsToFile(void)
\r
1000 char Tmp[FMAX_PATH*2];
\r
1001 char Fname[FMAX_PATH+1];
\r
1003 if(RegType == REGTYPE_REG)
\r
1005 strcpy(Fname, "FFFTP.reg");
\r
1006 if(SelectFile(GetMainHwnd(), Fname, MSGJPN286, MSGJPN287, "reg", OFN_EXTENSIONDIFFERENT | OFN_OVERWRITEPROMPT, 1) == TRUE)
\r
1008 sprintf(Tmp, "/e \x22%s\x22 HKEY_CURRENT_USER\\Software\\sota\\FFFTP", Fname);
\r
1009 if(ShellExecute(NULL, "open", "regedit", Tmp, ".", SW_SHOW) <= (HINSTANCE)32)
\r
1011 MessageBox(NULL, MSGJPN285, "FFFTP", MB_OK);
\r
1017 strcpy(Fname, "FFFTP-Backup.ini");
\r
1018 if(SelectFile(GetMainHwnd(), Fname, MSGJPN286, MSGJPN288, "ini", OFN_EXTENSIONDIFFERENT | OFN_OVERWRITEPROMPT, 1) == TRUE)
\r
1020 CopyFile(AskIniFilePath(), Fname, FALSE);
\r
1027 /*-----
\90Ý
\92è
\82ð
\83t
\83@
\83C
\83\8b\82©
\82ç
\95\9c\8c³ ------------------------------------------------
\r
1033 * int
\83\8d\81[
\83h
\82µ
\82½
\82©
\82Ç
\82¤
\82© (YES/NO)
\r
1034 *----------------------------------------------------------------------------*/
\r
1036 int LoadSettingsFromFile(void)
\r
1039 char Tmp[FMAX_PATH*2];
\r
1040 char Fname[FMAX_PATH+1];
\r
1043 strcpy(Fname, "");
\r
1044 if(SelectFile(GetMainHwnd(), Fname, MSGJPN291, MSGJPN290, "", OFN_FILEMUSTEXIST, 0) == TRUE)
\r
1046 if((strlen(Fname) >= 5) && (_stricmp(&Fname[strlen(Fname)-4], ".reg") == 0))
\r
1048 sprintf(Tmp, "\x22%s\x22", Fname);
\r
1049 if(ShellExecute(NULL, "open", "regedit", Tmp, ".", SW_SHOW) <= (HINSTANCE)32)
\r
1051 MessageBox(NULL, MSGJPN285, "FFFTP", MB_OK);
\r
1056 /*
\83\8c\83W
\83X
\83g
\83\8a\83G
\83f
\83B
\83^
\82ª
\8fI
\97¹
\82·
\82é
\82Ì
\82ð
\91Ò
\82Â */
\r
1057 // WaitForSingleObject(Info.hProcess, INFINITE);
\r
1060 else if((strlen(Fname) >= 5) && (_stricmp(&Fname[strlen(Fname)-4], ".ini") == 0))
\r
1062 CopyFile(Fname, AskIniFilePath(), FALSE);
\r
1066 MessageBox(NULL, MSGJPN293, "FFFTP", MB_OK);
\r
1074 /*-----
\83\8c\83W
\83X
\83g
\83\8a/INI
\83t
\83@
\83C
\83\8b\82É
\95¶
\8e\9a\97ñ
\82ð
\83Z
\81[
\83u --------------------------------
\r
1077 * HKEY hKey :
\83\8c\83W
\83X
\83g
\83\8a\83L
\81[
\r
1078 * char *Key :
\83L
\81[
\96¼
\r
1079 * char *Str :
\83Z
\81[
\83u
\82·
\82é
\95¶
\8e\9a\97ñ
\r
1080 * char *DefaultStr :
\83f
\83t
\83H
\83\8b\83g
\82Ì
\95¶
\8e\9a\97ñ
\r
1086 *
\95¶
\8e\9a\97ñ
\82ª
\83f
\83t
\83H
\83\8b\83g
\82Ì
\95¶
\8e\9a\97ñ
\82Æ
\93¯
\82¶
\82È
\82ç
\83Z
\81[
\83u
\82µ
\82È
\82¢
\r
1087 *----------------------------------------------------------------------------*/
\r
1089 static void SaveStr(HKEY hKey, char *Key, char *Str, char *DefaultStr)
\r
1091 if((DefaultStr != NULL) && (strcmp(Str, DefaultStr) == 0))
\r
1092 DeleteValue(hKey, Key);
\r
1094 WriteStringToReg(hKey, Key, Str);
\r
1100 /*-----
\83\8c\83W
\83X
\83g
\83\8a/INI
\83t
\83@
\83C
\83\8b\82É
\90\94\92l(INT)
\82ð
\83Z
\81[
\83u -----------------------------
\r
1103 * HKEY hKey :
\83\8c\83W
\83X
\83g
\83\8a\83L
\81[
\r
1104 * char *Key :
\83L
\81[
\96¼
\r
1105 * int Num :
\83Z
\81[
\83u
\82·
\82é
\92l
\r
1106 * int DefaultNum :
\83f
\83t
\83H
\83\8b\83g
\82Ì
\92l
\r
1112 *
\90\94\92l
\82ª
\83f
\83t
\83H
\83\8b\83g
\82Ì
\92l
\82Æ
\93¯
\82¶
\82È
\82ç
\83Z
\81[
\83u
\82µ
\82È
\82¢
\r
1113 *----------------------------------------------------------------------------*/
\r
1115 static void SaveIntNum(HKEY hKey, char *Key, int Num, int DefaultNum)
\r
1117 if(Num == DefaultNum)
\r
1118 DeleteValue(hKey, Key);
\r
1120 WriteIntValueToReg(hKey, Key, Num);
\r
1126 /*----- LOGFONT
\83f
\81[
\83^
\82ð
\95¶
\8e\9a\97ñ
\82É
\95Ï
\8a·
\82·
\82é ---------------------------------------
\r
1129 * LOGFONT Font :
\83t
\83H
\83\93\83g
\83f
\81[
\83^
\r
1130 * HFONT hFont :
\83t
\83H
\83\93\83g
\82Ì
\83n
\83\93\83h
\83\8b\r
1131 * NULL =
\83f
\83t
\83H
\83\8b\83g
\82Ì
\83t
\83H
\83\93\83g
\r
1132 * char *Buf :
\83o
\83b
\83t
\83@
\r
1136 *----------------------------------------------------------------------------*/
\r
1138 static void MakeFontData(LOGFONT Font, HFONT hFont, char *Buf)
\r
1142 sprintf(Buf, "%d %d %d %d %d %d %d %d %d %d %d %d %d %s",
\r
1143 Font.lfHeight, Font.lfWidth, Font.lfEscapement, Font.lfOrientation,
\r
1144 Font.lfWeight, Font.lfItalic, Font.lfUnderline, Font.lfStrikeOut,
\r
1145 Font.lfCharSet, Font.lfOutPrecision, Font.lfClipPrecision,
\r
1146 Font.lfQuality, Font.lfPitchAndFamily, Font.lfFaceName);
\r
1151 /*-----
\95¶
\8e\9a\97ñ
\82ðLOGFONT
\83f
\81[
\83^
\82É
\95Ï
\8a·
\82·
\82é ---------------------------------------
\r
1154 * char *Str :
\95¶
\8e\9a\97ñ
\r
1155 * LOGFONT *Font :
\83t
\83H
\83\93\83g
\83f
\81[
\83^
\r
1158 * int
\83X
\83e
\81[
\83^
\83X
\r
1159 * SUCCESS/FAIL=
\95Ï
\8a·
\82Å
\82«
\82È
\82¢
\r
1160 *----------------------------------------------------------------------------*/
\r
1162 static int RestoreFontData(char *Str, LOGFONT *Font)
\r
1168 if(sscanf(Str, "%d %d %d %d %d %d %d %d %d %d %d %d %d",
\r
1169 &(Font->lfHeight), &(Font->lfWidth), &(Font->lfEscapement), &(Font->lfOrientation),
\r
1170 &(Font->lfWeight), &(Font->lfItalic), &(Font->lfUnderline), &(Font->lfStrikeOut),
\r
1171 &(Font->lfCharSet), &(Font->lfOutPrecision), &(Font->lfClipPrecision),
\r
1172 &(Font->lfQuality), &(Font->lfPitchAndFamily)) == 13)
\r
1174 for(i = 13; i > 0; i--)
\r
1176 if((Str = strchr(Str, ' ')) == NULL)
\r
1182 strcpy(Font->lfFaceName, Str);
\r
1188 memset(Font, NUL, sizeof(LOGFONT));
\r
1193 /*-----
\83p
\83X
\83\8f\81[
\83h
\82ð
\88Ã
\8d\86\89»
\82·
\82é ------------------------------------------------
\r
1196 * char *Str :
\83p
\83X
\83\8f\81[
\83h
\r
1197 * char *Buf :
\88Ã
\8d\86\89»
\82µ
\82½
\83p
\83X
\83\8f\81[
\83h
\82ð
\8ai
\94[
\82·
\82é
\83o
\83b
\83t
\83@
\r
1201 *----------------------------------------------------------------------------*/
\r
1202 static void EncodePassword(char *Str, char *Buf)
\r
1204 EncodePassword3( Str, Buf, SecretKey );
\r
1207 /*-----
\83p
\83X
\83\8f\81[
\83h
\82ð
\88Ã
\8d\86\89»
\82·
\82é(
\83I
\83\8a\83W
\83i
\83\8b\83A
\83\8b\83S
\83\8a\83Y
\83\80) ------------------
\r
1210 * char *Str :
\83p
\83X
\83\8f\81[
\83h
\r
1211 * char *Buf :
\88Ã
\8d\86\89»
\82µ
\82½
\83p
\83X
\83\8f\81[
\83h
\82ð
\8ai
\94[
\82·
\82é
\83o
\83b
\83t
\83@
\r
1215 *----------------------------------------------------------------------------*/
\r
1217 static void EncodePasswordOriginal(char *Str, char *Buf)
\r
1219 unsigned char *Get;
\r
1220 unsigned char *Put;
\r
1224 srand((unsigned)time(NULL));
\r
1226 Get = (unsigned char *)Str;
\r
1227 Put = (unsigned char *)Buf;
\r
1229 if( *Get == NUL ){
\r
1234 /*
\8e¯
\95Ê
\8eq
\82ð
\90æ
\93ª
\82É
\92u
\82 */
\r
1239 while(*Get != NUL)
\r
1242 Ch = ((int)*Get++) << Rnd;
\r
1243 Ch = (unsigned char)Ch | (unsigned char)(Ch >> 8);
\r
1244 *Put++ = 0x40 | ((Rnd & 0x3) << 4) | (Ch & 0xF);
\r
1245 *Put++ = 0x40 | ((Ch >> 4) & 0xF);
\r
1246 if((*(Put-2) & 0x1) != 0)
\r
1247 *Put++ = (rand() % 62) + 0x40;
\r
1253 /*-----
\83p
\83X
\83\8f\81[
\83h
\82ð
\88Ã
\8d\86\89»
\82·
\82é(
\83I
\83\8a\83W
\83i
\83\8b\83A
\83\8b\83S
\83\8a\83Y
\83\80\81OKey) ----------------
\r
1256 * char *Str :
\83p
\83X
\83\8f\81[
\83h
\r
1257 * char *Buf :
\88Ã
\8d\86\89»
\82µ
\82½
\83p
\83X
\83\8f\81[
\83h
\82ð
\8ai
\94[
\82·
\82é
\83o
\83b
\83t
\83@
\r
1258 * const char *Key :
\88Ã
\8d\86\89»
\83L
\81[
\r
1262 *----------------------------------------------------------------------------*/
\r
1264 static void EncodePassword2(char *Str, char *Buf, const char* Key)
\r
1266 unsigned char *Get;
\r
1267 unsigned char *Put;
\r
1271 /* 2010.01.31 genta Key */
\r
1272 unsigned char *KeyHead = (unsigned char *)Key;
\r
1273 unsigned char *KeyEnd = KeyHead + strlen(KeyHead);
\r
1274 unsigned char *KeyCurrent = KeyHead;
\r
1276 srand((unsigned)time(NULL));
\r
1278 Get = (unsigned char *)Str;
\r
1279 Put = (unsigned char *)Buf;
\r
1281 if( *Get == NUL ){
\r
1286 /*
\8e¯
\95Ê
\8eq
\82ð
\90æ
\93ª
\82É
\92u
\82 */
\r
1291 while(*Get != NUL)
\r
1294 Ch = ((int)(*Get++ ^ *KeyCurrent)) << Rnd;
\r
1295 Ch = (unsigned char)Ch | (unsigned char)(Ch >> 8);
\r
1296 *Put++ = 0x40 | ((Rnd & 0x3) << 4) | (Ch & 0xF);
\r
1297 *Put++ = 0x40 | ((Ch >> 4) & 0xF);
\r
1298 if((*(Put-2) & 0x1) != 0)
\r
1299 *Put++ = (rand() % 62) + 0x40;
\r
1301 /* 2010.01.31 genta Key */
\r
1302 if( ++KeyCurrent == KeyEnd ){
\r
1303 KeyCurrent = KeyHead;
\r
1310 /*-----
\83p
\83X
\83\8f\81[
\83h
\82ð
\88Ã
\8d\86\89»
\82·
\82é(AES) ------------------------------------------
\r
1313 * char *Str :
\83p
\83X
\83\8f\81[
\83h
\r
1314 * char *Buf :
\88Ã
\8d\86\89»
\82µ
\82½
\83p
\83X
\83\8f\81[
\83h
\82ð
\8ai
\94[
\82·
\82é
\83o
\83b
\83t
\83@
\r
1315 * const char *Key :
\88Ã
\8d\86\89»
\83L
\81[
\r
1319 *----------------------------------------------------------------------------*/
\r
1321 static void EncodePassword3(char *Str, char *Buf, const char *Key)
\r
1323 unsigned char *Put;
\r
1324 unsigned char *AesEncBuf;
\r
1325 unsigned char *StrPadBuf;
\r
1328 size_t StrPadIndex;
\r
1330 size_t EncBufIndex;
\r
1332 int RandByteCount;
\r
1333 unsigned char AesKey[32];
\r
1334 unsigned char AesCbcIv[AES_BLOCK_SIZE];
\r
1335 aes_encrypt_ctx Ctx;
\r
1339 Put = (unsigned char *)Buf;
\r
1340 StrLen = strlen(Str);
\r
1341 StrPadLen = ((StrLen + AES_BLOCK_SIZE - 1) / AES_BLOCK_SIZE) * AES_BLOCK_SIZE;
\r
1343 /*
\8dÅ
\92á
\92·
\82ð32
\95¶
\8e\9a\82Æ
\82·
\82é */
\r
1344 // StrPadLen = min1(StrPadLen, AES_BLOCK_SIZE * 2);
\r
1345 StrPadLen = max1(StrPadLen, AES_BLOCK_SIZE * 2);
\r
1347 if((StrPadBuf = malloc(StrPadLen)) != NULL)
\r
1349 if((AesEncBuf = malloc(StrPadLen)) != NULL)
\r
1354 strncpy(StrPadBuf, Str, StrPadLen);
\r
1356 /* PAD
\95\94\95ª
\82ð
\97\90\90\94\82Å
\96\84\82ß
\82é StrPad[StrLen](
\82ª
\97L
\8cø
\82È
\8fê
\8d\87)
\82Í NUL */
\r
1357 for(StrPadIndex = StrLen + 1; StrPadIndex < StrPadLen;)
\r
1359 RandValue = GetRandamDWRODValue();
\r
1360 for(RandByteCount = 0; RandByteCount < 4; RandByteCount++)
\r
1362 if(StrPadIndex < StrPadLen)
\r
1364 StrPadBuf[StrPadIndex++] = (unsigned char)(RandValue & 0xff);
\r
1370 // IV
\82Ì
\8f\89\8aú
\89»
\r
1371 for(IvIndex = 0; IvIndex < AES_BLOCK_SIZE;)
\r
1373 RandValue = GetRandamDWRODValue();
\r
1374 for(RandByteCount = 0; RandByteCount < 4; RandByteCount++)
\r
1376 if(IvIndex < AES_BLOCK_SIZE)
\r
1378 AesCbcIv[IvIndex++] = (unsigned char)(RandValue & 0xff);
\r
1386 for(IvIndex = 0; IvIndex < AES_BLOCK_SIZE; IvIndex++)
\r
1388 sprintf(Put, "%02x", AesCbcIv[IvIndex]);
\r
1393 if(CreateAesKey(AesKey, Key) == SUCCESS)
\r
1395 aes_encrypt_key(AesKey, 32, &Ctx);
\r
1397 if(aes_cbc_encrypt(StrPadBuf, AesEncBuf, StrPadLen, AesCbcIv, &Ctx) == EXIT_SUCCESS)
\r
1399 for(EncBufIndex = 0; EncBufIndex < StrPadLen; EncBufIndex++)
\r
1401 sprintf(Put, "%02x", AesEncBuf[EncBufIndex]);
\r
1408 if(FALSE == PutState)
\r
1420 /*-----
\83p
\83X
\83\8f\81[
\83h
\82Ì
\88Ã
\8d\86\89»
\82ð
\89ð
\82 ----------------------------------------------
\r
1423 * char *Str :
\88Ã
\8d\86\89»
\82µ
\82½
\83p
\83X
\83\8f\81[
\83h
\r
1424 * char *Buf :
\83p
\83X
\83\8f\81[
\83h
\82ð
\8ai
\94[
\82·
\82é
\83o
\83b
\83t
\83@
\r
1428 *----------------------------------------------------------------------------*/
\r
1430 static void DecodePassword(char *Str, char *Buf)
\r
1432 unsigned char *Get;
\r
1433 unsigned char *Put;
\r
1435 Get = (unsigned char *)Str;
\r
1436 Put = (unsigned char *)Buf;
\r
1438 if( *Get == NUL ){
\r
1441 else if( 0x40 <= *Get && *Get < 0x80 ){
\r
1442 /* Original algorithm */
\r
1443 DecodePasswordOriginal( Str, Buf );
\r
1445 else if( strncmp( Get, "0A", 2 ) == 0 ){
\r
1446 DecodePasswordOriginal( Str + 2, Buf );
\r
1448 else if( strncmp( Get, "0B", 2 ) == 0 ){
\r
1449 DecodePassword2( Str + 2, Buf, SecretKey );
\r
1451 else if( strncmp( Get, "0C", 2 ) == 0 ){
\r
1452 DecodePassword3( Str + 2, Buf, SecretKey );
\r
1455 // unknown encoding
\r
1461 /*-----
\83p
\83X
\83\8f\81[
\83h
\82Ì
\88Ã
\8d\86\89»
\82ð
\89ð
\82(
\83I
\83\8a\83W
\83i
\83\8b\83A
\83\8b\83S
\83\8a\83Y
\83\80) -------------------
\r
1464 * char *Str :
\88Ã
\8d\86\89»
\82µ
\82½
\83p
\83X
\83\8f\81[
\83h
\r
1465 * char *Buf :
\83p
\83X
\83\8f\81[
\83h
\82ð
\8ai
\94[
\82·
\82é
\83o
\83b
\83t
\83@
\r
1469 *----------------------------------------------------------------------------*/
\r
1470 static void DecodePasswordOriginal(char *Str, char *Buf)
\r
1472 unsigned char *Get;
\r
1473 unsigned char *Put;
\r
1477 Get = (unsigned char *)Str;
\r
1478 Put = (unsigned char *)Buf;
\r
1480 while(*Get != NUL)
\r
1482 Rnd = ((unsigned int)*Get >> 4) & 0x3;
\r
1483 Ch = (*Get & 0xF) | ((*(Get+1) & 0xF) << 4);
\r
1485 if((*Get & 0x1) != 0)
\r
1489 Ch = (Ch & 0xFF) | ((Ch >> 8) & 0xFF);
\r
1496 /*-----
\83p
\83X
\83\8f\81[
\83h
\82Ì
\88Ã
\8d\86\89»
\82ð
\89ð
\82(
\83I
\83\8a\83W
\83i
\83\8b\83A
\83\8b\83S
\83\8a\83Y
\83\80\81OKey) -------------------
\r
1499 * char *Str :
\88Ã
\8d\86\89»
\82µ
\82½
\83p
\83X
\83\8f\81[
\83h
\r
1500 * char *Buf :
\83p
\83X
\83\8f\81[
\83h
\82ð
\8ai
\94[
\82·
\82é
\83o
\83b
\83t
\83@
\r
1501 * const char *Key :
\88Ã
\8d\86\89»
\83L
\81[
\r
1505 *----------------------------------------------------------------------------*/
\r
1506 static void DecodePassword2(char *Str, char *Buf, const char* Key)
\r
1510 unsigned char *Get = (unsigned char *)Str;
\r
1511 unsigned char *Put = (unsigned char *)Buf;
\r
1513 /* 2010.01.31 genta Key */
\r
1514 unsigned char *KeyHead = (unsigned char *)Key;
\r
1515 unsigned char *KeyEnd = KeyHead + strlen(KeyHead);
\r
1516 unsigned char *KeyCurrent = KeyHead;
\r
1518 while(*Get != NUL)
\r
1520 Rnd = ((unsigned int)*Get >> 4) & 0x3;
\r
1521 Ch = (*Get & 0xF) | ((*(Get+1) & 0xF) << 4);
\r
1523 if((*Get & 0x1) != 0)
\r
1527 Ch = (Ch & 0xFF) | ((Ch >> 8) & 0xFF);
\r
1528 *Put++ = Ch ^ *KeyCurrent;
\r
1530 /* 2010.01.31 genta Key */
\r
1531 if( ++KeyCurrent == KeyEnd ){
\r
1532 KeyCurrent = KeyHead;
\r
1539 /*-----
\83p
\83X
\83\8f\81[
\83h
\82Ì
\88Ã
\8d\86\89»
\82ð
\89ð
\82(AES) ---------------------------------------
\r
1542 * char *Str :
\88Ã
\8d\86\89»
\82µ
\82½
\83p
\83X
\83\8f\81[
\83h
\r
1543 * char *Buf :
\83p
\83X
\83\8f\81[
\83h
\82ð
\8ai
\94[
\82·
\82é
\83o
\83b
\83t
\83@
\r
1544 * const char *Key :
\88Ã
\8d\86\89»
\83L
\81[
\r
1548 *----------------------------------------------------------------------------*/
\r
1550 static void DecodePassword3(char *Str, char *Buf, const char *Key)
\r
1553 unsigned char *EncBuf;
\r
1556 size_t EncBufIndex;
\r
1558 unsigned char AesKey[32];
\r
1559 unsigned char AesCbcIv[AES_BLOCK_SIZE];
\r
1560 aes_decrypt_ctx Ctx;
\r
1565 StrLen = strlen(Str);
\r
1567 if(AES_BLOCK_SIZE * 2 + 1 < StrLen)
\r
1570 EncBufLen = (StrLen - 1 ) / 2 - AES_BLOCK_SIZE;
\r
1571 if((EncBuf = malloc(EncBufLen)) != NULL)
\r
1573 for(IvIndex = 0; IvIndex < AES_BLOCK_SIZE; IvIndex++)
\r
1575 AesCbcIv[IvIndex] = hex2bin(*Get++) << 4;
\r
1576 AesCbcIv[IvIndex] |= hex2bin(*Get++);
\r
1581 if(CreateAesKey(AesKey, Key) == SUCCESS)
\r
1583 aes_decrypt_key(AesKey, 32, &Ctx);
\r
1585 for(EncBufIndex = 0; EncBufIndex < EncBufLen; EncBufIndex++)
\r
1587 EncBuf[EncBufIndex] = hex2bin(*Get++) << 4;
\r
1588 EncBuf[EncBufIndex] |= hex2bin(*Get++);
\r
1590 if(aes_cbc_decrypt(EncBuf, Buf, EncBufLen, AesCbcIv, &Ctx) == EXIT_SUCCESS)
\r
1592 Buf[EncBufLen] = NUL;
\r
1602 /*----- AES
\97p
\8cÅ
\92è
\92·
\83L
\81[
\82ð
\8dì
\90¬ ----------------------------------------------
\r
1605 * unsigned char *AesKey : AES
\88Ã
\8d\86\8c®
\r
1606 * const char *Key :
\88Ã
\8d\86\89»
\83L
\81[
\r
1609 * int
\83X
\83e
\81[
\83^
\83X (SUCCESS/FAIL)
\r
1611 * SHA-1
\82ð
\82à
\82¿
\82¢
\82Ä32Byte
\8c®
\82ð
\90¶
\90¬
\82·
\82é
\r
1612 *----------------------------------------------------------------------------*/
\r
1614 static int CreateAesKey(unsigned char *AesKey, const char* Key)
\r
1617 uint32 HashKeyLen;
\r
1618 uint32 results[10];
\r
1623 HashKeyLen = strlen(Key) + 16;
\r
1624 if((HashKey = malloc(HashKeyLen + 1)) == NULL){
\r
1628 strcpy(HashKey, Key);
\r
1629 strcat(HashKey, ">g^r=@N7=//z<[`:");
\r
1630 sha_memory((uchar *)HashKey, HashKeyLen, results);
\r
1632 strcpy(HashKey, Key);
\r
1633 strcat(HashKey, "VG77dO1#EyC]$|C@");
\r
1634 sha_memory((uchar *)HashKey, HashKeyLen, results + 5);
\r
1638 while(ResIndex < 8){
\r
1639 for(ByteOffset = 0; ByteOffset < 4; ByteOffset++){
\r
1640 AesKey[KeyIndex++] = (results[ResIndex] >> ByteOffset * 8) & 0xff;
\r
1650 /*=====
\83\8c\83W
\83X
\83g
\83\8a\82ÆINI
\83t
\83@
\83C
\83\8b\82Ì
\83A
\83N
\83Z
\83X
\8f\88\97\9d ============*/
\r
1653 /*===== INI
\83t
\83@
\83C
\83\8b\97p
\82Ì
\83\8c\83W
\83X
\83g
\83\8a\83f
\81[
\83^ =====*/
\r
1655 typedef struct regdatatbl {
\r
1656 char KeyName[80+1]; /*
\83L
\81[
\96¼ */
\r
1657 char ValTbl[REG_SECT_MAX]; /*
\92l
\82Ì
\83e
\81[
\83u
\83\8b */
\r
1658 int ValLen; /*
\92l
\83f
\81[
\83^
\82Ì
\83o
\83C
\83g
\90\94 */
\r
1659 int Mode; /*
\83L
\81[
\82Ì
\83\82\81[
\83h */
\r
1660 struct regdatatbl *Next;
\r
1663 /*=====
\83v
\83\8d\83g
\83^
\83C
\83v =====*/
\r
1665 static BOOL WriteOutRegToFile(REGDATATBL *Pos);
\r
1666 static int ReadInReg(char *Name, REGDATATBL **Handle);
\r
1667 static int StrCatOut(char *Src, int Len, char *Dst);
\r
1668 static int StrReadIn(char *Src, int Max, char *Dst);
\r
1669 static char *ScanValue(void *Handle, char *Name);
\r
1672 /*=====
\83\8d\81[
\83J
\83\8b\82È
\83\8f\81[
\83N =====*/
\r
1674 static int TmpRegType;
\r
1678 /*-----
\83\8c\83W
\83X
\83g
\83\8a\82Ì
\83^
\83C
\83v
\82ð
\90Ý
\92è
\82·
\82é ------------------------------------------
\r
1681 * int Type :
\83^
\83C
\83v (REGTYPE_xxx)
\r
1684 * int
\83X
\83e
\81[
\83^
\83X
\r
1686 *----------------------------------------------------------------------------*/
\r
1688 static void SetRegType(int Type)
\r
1690 TmpRegType = Type;
\r
1695 /*-----
\83\8c\83W
\83X
\83g
\83\8a/INI
\83t
\83@
\83C
\83\8b\82ð
\83I
\81[
\83v
\83\93\82·
\82é
\81i
\93Ç
\82Ý
\8d\9e\82Ý
\81j-----------------------
\r
1698 * char *Name :
\83\8c\83W
\83X
\83g
\83\8a\96¼
\r
1699 * void **Handle :
\83n
\83\93\83h
\83\8b\82ð
\95Ô
\82·
\83\8f\81[
\83N
\r
1702 * int
\83X
\83e
\81[
\83^
\83X
\r
1704 *----------------------------------------------------------------------------*/
\r
1706 static int OpenReg(char *Name, void **Handle)
\r
1709 char Tmp[FMAX_PATH+1];
\r
1712 if(TmpRegType == REGTYPE_REG)
\r
1714 strcpy(Tmp, "Software\\Sota\\");
\r
1715 strcat(Tmp, Name);
\r
1716 if(RegOpenKeyEx(HKEY_CURRENT_USER, Tmp, 0, KEY_READ, (HKEY *)Handle) == ERROR_SUCCESS)
\r
1721 if((Sts = ReadInReg(Name, (REGDATATBL **)Handle)) == SUCCESS)
\r
1722 ((REGDATATBL *)(*Handle))->Mode = 0;
\r
1728 /*-----
\83\8c\83W
\83X
\83g
\83\8a/INI
\83t
\83@
\83C
\83\8b\82ð
\8dì
\90¬
\82·
\82é
\81i
\8f\91\82«
\8d\9e\82Ý
\81j---------------------------
\r
1731 * char *Name :
\83\8c\83W
\83X
\83g
\83\8a\96¼
\r
1732 * void **Handle :
\83n
\83\93\83h
\83\8b\82ð
\95Ô
\82·
\83\8f\81[
\83N
\r
1735 * int
\83X
\83e
\81[
\83^
\83X
\r
1737 *----------------------------------------------------------------------------*/
\r
1739 static int CreateReg(char *Name, void **Handle)
\r
1742 char Tmp[FMAX_PATH+1];
\r
1746 if(TmpRegType == REGTYPE_REG)
\r
1748 strcpy(Tmp, "Software\\Sota\\");
\r
1749 strcat(Tmp, Name);
\r
1750 if(RegCreateKeyEx(HKEY_CURRENT_USER, Tmp, 0, "", REG_OPTION_NON_VOLATILE, KEY_CREATE_SUB_KEY | KEY_SET_VALUE, NULL, (HKEY *)Handle, &Dispos) == ERROR_SUCCESS)
\r
1755 if((*Handle = malloc(sizeof(REGDATATBL))) != NULL)
\r
1757 strcpy(((REGDATATBL *)(*Handle))->KeyName, Name);
\r
1758 ((REGDATATBL *)(*Handle))->ValLen = 0;
\r
1759 ((REGDATATBL *)(*Handle))->Next = NULL;
\r
1760 ((REGDATATBL *)(*Handle))->Mode = 1;
\r
1768 /*-----
\83\8c\83W
\83X
\83g
\83\8a/INI
\83t
\83@
\83C
\83\8b\82ð
\83N
\83\8d\81[
\83Y
\82·
\82é ----------------------------------
\r
1771 * void *Handle :
\83n
\83\93\83h
\83\8b\r
1774 * int
\83X
\83e
\81[
\83^
\83X
\r
1776 *----------------------------------------------------------------------------*/
\r
1778 static int CloseReg(void *Handle)
\r
1784 if(TmpRegType == REGTYPE_REG)
\r
1786 RegCloseKey(Handle);
\r
1788 /* INI
\83t
\83@
\83C
\83\8b\82ð
\8dí
\8f\9c */
\r
1789 if((Strm = fopen(AskIniFilePath(), "rt")) != NULL)
\r
1792 MoveFileToTrashCan(AskIniFilePath());
\r
1797 if(((REGDATATBL *)Handle)->Mode == 1)
\r
1799 if(WriteOutRegToFile(Handle) == TRUE)
\r
1801 // /*
\83\8c\83W
\83X
\83g
\83\8a\82ð
\83N
\83\8a\83A */
\r
1802 // ClearRegistory();
\r
1805 /*
\83e
\81[
\83u
\83\8b\82ð
\8dí
\8f\9c */
\r
1807 while(Pos != NULL)
\r
1818 /*-----
\83\8c\83W
\83X
\83g
\83\8a\8fî
\95ñ
\82ðINI
\83t
\83@
\83C
\83\8b\82É
\8f\91\82«
\8d\9e\82Þ ---------------------------------
\r
1821 * REGDATATBL *Pos :
\83\8c\83W
\83X
\83g
\83\8a\83f
\81[
\83^
\r
1825 *----------------------------------------------------------------------------*/
\r
1827 static BOOL WriteOutRegToFile(REGDATATBL *Pos)
\r
1834 if((Strm = fopen(AskIniFilePath(), "wt")) != NULL)
\r
1836 fprintf(Strm, MSGJPN239);
\r
1837 while(Pos != NULL)
\r
1839 fprintf(Strm, "\n[%s]\n", Pos->KeyName);
\r
1841 Disp = Pos->ValTbl;
\r
1842 while(Disp < (Pos->ValTbl + Pos->ValLen))
\r
1844 fprintf(Strm, "%s\n", Disp);
\r
1845 Disp = Disp + strlen(Disp) + 1;
\r
1853 MessageBox(NULL, MSGJPN240, "FFFTP", MB_OK);
\r
1859 /*----- INI
\83t
\83@
\83C
\83\8b\82©
\82ç
\83\8c\83W
\83X
\83g
\83\8a\8fî
\95ñ
\82ð
\93Ç
\82Ý
\8d\9e\82Þ -------------------------------
\r
1862 * char *Name :
\96¼
\91O
\r
1863 * void *Handle :
\83n
\83\93\83h
\83\8b\r
1866 * int
\83X
\83e
\81[
\83^
\83X
\r
1868 *----------------------------------------------------------------------------*/
\r
1870 static int ReadInReg(char *Name, REGDATATBL **Handle)
\r
1883 if((Strm = fopen(AskIniFilePath(), "rt")) != NULL)
\r
1885 if((Buf = malloc(REG_SECT_MAX)) != NULL)
\r
1887 while(fgets(Buf, REG_SECT_MAX, Strm) != NULL)
\r
1891 if((Tmp = strchr(Buf, '\n')) != NULL)
\r
1896 if((New = malloc(sizeof(REGDATATBL))) != NULL)
\r
1898 if((Tmp = strchr(Buf, ']')) != NULL)
\r
1900 strcpy(New->KeyName, Buf+1);
\r
1903 Data = New->ValTbl;
\r
1905 if(*Handle == NULL)
\r
1910 while(Pos->Next != NULL)
\r
1915 else if(strlen(Buf) > 0)
\r
1917 strcpy(Data, Buf);
\r
1918 Data += strlen(Buf) + 1;
\r
1919 New->ValLen += strlen(Buf) + 1;
\r
1932 /*-----
\83T
\83u
\83L
\81[
\82ð
\83I
\81[
\83v
\83\93\82·
\82é ------------------------------------------------
\r
1935 * void *Parent :
\90e
\82Ì
\83n
\83\93\83h
\83\8b\r
1936 * char *Name :
\96¼
\91O
\r
1937 * void **Handle :
\83n
\83\93\83h
\83\8b\82ð
\95Ô
\82·
\83\8f\81[
\83N
\r
1940 * int
\83X
\83e
\81[
\83^
\83X
\r
1942 *----------------------------------------------------------------------------*/
\r
1944 static int OpenSubKey(void *Parent, char *Name, void **Handle)
\r
1951 if(TmpRegType == REGTYPE_REG)
\r
1953 if(RegOpenKeyEx(Parent, Name, 0, KEY_READ, (HKEY *)Handle) == ERROR_SUCCESS)
\r
1958 strcpy(Key, ((REGDATATBL *)Parent)->KeyName);
\r
1959 strcat(Key, "\\");
\r
1960 strcat(Key, Name);
\r
1962 while(Pos != NULL)
\r
1964 if(strcmp(Pos->KeyName, Key) == 0)
\r
1977 /*-----
\83T
\83u
\83L
\81[
\82ð
\8dì
\90¬
\82·
\82é ----------------------------------------------------
\r
1980 * void *Parent :
\90e
\82Ì
\83n
\83\93\83h
\83\8b\r
1981 * char *Name :
\96¼
\91O
\r
1982 * void **Handle :
\83n
\83\93\83h
\83\8b\82ð
\95Ô
\82·
\83\8f\81[
\83N
\r
1985 * int
\83X
\83e
\81[
\83^
\83X
\r
1987 *----------------------------------------------------------------------------*/
\r
1989 static int CreateSubKey(void *Parent, char *Name, void **Handle)
\r
1996 if(TmpRegType == REGTYPE_REG)
\r
1998 if(RegCreateKeyEx(Parent, Name, 0, "", REG_OPTION_NON_VOLATILE, KEY_SET_VALUE, NULL, (HKEY *)Handle, &Dispos) == ERROR_SUCCESS)
\r
2003 if((*Handle = malloc(sizeof(REGDATATBL))) != NULL)
\r
2005 strcpy(((REGDATATBL *)(*Handle))->KeyName, ((REGDATATBL *)Parent)->KeyName);
\r
2006 strcat(((REGDATATBL *)(*Handle))->KeyName, "\\");
\r
2007 strcat(((REGDATATBL *)(*Handle))->KeyName, Name);
\r
2009 ((REGDATATBL *)(*Handle))->ValLen = 0;
\r
2010 ((REGDATATBL *)(*Handle))->Next = NULL;
\r
2012 Pos = (REGDATATBL *)Parent;
\r
2013 while(Pos->Next != NULL)
\r
2015 Pos->Next = *Handle;
\r
2023 /*-----
\83T
\83u
\83L
\81[
\82ð
\83N
\83\8d\81[
\83Y
\82·
\82é ------------------------------------------------
\r
2026 * void *Handle :
\83n
\83\93\83h
\83\8b\r
2029 * int
\83X
\83e
\81[
\83^
\83X
\r
2031 *----------------------------------------------------------------------------*/
\r
2033 static int CloseSubKey(void *Handle)
\r
2035 if(TmpRegType == REGTYPE_REG)
\r
2036 RegCloseKey(Handle);
\r
2045 /*-----
\83T
\83u
\83L
\81[
\82ð
\8dí
\8f\9c\82·
\82é ----------------------------------------------------
\r
2048 * void *Handle :
\83n
\83\93\83h
\83\8b\r
2049 * char *Name :
\96¼
\91O
\r
2052 * int
\83X
\83e
\81[
\83^
\83X
\r
2054 *----------------------------------------------------------------------------*/
\r
2056 static int DeleteSubKey(void *Handle, char *Name)
\r
2061 if(TmpRegType == REGTYPE_REG)
\r
2063 if(RegDeleteKey(Handle, Name) == ERROR_SUCCESS)
\r
2074 /*-----
\92l
\82ð
\8dí
\8f\9c\82·
\82é ----------------------------------------------------------
\r
2077 * void *Handle :
\83n
\83\93\83h
\83\8b\r
2078 * char *Name :
\96¼
\91O
\r
2081 * int
\83X
\83e
\81[
\83^
\83X
\r
2083 *----------------------------------------------------------------------------*/
\r
2085 static int DeleteValue(void *Handle, char *Name)
\r
2090 if(TmpRegType == REGTYPE_REG)
\r
2092 if(RegDeleteValue(Handle, Name) == ERROR_SUCCESS)
\r
2103 /*----- INT
\92l
\82ð
\93Ç
\82Ý
\8d\9e\82Þ -------------------------------------------------------
\r
2106 * void *Handle :
\83n
\83\93\83h
\83\8b\r
2107 * char *Name :
\96¼
\91O
\r
2108 * int *Value : INT
\92l
\82ð
\95Ô
\82·
\83\8f\81[
\83N
\r
2111 * int
\83X
\83e
\81[
\83^
\83X
\r
2113 *----------------------------------------------------------------------------*/
\r
2115 static int ReadIntValueFromReg(void *Handle, char *Name, int *Value)
\r
2122 if(TmpRegType == REGTYPE_REG)
\r
2124 Size = sizeof(int);
\r
2125 if(RegQueryValueEx(Handle, Name, NULL, NULL, (BYTE *)Value, &Size) == ERROR_SUCCESS)
\r
2130 if((Pos = ScanValue(Handle, Name)) != NULL)
\r
2132 *Value = atoi(Pos);
\r
2140 /*----- INT
\92l
\82ð
\8f\91\82«
\8d\9e\82Þ -------------------------------------------------------
\r
2143 * void *Handle :
\83n
\83\93\83h
\83\8b\r
2144 * char *Name :
\96¼
\91O
\r
2145 * int Value : INT
\92l
\r
2148 * int
\83X
\83e
\81[
\83^
\83X
\r
2150 *----------------------------------------------------------------------------*/
\r
2152 static int WriteIntValueToReg(void *Handle, char *Name, int Value)
\r
2158 if(TmpRegType == REGTYPE_REG)
\r
2159 RegSetValueEx(Handle, Name, 0, REG_DWORD, (CONST BYTE *)&Value, sizeof(int));
\r
2162 Pos = (REGDATATBL *)Handle;
\r
2163 Data = Pos->ValTbl + Pos->ValLen;
\r
2164 strcpy(Data, Name);
\r
2165 strcat(Data, "=");
\r
2166 sprintf(Tmp, "%d", Value);
\r
2167 strcat(Data, Tmp);
\r
2168 Pos->ValLen += strlen(Data) + 1;
\r
2174 /*-----
\95¶
\8e\9a\97ñ
\82ð
\93Ç
\82Ý
\8d\9e\82Þ ------------------------------------------------------
\r
2177 * void *Handle :
\83n
\83\93\83h
\83\8b\r
2178 * char *Name :
\96¼
\91O
\r
2179 * char *Str :
\95¶
\8e\9a\97ñ
\82ð
\95Ô
\82·
\83\8f\81[
\83N
\r
2180 * DWORD Size :
\8dÅ
\91å
\83T
\83C
\83Y
\r
2183 * int
\83X
\83e
\81[
\83^
\83X
\r
2185 *----------------------------------------------------------------------------*/
\r
2187 static int ReadStringFromReg(void *Handle, char *Name, char *Str, DWORD Size)
\r
2193 if(TmpRegType == REGTYPE_REG)
\r
2195 if(RegQueryValueEx(Handle, Name, NULL, NULL, (BYTE *)Str, &Size) == ERROR_SUCCESS)
\r
2197 if(*(Str + Size - 1) != NUL)
\r
2198 *(Str + Size) = NUL;
\r
2204 if((Pos = ScanValue(Handle, Name)) != NULL)
\r
2206 Size = min1(Size-1, strlen(Pos));
\r
2207 Size = StrReadIn(Pos, Size, Str);
\r
2208 *(Str + Size) = NUL;
\r
2216 /*-----
\95¶
\8e\9a\97ñ
\82ð
\8f\91\82«
\8d\9e\82Þ ------------------------------------------------------
\r
2219 * void *Handle :
\83n
\83\93\83h
\83\8b\r
2220 * char *Name :
\96¼
\91O
\r
2221 * char *Str :
\95¶
\8e\9a\97ñ
\r
2224 * int
\83X
\83e
\81[
\83^
\83X
\r
2226 *----------------------------------------------------------------------------*/
\r
2228 static int WriteStringToReg(void *Handle, char *Name, char *Str)
\r
2233 if(TmpRegType == REGTYPE_REG)
\r
2234 RegSetValueEx(Handle, Name, 0, REG_SZ, (CONST BYTE *)Str, strlen(Str)+1);
\r
2237 Pos = (REGDATATBL *)Handle;
\r
2238 Data = Pos->ValTbl + Pos->ValLen;
\r
2239 strcpy(Data, Name);
\r
2240 strcat(Data, "=");
\r
2241 Pos->ValLen += strlen(Data);
\r
2242 Data = Pos->ValTbl + Pos->ValLen;
\r
2243 Pos->ValLen += StrCatOut(Str, strlen(Str), Data) + 1;
\r
2249 /*-----
\83}
\83\8b\83`
\95¶
\8e\9a\97ñ
\82ð
\93Ç
\82Ý
\8d\9e\82Þ ------------------------------------------------
\r
2252 * void *Handle :
\83n
\83\93\83h
\83\8b\r
2253 * char *Name :
\96¼
\91O
\r
2254 * char *Str :
\95¶
\8e\9a\97ñ
\82ð
\95Ô
\82·
\83\8f\81[
\83N
\r
2255 * DWORD Size :
\8dÅ
\91å
\83T
\83C
\83Y
\r
2258 * int
\83X
\83e
\81[
\83^
\83X
\r
2260 *----------------------------------------------------------------------------*/
\r
2262 static int ReadMultiStringFromReg(void *Handle, char *Name, char *Str, DWORD Size)
\r
2268 if(TmpRegType == REGTYPE_REG)
\r
2270 if(RegQueryValueEx(Handle, Name, NULL, NULL, (BYTE *)Str, &Size) == ERROR_SUCCESS)
\r
2272 if(*(Str + Size - 1) != NUL)
\r
2273 *(Str + Size) = NUL;
\r
2279 if((Pos = ScanValue(Handle, Name)) != NULL)
\r
2281 Size = min1(Size-1, strlen(Pos));
\r
2282 Size = StrReadIn(Pos, Size, Str);
\r
2283 *(Str + Size) = NUL;
\r
2291 /*-----
\83}
\83\8b\83`
\95¶
\8e\9a\97ñ
\82ð
\8f\91\82«
\8d\9e\82Þ ------------------------------------------------
\r
2294 * void *Handle :
\83n
\83\93\83h
\83\8b\r
2295 * char *Name :
\96¼
\91O
\r
2296 * char *Str :
\95¶
\8e\9a\97ñ
\r
2299 * int
\83X
\83e
\81[
\83^
\83X
\r
2301 *----------------------------------------------------------------------------*/
\r
2303 static int WriteMultiStringToReg(void *Handle, char *Name, char *Str)
\r
2308 if(TmpRegType == REGTYPE_REG)
\r
2309 RegSetValueEx(Handle, Name, 0, REG_MULTI_SZ, (CONST BYTE *)Str, StrMultiLen(Str)+1);
\r
2312 Pos = (REGDATATBL *)Handle;
\r
2313 Data = Pos->ValTbl + Pos->ValLen;
\r
2314 strcpy(Data, Name);
\r
2315 strcat(Data, "=");
\r
2316 Pos->ValLen += strlen(Data);
\r
2317 Data = Pos->ValTbl + Pos->ValLen;
\r
2318 Pos->ValLen += StrCatOut(Str, StrMultiLen(Str), Data) + 1;
\r
2324 /*-----
\83o
\83C
\83i
\83\8a\82ð
\93Ç
\82Ý
\8d\9e\82Þ-----------------------------------------------------
\r
2327 * void *Handle :
\83n
\83\93\83h
\83\8b\r
2328 * char *Name :
\96¼
\91O
\r
2329 * void *Bin :
\83o
\83C
\83i
\83\8a\82ð
\95Ô
\82·
\83\8f\81[
\83N
\r
2330 * DWORD Size :
\8dÅ
\91å
\83T
\83C
\83Y
\r
2333 * int
\83X
\83e
\81[
\83^
\83X
\r
2335 *----------------------------------------------------------------------------*/
\r
2337 static int ReadBinaryFromReg(void *Handle, char *Name, void *Bin, DWORD Size)
\r
2343 if(TmpRegType == REGTYPE_REG)
\r
2345 if(RegQueryValueEx(Handle, Name, NULL, NULL, (BYTE *)Bin, &Size) == ERROR_SUCCESS)
\r
2350 if((Pos = ScanValue(Handle, Name)) != NULL)
\r
2352 Size = min1(Size, strlen(Pos));
\r
2353 Size = StrReadIn(Pos, Size, Bin);
\r
2361 /*-----
\83o
\83C
\83i
\83\8a\82ð
\8f\91\82«
\8d\9e\82Þ ----------------------------------------------------
\r
2364 * void *Handle :
\83n
\83\93\83h
\83\8b\r
2365 * char *Name :
\96¼
\91O
\r
2366 * void *Bin :
\83o
\83C
\83i
\83\8a\r
2367 * int Len :
\92·
\82³
\r
2370 * int
\83X
\83e
\81[
\83^
\83X
\r
2372 *----------------------------------------------------------------------------*/
\r
2374 static int WriteBinaryToReg(void *Handle, char *Name, void *Bin, int Len)
\r
2379 if(TmpRegType == REGTYPE_REG)
\r
2380 RegSetValueEx(Handle, Name, 0, REG_BINARY, (CONST BYTE *)Bin, Len);
\r
2383 Pos = (REGDATATBL *)Handle;
\r
2384 Data = Pos->ValTbl + Pos->ValLen;
\r
2385 strcpy(Data, Name);
\r
2386 strcat(Data, "=");
\r
2387 Pos->ValLen += strlen(Data);
\r
2388 Data = Pos->ValTbl + Pos->ValLen;
\r
2389 Pos->ValLen += StrCatOut(Bin, Len, Data) + 1;
\r
2395 /*-----
\95¶
\8e\9a\97ñ
\82ð
\83o
\83b
\83t
\83@
\82É
\92Ç
\89Á
\8f\91\82«
\8d\9e\82Ý
\82·
\82é ------------------------------------
\r
2398 * char *Src :
\95¶
\8e\9a\97ñ
\r
2399 * int len :
\95¶
\8e\9a\97ñ
\82Ì
\92·
\82³
\r
2400 * char *Dst :
\8f\91\82«
\8d\9e\82Ý
\82·
\82é
\83o
\83b
\83t
\83@
\r
2403 * int
\92Ç
\89Á
\82µ
\82½
\83o
\83C
\83g
\90\94\r
2404 *----------------------------------------------------------------------------*/
\r
2406 static int StrCatOut(char *Src, int Len, char *Dst)
\r
2410 Dst += strlen(Dst);
\r
2412 for(; Len > 0; Len--)
\r
2420 else if((*Src >= 0x20) && (*Src <= 0x7E))
\r
2427 sprintf(Dst, "\\%02X", *(unsigned char *)Src);
\r
2438 /*-----
\95¶
\8e\9a\97ñ
\82ð
\83o
\83b
\83t
\83@
\82É
\93Ç
\82Ý
\8d\9e\82Þ --------------------------------------------
\r
2441 * char *Src :
\95¶
\8e\9a\97ñ
\r
2442 * int Max :
\8dÅ
\91å
\83T
\83C
\83Y
\r
2443 * char *Dst :
\8f\91\82«
\8d\9e\82Ý
\82·
\82é
\83o
\83b
\83t
\83@
\r
2446 * int
\93Ç
\82Ý
\8d\9e\82ñ
\82¾
\83o
\83C
\83g
\90\94\r
2447 *----------------------------------------------------------------------------*/
\r
2449 static int StrReadIn(char *Src, int Max, char *Dst)
\r
2455 while(*Src != NUL)
\r
2467 sscanf(Src, "%02x", &Tmp);
\r
2483 /*-----
\92l
\82ð
\8c\9f\8dõ
\82·
\82é ----------------------------------------------------------
\r
2486 * char *Handle :
\83n
\83\93\83h
\83\8b\r
2487 * char *Name :
\96¼
\91O
\r
2490 * char *
\92l
\83f
\81[
\83^
\82Ì
\90æ
\93ª
\r
2491 * NULL=
\8ew
\92è
\82Ì
\96¼
\91O
\82Ì
\92l
\82ª
\8c©
\82Â
\82©
\82ç
\82È
\82¢
\r
2492 *----------------------------------------------------------------------------*/
\r
2494 static char *ScanValue(void *Handle, char *Name)
\r
2502 Pos = Cur->ValTbl;
\r
2503 while(Pos < (Cur->ValTbl + Cur->ValLen))
\r
2505 if((strncmp(Name, Pos, strlen(Name)) == 0) &&
\r
2506 (*(Pos + strlen(Name)) == '='))
\r
2508 Ret = Pos + strlen(Name) + 1;
\r
2511 Pos += strlen(Pos) + 1;
\r
2517 /*-----------
\83p
\83X
\83\8f\81[
\83h
\82Ì
\91Ã
\93\96\90«
\82ð
\8am
\94F
\82·
\82é ------------------------------------
\r
2520 * char *Password:
\83p
\83X
\83\8f\81[
\83h
\95¶
\8e\9a\97ñ
\r
2521 * char *HashStr: SHA-1
\83n
\83b
\83V
\83\85\95¶
\8e\9a\97ñ
\r
2524 * int 0
\95s
\88ê
\92v
\r
2527 *----------------------------------------------------------------------------*/
\r
2528 int CheckPasswordValidity( char* Password, int length, const char* HashStr )
\r
2535 const char* p = HashStr;
\r
2537 /*
\8bó
\95¶
\8e\9a\97ñ
\82Í
\88ê
\92v
\82µ
\82½
\82±
\82Æ
\82É
\82·
\82é */
\r
2538 if( HashStr[0] == NUL ) return 1;
\r
2540 /* Hash
\82ð
\83`
\83F
\83b
\83N
\82·
\82é
\82·
\82é*/
\r
2541 if( strlen(HashStr) != 40 ) return 2;
\r
2543 /* Hash
\82ð
\83f
\83R
\81[
\83h
\82·
\82é*/
\r
2544 for( i = 0; i < 5; i++ ){
\r
2546 for( j = 0; j < 8; j++ ){
\r
2547 if( *p < 0x40 || 0x40 + 15 < *p ){
\r
2550 decode = (decode << 4 ) + (*p - 0x40);
\r
2553 hash1[i] = decode;
\r
2556 /* Password
\82ð
\83n
\83b
\83V
\83\85\82·
\82é */
\r
2557 sha_memory( Password, length, hash2 );
\r
2559 if( memcmp( (char*)hash1, (char*)hash2, sizeof( hash1 )) == 0 ){
\r
2565 /*-----------
\83p
\83X
\83\8f\81[
\83h
\82Ì
\91Ã
\93\96\90«
\83`
\83F
\83b
\83N
\82Ì
\82½
\82ß
\82Ì
\95¶
\8e\9a\97ñ
\82ð
\8dì
\90¬
\82·
\82é ------------
\r
2568 * char *Password:
\83p
\83X
\83\8f\81[
\83h
\95¶
\8e\9a\97ñ
\r
2569 * char *Str: SHA-1
\83n
\83b
\83V
\83\85\95¶
\8e\9a\97ñ
\8ai
\94[
\8fê
\8f\8a (41bytes
\88È
\8fã)
\r
2573 *----------------------------------------------------------------------------*/
\r
2574 void CreatePasswordHash( char* Password, int length, char* HashStr )
\r
2578 unsigned char *p = (unsigned char *)HashStr;
\r
2580 sha_memory( Password, length, hash );
\r
2582 for( i = 0; i < 5; i++ ){
\r
2583 ulong rest = hash[i];
\r
2584 for( j = 0; j < 8; j++ ){
\r
2585 *p++ = (unsigned char)((rest & 0xf0000000) >> 28) + '@';
\r
2592 void SetHashSalt( DWORD salt )
\r
2594 unsigned char* pos = &SecretKey[strlen(SecretKey) + 1];
\r
2595 *pos++ = ( salt >> 24 ) & 0xff;
\r
2596 *pos++ = ( salt >> 16 ) & 0xff;
\r
2597 *pos++ = ( salt >> 8 ) & 0xff;
\r
2598 *pos++ = ( salt ) & 0xff;
\r
2600 SecretKeyLength = strlen( SecretKey ) + 5;
\r
2603 /*-----------
\97\90\90\94\90¶
\90¬
\82ð
\82·
\82é -------------------------------------------------
\r
2608 *
\83\89\83\93\83_
\83\80\82È
\92l
\81F
\83R
\83\93\83p
\83C
\83\89VS2005/
\93®
\8dì
\8aÂ
\8b«WinXP
\88È
\8fã
\82Å
\82Í rand_s
\82©
\82ç
\8eæ
\93¾
\82·
\82é
\r
2609 *----------------------------------------------------------------------------*/
\r
2610 DWORD GetRandamDWRODValue(void)
\r
2614 #ifdef _CRT_RAND_S
\r
2615 errno_t errnoRand_s;
\r
2616 errnoRand_s = rand_s(&rndValue);
\r
2617 errorCode = (0 != errnoRand_s ? 1 : 0);
\r
2621 if(0 != errorCode){
\r
2622 #ifdef USE_RANDAM_C_RAND
\r
2623 rndValue = rand() | (rand() << 16);
\r
2625 /* rand()
\82Ì
\82©
\82í
\82è
\82É
\81ASHA-1
\82Æ
\83p
\83t
\83H
\81[
\83}
\83\93\83X
\83J
\83E
\83\93\83^
\82ð
\97p
\82¢
\82é */
\r
2626 ulong shaValue[5];
\r
2627 LARGE_INTEGER Counter;
\r
2629 if(0 == IsRndSourceInit){
\r
2630 /*
\8f\89\89ñ
\8eæ
\93¾
\8e\9e */
\r
2631 HANDLE CurProcHandle;
\r
2632 HANDLE CurThreadHandle;
\r
2634 if(DuplicateHandle(GetCurrentProcess(), GetCurrentProcess(), GetCurrentProcess(),
\r
2635 &CurProcHandle, 0, FALSE, DUPLICATE_SAME_ACCESS))
\r
2637 CloseHandle(CurProcHandle);
\r
2639 if(DuplicateHandle(GetCurrentProcess(), GetCurrentThread(), GetCurrentProcess(),
\r
2640 &CurThreadHandle, 0, FALSE, DUPLICATE_SAME_ACCESS))
\r
2642 CloseHandle(CurThreadHandle);
\r
2645 /* _WIN64
\82Å
\82Í64bit
\82¾
\82ª
\81A
\82»
\82Ì
\8fê
\8d\87\82Írand_s
\82ª
\91å
\92ï
\97\98\97p
\89Â
\94\
\82È
\82Ì
\82Å
\82±
\82±
\82Å
\82Í32bit
\82Ì
\82Ý
\97p
\82¢
\82é */
\r
2646 RndSource[0] = (ulong)CurProcHandle;
\r
2647 RndSource[1] = (ulong)CurThreadHandle;
\r
2648 RndSource[2] = (ulong)GetTickCount();
\r
2649 RndSource[3] = (ulong)timeGetTime();
\r
2650 RndSource[4] = 0; /*
\83J
\83E
\83\93\83g
\83A
\83b
\83v */
\r
2651 RndSource[5] = RndSource[3] + 1;
\r
2652 IsRndSourceInit = 1;
\r
2655 RndSource[5] += 0x00010010;
\r
2656 if(QueryPerformanceCounter(&Counter)){
\r
2657 RndSource[6] = Counter.LowPart;
\r
2658 RndSource[7] = Counter.HighPart;
\r
2659 RndSource[8] = (ulong)rand();
\r
2661 RndSource[6] = (ulong)timeGetTime();
\r
2662 RndSource[7] = (ulong)rand();
\r
2663 RndSource[8] = (ulong)rand();
\r
2666 sha_memory((char *)RndSource, sizeof(RndSource), shaValue);
\r
2667 rndValue = shaValue[0] ^ shaValue[1] ^ shaValue[2] ^ shaValue[3] ^ shaValue[4];
\r