1 /*=============================================================================
\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)以上でのみ rand_s を利用可能
\r
31 #if 1400 <= _MSC_VER
\r
32 //#define _CRT_RAND_S
\r
37 #include <winsock2.h>
\r
38 #include <windows.h>
\r
43 #include <windowsx.h>
\r
44 #include <process.h>
\r
48 #include "resource.h"
\r
54 /*===== プロトタイプ =====*/
\r
57 //static void SaveStr(HKEY hKey, char *Key, char *Str, char *DefaultStr);
\r
58 //static void SaveIntNum(HKEY hKey, char *Key, int Num, int DefaultNum);
\r
59 static void SaveStr(void *Handle, char *Key, char *Str, char *DefaultStr);
\r
60 static void SaveIntNum(void *Handle, char *Key, int Num, int DefaultNum);
\r
61 static void MakeFontData(LOGFONT Font, HFONT hFont, char *Buf);
\r
62 static int RestoreFontData(char *Str, LOGFONT *Font);
\r
64 static void EncodePassword(char *Str, char *Buf);
\r
65 static void EncodePasswordOriginal(char *Str, char *Buf);
\r
66 static void EncodePassword2(char *Str, char *Buf, const char *Key);
\r
67 static void EncodePassword3(char *Str, char *Buf, const char *Key);
\r
69 static void DecodePassword(char *Str, char *Buf);
\r
70 static void DecodePasswordOriginal(char *Str, char *Buf);
\r
71 static void DecodePassword2(char *Str, char *Buf, const char *Key);
\r
72 static void DecodePassword3(char *Str, char *Buf, const char *Key);
\r
73 static int CreateAesKey(unsigned char *AesKey, const char* Key);
\r
75 static void SetRegType(int Type);
\r
76 static int OpenReg(char *Name, void **Handle);
\r
77 static int CreateReg(char *Name, void **Handle);
\r
78 static int CloseReg(void *Handle);
\r
79 static int OpenSubKey(void *Parent, char *Name, void **Handle);
\r
80 static int CreateSubKey(void *Parent, char *Name, void **Handle);
\r
81 static int CloseSubKey(void *Handle);
\r
82 static int DeleteSubKey(void *Handle, char *Name);
\r
83 static int DeleteValue(void *Handle, char *Name);
\r
84 static int ReadIntValueFromReg(void *Handle, char *Name, int *Value);
\r
85 static int WriteIntValueToReg(void *Handle, char *Name, int Value);
\r
86 static int ReadStringFromReg(void *Handle, char *Name, char *Str, DWORD Size);
\r
87 static int WriteStringToReg(void *Handle, char *Name, char *Str);
\r
88 static int ReadMultiStringFromReg(void *Handle, char *Name, char *Str, DWORD Size);
\r
89 static int WriteMultiStringToReg(void *Handle, char *Name, char *Str);
\r
90 static int ReadBinaryFromReg(void *Handle, char *Name, void *Bin, DWORD Size);
\r
91 static int WriteBinaryToReg(void *Handle, char *Name, void *Bin, int Len);
\r
93 static int StrCatOut(char *Src, int Len, char *Dst);
\r
94 static int StrReadIn(char *Src, int Max, char *Dst);
\r
97 //int CheckPasswordValidity( char* Password, int length, const char* HashStr );
\r
98 //void CreatePasswordHash( char* Password, int length, char* HashStr );
\r
99 int CheckPasswordValidity( char* Password, int length, const char* HashStr, int StretchCount );
\r
100 void CreatePasswordHash( char* Password, int length, char* HashStr, int StretchCount );
\r
101 void SetHashSalt( DWORD salt );
\r
103 void SetHashSalt1(void* Salt, int Length);
\r
105 DWORD GetRandamDWORDValue(void);
\r
108 void GetMaskWithHMACSHA1(DWORD IV, const char* Salt, int SaltLength, void* pHash);
\r
109 void MaskSettingsData(const char* Salt, int SaltLength, void* Data, DWORD Size, int EscapeZero);
\r
110 void UnmaskSettingsData(const char* Salt, int SaltLength, void* Data, DWORD Size, int EscapeZero);
\r
111 void CalculateSettingsDataChecksum(void* Data, DWORD Size);
\r
113 /* 2010.01.30 genta 追加 */
\r
114 static char SecretKey[FMAX_PATH+1];
\r
115 static int SecretKeyLength;
\r
116 static int IsMasterPasswordError = PASSWORD_OK;
\r
118 static int IsRndSourceInit = 0;
\r
119 static ulong RndSource[9];
\r
122 static int IniKanjiCode = KANJI_NOCNV;
\r
125 static int EncryptSettings = NO;
\r
126 static BYTE EncryptSettingsChecksum[20];
\r
127 static int EncryptSettingsError = NO;
\r
129 /*===== 外部参照 =====*/
\r
132 extern int WinPosX;
\r
133 extern int WinPosY;
\r
134 extern int WinWidth;
\r
135 extern int WinHeight;
\r
136 extern int LocalWidth;
\r
137 extern int TaskHeight;
\r
138 extern int LocalTabWidth[4];
\r
139 extern int RemoteTabWidth[6];
\r
140 extern char UserMailAdrs[USER_MAIL_LEN+1];
\r
141 extern char ViewerName[VIEWERS][FMAX_PATH+1];
\r
142 extern HFONT ListFont;
\r
143 extern LOGFONT ListLogFont;
\r
144 extern int LocalFileSort;
\r
145 extern int LocalDirSort;
\r
146 extern int RemoteFileSort;
\r
147 extern int RemoteDirSort;
\r
148 extern int TransMode;
\r
149 extern int ConnectOnStart;
\r
150 extern int DebugConsole;
\r
151 extern int SaveWinPos;
\r
152 extern char AsciiExt[ASCII_EXT_LEN+1];
\r
153 extern int RecvMode;
\r
154 extern int SendMode;
\r
155 extern int MoveMode;
\r
156 extern int ListType;
\r
157 extern int CacheEntry;
\r
158 extern int CacheSave;
\r
159 extern char DefaultLocalPath[FMAX_PATH+1];
\r
160 extern int SaveTimeStamp;
\r
161 extern int FindMode;
\r
162 extern int DotFile;
\r
163 extern int DclickOpen;
\r
164 extern SOUNDFILE Sound[SOUND_TYPES];
\r
165 extern int FnameCnv;
\r
166 extern int ConnectAndSet;
\r
167 extern int TimeOut;
\r
169 extern int RegType;
\r
170 extern char FwallHost[HOST_ADRS_LEN+1];
\r
171 extern char FwallUser[USER_NAME_LEN+1];
\r
172 extern char FwallPass[PASSWORD_LEN+1];
\r
173 extern int FwallPort;
\r
174 extern int FwallType;
\r
175 extern int FwallDefault;
\r
176 extern int FwallSecurity;
\r
177 extern int FwallResolve;
\r
178 extern int FwallLower;
\r
179 extern int FwallDelimiter;
\r
180 extern int PasvDefault;
\r
181 extern char MirrorNoTrn[MIRROR_LEN+1];
\r
182 extern char MirrorNoDel[MIRROR_LEN+1];
\r
183 extern int MirrorFnameCnv;
\r
184 //extern int MirrorFolderCnv;
\r
185 extern int RasClose;
\r
186 extern int RasCloseNotify;
\r
187 extern int FileHist;
\r
188 extern char DefAttrList[DEFATTRLIST_LEN+1];
\r
189 extern SIZE HostDlgSize;
\r
190 extern SIZE BmarkDlgSize;
\r
191 extern SIZE MirrorDlgSize;
\r
193 extern int SortSave;
\r
194 extern char TmpPath[FMAX_PATH+1];
\r
195 extern int QuickAnonymous;
\r
196 extern int PassToHist;
\r
197 extern int VaxSemicolon;
\r
198 extern int SendQuit;
\r
199 extern int NoRasControl;
\r
200 extern int SuppressSave;
\r
202 extern int UpExistMode;
\r
203 extern int ExistMode;
\r
204 extern int DispIgnoreHide;
\r
205 extern int DispDrives;
\r
206 extern int MirUpDelNotify;
\r
207 extern int MirDownDelNotify;
\r
209 extern int FolderAttr;
\r
210 extern int FolderAttrNum;
\r
213 extern BYTE CertificateCacheHash[MAX_CERT_CACHE_HASH][20];
\r
214 extern BYTE SSLRootCAFileHash[20];
\r
216 extern int DispFileIcon;
\r
218 extern int DispTimeSeconds;
\r
220 extern int DispPermissionsNumber;
\r
222 extern int MakeAllDir;
\r
224 extern int LocalKanjiCode;
\r
226 extern int UPnPEnabled;
\r
228 extern int EncryptAllSettings;
\r
230 extern int AutoRefreshFileList;
\r
232 extern int RemoveOldLog;
\r
234 extern int ReadOnlySettings;
\r
236 extern int AutoCheckForUpdates;
\r
237 extern int AutoApplyUpdates;
\r
238 extern int AutoCheckForUptatesInterval;
\r
239 extern time_t LastAutoCheckForUpdates;
\r
241 extern int AbortOnListError;
\r
243 extern int MirrorNoTransferContents;
\r
245 /*----- マスタパスワードの設定 ----------------------------------------------
\r
248 * const char* Password : マスターパスワード
\r
252 *----------------------------------------------------------------------------*/
\r
253 void SetMasterPassword( const char* Password )
\r
255 ZeroMemory( SecretKey, MAX_PASSWORD_LEN + 12 );
\r
256 if( Password != NULL ){
\r
257 strncpy( SecretKey, Password, MAX_PASSWORD_LEN );
\r
260 strcpy( SecretKey, DEFAULT_PASSWORD );
\r
262 SecretKeyLength = strlen( SecretKey );
\r
264 /* 未検証なので,初期状態はOKにする (強制再設定→保存にを可能にする)*/
\r
265 IsMasterPasswordError = PASSWORD_OK;
\r
269 void GetMasterPassword(char* Password)
\r
271 strcpy(Password, SecretKey);
\r
274 /*----- マスタパスワードの状態取得 ----------------------------------------------
\r
281 * PASSWORD_UNMATCH : パスワード不一致
\r
282 * BAD_PASSWORD_HASH : パスワード確認失敗
\r
283 *----------------------------------------------------------------------------*/
\r
284 int GetMasterPasswordStatus(void)
\r
286 return IsMasterPasswordError;
\r
289 /*----- レジストリ/INIファイルのマスターパスワードの検証を行う ------------
\r
296 *----------------------------------------------------------------------------*/
\r
298 int ValidateMasterPassword(void)
\r
303 SetRegType(REGTYPE_INI);
\r
304 if((i = OpenReg("FFFTP", &hKey3)) != FFFTP_SUCCESS)
\r
306 if(AskForceIni() == NO)
\r
308 SetRegType(REGTYPE_REG);
\r
309 i = OpenReg("FFFTP", &hKey3);
\r
312 if(i == FFFTP_SUCCESS){
\r
317 unsigned char salt1[16];
\r
320 // if( ReadIntValueFromReg(hKey3, "CredentialSalt", &salt)){
\r
321 // SetHashSalt( salt );
\r
323 // if( ReadStringFromReg(hKey3, "CredentialCheck", checkbuf, sizeof( checkbuf )) == FFFTP_SUCCESS ){
\r
324 // switch( CheckPasswordValidity( SecretKey, SecretKeyLength, checkbuf ) ){
\r
325 // case 0: /* not match */
\r
326 // IsMasterPasswordError = PASSWORD_UNMATCH;
\r
328 // case 1: /* match */
\r
329 // IsMasterPasswordError = PASSWORD_OK;
\r
331 // case 2: /* invalid hash */
\r
333 // IsMasterPasswordError = BAD_PASSWORD_HASH;
\r
337 if(ReadStringFromReg(hKey3, "CredentialCheck1", checkbuf, sizeof(checkbuf)) == FFFTP_SUCCESS)
\r
339 if(ReadBinaryFromReg(hKey3, "CredentialSalt1", &salt1, sizeof(salt1)) == FFFTP_SUCCESS)
\r
340 SetHashSalt1(&salt1, 16);
\r
342 SetHashSalt1(NULL, 0);
\r
343 ReadIntValueFromReg(hKey3, "CredentialStretch", &stretch);
\r
344 switch(CheckPasswordValidity(SecretKey, SecretKeyLength, checkbuf, stretch))
\r
347 IsMasterPasswordError = PASSWORD_UNMATCH;
\r
350 IsMasterPasswordError = PASSWORD_OK;
\r
353 IsMasterPasswordError = BAD_PASSWORD_HASH;
\r
357 else if(ReadStringFromReg(hKey3, "CredentialCheck", checkbuf, sizeof(checkbuf)) == FFFTP_SUCCESS)
\r
359 if(ReadIntValueFromReg(hKey3, "CredentialSalt", &salt) == FFFTP_SUCCESS)
\r
362 SetHashSalt1(NULL, 0);
\r
363 switch(CheckPasswordValidity(SecretKey, SecretKeyLength, checkbuf, 0))
\r
366 IsMasterPasswordError = PASSWORD_UNMATCH;
\r
369 IsMasterPasswordError = PASSWORD_OK;
\r
372 IsMasterPasswordError = BAD_PASSWORD_HASH;
\r
382 /*----- レジストリ/INIファイルに設定値を保存 ---------------------------------
\r
389 *----------------------------------------------------------------------------*/
\r
391 void SaveRegistry(void)
\r
397 // char Str[FMAX_PATH+1];
\r
398 char Str[PRIVATE_KEY_LEN*4+1];
\r
399 char Buf[FMAX_PATH+1];
\r
402 HOSTDATA DefaultHost;
\r
405 HISTORYDATA DefaultHist;
\r
407 if( GetMasterPasswordStatus() == PASSWORD_UNMATCH ){
\r
408 /* 2010.01.30 genta: マスターパスワードが不一致の場合は不用意に上書きしない */
\r
413 if(EncryptSettingsError == YES)
\r
417 if(ReadOnlySettings == YES)
\r
420 SetRegType(RegType);
\r
421 if(CreateReg("FFFTP", &hKey3) == FFFTP_SUCCESS)
\r
424 int salt = GetTickCount();
\r
426 unsigned char salt1[16];
\r
429 WriteIntValueToReg(hKey3, "Version", VER_NUM);
\r
431 // WriteIntValueToReg(hKey3, "CredentialSalt", salt);
\r
433 // SetHashSalt( salt );
\r
434 // /* save password hash */
\r
435 // CreatePasswordHash( SecretKey, SecretKeyLength, buf );
\r
436 // WriteStringToReg(hKey3, "CredentialCheck", buf);
\r
437 if(EncryptAllSettings == YES)
\r
439 GetProcessTimes(GetCurrentProcess(), &ft[0], &ft[1], &ft[2], &ft[3]);
\r
440 memcpy(&salt1[0], &salt, 4);
\r
441 memcpy(&salt1[4], &ft[0].dwLowDateTime, 4);
\r
442 memcpy(&salt1[8], &ft[2].dwLowDateTime, 4);
\r
443 memcpy(&salt1[12], &ft[3].dwLowDateTime, 4);
\r
444 SetHashSalt1(&salt1, 16);
\r
445 WriteBinaryToReg(hKey3, "CredentialSalt1", &salt1, sizeof(salt1));
\r
446 WriteIntValueToReg(hKey3, "CredentialStretch", 65535);
\r
447 CreatePasswordHash(SecretKey, SecretKeyLength, buf, 65535);
\r
448 WriteStringToReg(hKey3, "CredentialCheck1", buf);
\r
452 SetHashSalt( salt );
\r
453 WriteIntValueToReg(hKey3, "CredentialSalt", salt);
\r
454 CreatePasswordHash(SecretKey, SecretKeyLength, buf, 0);
\r
455 WriteStringToReg(hKey3, "CredentialCheck", buf);
\r
459 WriteIntValueToReg(hKey3, "EncryptAll", EncryptAllSettings);
\r
460 sprintf(Buf, "%d", EncryptAllSettings);
\r
461 EncodePassword(Buf, Str);
\r
462 WriteStringToReg(hKey3, "EncryptAllDetector", Str);
\r
463 EncryptSettings = EncryptAllSettings;
\r
464 memset(&EncryptSettingsChecksum, 0, 20);
\r
467 // if(CreateSubKey(hKey3, "Options", &hKey4) == FFFTP_SUCCESS)
\r
468 if(EncryptAllSettings == YES)
\r
469 strcpy(Str, "EncryptedOptions");
\r
471 strcpy(Str, "Options");
\r
472 if(CreateSubKey(hKey3, Str, &hKey4) == FFFTP_SUCCESS)
\r
474 WriteIntValueToReg(hKey4, "NoSave", SuppressSave);
\r
476 if(SuppressSave != YES)
\r
478 WriteIntValueToReg(hKey4, "WinPosX", WinPosX);
\r
479 WriteIntValueToReg(hKey4, "WinPosY", WinPosY);
\r
480 WriteIntValueToReg(hKey4, "WinWidth", WinWidth);
\r
481 WriteIntValueToReg(hKey4, "WinHeight", WinHeight);
\r
482 WriteIntValueToReg(hKey4, "LocalWidth", LocalWidth);
\r
483 WriteIntValueToReg(hKey4, "TaskHeight", TaskHeight);
\r
484 WriteBinaryToReg(hKey4, "LocalColm", LocalTabWidth, sizeof(LocalTabWidth));
\r
485 WriteBinaryToReg(hKey4, "RemoteColm", RemoteTabWidth, sizeof(RemoteTabWidth));
\r
486 WriteIntValueToReg(hKey4, "SwCmd", Sizing);
\r
488 WriteStringToReg(hKey4, "UserMail", UserMailAdrs);
\r
489 WriteStringToReg(hKey4, "Viewer", ViewerName[0]);
\r
490 WriteStringToReg(hKey4, "Viewer2", ViewerName[1]);
\r
491 WriteStringToReg(hKey4, "Viewer3", ViewerName[2]);
\r
493 WriteIntValueToReg(hKey4, "TrType", TransMode);
\r
494 WriteIntValueToReg(hKey4, "Recv", RecvMode);
\r
495 WriteIntValueToReg(hKey4, "Send", SendMode);
\r
496 WriteIntValueToReg(hKey4, "Move", MoveMode);
\r
497 WriteStringToReg(hKey4, "Path", DefaultLocalPath);
\r
498 WriteIntValueToReg(hKey4, "Time", SaveTimeStamp);
\r
499 WriteIntValueToReg(hKey4, "EOF", RmEOF);
\r
500 WriteIntValueToReg(hKey4, "Scolon", VaxSemicolon);
\r
502 WriteIntValueToReg(hKey4, "RecvEx", ExistMode);
\r
503 WriteIntValueToReg(hKey4, "SendEx", UpExistMode);
\r
505 WriteIntValueToReg(hKey4, "LFsort", LocalFileSort);
\r
506 WriteIntValueToReg(hKey4, "LDsort", LocalDirSort);
\r
507 WriteIntValueToReg(hKey4, "RFsort", RemoteFileSort);
\r
508 WriteIntValueToReg(hKey4, "RDsort", RemoteDirSort);
\r
509 WriteIntValueToReg(hKey4, "SortSave", SortSave);
\r
511 WriteIntValueToReg(hKey4, "ListType", ListType);
\r
512 WriteIntValueToReg(hKey4, "Cache", CacheEntry);
\r
513 WriteIntValueToReg(hKey4, "CacheSave", CacheSave);
\r
514 WriteIntValueToReg(hKey4, "DotFile", DotFile);
\r
515 WriteIntValueToReg(hKey4, "Dclick", DclickOpen);
\r
517 WriteIntValueToReg(hKey4, "ConS", ConnectOnStart);
\r
518 WriteIntValueToReg(hKey4, "OldDlg", ConnectAndSet);
\r
519 WriteIntValueToReg(hKey4, "RasClose", RasClose);
\r
520 WriteIntValueToReg(hKey4, "RasNotify", RasCloseNotify);
\r
521 WriteIntValueToReg(hKey4, "Qanony", QuickAnonymous);
\r
522 WriteIntValueToReg(hKey4, "PassHist", PassToHist);
\r
523 WriteIntValueToReg(hKey4, "SendQuit", SendQuit);
\r
524 WriteIntValueToReg(hKey4, "NoRas", NoRasControl);
\r
526 WriteIntValueToReg(hKey4, "Debug", DebugConsole);
\r
527 WriteIntValueToReg(hKey4, "WinPos", SaveWinPos);
\r
528 WriteIntValueToReg(hKey4, "RegExp", FindMode);
\r
529 WriteIntValueToReg(hKey4, "Reg", RegType);
\r
531 WriteMultiStringToReg(hKey4, "AsciiFile", AsciiExt);
\r
532 WriteIntValueToReg(hKey4, "LowUp", FnameCnv);
\r
533 WriteIntValueToReg(hKey4, "Tout", TimeOut);
\r
535 WriteMultiStringToReg(hKey4, "NoTrn", MirrorNoTrn);
\r
536 WriteMultiStringToReg(hKey4, "NoDel", MirrorNoDel);
\r
537 WriteIntValueToReg(hKey4, "MirFile", MirrorFnameCnv);
\r
538 WriteIntValueToReg(hKey4, "MirUNot", MirUpDelNotify);
\r
539 WriteIntValueToReg(hKey4, "MirDNot", MirDownDelNotify);
\r
541 MakeFontData(ListLogFont, ListFont, Str);
\r
542 WriteStringToReg(hKey4, "ListFont", Str);
\r
543 WriteIntValueToReg(hKey4, "ListHide", DispIgnoreHide);
\r
544 WriteIntValueToReg(hKey4, "ListDrv", DispDrives);
\r
546 WriteStringToReg(hKey4, "FwallHost", FwallHost);
\r
547 WriteStringToReg(hKey4, "FwallUser", FwallUser);
\r
548 EncodePassword(FwallPass, Str);
\r
549 WriteStringToReg(hKey4, "FwallPass", Str);
\r
550 WriteIntValueToReg(hKey4, "FwallPort", FwallPort);
\r
551 WriteIntValueToReg(hKey4, "FwallType", FwallType);
\r
552 WriteIntValueToReg(hKey4, "FwallDef", FwallDefault);
\r
553 WriteIntValueToReg(hKey4, "FwallSec", FwallSecurity);
\r
554 WriteIntValueToReg(hKey4, "PasvDef", PasvDefault);
\r
555 WriteIntValueToReg(hKey4, "FwallRes", FwallResolve);
\r
556 WriteIntValueToReg(hKey4, "FwallLow", FwallLower);
\r
557 WriteIntValueToReg(hKey4, "FwallDel", FwallDelimiter);
\r
559 WriteIntValueToReg(hKey4, "SndConSw", Sound[SND_CONNECT].On);
\r
560 WriteIntValueToReg(hKey4, "SndTrnSw", Sound[SND_TRANS].On);
\r
561 WriteIntValueToReg(hKey4, "SndErrSw", Sound[SND_ERROR].On);
\r
562 WriteStringToReg(hKey4, "SndCon", Sound[SND_CONNECT].Fname);
\r
563 WriteStringToReg(hKey4, "SndTrn", Sound[SND_TRANS].Fname);
\r
564 WriteStringToReg(hKey4, "SndErr", Sound[SND_ERROR].Fname);
\r
566 WriteMultiStringToReg(hKey4, "DefAttr", DefAttrList);
\r
569 // GetTempPath(FMAX_PATH, Str);
\r
570 GetAppTempPath(Str);
\r
572 SaveStr(hKey4, "Tmp", TmpPath, Str);
\r
574 WriteBinaryToReg(hKey4, "Hdlg", &HostDlgSize, sizeof(SIZE));
\r
575 WriteBinaryToReg(hKey4, "Bdlg", &BmarkDlgSize, sizeof(SIZE));
\r
576 WriteBinaryToReg(hKey4, "Mdlg", &MirrorDlgSize, sizeof(SIZE));
\r
578 WriteIntValueToReg(hKey4, "FAttrSw", FolderAttr);
\r
579 WriteIntValueToReg(hKey4, "FAttr", FolderAttrNum);
\r
581 WriteIntValueToReg(hKey4, "HistNum", FileHist);
\r
583 /* Ver1.54a以前の形式のヒストリデータは削除 */
\r
584 DeleteValue(hKey4, "Hist");
\r
587 CopyDefaultHistory(&DefaultHist);
\r
589 for(i = AskHistoryNum(); i > 0; i--)
\r
591 if(GetHistoryByNum(i-1, &Hist) == FFFTP_SUCCESS)
\r
593 sprintf(Str, "History%d", n);
\r
594 if(CreateSubKey(hKey4, Str, &hKey5) == FFFTP_SUCCESS)
\r
596 SaveStr(hKey5, "HostAdrs", Hist.HostAdrs, DefaultHist.HostAdrs);
\r
597 SaveStr(hKey5, "UserName", Hist.UserName, DefaultHist.UserName);
\r
598 SaveStr(hKey5, "Account", Hist.Account, DefaultHist.Account);
\r
599 SaveStr(hKey5, "LocalDir", Hist.LocalInitDir, NULL);
\r
600 SaveStr(hKey5, "RemoteDir", Hist.RemoteInitDir, DefaultHist.RemoteInitDir);
\r
601 SaveStr(hKey5, "Chmod", Hist.ChmodCmd, DefaultHist.ChmodCmd);
\r
602 SaveStr(hKey5, "Nlst", Hist.LsName, DefaultHist.LsName);
\r
603 SaveStr(hKey5, "Init", Hist.InitCmd, DefaultHist.InitCmd);
\r
604 EncodePassword(Hist.PassWord, Str);
\r
605 SaveStr(hKey5, "Password", Str, DefaultHist.PassWord);
\r
606 SaveIntNum(hKey5, "Port", Hist.Port, DefaultHist.Port);
\r
607 SaveIntNum(hKey5, "Kanji", Hist.KanjiCode, DefaultHist.KanjiCode);
\r
608 SaveIntNum(hKey5, "KanaCnv", Hist.KanaCnv, DefaultHist.KanaCnv);
\r
609 SaveIntNum(hKey5, "NameKanji", Hist.NameKanjiCode, DefaultHist.NameKanjiCode);
\r
610 SaveIntNum(hKey5, "NameKana", Hist.NameKanaCnv, DefaultHist.NameKanaCnv);
\r
611 SaveIntNum(hKey5, "Pasv", Hist.Pasv, DefaultHist.Pasv);
\r
612 SaveIntNum(hKey5, "Fwall", Hist.FireWall, DefaultHist.FireWall);
\r
613 SaveIntNum(hKey5, "List", Hist.ListCmdOnly, DefaultHist.ListCmdOnly);
\r
614 SaveIntNum(hKey5, "NLST-R", Hist.UseNLST_R, DefaultHist.UseNLST_R);
\r
615 SaveIntNum(hKey5, "Tzone", Hist.TimeZone, DefaultHist.TimeZone);
\r
616 SaveIntNum(hKey5, "Type", Hist.HostType, DefaultHist.HostType);
\r
617 SaveIntNum(hKey5, "Sync", Hist.SyncMove, DefaultHist.SyncMove);
\r
618 SaveIntNum(hKey5, "Fpath", Hist.NoFullPath, DefaultHist.NoFullPath);
\r
619 WriteBinaryToReg(hKey5, "Sort", &Hist.Sort, sizeof(Hist.Sort));
\r
620 SaveIntNum(hKey5, "Secu", Hist.Security, DefaultHist.Security);
\r
621 WriteIntValueToReg(hKey5, "TrType", Hist.Type);
\r
622 SaveIntNum(hKey5, "Dial", Hist.Dialup, DefaultHist.Dialup);
\r
623 SaveIntNum(hKey5, "UseIt", Hist.DialupAlways, DefaultHist.DialupAlways);
\r
624 SaveIntNum(hKey5, "Notify", Hist.DialupNotify, DefaultHist.DialupNotify);
\r
625 SaveStr(hKey5, "DialTo", Hist.DialEntry, DefaultHist.DialEntry);
\r
627 SaveIntNum(hKey5, "NoEncryption", Hist.UseNoEncryption, DefaultHist.UseNoEncryption);
\r
628 SaveIntNum(hKey5, "FTPES", Hist.UseFTPES, DefaultHist.UseFTPES);
\r
629 SaveIntNum(hKey5, "FTPIS", Hist.UseFTPIS, DefaultHist.UseFTPIS);
\r
630 SaveIntNum(hKey5, "SFTP", Hist.UseSFTP, DefaultHist.UseSFTP);
\r
631 EncodePassword(Hist.PrivateKey, Str);
\r
632 SaveStr(hKey5, "PKey", Str, DefaultHist.PrivateKey);
\r
633 SaveIntNum(hKey5, "NoWeak", Hist.NoWeakEncryption, DefaultHist.NoWeakEncryption);
\r
635 SaveIntNum(hKey5, "ThreadCount", Hist.MaxThreadCount, DefaultHist.MaxThreadCount);
\r
636 SaveIntNum(hKey5, "ReuseCmdSkt", Hist.ReuseCmdSkt, DefaultHist.ReuseCmdSkt);
\r
638 SaveIntNum(hKey5, "MLSD", Hist.UseMLSD, DefaultHist.UseMLSD);
\r
640 SaveIntNum(hKey5, "NetType", Hist.NetType, DefaultHist.NetType);
\r
642 SaveIntNum(hKey5, "Noop", Hist.NoopInterval, DefaultHist.NoopInterval);
\r
644 SaveIntNum(hKey5, "ErrMode", Hist.TransferErrorMode, DefaultHist.TransferErrorMode);
\r
645 SaveIntNum(hKey5, "ErrNotify", Hist.TransferErrorNotify, DefaultHist.TransferErrorNotify);
\r
646 // セッションあたりの転送量制限対策
\r
647 SaveIntNum(hKey5, "ErrReconnect", Hist.TransferErrorReconnect, DefaultHist.TransferErrorReconnect);
\r
649 CloseSubKey(hKey5);
\r
654 WriteIntValueToReg(hKey4, "SavedHist", n);
\r
656 /* 余分なヒストリがあったら削除 */
\r
657 for(; n < 999; n++)
\r
659 sprintf(Str, "History%d", n);
\r
660 if(DeleteSubKey(hKey4, Str) != FFFTP_SUCCESS)
\r
665 if(CreateSubKey(hKey4, "DefaultHost", &hKey5) == FFFTP_SUCCESS)
\r
667 CopyDefaultDefaultHost(&DefaultHost);
\r
668 CopyDefaultHost(&Host);
\r
669 WriteIntValueToReg(hKey5, "Set", Host.Level);
\r
670 SaveStr(hKey5, "HostName", Host.HostName, DefaultHost.HostName);
\r
671 SaveStr(hKey5, "HostAdrs", Host.HostAdrs, DefaultHost.HostAdrs);
\r
672 SaveStr(hKey5, "UserName", Host.UserName, DefaultHost.UserName);
\r
673 SaveStr(hKey5, "Account", Host.Account, DefaultHost.Account);
\r
674 SaveStr(hKey5, "LocalDir", Host.LocalInitDir, NULL);
\r
675 SaveStr(hKey5, "RemoteDir", Host.RemoteInitDir, DefaultHost.RemoteInitDir);
\r
676 SaveStr(hKey5, "Chmod", Host.ChmodCmd, DefaultHost.ChmodCmd);
\r
677 SaveStr(hKey5, "Nlst", Host.LsName, DefaultHost.LsName);
\r
678 SaveStr(hKey5, "Init", Host.InitCmd, DefaultHost.InitCmd);
\r
679 if(Host.Anonymous == NO)
\r
680 EncodePassword(Host.PassWord, Str);
\r
682 strcpy(Str, DefaultHost.PassWord);
\r
683 SaveStr(hKey5, "Password", Str, DefaultHost.PassWord);
\r
684 SaveIntNum(hKey5, "Port", Host.Port, DefaultHost.Port);
\r
685 SaveIntNum(hKey5, "Anonymous", Host.Anonymous, DefaultHost.Anonymous);
\r
686 SaveIntNum(hKey5, "Kanji", Host.KanjiCode, DefaultHost.KanjiCode);
\r
687 SaveIntNum(hKey5, "KanaCnv", Host.KanaCnv, DefaultHost.KanaCnv);
\r
688 SaveIntNum(hKey5, "NameKanji", Host.NameKanjiCode, DefaultHost.NameKanjiCode);
\r
689 SaveIntNum(hKey5, "NameKana", Host.NameKanaCnv, DefaultHost.NameKanaCnv);
\r
690 SaveIntNum(hKey5, "Pasv", Host.Pasv, DefaultHost.Pasv);
\r
691 SaveIntNum(hKey5, "Fwall", Host.FireWall, DefaultHost.FireWall);
\r
692 SaveIntNum(hKey5, "List", Host.ListCmdOnly, DefaultHost.ListCmdOnly);
\r
693 SaveIntNum(hKey5, "NLST-R", Host.UseNLST_R, DefaultHost.UseNLST_R);
\r
694 SaveIntNum(hKey5, "Last", Host.LastDir, DefaultHost.LastDir);
\r
695 SaveIntNum(hKey5, "Tzone", Host.TimeZone, DefaultHost.TimeZone);
\r
696 SaveIntNum(hKey5, "Type", Host.HostType, DefaultHost.HostType);
\r
697 SaveIntNum(hKey5, "Sync", Host.SyncMove, DefaultHost.SyncMove);
\r
698 SaveIntNum(hKey5, "Fpath", Host.NoFullPath, DefaultHost.NoFullPath);
\r
699 WriteBinaryToReg(hKey5, "Sort", &Host.Sort, sizeof(Host.Sort));
\r
700 SaveIntNum(hKey5, "Secu", Host.Security, DefaultHost.Security);
\r
701 WriteMultiStringToReg(hKey5, "Bmarks", Host.BookMark);
\r
702 SaveIntNum(hKey5, "Dial", Host.Dialup, DefaultHost.Dialup);
\r
703 SaveIntNum(hKey5, "UseIt", Host.DialupAlways, DefaultHost.DialupAlways);
\r
704 SaveIntNum(hKey5, "Notify", Host.DialupNotify, DefaultHost.DialupNotify);
\r
705 SaveStr(hKey5, "DialTo", Host.DialEntry, DefaultHost.DialEntry);
\r
706 SaveIntNum(hKey5, "NoEncryption", Host.UseNoEncryption, DefaultHost.UseNoEncryption);
\r
707 SaveIntNum(hKey5, "FTPES", Host.UseFTPES, DefaultHost.UseFTPES);
\r
708 SaveIntNum(hKey5, "FTPIS", Host.UseFTPIS, DefaultHost.UseFTPIS);
\r
709 SaveIntNum(hKey5, "SFTP", Host.UseSFTP, DefaultHost.UseSFTP);
\r
710 EncodePassword(Host.PrivateKey, Str);
\r
711 SaveStr(hKey5, "PKey", Str, DefaultHost.PrivateKey);
\r
712 SaveIntNum(hKey5, "NoWeak", Host.NoWeakEncryption, DefaultHost.NoWeakEncryption);
\r
713 SaveIntNum(hKey5, "ThreadCount", Host.MaxThreadCount, DefaultHost.MaxThreadCount);
\r
714 SaveIntNum(hKey5, "ReuseCmdSkt", Host.ReuseCmdSkt, DefaultHost.ReuseCmdSkt);
\r
715 SaveIntNum(hKey5, "MLSD", Host.UseMLSD, DefaultHost.UseMLSD);
\r
716 SaveIntNum(hKey5, "NetType", Host.NetType, DefaultHost.NetType);
\r
717 SaveIntNum(hKey5, "Noop", Host.NoopInterval, DefaultHost.NoopInterval);
\r
718 SaveIntNum(hKey5, "ErrMode", Host.TransferErrorMode, DefaultHost.TransferErrorMode);
\r
719 SaveIntNum(hKey5, "ErrNotify", Host.TransferErrorNotify, DefaultHost.TransferErrorNotify);
\r
720 SaveIntNum(hKey5, "ErrReconnect", Host.TransferErrorReconnect, DefaultHost.TransferErrorReconnect);
\r
721 CloseSubKey(hKey5);
\r
725 CopyDefaultHost(&DefaultHost);
\r
727 while(CopyHostFromList(i, &Host) == FFFTP_SUCCESS)
\r
729 sprintf(Str, "Host%d", i);
\r
730 if(CreateSubKey(hKey4, Str, &hKey5) == FFFTP_SUCCESS)
\r
732 // SaveIntNum(hKey5, "Set", Host.Level, DefaultHost.Level);
\r
733 WriteIntValueToReg(hKey5, "Set", Host.Level);
\r
734 SaveStr(hKey5, "HostName", Host.HostName, DefaultHost.HostName);
\r
735 if((Host.Level & SET_LEVEL_GROUP) == 0)
\r
737 SaveStr(hKey5, "HostAdrs", Host.HostAdrs, DefaultHost.HostAdrs);
\r
738 SaveStr(hKey5, "UserName", Host.UserName, DefaultHost.UserName);
\r
739 SaveStr(hKey5, "Account", Host.Account, DefaultHost.Account);
\r
740 SaveStr(hKey5, "LocalDir", Host.LocalInitDir, NULL);
\r
741 SaveStr(hKey5, "RemoteDir", Host.RemoteInitDir, DefaultHost.RemoteInitDir);
\r
742 SaveStr(hKey5, "Chmod", Host.ChmodCmd, DefaultHost.ChmodCmd);
\r
743 SaveStr(hKey5, "Nlst", Host.LsName, DefaultHost.LsName);
\r
744 SaveStr(hKey5, "Init", Host.InitCmd, DefaultHost.InitCmd);
\r
746 if(Host.Anonymous == NO)
\r
747 EncodePassword(Host.PassWord, Str);
\r
749 strcpy(Str, DefaultHost.PassWord);
\r
750 SaveStr(hKey5, "Password", Str, DefaultHost.PassWord);
\r
752 SaveIntNum(hKey5, "Port", Host.Port, DefaultHost.Port);
\r
753 SaveIntNum(hKey5, "Anonymous", Host.Anonymous, DefaultHost.Anonymous);
\r
754 SaveIntNum(hKey5, "Kanji", Host.KanjiCode, DefaultHost.KanjiCode);
\r
755 SaveIntNum(hKey5, "KanaCnv", Host.KanaCnv, DefaultHost.KanaCnv);
\r
756 SaveIntNum(hKey5, "NameKanji", Host.NameKanjiCode, DefaultHost.NameKanjiCode);
\r
757 SaveIntNum(hKey5, "NameKana", Host.NameKanaCnv, DefaultHost.NameKanaCnv);
\r
758 SaveIntNum(hKey5, "Pasv", Host.Pasv, DefaultHost.Pasv);
\r
759 SaveIntNum(hKey5, "Fwall", Host.FireWall, DefaultHost.FireWall);
\r
760 SaveIntNum(hKey5, "List", Host.ListCmdOnly, DefaultHost.ListCmdOnly);
\r
761 SaveIntNum(hKey5, "NLST-R", Host.UseNLST_R, DefaultHost.UseNLST_R);
\r
762 SaveIntNum(hKey5, "Last", Host.LastDir, DefaultHost.LastDir);
\r
763 SaveIntNum(hKey5, "Tzone", Host.TimeZone, DefaultHost.TimeZone);
\r
764 SaveIntNum(hKey5, "Type", Host.HostType, DefaultHost.HostType);
\r
765 SaveIntNum(hKey5, "Sync", Host.SyncMove, DefaultHost.SyncMove);
\r
766 SaveIntNum(hKey5, "Fpath", Host.NoFullPath, DefaultHost.NoFullPath);
\r
767 WriteBinaryToReg(hKey5, "Sort", &Host.Sort, sizeof(Host.Sort));
\r
768 SaveIntNum(hKey5, "Secu", Host.Security, DefaultHost.Security);
\r
770 WriteMultiStringToReg(hKey5, "Bmarks", Host.BookMark);
\r
772 SaveIntNum(hKey5, "Dial", Host.Dialup, DefaultHost.Dialup);
\r
773 SaveIntNum(hKey5, "UseIt", Host.DialupAlways, DefaultHost.DialupAlways);
\r
774 SaveIntNum(hKey5, "Notify", Host.DialupNotify, DefaultHost.DialupNotify);
\r
775 SaveStr(hKey5, "DialTo", Host.DialEntry, DefaultHost.DialEntry);
\r
777 SaveIntNum(hKey5, "NoEncryption", Host.UseNoEncryption, DefaultHost.UseNoEncryption);
\r
778 SaveIntNum(hKey5, "FTPES", Host.UseFTPES, DefaultHost.UseFTPES);
\r
779 SaveIntNum(hKey5, "FTPIS", Host.UseFTPIS, DefaultHost.UseFTPIS);
\r
780 SaveIntNum(hKey5, "SFTP", Host.UseSFTP, DefaultHost.UseSFTP);
\r
781 EncodePassword(Host.PrivateKey, Str);
\r
782 SaveStr(hKey5, "PKey", Str, DefaultHost.PrivateKey);
\r
783 SaveIntNum(hKey5, "NoWeak", Host.NoWeakEncryption, DefaultHost.NoWeakEncryption);
\r
785 SaveIntNum(hKey5, "ThreadCount", Host.MaxThreadCount, DefaultHost.MaxThreadCount);
\r
786 SaveIntNum(hKey5, "ReuseCmdSkt", Host.ReuseCmdSkt, DefaultHost.ReuseCmdSkt);
\r
788 SaveIntNum(hKey5, "MLSD", Host.UseMLSD, DefaultHost.UseMLSD);
\r
790 SaveIntNum(hKey5, "NetType", Host.NetType, DefaultHost.NetType);
\r
792 SaveIntNum(hKey5, "Noop", Host.NoopInterval, DefaultHost.NoopInterval);
\r
794 SaveIntNum(hKey5, "ErrMode", Host.TransferErrorMode, DefaultHost.TransferErrorMode);
\r
795 SaveIntNum(hKey5, "ErrNotify", Host.TransferErrorNotify, DefaultHost.TransferErrorNotify);
\r
796 // セッションあたりの転送量制限対策
\r
797 SaveIntNum(hKey5, "ErrReconnect", Host.TransferErrorReconnect, DefaultHost.TransferErrorReconnect);
\r
799 CloseSubKey(hKey5);
\r
803 WriteIntValueToReg(hKey4, "SetNum", i);
\r
805 /* 余分なホストの設定があったら削除 */
\r
806 for(; i < 998; i++)
\r
808 sprintf(Str, "Host%d", i);
\r
809 if(DeleteSubKey(hKey4, Str) != FFFTP_SUCCESS)
\r
813 if((i = AskCurrentHost()) == HOSTNUM_NOENTRY)
\r
815 WriteIntValueToReg(hKey4, "CurSet", i);
\r
818 WriteBinaryToReg(hKey4, "CertCacheHash", &CertificateCacheHash, sizeof(CertificateCacheHash));
\r
820 StrCatOut((char*)&SSLRootCAFileHash, sizeof(SSLRootCAFileHash), Buf);
\r
821 EncodePassword(Buf, Str);
\r
822 WriteStringToReg(hKey4, "RootCertHash", Str);
\r
824 WriteIntValueToReg(hKey4, "ListIcon", DispFileIcon);
\r
826 WriteIntValueToReg(hKey4, "ListSecond", DispTimeSeconds);
\r
828 WriteIntValueToReg(hKey4, "ListPermitNum", DispPermissionsNumber);
\r
830 WriteIntValueToReg(hKey4, "MakeDir", MakeAllDir);
\r
832 WriteIntValueToReg(hKey4, "Kanji", LocalKanjiCode);
\r
834 WriteIntValueToReg(hKey4, "UPnP", UPnPEnabled);
\r
836 WriteIntValueToReg(hKey4, "ListRefresh", AutoRefreshFileList);
\r
838 WriteIntValueToReg(hKey4, "OldLog", RemoveOldLog);
\r
840 WriteIntValueToReg(hKey4, "UpdCheck", AutoCheckForUpdates);
\r
841 WriteIntValueToReg(hKey4, "UpdApply", AutoApplyUpdates);
\r
842 WriteIntValueToReg(hKey4, "UpdInterval", AutoCheckForUptatesInterval);
\r
843 WriteBinaryToReg(hKey4, "UpdLastCheck", &LastAutoCheckForUpdates, sizeof(LastAutoCheckForUpdates));
\r
845 WriteIntValueToReg(hKey4, "AbortListErr", AbortOnListError);
\r
847 WriteIntValueToReg(hKey4, "MirNoTransfer", MirrorNoTransferContents);
\r
849 CloseSubKey(hKey4);
\r
852 EncryptSettings = NO;
\r
853 WriteBinaryToReg(hKey3, "EncryptAllChecksum", &EncryptSettingsChecksum, 20);
\r
854 if(EncryptAllSettings == YES)
\r
856 if(OpenSubKey(hKey3, "Options", &hKey4) == FFFTP_SUCCESS)
\r
860 sprintf(Str, "Host%d", i);
\r
861 if(DeleteSubKey(hKey4, Str) != FFFTP_SUCCESS)
\r
866 sprintf(Str, "History%d", i);
\r
867 if(DeleteSubKey(hKey4, Str) != FFFTP_SUCCESS)
\r
870 CloseSubKey(hKey4);
\r
872 DeleteSubKey(hKey3, "Options");
\r
873 DeleteValue(hKey3, "CredentialSalt");
\r
874 DeleteValue(hKey3, "CredentialCheck");
\r
878 if(OpenSubKey(hKey3, "EncryptedOptions", &hKey4) == FFFTP_SUCCESS)
\r
882 sprintf(Str, "Host%d", i);
\r
883 if(DeleteSubKey(hKey4, Str) != FFFTP_SUCCESS)
\r
888 sprintf(Str, "History%d", i);
\r
889 if(DeleteSubKey(hKey4, Str) != FFFTP_SUCCESS)
\r
892 CloseSubKey(hKey4);
\r
894 DeleteSubKey(hKey3, "EncryptedOptions");
\r
895 DeleteValue(hKey3, "CredentialSalt1");
\r
896 DeleteValue(hKey3, "CredentialStretch");
\r
897 DeleteValue(hKey3, "CredentialCheck1");
\r
904 /*----- レジストリ/INIファイルから設定値を呼び出す ---------------------------
\r
906 * この関数を複数回呼び出すと,ホスト設定が追加される.
\r
914 *----------------------------------------------------------------------------*/
\r
916 int LoadRegistry(void)
\r
924 // char Str[256]; /* ASCII_EXT_LENより大きい事 */
\r
925 char Str[PRIVATE_KEY_LEN*4+1];
\r
926 char Buf[FMAX_PATH+1];
\r
928 char Buf2[FMAX_PATH+1];
\r
940 SetRegType(REGTYPE_INI);
\r
941 if((i = OpenReg("FFFTP", &hKey3)) != FFFTP_SUCCESS)
\r
943 if(AskForceIni() == NO)
\r
945 SetRegType(REGTYPE_REG);
\r
946 i = OpenReg("FFFTP", &hKey3);
\r
950 if(i == FFFTP_SUCCESS)
\r
952 // char checkbuf[48];
\r
956 ReadIntValueFromReg(hKey3, "Version", &Version);
\r
959 IniKanjiCode = KANJI_SJIS;
\r
962 if(Version >= 1990)
\r
964 if(GetMasterPasswordStatus() == PASSWORD_OK)
\r
966 ReadIntValueFromReg(hKey3, "EncryptAll", &EncryptAllSettings);
\r
967 sprintf(Buf, "%d", EncryptAllSettings);
\r
968 ReadStringFromReg(hKey3, "EncryptAllDetector", Str, 255);
\r
969 DecodePassword(Str, Buf2);
\r
970 EncryptSettings = EncryptAllSettings;
\r
971 memset(&EncryptSettingsChecksum, 0, 20);
\r
972 if(strcmp(Buf, Buf2) != 0)
\r
974 switch(DialogBox(GetFtpInst(), MAKEINTRESOURCE(corruptsettings_dlg), GetMainHwnd(), AnyButtonDialogProc))
\r
987 EncryptSettingsError = YES;
\r
997 // if(OpenSubKey(hKey3, "Options", &hKey4) == FFFTP_SUCCESS)
\r
998 if(EncryptAllSettings == YES)
\r
999 strcpy(Str, "EncryptedOptions");
\r
1001 strcpy(Str, "Options");
\r
1002 if(OpenSubKey(hKey3, Str, &hKey4) == FFFTP_SUCCESS)
\r
1004 ReadIntValueFromReg(hKey4, "WinPosX", &WinPosX);
\r
1005 ReadIntValueFromReg(hKey4, "WinPosY", &WinPosY);
\r
1006 ReadIntValueFromReg(hKey4, "WinWidth", &WinWidth);
\r
1007 ReadIntValueFromReg(hKey4, "WinHeight", &WinHeight);
\r
1008 ReadIntValueFromReg(hKey4, "LocalWidth", &LocalWidth);
\r
1009 /* ↓旧バージョンのバグ対策 */
\r
1010 LocalWidth = max1(0, LocalWidth);
\r
1011 ReadIntValueFromReg(hKey4, "TaskHeight", &TaskHeight);
\r
1012 /* ↓旧バージョンのバグ対策 */
\r
1013 TaskHeight = max1(0, TaskHeight);
\r
1014 ReadBinaryFromReg(hKey4, "LocalColm", &LocalTabWidth, sizeof(LocalTabWidth));
\r
1015 ReadBinaryFromReg(hKey4, "RemoteColm", &RemoteTabWidth, sizeof(RemoteTabWidth));
\r
1016 ReadIntValueFromReg(hKey4, "SwCmd", &Sizing);
\r
1018 ReadStringFromReg(hKey4, "UserMail", UserMailAdrs, USER_MAIL_LEN+1);
\r
1019 ReadStringFromReg(hKey4, "Viewer", ViewerName[0], FMAX_PATH+1);
\r
1020 ReadStringFromReg(hKey4, "Viewer2", ViewerName[1], FMAX_PATH+1);
\r
1021 ReadStringFromReg(hKey4, "Viewer3", ViewerName[2], FMAX_PATH+1);
\r
1023 ReadIntValueFromReg(hKey4, "TrType", &TransMode);
\r
1024 ReadIntValueFromReg(hKey4, "Recv", &RecvMode);
\r
1025 ReadIntValueFromReg(hKey4, "Send", &SendMode);
\r
1026 ReadIntValueFromReg(hKey4, "Move", &MoveMode);
\r
1027 ReadStringFromReg(hKey4, "Path", DefaultLocalPath, FMAX_PATH+1);
\r
1028 ReadIntValueFromReg(hKey4, "Time", &SaveTimeStamp);
\r
1029 ReadIntValueFromReg(hKey4, "EOF", &RmEOF);
\r
1030 ReadIntValueFromReg(hKey4, "Scolon", &VaxSemicolon);
\r
1032 ReadIntValueFromReg(hKey4, "RecvEx", &ExistMode);
\r
1033 ReadIntValueFromReg(hKey4, "SendEx", &UpExistMode);
\r
1035 ReadIntValueFromReg(hKey4, "LFsort", &LocalFileSort);
\r
1036 ReadIntValueFromReg(hKey4, "LDsort", &LocalDirSort);
\r
1037 ReadIntValueFromReg(hKey4, "RFsort", &RemoteFileSort);
\r
1038 ReadIntValueFromReg(hKey4, "RDsort", &RemoteDirSort);
\r
1039 ReadIntValueFromReg(hKey4, "SortSave", &SortSave);
\r
1041 ReadIntValueFromReg(hKey4, "ListType", &ListType);
\r
1042 ReadIntValueFromReg(hKey4, "Cache", &CacheEntry);
\r
1043 ReadIntValueFromReg(hKey4, "CacheSave", &CacheSave);
\r
1044 ReadIntValueFromReg(hKey4, "DotFile", &DotFile);
\r
1045 ReadIntValueFromReg(hKey4, "Dclick", &DclickOpen);
\r
1047 ReadIntValueFromReg(hKey4, "ConS", &ConnectOnStart);
\r
1048 ReadIntValueFromReg(hKey4, "OldDlg", &ConnectAndSet);
\r
1049 ReadIntValueFromReg(hKey4, "RasClose", &RasClose);
\r
1050 ReadIntValueFromReg(hKey4, "RasNotify", &RasCloseNotify);
\r
1051 ReadIntValueFromReg(hKey4, "Qanony", &QuickAnonymous);
\r
1052 ReadIntValueFromReg(hKey4, "PassHist", &PassToHist);
\r
1053 ReadIntValueFromReg(hKey4, "SendQuit", &SendQuit);
\r
1054 ReadIntValueFromReg(hKey4, "NoRas", &NoRasControl);
\r
1056 ReadIntValueFromReg(hKey4, "Debug", &DebugConsole);
\r
1057 ReadIntValueFromReg(hKey4, "WinPos", &SaveWinPos);
\r
1058 ReadIntValueFromReg(hKey4, "RegExp", &FindMode);
\r
1059 ReadIntValueFromReg(hKey4, "Reg", &RegType);
\r
1061 if(ReadMultiStringFromReg(hKey4, "AsciiFile", AsciiExt, ASCII_EXT_LEN+1) == FFFTP_FAIL)
\r
1063 /* 旧ASCIIモードの拡張子の設定を新しいものに変換 */
\r
1065 // ReadStringFromReg(hKey4, "Ascii", Str, ASCII_EXT_LEN+1);
\r
1066 // memset(AsciiExt, NUL, ASCII_EXT_LEN+1);
\r
1068 if(ReadStringFromReg(hKey4, "Ascii", Str, ASCII_EXT_LEN+1) == FFFTP_SUCCESS)
\r
1069 memset(AsciiExt, NUL, ASCII_EXT_LEN+1);
\r
1071 while(*Pos != NUL)
\r
1073 if((Pos2 = strchr(Pos, ';')) == NULL)
\r
1074 Pos2 = strchr(Pos, NUL);
\r
1075 if((Pos2 - Pos) > 0)
\r
1077 if((StrMultiLen(AsciiExt) + (Pos2 - Pos) + 2) >= ASCII_EXT_LEN)
\r
1079 strcpy(AsciiExt + StrMultiLen(AsciiExt), "*.");
\r
1080 strncpy(AsciiExt + StrMultiLen(AsciiExt) - 1, Pos, (Pos2 - Pos));
\r
1088 if(Version < 1986)
\r
1090 Pos = "*.js\0*.vbs\0*.css\0*.rss\0*.rdf\0*.xml\0*.xhtml\0*.xht\0*.shtml\0*.shtm\0*.sh\0*.py\0*.rb\0*.properties\0*.sql\0*.asp\0*.aspx\0*.php\0*.htaccess\0";
\r
1091 while(*Pos != NUL)
\r
1094 while(*Pos2 != NUL)
\r
1096 if(_stricmp(Pos2, Pos) == 0)
\r
1098 Pos2 = strchr(Pos2, NUL) + 1;
\r
1102 if((StrMultiLen(AsciiExt) + strlen(Pos) + 2) < ASCII_EXT_LEN)
\r
1103 strncpy(AsciiExt + StrMultiLen(AsciiExt), Pos, strlen(Pos) + 2);
\r
1105 Pos = strchr(Pos, NUL) + 1;
\r
1109 ReadIntValueFromReg(hKey4, "LowUp", &FnameCnv);
\r
1110 ReadIntValueFromReg(hKey4, "Tout", &TimeOut);
\r
1112 ReadMultiStringFromReg(hKey4, "NoTrn", MirrorNoTrn, MIRROR_LEN+1);
\r
1113 ReadMultiStringFromReg(hKey4, "NoDel", MirrorNoDel, MIRROR_LEN+1);
\r
1114 ReadIntValueFromReg(hKey4, "MirFile", &MirrorFnameCnv);
\r
1115 ReadIntValueFromReg(hKey4, "MirUNot", &MirUpDelNotify);
\r
1116 ReadIntValueFromReg(hKey4, "MirDNot", &MirDownDelNotify);
\r
1118 if(ReadStringFromReg(hKey4, "ListFont", Str, 256) == FFFTP_SUCCESS)
\r
1120 if(RestoreFontData(Str, &ListLogFont) == FFFTP_SUCCESS)
\r
1121 ListFont = CreateFontIndirect(&ListLogFont);
\r
1123 ReadIntValueFromReg(hKey4, "ListHide", &DispIgnoreHide);
\r
1124 ReadIntValueFromReg(hKey4, "ListDrv", &DispDrives);
\r
1126 ReadStringFromReg(hKey4, "FwallHost", FwallHost, HOST_ADRS_LEN+1);
\r
1127 ReadStringFromReg(hKey4, "FwallUser", FwallUser, USER_NAME_LEN+1);
\r
1128 ReadStringFromReg(hKey4, "FwallPass", Str, 255);
\r
1129 DecodePassword(Str, FwallPass);
\r
1130 ReadIntValueFromReg(hKey4, "FwallPort", &FwallPort);
\r
1131 ReadIntValueFromReg(hKey4, "FwallType", &FwallType);
\r
1132 ReadIntValueFromReg(hKey4, "FwallDef", &FwallDefault);
\r
1133 ReadIntValueFromReg(hKey4, "FwallSec", &FwallSecurity);
\r
1134 ReadIntValueFromReg(hKey4, "PasvDef", &PasvDefault);
\r
1135 ReadIntValueFromReg(hKey4, "FwallRes", &FwallResolve);
\r
1136 ReadIntValueFromReg(hKey4, "FwallLow", &FwallLower);
\r
1137 ReadIntValueFromReg(hKey4, "FwallDel", &FwallDelimiter);
\r
1139 ReadIntValueFromReg(hKey4, "SndConSw", &Sound[SND_CONNECT].On);
\r
1140 ReadIntValueFromReg(hKey4, "SndTrnSw", &Sound[SND_TRANS].On);
\r
1141 ReadIntValueFromReg(hKey4, "SndErrSw", &Sound[SND_ERROR].On);
\r
1142 ReadStringFromReg(hKey4, "SndCon", Sound[SND_CONNECT].Fname, FMAX_PATH+1);
\r
1143 ReadStringFromReg(hKey4, "SndTrn", Sound[SND_TRANS].Fname, FMAX_PATH+1);
\r
1144 ReadStringFromReg(hKey4, "SndErr", Sound[SND_ERROR].Fname, FMAX_PATH+1);
\r
1146 ReadMultiStringFromReg(hKey4, "DefAttr", DefAttrList, DEFATTRLIST_LEN+1);
\r
1148 ReadStringFromReg(hKey4, "Tmp", TmpPath, FMAX_PATH+1);
\r
1150 ReadBinaryFromReg(hKey4, "Hdlg", &HostDlgSize, sizeof(SIZE));
\r
1151 ReadBinaryFromReg(hKey4, "Bdlg", &BmarkDlgSize, sizeof(SIZE));
\r
1152 ReadBinaryFromReg(hKey4, "Mdlg", &MirrorDlgSize, sizeof(SIZE));
\r
1154 ReadIntValueFromReg(hKey4, "FAttrSw", &FolderAttr);
\r
1155 ReadIntValueFromReg(hKey4, "FAttr", &FolderAttrNum);
\r
1157 ReadIntValueFromReg(hKey4, "NoSave", &SuppressSave);
\r
1159 ReadIntValueFromReg(hKey4, "HistNum", &FileHist);
\r
1160 // ReadMultiStringFromReg(hKey4, "Hist", Hist, (FMAX_PATH+1)*HISTORY_MAX+1);
\r
1162 /* ヒストリの設定を読み込む */
\r
1164 ReadIntValueFromReg(hKey4, "SavedHist", &Sets);
\r
1166 for(i = 0; i < Sets; i++)
\r
1168 sprintf(Str, "History%d", i);
\r
1169 if(OpenSubKey(hKey4, Str, &hKey5) == FFFTP_SUCCESS)
\r
1171 CopyDefaultHistory(&Hist);
\r
1173 ReadStringFromReg(hKey5, "HostAdrs", Hist.HostAdrs, HOST_ADRS_LEN+1);
\r
1174 ReadStringFromReg(hKey5, "UserName", Hist.UserName, USER_NAME_LEN+1);
\r
1175 ReadStringFromReg(hKey5, "Account", Hist.Account, ACCOUNT_LEN+1);
\r
1176 ReadStringFromReg(hKey5, "LocalDir", Hist.LocalInitDir, INIT_DIR_LEN+1);
\r
1177 ReadStringFromReg(hKey5, "RemoteDir", Hist.RemoteInitDir, INIT_DIR_LEN+1);
\r
1178 ReadStringFromReg(hKey5, "Chmod", Hist.ChmodCmd, CHMOD_CMD_LEN+1);
\r
1179 ReadStringFromReg(hKey5, "Nlst", Hist.LsName, NLST_NAME_LEN+1);
\r
1180 ReadStringFromReg(hKey5, "Init", Hist.InitCmd, INITCMD_LEN+1);
\r
1181 ReadIntValueFromReg(hKey5, "Port", &Hist.Port);
\r
1182 ReadIntValueFromReg(hKey5, "Kanji", &Hist.KanjiCode);
\r
1183 ReadIntValueFromReg(hKey5, "KanaCnv", &Hist.KanaCnv);
\r
1184 ReadIntValueFromReg(hKey5, "NameKanji", &Hist.NameKanjiCode);
\r
1185 ReadIntValueFromReg(hKey5, "NameKana", &Hist.NameKanaCnv);
\r
1186 ReadIntValueFromReg(hKey5, "Pasv", &Hist.Pasv);
\r
1187 ReadIntValueFromReg(hKey5, "Fwall", &Hist.FireWall);
\r
1188 ReadIntValueFromReg(hKey5, "List", &Hist.ListCmdOnly);
\r
1189 ReadIntValueFromReg(hKey5, "NLST-R", &Hist.UseNLST_R);
\r
1190 ReadIntValueFromReg(hKey5, "Tzone", &Hist.TimeZone);
\r
1191 ReadIntValueFromReg(hKey5, "Type", &Hist.HostType);
\r
1192 ReadIntValueFromReg(hKey5, "Sync", &Hist.SyncMove);
\r
1193 ReadIntValueFromReg(hKey5, "Fpath", &Hist.NoFullPath);
\r
1194 ReadBinaryFromReg(hKey5, "Sort", &Hist.Sort, sizeof(Hist.Sort));
\r
1195 ReadIntValueFromReg(hKey5, "Secu", &Hist.Security);
\r
1196 ReadIntValueFromReg(hKey5, "TrType", &Hist.Type);
\r
1198 ReadStringFromReg(hKey5, "Password", Str, 255);
\r
1199 DecodePassword(Str, Hist.PassWord);
\r
1200 ReadIntValueFromReg(hKey5, "Dial", &Hist.Dialup);
\r
1201 ReadIntValueFromReg(hKey5, "UseIt", &Hist.DialupAlways);
\r
1202 ReadIntValueFromReg(hKey5, "Notify", &Hist.DialupNotify);
\r
1203 ReadStringFromReg(hKey5, "DialTo", Hist.DialEntry, RAS_NAME_LEN+1);
\r
1205 ReadIntValueFromReg(hKey5, "NoEncryption", &Hist.UseNoEncryption);
\r
1206 ReadIntValueFromReg(hKey5, "FTPES", &Hist.UseFTPES);
\r
1207 ReadIntValueFromReg(hKey5, "FTPIS", &Hist.UseFTPIS);
\r
1208 ReadIntValueFromReg(hKey5, "SFTP", &Hist.UseSFTP);
\r
1210 ReadStringFromReg(hKey5, "PKey", Str, PRIVATE_KEY_LEN*4+1);
\r
1211 DecodePassword(Str, Hist.PrivateKey);
\r
1212 ReadIntValueFromReg(hKey5, "NoWeak", &Hist.NoWeakEncryption);
\r
1214 ReadIntValueFromReg(hKey5, "ThreadCount", &Hist.MaxThreadCount);
\r
1215 ReadIntValueFromReg(hKey5, "ReuseCmdSkt", &Hist.ReuseCmdSkt);
\r
1217 ReadIntValueFromReg(hKey5, "MLSD", &Hist.UseMLSD);
\r
1219 ReadIntValueFromReg(hKey5, "NetType", &Hist.NetType);
\r
1221 ReadIntValueFromReg(hKey5, "Noop", &Hist.NoopInterval);
\r
1223 ReadIntValueFromReg(hKey5, "ErrMode", &Hist.TransferErrorMode);
\r
1224 ReadIntValueFromReg(hKey5, "ErrNotify", &Hist.TransferErrorNotify);
\r
1225 // セッションあたりの転送量制限対策
\r
1226 ReadIntValueFromReg(hKey5, "ErrReconnect", &Hist.TransferErrorReconnect);
\r
1228 CloseSubKey(hKey5);
\r
1229 AddHistoryToHistory(&Hist);
\r
1234 if(OpenSubKey(hKey4, "DefaultHost", &hKey5) == FFFTP_SUCCESS)
\r
1236 CopyDefaultDefaultHost(&Host);
\r
1237 ReadIntValueFromReg(hKey5, "Set", &Host.Level);
\r
1238 ReadStringFromReg(hKey5, "HostName", Host.HostName, HOST_NAME_LEN+1);
\r
1239 ReadStringFromReg(hKey5, "HostAdrs", Host.HostAdrs, HOST_ADRS_LEN+1);
\r
1240 ReadStringFromReg(hKey5, "UserName", Host.UserName, USER_NAME_LEN+1);
\r
1241 ReadStringFromReg(hKey5, "Account", Host.Account, ACCOUNT_LEN+1);
\r
1242 ReadStringFromReg(hKey5, "LocalDir", Host.LocalInitDir, INIT_DIR_LEN+1);
\r
1243 ReadStringFromReg(hKey5, "RemoteDir", Host.RemoteInitDir, INIT_DIR_LEN+1);
\r
1244 ReadStringFromReg(hKey5, "Chmod", Host.ChmodCmd, CHMOD_CMD_LEN+1);
\r
1245 ReadStringFromReg(hKey5, "Nlst", Host.LsName, NLST_NAME_LEN+1);
\r
1246 ReadStringFromReg(hKey5, "Init", Host.InitCmd, INITCMD_LEN+1);
\r
1247 ReadIntValueFromReg(hKey5, "Port", &Host.Port);
\r
1248 ReadIntValueFromReg(hKey5, "Anonymous", &Host.Anonymous);
\r
1249 ReadIntValueFromReg(hKey5, "Kanji", &Host.KanjiCode);
\r
1250 ReadIntValueFromReg(hKey5, "KanaCnv", &Host.KanaCnv);
\r
1251 ReadIntValueFromReg(hKey5, "NameKanji", &Host.NameKanjiCode);
\r
1252 ReadIntValueFromReg(hKey5, "NameKana", &Host.NameKanaCnv);
\r
1253 ReadIntValueFromReg(hKey5, "Pasv", &Host.Pasv);
\r
1254 ReadIntValueFromReg(hKey5, "Fwall", &Host.FireWall);
\r
1255 ReadIntValueFromReg(hKey5, "List", &Host.ListCmdOnly);
\r
1256 ReadIntValueFromReg(hKey5, "NLST-R", &Host.UseNLST_R);
\r
1257 ReadIntValueFromReg(hKey5, "Last", &Host.LastDir);
\r
1258 ReadIntValueFromReg(hKey5, "Tzone", &Host.TimeZone);
\r
1259 ReadIntValueFromReg(hKey5, "Type", &Host.HostType);
\r
1260 ReadIntValueFromReg(hKey5, "Sync", &Host.SyncMove);
\r
1261 ReadIntValueFromReg(hKey5, "Fpath", &Host.NoFullPath);
\r
1262 ReadBinaryFromReg(hKey5, "Sort", &Host.Sort, sizeof(Host.Sort));
\r
1263 ReadIntValueFromReg(hKey5, "Secu", &Host.Security);
\r
1264 if(Host.Anonymous != YES)
\r
1267 ReadStringFromReg(hKey5, "Password", Str, 255);
\r
1268 DecodePassword(Str, Host.PassWord);
\r
1271 strcpy(Host.PassWord, UserMailAdrs);
\r
1272 ReadMultiStringFromReg(hKey5, "Bmarks", Host.BookMark, BOOKMARK_SIZE);
\r
1273 ReadIntValueFromReg(hKey5, "Dial", &Host.Dialup);
\r
1274 ReadIntValueFromReg(hKey5, "UseIt", &Host.DialupAlways);
\r
1275 ReadIntValueFromReg(hKey5, "Notify", &Host.DialupNotify);
\r
1276 ReadStringFromReg(hKey5, "DialTo", Host.DialEntry, RAS_NAME_LEN+1);
\r
1277 ReadIntValueFromReg(hKey5, "NoEncryption", &Host.UseNoEncryption);
\r
1278 ReadIntValueFromReg(hKey5, "FTPES", &Host.UseFTPES);
\r
1279 ReadIntValueFromReg(hKey5, "FTPIS", &Host.UseFTPIS);
\r
1280 ReadIntValueFromReg(hKey5, "SFTP", &Host.UseSFTP);
\r
1282 ReadStringFromReg(hKey5, "PKey", Str, PRIVATE_KEY_LEN*4+1);
\r
1283 DecodePassword(Str, Host.PrivateKey);
\r
1284 ReadIntValueFromReg(hKey5, "NoWeak", &Host.NoWeakEncryption);
\r
1285 ReadIntValueFromReg(hKey5, "ThreadCount", &Host.MaxThreadCount);
\r
1286 ReadIntValueFromReg(hKey5, "ReuseCmdSkt", &Host.ReuseCmdSkt);
\r
1287 ReadIntValueFromReg(hKey5, "MLSD", &Host.UseMLSD);
\r
1288 ReadIntValueFromReg(hKey5, "NetType", &Host.NetType);
\r
1289 ReadIntValueFromReg(hKey5, "Noop", &Host.NoopInterval);
\r
1290 ReadIntValueFromReg(hKey5, "ErrMode", &Host.TransferErrorMode);
\r
1291 ReadIntValueFromReg(hKey5, "ErrNotify", &Host.TransferErrorNotify);
\r
1292 ReadIntValueFromReg(hKey5, "ErrReconnect", &Host.TransferErrorReconnect);
\r
1294 CloseSubKey(hKey5);
\r
1296 SetDefaultHost(&Host);
\r
1301 ReadIntValueFromReg(hKey4, "SetNum", &Sets);
\r
1303 for(i = 0; i < Sets; i++)
\r
1305 sprintf(Str, "Host%d", i);
\r
1306 if(OpenSubKey(hKey4, Str, &hKey5) == FFFTP_SUCCESS)
\r
1308 CopyDefaultHost(&Host);
\r
1310 // SourceForge.JPによるフォーク
\r
1311 // if(Version < VER_NUM)
\r
1312 if(Version < 1921)
\r
1315 Host.ListCmdOnly = NO;
\r
1317 // 1.97b以前はデフォルトでShift_JIS
\r
1318 if(Version < 1980)
\r
1319 Host.NameKanjiCode = KANJI_SJIS;
\r
1320 ReadIntValueFromReg(hKey5, "Set", &Host.Level);
\r
1322 ReadStringFromReg(hKey5, "HostName", Host.HostName, HOST_NAME_LEN+1);
\r
1323 ReadStringFromReg(hKey5, "HostAdrs", Host.HostAdrs, HOST_ADRS_LEN+1);
\r
1324 ReadStringFromReg(hKey5, "UserName", Host.UserName, USER_NAME_LEN+1);
\r
1325 ReadStringFromReg(hKey5, "Account", Host.Account, ACCOUNT_LEN+1);
\r
1326 ReadStringFromReg(hKey5, "LocalDir", Host.LocalInitDir, INIT_DIR_LEN+1);
\r
1327 ReadStringFromReg(hKey5, "RemoteDir", Host.RemoteInitDir, INIT_DIR_LEN+1);
\r
1328 ReadStringFromReg(hKey5, "Chmod", Host.ChmodCmd, CHMOD_CMD_LEN+1);
\r
1329 ReadStringFromReg(hKey5, "Nlst", Host.LsName, NLST_NAME_LEN+1);
\r
1330 ReadStringFromReg(hKey5, "Init", Host.InitCmd, INITCMD_LEN+1);
\r
1331 ReadIntValueFromReg(hKey5, "Port", &Host.Port);
\r
1332 ReadIntValueFromReg(hKey5, "Anonymous", &Host.Anonymous);
\r
1333 ReadIntValueFromReg(hKey5, "Kanji", &Host.KanjiCode);
\r
1334 // 1.98b以前のUTF-8はBOMあり
\r
1335 if(Version < 1983)
\r
1337 if(Host.KanjiCode == KANJI_UTF8N)
\r
1338 Host.KanjiCode = KANJI_UTF8BOM;
\r
1340 ReadIntValueFromReg(hKey5, "KanaCnv", &Host.KanaCnv);
\r
1341 ReadIntValueFromReg(hKey5, "NameKanji", &Host.NameKanjiCode);
\r
1342 ReadIntValueFromReg(hKey5, "NameKana", &Host.NameKanaCnv);
\r
1343 ReadIntValueFromReg(hKey5, "Pasv", &Host.Pasv);
\r
1344 ReadIntValueFromReg(hKey5, "Fwall", &Host.FireWall);
\r
1345 ReadIntValueFromReg(hKey5, "List", &Host.ListCmdOnly);
\r
1346 ReadIntValueFromReg(hKey5, "NLST-R", &Host.UseNLST_R);
\r
1347 ReadIntValueFromReg(hKey5, "Last", &Host.LastDir);
\r
1348 ReadIntValueFromReg(hKey5, "Tzone", &Host.TimeZone);
\r
1349 ReadIntValueFromReg(hKey5, "Type", &Host.HostType);
\r
1350 ReadIntValueFromReg(hKey5, "Sync", &Host.SyncMove);
\r
1351 ReadIntValueFromReg(hKey5, "Fpath", &Host.NoFullPath);
\r
1352 ReadBinaryFromReg(hKey5, "Sort", &Host.Sort, sizeof(Host.Sort));
\r
1353 ReadIntValueFromReg(hKey5, "Secu", &Host.Security);
\r
1354 if(Host.Anonymous != YES)
\r
1357 ReadStringFromReg(hKey5, "Password", Str, 255);
\r
1358 DecodePassword(Str, Host.PassWord);
\r
1361 strcpy(Host.PassWord, UserMailAdrs);
\r
1363 ReadMultiStringFromReg(hKey5, "Bmarks", Host.BookMark, BOOKMARK_SIZE);
\r
1365 ReadIntValueFromReg(hKey5, "Dial", &Host.Dialup);
\r
1366 ReadIntValueFromReg(hKey5, "UseIt", &Host.DialupAlways);
\r
1367 ReadIntValueFromReg(hKey5, "Notify", &Host.DialupNotify);
\r
1368 ReadStringFromReg(hKey5, "DialTo", Host.DialEntry, RAS_NAME_LEN+1);
\r
1370 ReadIntValueFromReg(hKey5, "NoEncryption", &Host.UseNoEncryption);
\r
1371 ReadIntValueFromReg(hKey5, "FTPES", &Host.UseFTPES);
\r
1372 ReadIntValueFromReg(hKey5, "FTPIS", &Host.UseFTPIS);
\r
1373 ReadIntValueFromReg(hKey5, "SFTP", &Host.UseSFTP);
\r
1375 ReadStringFromReg(hKey5, "PKey", Str, PRIVATE_KEY_LEN*4+1);
\r
1376 DecodePassword(Str, Host.PrivateKey);
\r
1377 ReadIntValueFromReg(hKey5, "NoWeak", &Host.NoWeakEncryption);
\r
1379 ReadIntValueFromReg(hKey5, "ThreadCount", &Host.MaxThreadCount);
\r
1380 ReadIntValueFromReg(hKey5, "ReuseCmdSkt", &Host.ReuseCmdSkt);
\r
1381 // 1.98d以前で同時接続数が1より大きい場合はソケットの再利用なし
\r
1382 if(Version < 1985)
\r
1384 if(Host.MaxThreadCount > 1)
\r
1385 Host.ReuseCmdSkt = NO;
\r
1388 ReadIntValueFromReg(hKey5, "MLSD", &Host.UseMLSD);
\r
1390 ReadIntValueFromReg(hKey5, "NetType", &Host.NetType);
\r
1392 ReadIntValueFromReg(hKey5, "Noop", &Host.NoopInterval);
\r
1394 ReadIntValueFromReg(hKey5, "ErrMode", &Host.TransferErrorMode);
\r
1395 ReadIntValueFromReg(hKey5, "ErrNotify", &Host.TransferErrorNotify);
\r
1396 // セッションあたりの転送量制限対策
\r
1397 ReadIntValueFromReg(hKey5, "ErrReconnect", &Host.TransferErrorReconnect);
\r
1399 CloseSubKey(hKey5);
\r
1401 AddHostToList(&Host, -1, Host.Level);
\r
1405 ReadIntValueFromReg(hKey4, "CurSet", &Sets);
\r
1406 SetCurrentHost(Sets);
\r
1409 ReadBinaryFromReg(hKey4, "CertCacheHash", &CertificateCacheHash, sizeof(CertificateCacheHash));
\r
1410 ReadStringFromReg(hKey4, "RootCertHash", Str, PRIVATE_KEY_LEN*4+1);
\r
1411 DecodePassword(Str, Buf);
\r
1412 StrReadIn(Buf, sizeof(SSLRootCAFileHash), (char*)&SSLRootCAFileHash);
\r
1414 ReadIntValueFromReg(hKey4, "ListIcon", &DispFileIcon);
\r
1416 ReadIntValueFromReg(hKey4, "ListSecond", &DispTimeSeconds);
\r
1418 ReadIntValueFromReg(hKey4, "ListPermitNum", &DispPermissionsNumber);
\r
1420 ReadIntValueFromReg(hKey4, "MakeDir", &MakeAllDir);
\r
1422 ReadIntValueFromReg(hKey4, "Kanji", &LocalKanjiCode);
\r
1424 ReadIntValueFromReg(hKey4, "UPnP", &UPnPEnabled);
\r
1426 ReadIntValueFromReg(hKey4, "ListRefresh", &AutoRefreshFileList);
\r
1428 ReadIntValueFromReg(hKey4, "OldLog", &RemoveOldLog);
\r
1430 ReadIntValueFromReg(hKey4, "UpdCheck", &AutoCheckForUpdates);
\r
1431 ReadIntValueFromReg(hKey4, "UpdApply", &AutoApplyUpdates);
\r
1432 ReadIntValueFromReg(hKey4, "UpdInterval", &AutoCheckForUptatesInterval);
\r
1433 ReadBinaryFromReg(hKey4, "UpdLastCheck", &LastAutoCheckForUpdates, sizeof(LastAutoCheckForUpdates));
\r
1435 ReadIntValueFromReg(hKey4, "AbortListErr", &AbortOnListError);
\r
1437 ReadIntValueFromReg(hKey4, "MirNoTransfer", &MirrorNoTransferContents);
\r
1439 CloseSubKey(hKey4);
\r
1442 EncryptSettings = NO;
\r
1443 if(Version >= 1990)
\r
1445 if(GetMasterPasswordStatus() == PASSWORD_OK)
\r
1447 memset(&Checksum, 0, 20);
\r
1448 ReadBinaryFromReg(hKey3, "EncryptAllChecksum", &Checksum, 20);
\r
1449 if(memcmp(&Checksum, &EncryptSettingsChecksum, 20) != 0)
\r
1451 switch(DialogBox(GetFtpInst(), MAKEINTRESOURCE(corruptsettings_dlg), GetMainHwnd(), AnyButtonDialogProc))
\r
1464 EncryptSettingsError = YES;
\r
1476 /*===== 最初の起動時(設定が無い) =====*/
\r
1479 strcpy(UserMailAdrs, "");
\r
1481 if(InputDialogBox(mailadrs_dlg, HWND_DESKTOP, NULL, Str, USER_MAIL_LEN+1, &i, IDH_HELP_TOPIC_0000001) == YES)
\r
1482 strcpy(UserMailAdrs, Str);
\r
1484 for(i = 0; i < SAMPLE_HOSTS; i++)
\r
1486 CopyDefaultHost(&Host);
\r
1487 Host.Level = Sample[i].Level;
\r
1488 strcpy(Host.PassWord, UserMailAdrs);
\r
1489 strcpy(Host.HostName, Sample[i].HostName);
\r
1490 strcpy(Host.HostAdrs, Sample[i].HostAdrs);
\r
1491 strcpy(Host.UserName, "anonymous");
\r
1492 AddHostToList(&Host, -1, Host.Level);
\r
1500 /*----- 隠しドライブ情報を取得 ------------------------------------------------
\r
1508 *----------------------------------------------------------------------------*/
\r
1510 DWORD LoadHideDriveListRegistry(void)
\r
1523 if(RegOpenKeyEx(HKEY_CURRENT_USER, "Software", 0, KEY_READ, &hKey1) == ERROR_SUCCESS)
\r
1525 if(RegOpenKeyEx(hKey1, "Microsoft", 0, KEY_READ, &hKey2) == ERROR_SUCCESS)
\r
1527 if(RegOpenKeyEx(hKey2, "Windows", 0, KEY_READ, &hKey3) == ERROR_SUCCESS)
\r
1529 if(RegOpenKeyEx(hKey3, "CurrentVersion", 0, KEY_READ, &hKey4) == ERROR_SUCCESS)
\r
1531 if(RegOpenKeyEx(hKey4, "Policies", 0, KEY_READ, &hKey5) == ERROR_SUCCESS)
\r
1533 if(RegOpenKeyEx(hKey5, "Explorer", 0, KEY_READ, &hKey6) == ERROR_SUCCESS)
\r
1535 Size = sizeof(DWORD);
\r
1536 RegQueryValueEx(hKey6, "NoDrives", NULL, &Type, (BYTE *)&Ret, &Size);
\r
1537 RegCloseKey(hKey6);
\r
1539 RegCloseKey(hKey5);
\r
1541 RegCloseKey(hKey4);
\r
1543 RegCloseKey(hKey3);
\r
1545 RegCloseKey(hKey2);
\r
1547 RegCloseKey(hKey1);
\r
1553 /*----- レジストリの設定値をクリア --------------------------------------------
\r
1560 *----------------------------------------------------------------------------*/
\r
1562 void ClearRegistry(void)
\r
1571 if(RegCreateKeyEx(HKEY_CURRENT_USER, "Software\\Sota", 0, "", REG_OPTION_NON_VOLATILE, KEY_CREATE_SUB_KEY, NULL, &hKey2, &Dispos) == ERROR_SUCCESS)
\r
1573 if(RegCreateKeyEx(hKey2, "FFFTP", 0, "", REG_OPTION_NON_VOLATILE, KEY_WRITE, NULL, &hKey3, &Dispos) == ERROR_SUCCESS)
\r
1575 if(RegCreateKeyEx(hKey3, "Options", 0, "", REG_OPTION_NON_VOLATILE, KEY_WRITE, NULL, &hKey4, &Dispos) == ERROR_SUCCESS)
\r
1579 sprintf(Str, "Host%d", i);
\r
1580 if(RegDeleteKey(hKey4, Str) != ERROR_SUCCESS)
\r
1585 sprintf(Str, "History%d", i);
\r
1586 if(RegDeleteKey(hKey4, Str) != ERROR_SUCCESS)
\r
1589 RegCloseKey(hKey4);
\r
1591 RegDeleteKey(hKey3, "Options");
\r
1593 if(RegCreateKeyEx(hKey3, "EncryptedOptions", 0, "", REG_OPTION_NON_VOLATILE, KEY_WRITE, NULL, &hKey4, &Dispos) == ERROR_SUCCESS)
\r
1597 sprintf(Str, "Host%d", i);
\r
1598 if(RegDeleteKey(hKey4, Str) != ERROR_SUCCESS)
\r
1603 sprintf(Str, "History%d", i);
\r
1604 if(RegDeleteKey(hKey4, Str) != ERROR_SUCCESS)
\r
1607 RegCloseKey(hKey4);
\r
1609 RegDeleteKey(hKey3, "EncryptedOptions");
\r
1610 RegCloseKey(hKey3);
\r
1612 RegDeleteKey(hKey2, "FFFTP");
\r
1613 RegCloseKey(hKey2);
\r
1620 void ClearIni(void)
\r
1623 // if((Strm = fopen(AskIniFilePath(), "rt")) != NULL)
\r
1626 // MoveFileToTrashCan(AskIniFilePath());
\r
1628 DeleteFile(AskIniFilePath());
\r
1633 /*----- 設定をファイルに保存 --------------------------------------------------
\r
1640 *----------------------------------------------------------------------------*/
\r
1642 void SaveSettingsToFile(void)
\r
1644 char Tmp[FMAX_PATH*2];
\r
1645 char Fname[FMAX_PATH+1];
\r
1646 // 任意のコードが実行されるバグ修正
\r
1647 char CurDir[FMAX_PATH+1];
\r
1648 char SysDir[FMAX_PATH+1];
\r
1650 if(RegType == REGTYPE_REG)
\r
1652 strcpy(Fname, "FFFTP.reg");
\r
1653 if(SelectFile(GetMainHwnd(), Fname, MSGJPN286, MSGJPN287, "reg", OFN_EXTENSIONDIFFERENT | OFN_OVERWRITEPROMPT, 1) == TRUE)
\r
1655 sprintf(Tmp, "/e \x22%s\x22 HKEY_CURRENT_USER\\Software\\sota\\FFFTP", Fname);
\r
1656 // 任意のコードが実行されるバグ修正
\r
1657 // if(ShellExecute(NULL, "open", "regedit", Tmp, ".", SW_SHOW) <= (HINSTANCE)32)
\r
1659 // MessageBox(NULL, MSGJPN285, "FFFTP", MB_OK);
\r
1661 if(GetCurrentDirectory(FMAX_PATH, CurDir) > 0)
\r
1663 if(GetSystemDirectory(SysDir, FMAX_PATH) > 0)
\r
1665 if(SetCurrentDirectory(SysDir))
\r
1667 if(ShellExecute(NULL, "open", "regedit", Tmp, NULL, SW_SHOW) <= (HINSTANCE)32)
\r
1669 MessageBox(GetMainHwnd(), MSGJPN285, "FFFTP", MB_OK | MB_ICONERROR);
\r
1671 SetCurrentDirectory(CurDir);
\r
1679 strcpy(Fname, "FFFTP-Backup.ini");
\r
1680 if(SelectFile(GetMainHwnd(), Fname, MSGJPN286, MSGJPN288, "ini", OFN_EXTENSIONDIFFERENT | OFN_OVERWRITEPROMPT, 1) == TRUE)
\r
1682 CopyFile(AskIniFilePath(), Fname, FALSE);
\r
1689 /*----- 設定をファイルから復元 ------------------------------------------------
\r
1695 * int ロードしたかどうか (YES/NO)
\r
1696 *----------------------------------------------------------------------------*/
\r
1698 int LoadSettingsFromFile(void)
\r
1701 char Tmp[FMAX_PATH*2];
\r
1702 char Fname[FMAX_PATH+1];
\r
1703 // 任意のコードが実行されるバグ修正
\r
1704 char CurDir[FMAX_PATH+1];
\r
1705 char SysDir[FMAX_PATH+1];
\r
1708 strcpy(Fname, "");
\r
1709 if(SelectFile(GetMainHwnd(), Fname, MSGJPN291, MSGJPN290, "", OFN_FILEMUSTEXIST, 0) == TRUE)
\r
1711 if((strlen(Fname) >= 5) && (_stricmp(&Fname[strlen(Fname)-4], ".reg") == 0))
\r
1713 sprintf(Tmp, "\x22%s\x22", Fname);
\r
1714 // 任意のコードが実行されるバグ修正
\r
1715 // if(ShellExecute(NULL, "open", "regedit", Tmp, ".", SW_SHOW) <= (HINSTANCE)32)
\r
1717 // MessageBox(NULL, MSGJPN285, "FFFTP", MB_OK);
\r
1722 // /* レジストリエディタが終了するのを待つ */
\r
1723 // WaitForSingleObject(Info.hProcess, INFINITE);
\r
1725 if(GetCurrentDirectory(FMAX_PATH, CurDir) > 0)
\r
1727 if(GetSystemDirectory(SysDir, FMAX_PATH) > 0)
\r
1729 if(SetCurrentDirectory(SysDir))
\r
1731 if(ShellExecute(NULL, "open", "regedit", Tmp, NULL, SW_SHOW) <= (HINSTANCE)32)
\r
1733 MessageBox(GetMainHwnd(), MSGJPN285, "FFFTP", MB_OK | MB_ICONERROR);
\r
1738 /* レジストリエディタが終了するのを待つ */
\r
1739 // WaitForSingleObject(Info.hProcess, INFINITE);
\r
1741 SetCurrentDirectory(CurDir);
\r
1746 else if((strlen(Fname) >= 5) && (_stricmp(&Fname[strlen(Fname)-4], ".ini") == 0))
\r
1748 CopyFile(Fname, AskIniFilePath(), FALSE);
\r
1753 // MessageBox(NULL, MSGJPN293, "FFFTP", MB_OK);
\r
1754 MessageBox(GetMainHwnd(), MSGJPN293, "FFFTP", MB_OK | MB_ICONERROR);
\r
1762 /*----- レジストリ/INIファイルに文字列をセーブ --------------------------------
\r
1765 * HKEY hKey : レジストリキー
\r
1767 * char *Str : セーブする文字列
\r
1768 * char *DefaultStr : デフォルトの文字列
\r
1774 * 文字列がデフォルトの文字列と同じならセーブしない
\r
1775 *----------------------------------------------------------------------------*/
\r
1778 //static void SaveStr(HKEY hKey, char *Key, char *Str, char *DefaultStr)
\r
1779 static void SaveStr(void *Handle, char *Key, char *Str, char *DefaultStr)
\r
1781 if((DefaultStr != NULL) && (strcmp(Str, DefaultStr) == 0))
\r
1782 // DeleteValue(hKey, Key);
\r
1783 DeleteValue(Handle, Key);
\r
1785 // WriteStringToReg(hKey, Key, Str);
\r
1786 WriteStringToReg(Handle, Key, Str);
\r
1792 /*----- レジストリ/INIファイルに数値(INT)をセーブ -----------------------------
\r
1795 * HKEY hKey : レジストリキー
\r
1797 * int Num : セーブする値
\r
1798 * int DefaultNum : デフォルトの値
\r
1804 * 数値がデフォルトの値と同じならセーブしない
\r
1805 *----------------------------------------------------------------------------*/
\r
1808 //static void SaveIntNum(HKEY hKey, char *Key, int Num, int DefaultNum)
\r
1809 static void SaveIntNum(void *Handle, char *Key, int Num, int DefaultNum)
\r
1811 if(Num == DefaultNum)
\r
1812 // DeleteValue(hKey, Key);
\r
1813 DeleteValue(Handle, Key);
\r
1815 // WriteIntValueToReg(hKey, Key, Num);
\r
1816 WriteIntValueToReg(Handle, Key, Num);
\r
1822 /*----- LOGFONTデータを文字列に変換する ---------------------------------------
\r
1825 * LOGFONT Font : フォントデータ
\r
1826 * HFONT hFont : フォントのハンドル
\r
1827 * NULL = デフォルトのフォント
\r
1828 * char *Buf : バッファ
\r
1832 *----------------------------------------------------------------------------*/
\r
1834 static void MakeFontData(LOGFONT Font, HFONT hFont, char *Buf)
\r
1838 sprintf(Buf, "%d %d %d %d %d %d %d %d %d %d %d %d %d %s",
\r
1839 Font.lfHeight, Font.lfWidth, Font.lfEscapement, Font.lfOrientation,
\r
1840 Font.lfWeight, Font.lfItalic, Font.lfUnderline, Font.lfStrikeOut,
\r
1841 Font.lfCharSet, Font.lfOutPrecision, Font.lfClipPrecision,
\r
1842 Font.lfQuality, Font.lfPitchAndFamily, Font.lfFaceName);
\r
1847 /*----- 文字列をLOGFONTデータに変換する ---------------------------------------
\r
1851 * LOGFONT *Font : フォントデータ
\r
1855 * FFFTP_SUCCESS/FFFTP_FAIL=変換できない
\r
1856 *----------------------------------------------------------------------------*/
\r
1858 static int RestoreFontData(char *Str, LOGFONT *Font)
\r
1864 if(sscanf(Str, "%d %d %d %d %d %d %d %d %d %d %d %d %d",
\r
1865 &(Font->lfHeight), &(Font->lfWidth), &(Font->lfEscapement), &(Font->lfOrientation),
\r
1866 &(Font->lfWeight), &(Font->lfItalic), &(Font->lfUnderline), &(Font->lfStrikeOut),
\r
1867 &(Font->lfCharSet), &(Font->lfOutPrecision), &(Font->lfClipPrecision),
\r
1868 &(Font->lfQuality), &(Font->lfPitchAndFamily)) == 13)
\r
1870 for(i = 13; i > 0; i--)
\r
1872 if((Str = strchr(Str, ' ')) == NULL)
\r
1878 strcpy(Font->lfFaceName, Str);
\r
1879 Sts = FFFTP_SUCCESS;
\r
1883 if(Sts == FFFTP_FAIL)
\r
1884 memset(Font, NUL, sizeof(LOGFONT));
\r
1889 /*----- パスワードを暗号化する ------------------------------------------------
\r
1892 * char *Str : パスワード
\r
1893 * char *Buf : 暗号化したパスワードを格納するバッファ
\r
1897 *----------------------------------------------------------------------------*/
\r
1898 static void EncodePassword(char *Str, char *Buf)
\r
1900 EncodePassword3( Str, Buf, SecretKey );
\r
1903 /*----- パスワードを暗号化する(オリジナルアルゴリズム) ------------------
\r
1906 * char *Str : パスワード
\r
1907 * char *Buf : 暗号化したパスワードを格納するバッファ
\r
1911 *----------------------------------------------------------------------------*/
\r
1913 static void EncodePasswordOriginal(char *Str, char *Buf)
\r
1915 unsigned char *Get;
\r
1916 unsigned char *Put;
\r
1920 srand((unsigned)time(NULL));
\r
1922 Get = (unsigned char *)Str;
\r
1923 Put = (unsigned char *)Buf;
\r
1925 if( *Get == NUL ){
\r
1935 while(*Get != NUL)
\r
1938 Ch = ((int)*Get++) << Rnd;
\r
1939 Ch = (unsigned char)Ch | (unsigned char)(Ch >> 8);
\r
1940 *Put++ = 0x40 | ((Rnd & 0x3) << 4) | (Ch & 0xF);
\r
1941 *Put++ = 0x40 | ((Ch >> 4) & 0xF);
\r
1942 if((*(Put-2) & 0x1) != 0)
\r
1943 *Put++ = (rand() % 62) + 0x40;
\r
1949 /*----- パスワードを暗号化する(オリジナルアルゴリズム^Key) ----------------
\r
1952 * char *Str : パスワード
\r
1953 * char *Buf : 暗号化したパスワードを格納するバッファ
\r
1954 * const char *Key : 暗号化キー
\r
1958 *----------------------------------------------------------------------------*/
\r
1960 static void EncodePassword2(char *Str, char *Buf, const char* Key)
\r
1962 unsigned char *Get;
\r
1963 unsigned char *Put;
\r
1967 /* 2010.01.31 genta Key */
\r
1968 unsigned char *KeyHead = (unsigned char *)Key;
\r
1969 unsigned char *KeyEnd = KeyHead + strlen(KeyHead);
\r
1970 unsigned char *KeyCurrent = KeyHead;
\r
1972 srand((unsigned)time(NULL));
\r
1974 Get = (unsigned char *)Str;
\r
1975 Put = (unsigned char *)Buf;
\r
1977 if( *Get == NUL ){
\r
1987 while(*Get != NUL)
\r
1990 Ch = ((int)(*Get++ ^ *KeyCurrent)) << Rnd;
\r
1991 Ch = (unsigned char)Ch | (unsigned char)(Ch >> 8);
\r
1992 *Put++ = 0x40 | ((Rnd & 0x3) << 4) | (Ch & 0xF);
\r
1993 *Put++ = 0x40 | ((Ch >> 4) & 0xF);
\r
1994 if((*(Put-2) & 0x1) != 0)
\r
1995 *Put++ = (rand() % 62) + 0x40;
\r
1997 /* 2010.01.31 genta Key */
\r
1998 if( ++KeyCurrent == KeyEnd ){
\r
1999 KeyCurrent = KeyHead;
\r
2006 /*----- パスワードを暗号化する(AES) ------------------------------------------
\r
2009 * char *Str : パスワード
\r
2010 * char *Buf : 暗号化したパスワードを格納するバッファ
\r
2011 * const char *Key : 暗号化キー
\r
2015 *----------------------------------------------------------------------------*/
\r
2017 static void EncodePassword3(char *Str, char *Buf, const char *Key)
\r
2019 unsigned char *Put;
\r
2020 unsigned char *AesEncBuf;
\r
2021 unsigned char *StrPadBuf;
\r
2024 size_t StrPadIndex;
\r
2026 size_t EncBufIndex;
\r
2028 int RandByteCount;
\r
2029 unsigned char AesKey[32];
\r
2030 unsigned char AesCbcIv[AES_BLOCK_SIZE];
\r
2031 aes_encrypt_ctx Ctx;
\r
2035 Put = (unsigned char *)Buf;
\r
2036 StrLen = strlen(Str);
\r
2037 StrPadLen = ((StrLen + AES_BLOCK_SIZE - 1) / AES_BLOCK_SIZE) * AES_BLOCK_SIZE;
\r
2040 // StrPadLen = min1(StrPadLen, AES_BLOCK_SIZE * 2);
\r
2041 StrPadLen = max1(StrPadLen, AES_BLOCK_SIZE * 2);
\r
2043 if((StrPadBuf = malloc(StrPadLen)) != NULL)
\r
2045 if((AesEncBuf = malloc(StrPadLen)) != NULL)
\r
2050 strncpy(StrPadBuf, Str, StrPadLen);
\r
2052 /* PAD部分を乱数で埋める StrPad[StrLen](が有効な場合) は NUL */
\r
2053 for(StrPadIndex = StrLen + 1; StrPadIndex < StrPadLen;)
\r
2055 RandValue = GetRandamDWORDValue();
\r
2056 for(RandByteCount = 0; RandByteCount < 4; RandByteCount++)
\r
2058 if(StrPadIndex < StrPadLen)
\r
2060 StrPadBuf[StrPadIndex++] = (unsigned char)(RandValue & 0xff);
\r
2067 for(IvIndex = 0; IvIndex < AES_BLOCK_SIZE;)
\r
2069 RandValue = GetRandamDWORDValue();
\r
2070 for(RandByteCount = 0; RandByteCount < 4; RandByteCount++)
\r
2072 if(IvIndex < AES_BLOCK_SIZE)
\r
2074 AesCbcIv[IvIndex++] = (unsigned char)(RandValue & 0xff);
\r
2082 for(IvIndex = 0; IvIndex < AES_BLOCK_SIZE; IvIndex++)
\r
2084 sprintf(Put, "%02x", AesCbcIv[IvIndex]);
\r
2089 if(CreateAesKey(AesKey, Key) == FFFTP_SUCCESS)
\r
2091 aes_encrypt_key(AesKey, 32, &Ctx);
\r
2093 if(aes_cbc_encrypt(StrPadBuf, AesEncBuf, StrPadLen, AesCbcIv, &Ctx) == EXIT_SUCCESS)
\r
2095 for(EncBufIndex = 0; EncBufIndex < StrPadLen; EncBufIndex++)
\r
2097 sprintf(Put, "%02x", AesEncBuf[EncBufIndex]);
\r
2104 if(FALSE == PutState)
\r
2116 /*----- パスワードの暗号化を解く ----------------------------------------------
\r
2119 * char *Str : 暗号化したパスワード
\r
2120 * char *Buf : パスワードを格納するバッファ
\r
2124 *----------------------------------------------------------------------------*/
\r
2126 static void DecodePassword(char *Str, char *Buf)
\r
2128 unsigned char *Get;
\r
2129 unsigned char *Put;
\r
2131 Get = (unsigned char *)Str;
\r
2132 Put = (unsigned char *)Buf;
\r
2134 if( *Get == NUL ){
\r
2137 else if( 0x40 <= *Get && *Get < 0x80 ){
\r
2138 /* Original algorithm */
\r
2139 DecodePasswordOriginal( Str, Buf );
\r
2141 else if( strncmp( Get, "0A", 2 ) == 0 ){
\r
2142 DecodePasswordOriginal( Str + 2, Buf );
\r
2144 else if( strncmp( Get, "0B", 2 ) == 0 ){
\r
2145 DecodePassword2( Str + 2, Buf, SecretKey );
\r
2147 else if( strncmp( Get, "0C", 2 ) == 0 ){
\r
2148 DecodePassword3( Str + 2, Buf, SecretKey );
\r
2151 // unknown encoding
\r
2157 /*----- パスワードの暗号化を解く(オリジナルアルゴリズム) -------------------
\r
2160 * char *Str : 暗号化したパスワード
\r
2161 * char *Buf : パスワードを格納するバッファ
\r
2165 *----------------------------------------------------------------------------*/
\r
2166 static void DecodePasswordOriginal(char *Str, char *Buf)
\r
2168 unsigned char *Get;
\r
2169 unsigned char *Put;
\r
2173 Get = (unsigned char *)Str;
\r
2174 Put = (unsigned char *)Buf;
\r
2176 while(*Get != NUL)
\r
2178 Rnd = ((unsigned int)*Get >> 4) & 0x3;
\r
2179 Ch = (*Get & 0xF) | ((*(Get+1) & 0xF) << 4);
\r
2181 if((*Get & 0x1) != 0)
\r
2185 Ch = (Ch & 0xFF) | ((Ch >> 8) & 0xFF);
\r
2192 /*----- パスワードの暗号化を解く(オリジナルアルゴリズム^Key) -------------------
\r
2195 * char *Str : 暗号化したパスワード
\r
2196 * char *Buf : パスワードを格納するバッファ
\r
2197 * const char *Key : 暗号化キー
\r
2201 *----------------------------------------------------------------------------*/
\r
2202 static void DecodePassword2(char *Str, char *Buf, const char* Key)
\r
2206 unsigned char *Get = (unsigned char *)Str;
\r
2207 unsigned char *Put = (unsigned char *)Buf;
\r
2209 /* 2010.01.31 genta Key */
\r
2210 unsigned char *KeyHead = (unsigned char *)Key;
\r
2211 unsigned char *KeyEnd = KeyHead + strlen(KeyHead);
\r
2212 unsigned char *KeyCurrent = KeyHead;
\r
2214 while(*Get != NUL)
\r
2216 Rnd = ((unsigned int)*Get >> 4) & 0x3;
\r
2217 Ch = (*Get & 0xF) | ((*(Get+1) & 0xF) << 4);
\r
2219 if((*Get & 0x1) != 0)
\r
2223 Ch = (Ch & 0xFF) | ((Ch >> 8) & 0xFF);
\r
2224 *Put++ = Ch ^ *KeyCurrent;
\r
2226 /* 2010.01.31 genta Key */
\r
2227 if( ++KeyCurrent == KeyEnd ){
\r
2228 KeyCurrent = KeyHead;
\r
2235 /*----- パスワードの暗号化を解く(AES) ---------------------------------------
\r
2238 * char *Str : 暗号化したパスワード
\r
2239 * char *Buf : パスワードを格納するバッファ
\r
2240 * const char *Key : 暗号化キー
\r
2244 *----------------------------------------------------------------------------*/
\r
2246 static void DecodePassword3(char *Str, char *Buf, const char *Key)
\r
2249 unsigned char *EncBuf;
\r
2252 size_t EncBufIndex;
\r
2254 unsigned char AesKey[32];
\r
2255 unsigned char AesCbcIv[AES_BLOCK_SIZE];
\r
2256 aes_decrypt_ctx Ctx;
\r
2261 StrLen = strlen(Str);
\r
2263 if(AES_BLOCK_SIZE * 2 + 1 < StrLen)
\r
2266 EncBufLen = (StrLen - 1 ) / 2 - AES_BLOCK_SIZE;
\r
2267 if((EncBuf = malloc(EncBufLen)) != NULL)
\r
2269 for(IvIndex = 0; IvIndex < AES_BLOCK_SIZE; IvIndex++)
\r
2271 AesCbcIv[IvIndex] = hex2bin(*Get++) << 4;
\r
2272 AesCbcIv[IvIndex] |= hex2bin(*Get++);
\r
2277 if(CreateAesKey(AesKey, Key) == FFFTP_SUCCESS)
\r
2279 aes_decrypt_key(AesKey, 32, &Ctx);
\r
2281 for(EncBufIndex = 0; EncBufIndex < EncBufLen; EncBufIndex++)
\r
2283 EncBuf[EncBufIndex] = hex2bin(*Get++) << 4;
\r
2284 EncBuf[EncBufIndex] |= hex2bin(*Get++);
\r
2286 if(aes_cbc_decrypt(EncBuf, Buf, EncBufLen, AesCbcIv, &Ctx) == EXIT_SUCCESS)
\r
2288 Buf[EncBufLen] = NUL;
\r
2298 /*----- AES用固定長キーを作成 ----------------------------------------------
\r
2301 * unsigned char *AesKey : AES暗号鍵
\r
2302 * const char *Key : 暗号化キー
\r
2305 * int ステータス (FFFTP_SUCCESS/FFFTP_FAIL)
\r
2307 * SHA-1をもちいて32Byte鍵を生成する
\r
2308 *----------------------------------------------------------------------------*/
\r
2310 static int CreateAesKey(unsigned char *AesKey, const char* Key)
\r
2313 uint32 HashKeyLen;
\r
2314 uint32 results[10];
\r
2319 HashKeyLen = strlen(Key) + 16;
\r
2320 if((HashKey = malloc(HashKeyLen + 1)) == NULL){
\r
2321 return (FFFTP_FAIL);
\r
2324 strcpy(HashKey, Key);
\r
2325 strcat(HashKey, ">g^r=@N7=//z<[`:");
\r
2326 sha_memory((uchar *)HashKey, HashKeyLen, results);
\r
2328 strcpy(HashKey, Key);
\r
2329 strcat(HashKey, "VG77dO1#EyC]$|C@");
\r
2330 sha_memory((uchar *)HashKey, HashKeyLen, results + 5);
\r
2334 while(ResIndex < 8){
\r
2335 for(ByteOffset = 0; ByteOffset < 4; ByteOffset++){
\r
2336 AesKey[KeyIndex++] = (results[ResIndex] >> ByteOffset * 8) & 0xff;
\r
2342 return (FFFTP_SUCCESS);
\r
2346 /*===== レジストリとINIファイルのアクセス処理 ============*/
\r
2349 /*===== INIファイル用のレジストリデータ =====*/
\r
2351 typedef struct regdatatbl {
\r
2352 char KeyName[80+1]; /* キー名 */
\r
2353 char ValTbl[REG_SECT_MAX]; /* 値のテーブル */
\r
2354 int ValLen; /* 値データのバイト数 */
\r
2355 int Mode; /* キーのモード */
\r
2356 struct regdatatbl *Next;
\r
2360 typedef struct regdatatbl_reg {
\r
2361 char KeyName[80+1]; /* キー名 */
\r
2365 /*===== プロトタイプ =====*/
\r
2367 static BOOL WriteOutRegToFile(REGDATATBL *Pos);
\r
2368 static int ReadInReg(char *Name, REGDATATBL **Handle);
\r
2370 //static int StrCatOut(char *Src, int Len, char *Dst);
\r
2371 //static int StrReadIn(char *Src, int Max, char *Dst);
\r
2372 static char *ScanValue(void *Handle, char *Name);
\r
2375 /*===== ローカルなワーク =====*/
\r
2377 static int TmpRegType;
\r
2381 /*----- レジストリのタイプを設定する ------------------------------------------
\r
2384 * int Type : タイプ (REGTYPE_xxx)
\r
2388 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2389 *----------------------------------------------------------------------------*/
\r
2391 static void SetRegType(int Type)
\r
2393 TmpRegType = Type;
\r
2398 /*----- レジストリ/INIファイルをオープンする(読み込み)-----------------------
\r
2401 * char *Name : レジストリ名
\r
2402 * void **Handle : ハンドルを返すワーク
\r
2406 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2407 *----------------------------------------------------------------------------*/
\r
2409 static int OpenReg(char *Name, void **Handle)
\r
2412 char Tmp[FMAX_PATH+1];
\r
2415 if(TmpRegType == REGTYPE_REG)
\r
2418 // strcpy(Tmp, "Software\\Sota\\");
\r
2419 // strcat(Tmp, Name);
\r
2420 // if(RegOpenKeyEx(HKEY_CURRENT_USER, Tmp, 0, KEY_READ, (HKEY *)Handle) == ERROR_SUCCESS)
\r
2421 // Sts = FFFTP_SUCCESS;
\r
2422 if((*Handle = malloc(sizeof(REGDATATBL_REG))) != NULL)
\r
2424 strcpy(((REGDATATBL_REG *)(*Handle))->KeyName, Name);
\r
2425 strcpy(Tmp, "Software\\Sota\\");
\r
2426 strcat(Tmp, Name);
\r
2427 if(RegOpenKeyEx(HKEY_CURRENT_USER, Tmp, 0, KEY_READ, &(((REGDATATBL_REG *)(*Handle))->hKey)) == ERROR_SUCCESS)
\r
2428 Sts = FFFTP_SUCCESS;
\r
2429 if(Sts != FFFTP_SUCCESS)
\r
2435 if((Sts = ReadInReg(Name, (REGDATATBL **)Handle)) == FFFTP_SUCCESS)
\r
2436 ((REGDATATBL *)(*Handle))->Mode = 0;
\r
2442 /*----- レジストリ/INIファイルを作成する(書き込み)---------------------------
\r
2445 * char *Name : レジストリ名
\r
2446 * void **Handle : ハンドルを返すワーク
\r
2450 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2451 *----------------------------------------------------------------------------*/
\r
2453 static int CreateReg(char *Name, void **Handle)
\r
2456 char Tmp[FMAX_PATH+1];
\r
2460 if(TmpRegType == REGTYPE_REG)
\r
2463 // strcpy(Tmp, "Software\\Sota\\");
\r
2464 // strcat(Tmp, Name);
\r
2465 // 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
2466 // Sts = FFFTP_SUCCESS;
\r
2467 if((*Handle = malloc(sizeof(REGDATATBL_REG))) != NULL)
\r
2469 strcpy(((REGDATATBL_REG *)(*Handle))->KeyName, Name);
\r
2470 strcpy(Tmp, "Software\\Sota\\");
\r
2471 strcat(Tmp, Name);
\r
2472 if(RegCreateKeyEx(HKEY_CURRENT_USER, Tmp, 0, "", REG_OPTION_NON_VOLATILE, KEY_CREATE_SUB_KEY | KEY_SET_VALUE, NULL, &(((REGDATATBL_REG *)(*Handle))->hKey), &Dispos) == ERROR_SUCCESS)
\r
2473 Sts = FFFTP_SUCCESS;
\r
2474 if(Sts != FFFTP_SUCCESS)
\r
2480 if((*Handle = malloc(sizeof(REGDATATBL))) != NULL)
\r
2482 strcpy(((REGDATATBL *)(*Handle))->KeyName, Name);
\r
2483 ((REGDATATBL *)(*Handle))->ValLen = 0;
\r
2484 ((REGDATATBL *)(*Handle))->Next = NULL;
\r
2485 ((REGDATATBL *)(*Handle))->Mode = 1;
\r
2486 Sts = FFFTP_SUCCESS;
\r
2493 /*----- レジストリ/INIファイルをクローズする ----------------------------------
\r
2496 * void *Handle : ハンドル
\r
2500 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2501 *----------------------------------------------------------------------------*/
\r
2503 static int CloseReg(void *Handle)
\r
2510 if(TmpRegType == REGTYPE_REG)
\r
2513 // RegCloseKey(Handle);
\r
2514 RegCloseKey(((REGDATATBL_REG *)Handle)->hKey);
\r
2519 // if((Strm = fopen(AskIniFilePath(), "rt")) != NULL)
\r
2522 // MoveFileToTrashCan(AskIniFilePath());
\r
2527 if(((REGDATATBL *)Handle)->Mode == 1)
\r
2529 if(WriteOutRegToFile(Handle) == TRUE)
\r
2531 // /* レジストリをクリア */
\r
2532 // ClearRegistry();
\r
2537 while(Pos != NULL)
\r
2544 return(FFFTP_SUCCESS);
\r
2548 /*----- レジストリ情報をINIファイルに書き込む ---------------------------------
\r
2551 * REGDATATBL *Pos : レジストリデータ
\r
2555 *----------------------------------------------------------------------------*/
\r
2557 static BOOL WriteOutRegToFile(REGDATATBL *Pos)
\r
2564 if((Strm = fopen(AskIniFilePath(), "wt")) != NULL)
\r
2566 fprintf(Strm, MSGJPN239);
\r
2567 while(Pos != NULL)
\r
2569 fprintf(Strm, "\n[%s]\n", Pos->KeyName);
\r
2571 Disp = Pos->ValTbl;
\r
2572 while(Disp < (Pos->ValTbl + Pos->ValLen))
\r
2574 fprintf(Strm, "%s\n", Disp);
\r
2575 Disp = Disp + strlen(Disp) + 1;
\r
2584 // MessageBox(NULL, MSGJPN240, "FFFTP", MB_OK);
\r
2585 MessageBox(GetMainHwnd(), MSGJPN240, "FFFTP", MB_OK | MB_ICONERROR);
\r
2591 /*----- INIファイルからレジストリ情報を読み込む -------------------------------
\r
2595 * void *Handle : ハンドル
\r
2599 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2600 *----------------------------------------------------------------------------*/
\r
2602 static int ReadInReg(char *Name, REGDATATBL **Handle)
\r
2617 if((Strm = fopen(AskIniFilePath(), "rt")) != NULL)
\r
2619 if((Buf = malloc(REG_SECT_MAX)) != NULL)
\r
2621 while(fgets(Buf, REG_SECT_MAX, Strm) != NULL)
\r
2625 if((Tmp = strchr(Buf, '\n')) != NULL)
\r
2630 if((New = malloc(sizeof(REGDATATBL))) != NULL)
\r
2632 if((Tmp = strchr(Buf, ']')) != NULL)
\r
2635 // strcpy(New->KeyName, Buf+1);
\r
2636 strncpy(New->KeyName, Buf+1, 80);
\r
2637 New->KeyName[80] = NUL;
\r
2640 Data = New->ValTbl;
\r
2642 if(*Handle == NULL)
\r
2647 while(Pos->Next != NULL)
\r
2652 else if(strlen(Buf) > 0)
\r
2655 // strcpy(Data, Buf);
\r
2656 // Data += strlen(Buf) + 1;
\r
2657 // New->ValLen += strlen(Buf) + 1;
\r
2658 if(Data != NULL && New != NULL)
\r
2660 if(New->ValLen + strlen(Buf) + 1 <= REG_SECT_MAX)
\r
2662 strcpy(Data, Buf);
\r
2663 Data += strlen(Buf) + 1;
\r
2664 New->ValLen += strlen(Buf) + 1;
\r
2670 Sts = FFFTP_SUCCESS;
\r
2679 /*----- サブキーをオープンする ------------------------------------------------
\r
2682 * void *Parent : 親のハンドル
\r
2684 * void **Handle : ハンドルを返すワーク
\r
2688 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2689 *----------------------------------------------------------------------------*/
\r
2691 static int OpenSubKey(void *Parent, char *Name, void **Handle)
\r
2698 if(TmpRegType == REGTYPE_REG)
\r
2701 // if(RegOpenKeyEx(Parent, Name, 0, KEY_READ, (HKEY *)Handle) == ERROR_SUCCESS)
\r
2702 // Sts = FFFTP_SUCCESS;
\r
2703 if((*Handle = malloc(sizeof(REGDATATBL_REG))) != NULL)
\r
2705 strcpy(((REGDATATBL_REG *)(*Handle))->KeyName, ((REGDATATBL_REG *)Parent)->KeyName);
\r
2706 strcat(((REGDATATBL_REG *)(*Handle))->KeyName, "\\");
\r
2707 strcat(((REGDATATBL_REG *)(*Handle))->KeyName, Name);
\r
2708 if(RegOpenKeyEx(((REGDATATBL_REG *)Parent)->hKey, Name, 0, KEY_READ, &(((REGDATATBL_REG *)(*Handle))->hKey)) == ERROR_SUCCESS)
\r
2709 Sts = FFFTP_SUCCESS;
\r
2710 if(Sts != FFFTP_SUCCESS)
\r
2716 strcpy(Key, ((REGDATATBL *)Parent)->KeyName);
\r
2717 strcat(Key, "\\");
\r
2718 strcat(Key, Name);
\r
2720 while(Pos != NULL)
\r
2722 if(strcmp(Pos->KeyName, Key) == 0)
\r
2725 Sts = FFFTP_SUCCESS;
\r
2735 /*----- サブキーを作成する ----------------------------------------------------
\r
2738 * void *Parent : 親のハンドル
\r
2740 * void **Handle : ハンドルを返すワーク
\r
2744 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2745 *----------------------------------------------------------------------------*/
\r
2747 static int CreateSubKey(void *Parent, char *Name, void **Handle)
\r
2754 if(TmpRegType == REGTYPE_REG)
\r
2757 // if(RegCreateKeyEx(Parent, Name, 0, "", REG_OPTION_NON_VOLATILE, KEY_SET_VALUE, NULL, (HKEY *)Handle, &Dispos) == ERROR_SUCCESS)
\r
2758 // Sts = FFFTP_SUCCESS;
\r
2759 if((*Handle = malloc(sizeof(REGDATATBL_REG))) != NULL)
\r
2761 strcpy(((REGDATATBL_REG *)(*Handle))->KeyName, ((REGDATATBL_REG *)Parent)->KeyName);
\r
2762 strcat(((REGDATATBL_REG *)(*Handle))->KeyName, "\\");
\r
2763 strcat(((REGDATATBL_REG *)(*Handle))->KeyName, Name);
\r
2764 if(RegCreateKeyEx(((REGDATATBL_REG *)Parent)->hKey, Name, 0, "", REG_OPTION_NON_VOLATILE, KEY_SET_VALUE, NULL, &(((REGDATATBL_REG *)(*Handle))->hKey), &Dispos) == ERROR_SUCCESS)
\r
2765 Sts = FFFTP_SUCCESS;
\r
2766 if(Sts != FFFTP_SUCCESS)
\r
2772 if((*Handle = malloc(sizeof(REGDATATBL))) != NULL)
\r
2774 strcpy(((REGDATATBL *)(*Handle))->KeyName, ((REGDATATBL *)Parent)->KeyName);
\r
2775 strcat(((REGDATATBL *)(*Handle))->KeyName, "\\");
\r
2776 strcat(((REGDATATBL *)(*Handle))->KeyName, Name);
\r
2778 ((REGDATATBL *)(*Handle))->ValLen = 0;
\r
2779 ((REGDATATBL *)(*Handle))->Next = NULL;
\r
2781 Pos = (REGDATATBL *)Parent;
\r
2782 while(Pos->Next != NULL)
\r
2784 Pos->Next = *Handle;
\r
2785 Sts = FFFTP_SUCCESS;
\r
2792 /*----- サブキーをクローズする ------------------------------------------------
\r
2795 * void *Handle : ハンドル
\r
2799 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2800 *----------------------------------------------------------------------------*/
\r
2802 static int CloseSubKey(void *Handle)
\r
2804 if(TmpRegType == REGTYPE_REG)
\r
2806 // RegCloseKey(Handle);
\r
2808 RegCloseKey(((REGDATATBL_REG *)Handle)->hKey);
\r
2815 return(FFFTP_SUCCESS);
\r
2819 /*----- サブキーを削除する ----------------------------------------------------
\r
2822 * void *Handle : ハンドル
\r
2827 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2828 *----------------------------------------------------------------------------*/
\r
2830 static int DeleteSubKey(void *Handle, char *Name)
\r
2835 if(TmpRegType == REGTYPE_REG)
\r
2838 // if(RegDeleteKey(Handle, Name) == ERROR_SUCCESS)
\r
2839 if(RegDeleteKey(((REGDATATBL_REG *)Handle)->hKey, Name) == ERROR_SUCCESS)
\r
2840 Sts = FFFTP_SUCCESS;
\r
2850 /*----- 値を削除する ----------------------------------------------------------
\r
2853 * void *Handle : ハンドル
\r
2858 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2859 *----------------------------------------------------------------------------*/
\r
2861 static int DeleteValue(void *Handle, char *Name)
\r
2866 if(TmpRegType == REGTYPE_REG)
\r
2869 // if(RegDeleteValue(Handle, Name) == ERROR_SUCCESS)
\r
2870 if(RegDeleteValue(((REGDATATBL_REG *)Handle)->hKey, Name) == ERROR_SUCCESS)
\r
2871 Sts = FFFTP_SUCCESS;
\r
2881 /*----- INT値を読み込む -------------------------------------------------------
\r
2884 * void *Handle : ハンドル
\r
2886 * int *Value : INT値を返すワーク
\r
2890 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2891 *----------------------------------------------------------------------------*/
\r
2893 static int ReadIntValueFromReg(void *Handle, char *Name, int *Value)
\r
2902 if(TmpRegType == REGTYPE_REG)
\r
2904 Size = sizeof(int);
\r
2906 // if(RegQueryValueEx(Handle, Name, NULL, NULL, (BYTE *)Value, &Size) == ERROR_SUCCESS)
\r
2907 if(RegQueryValueEx(((REGDATATBL_REG *)Handle)->hKey, Name, NULL, NULL, (BYTE *)Value, &Size) == ERROR_SUCCESS)
\r
2908 Sts = FFFTP_SUCCESS;
\r
2912 if((Pos = ScanValue(Handle, Name)) != NULL)
\r
2914 *Value = atoi(Pos);
\r
2915 Sts = FFFTP_SUCCESS;
\r
2919 if(Sts == FFFTP_SUCCESS)
\r
2921 if(EncryptSettings == YES)
\r
2923 if(TmpRegType == REGTYPE_REG)
\r
2924 strcpy(Path, ((REGDATATBL_REG *)Handle)->KeyName);
\r
2926 strcpy(Path, ((REGDATATBL *)Handle)->KeyName);
\r
2927 strcat(Path, "\\");
\r
2928 strcat(Path, Name);
\r
2929 UnmaskSettingsData(Path, strlen(Path), Value, sizeof(int), NO);
\r
2930 CalculateSettingsDataChecksum(Value, sizeof(int));
\r
2937 /*----- INT値を書き込む -------------------------------------------------------
\r
2940 * void *Handle : ハンドル
\r
2942 * int Value : INT値
\r
2946 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2947 *----------------------------------------------------------------------------*/
\r
2949 static int WriteIntValueToReg(void *Handle, char *Name, int Value)
\r
2958 if(EncryptSettings == YES)
\r
2960 if(TmpRegType == REGTYPE_REG)
\r
2961 strcpy(Path, ((REGDATATBL_REG *)Handle)->KeyName);
\r
2963 strcpy(Path, ((REGDATATBL *)Handle)->KeyName);
\r
2964 strcat(Path, "\\");
\r
2965 strcat(Path, Name);
\r
2966 MaskSettingsData(Path, strlen(Path), &Value, sizeof(int), NO);
\r
2968 if(TmpRegType == REGTYPE_REG)
\r
2970 // RegSetValueEx(Handle, Name, 0, REG_DWORD, (CONST BYTE *)&Value, sizeof(int));
\r
2971 RegSetValueEx(((REGDATATBL_REG *)Handle)->hKey, Name, 0, REG_DWORD, (CONST BYTE *)&Value, sizeof(int));
\r
2974 Pos = (REGDATATBL *)Handle;
\r
2975 Data = Pos->ValTbl + Pos->ValLen;
\r
2976 strcpy(Data, Name);
\r
2977 strcat(Data, "=");
\r
2978 sprintf(Tmp, "%d", Value);
\r
2979 strcat(Data, Tmp);
\r
2980 Pos->ValLen += strlen(Data) + 1;
\r
2983 if(EncryptSettings == YES)
\r
2985 UnmaskSettingsData(Path, strlen(Path), &Value, sizeof(int), NO);
\r
2986 CalculateSettingsDataChecksum(&Value, sizeof(int));
\r
2988 return(FFFTP_SUCCESS);
\r
2992 /*----- 文字列を読み込む ------------------------------------------------------
\r
2995 * void *Handle : ハンドル
\r
2997 * char *Str : 文字列を返すワーク
\r
2998 * DWORD Size : 最大サイズ
\r
3002 * FFFTP_SUCCESS/FFFTP_FAIL
\r
3003 *----------------------------------------------------------------------------*/
\r
3005 static int ReadStringFromReg(void *Handle, char *Name, char *Str, DWORD Size)
\r
3017 if(TmpRegType == REGTYPE_REG)
\r
3020 // if(RegQueryValueEx(Handle, Name, NULL, NULL, (BYTE *)Str, &Size) == ERROR_SUCCESS)
\r
3021 if(RegQueryValueEx(((REGDATATBL_REG *)Handle)->hKey, Name, NULL, NULL, (BYTE *)Str, &Size) == ERROR_SUCCESS)
\r
3023 if(*(Str + Size - 1) != NUL)
\r
3024 *(Str + Size) = NUL;
\r
3025 Sts = FFFTP_SUCCESS;
\r
3030 if((Pos = ScanValue(Handle, Name)) != NULL)
\r
3033 // Size = min1(Size-1, strlen(Pos));
\r
3034 // Size = StrReadIn(Pos, Size, Str);
\r
3035 // *(Str + Size) = NUL;
\r
3036 // Sts = FFFTP_SUCCESS;
\r
3037 switch(IniKanjiCode)
\r
3040 TempSize = min1(Size-1, strlen(Pos));
\r
3041 TempSize = StrReadIn(Pos, TempSize, Str);
\r
3042 *(Str + TempSize) = NUL;
\r
3043 Sts = FFFTP_SUCCESS;
\r
3046 if(pa0 = AllocateStringA(Size * 4))
\r
3048 if(pw0 = AllocateStringW(Size * 4 * 4))
\r
3050 TempSize = min1((Size * 4) - 1, strlen(Pos));
\r
3051 TempSize = StrReadIn(Pos, TempSize, pa0);
\r
3052 *(pa0 + TempSize) = NUL;
\r
3053 AtoW(pw0, Size * 4 * 4, pa0, -1);
\r
3054 WtoM(Str, Size, pw0, -1);
\r
3055 TerminateStringM(Str, Size);
\r
3056 Sts = FFFTP_SUCCESS;
\r
3057 FreeDuplicatedString(pw0);
\r
3059 FreeDuplicatedString(pa0);
\r
3066 if(Sts == FFFTP_SUCCESS)
\r
3068 if(EncryptSettings == YES)
\r
3070 if(TmpRegType == REGTYPE_REG)
\r
3071 strcpy(Path, ((REGDATATBL_REG *)Handle)->KeyName);
\r
3073 strcpy(Path, ((REGDATATBL *)Handle)->KeyName);
\r
3074 strcat(Path, "\\");
\r
3075 strcat(Path, Name);
\r
3076 UnmaskSettingsData(Path, strlen(Path), Str, strlen(Str) + 1, YES);
\r
3077 CalculateSettingsDataChecksum(Str, strlen(Str) + 1);
\r
3084 /*----- 文字列を書き込む ------------------------------------------------------
\r
3087 * void *Handle : ハンドル
\r
3093 * FFFTP_SUCCESS/FFFTP_FAIL
\r
3094 *----------------------------------------------------------------------------*/
\r
3096 static int WriteStringToReg(void *Handle, char *Name, char *Str)
\r
3104 if(EncryptSettings == YES)
\r
3106 if(TmpRegType == REGTYPE_REG)
\r
3107 strcpy(Path, ((REGDATATBL_REG *)Handle)->KeyName);
\r
3109 strcpy(Path, ((REGDATATBL *)Handle)->KeyName);
\r
3110 strcat(Path, "\\");
\r
3111 strcat(Path, Name);
\r
3112 MaskSettingsData(Path, strlen(Path), Str, strlen(Str) + 1, YES);
\r
3114 if(TmpRegType == REGTYPE_REG)
\r
3116 // RegSetValueEx(Handle, Name, 0, REG_SZ, (CONST BYTE *)Str, strlen(Str)+1);
\r
3117 RegSetValueEx(((REGDATATBL_REG *)Handle)->hKey, Name, 0, EncryptSettings == YES ? REG_BINARY : REG_SZ, (CONST BYTE *)Str, strlen(Str)+1);
\r
3120 Pos = (REGDATATBL *)Handle;
\r
3121 Data = Pos->ValTbl + Pos->ValLen;
\r
3122 strcpy(Data, Name);
\r
3123 strcat(Data, "=");
\r
3124 Pos->ValLen += strlen(Data);
\r
3125 Data = Pos->ValTbl + Pos->ValLen;
\r
3126 Pos->ValLen += StrCatOut(Str, strlen(Str), Data) + 1;
\r
3129 if(EncryptSettings == YES)
\r
3131 UnmaskSettingsData(Path, strlen(Path), Str, strlen(Str) + 1, YES);
\r
3132 CalculateSettingsDataChecksum(Str, strlen(Str) + 1);
\r
3134 return(FFFTP_SUCCESS);
\r
3138 /*----- マルチ文字列を読み込む ------------------------------------------------
\r
3141 * void *Handle : ハンドル
\r
3143 * char *Str : 文字列を返すワーク
\r
3144 * DWORD Size : 最大サイズ
\r
3148 * FFFTP_SUCCESS/FFFTP_FAIL
\r
3149 *----------------------------------------------------------------------------*/
\r
3151 static int ReadMultiStringFromReg(void *Handle, char *Name, char *Str, DWORD Size)
\r
3163 if(TmpRegType == REGTYPE_REG)
\r
3166 // if(RegQueryValueEx(Handle, Name, NULL, NULL, (BYTE *)Str, &Size) == ERROR_SUCCESS)
\r
3167 if(RegQueryValueEx(((REGDATATBL_REG *)Handle)->hKey, Name, NULL, NULL, (BYTE *)Str, &Size) == ERROR_SUCCESS)
\r
3169 if(*(Str + Size - 1) != NUL)
\r
3170 *(Str + Size) = NUL;
\r
3171 Sts = FFFTP_SUCCESS;
\r
3176 if((Pos = ScanValue(Handle, Name)) != NULL)
\r
3179 // Size = min1(Size-1, strlen(Pos));
\r
3180 // Size = StrReadIn(Pos, Size, Str);
\r
3181 // *(Str + Size) = NUL;
\r
3182 // Sts = FFFTP_SUCCESS;
\r
3183 switch(IniKanjiCode)
\r
3186 TempSize = min1(Size - 2, strlen(Pos));
\r
3187 TempSize = StrReadIn(Pos, TempSize, Str);
\r
3188 *(Str + TempSize) = NUL;
\r
3189 *(Str + TempSize + 1) = NUL;
\r
3190 Sts = FFFTP_SUCCESS;
\r
3193 if(pa0 = AllocateStringA(Size * 4))
\r
3195 if(pw0 = AllocateStringW(Size * 4 * 4))
\r
3197 TempSize = min1((Size * 4) - 2, strlen(Pos));
\r
3198 TempSize = StrReadIn(Pos, TempSize, pa0);
\r
3199 *(pa0 + TempSize) = NUL;
\r
3200 *(pa0 + TempSize + 1) = NUL;
\r
3201 AtoWMultiString(pw0, Size * 4 * 4, pa0);
\r
3202 WtoMMultiString(Str, Size, pw0);
\r
3203 TerminateStringM(Str, Size);
\r
3204 TerminateStringM(Str, Size - 1);
\r
3205 Sts = FFFTP_SUCCESS;
\r
3206 FreeDuplicatedString(pw0);
\r
3208 FreeDuplicatedString(pa0);
\r
3215 if(Sts == FFFTP_SUCCESS)
\r
3217 if(EncryptSettings == YES)
\r
3219 if(TmpRegType == REGTYPE_REG)
\r
3220 strcpy(Path, ((REGDATATBL_REG *)Handle)->KeyName);
\r
3222 strcpy(Path, ((REGDATATBL *)Handle)->KeyName);
\r
3223 strcat(Path, "\\");
\r
3224 strcat(Path, Name);
\r
3225 UnmaskSettingsData(Path, strlen(Path), Str, StrMultiLen(Str) + 1, YES);
\r
3226 CalculateSettingsDataChecksum(Str, StrMultiLen(Str) + 1);
\r
3233 /*----- マルチ文字列を書き込む ------------------------------------------------
\r
3236 * void *Handle : ハンドル
\r
3242 * FFFTP_SUCCESS/FFFTP_FAIL
\r
3243 *----------------------------------------------------------------------------*/
\r
3245 static int WriteMultiStringToReg(void *Handle, char *Name, char *Str)
\r
3253 if(EncryptSettings == YES)
\r
3255 if(TmpRegType == REGTYPE_REG)
\r
3256 strcpy(Path, ((REGDATATBL_REG *)Handle)->KeyName);
\r
3258 strcpy(Path, ((REGDATATBL *)Handle)->KeyName);
\r
3259 strcat(Path, "\\");
\r
3260 strcat(Path, Name);
\r
3261 MaskSettingsData(Path, strlen(Path), Str, StrMultiLen(Str) + 1, YES);
\r
3263 if(TmpRegType == REGTYPE_REG)
\r
3265 // RegSetValueEx(Handle, Name, 0, REG_MULTI_SZ, (CONST BYTE *)Str, StrMultiLen(Str)+1);
\r
3266 RegSetValueEx(((REGDATATBL_REG *)Handle)->hKey, Name, 0, EncryptSettings == YES ? REG_BINARY : REG_MULTI_SZ, (CONST BYTE *)Str, StrMultiLen(Str)+1);
\r
3269 Pos = (REGDATATBL *)Handle;
\r
3270 Data = Pos->ValTbl + Pos->ValLen;
\r
3271 strcpy(Data, Name);
\r
3272 strcat(Data, "=");
\r
3273 Pos->ValLen += strlen(Data);
\r
3274 Data = Pos->ValTbl + Pos->ValLen;
\r
3275 Pos->ValLen += StrCatOut(Str, StrMultiLen(Str), Data) + 1;
\r
3278 if(EncryptSettings == YES)
\r
3280 UnmaskSettingsData(Path, strlen(Path), Str, StrMultiLen(Str) + 1, YES);
\r
3281 CalculateSettingsDataChecksum(Str, StrMultiLen(Str) + 1);
\r
3283 return(FFFTP_SUCCESS);
\r
3287 /*----- バイナリを読み込む-----------------------------------------------------
\r
3290 * void *Handle : ハンドル
\r
3292 * void *Bin : バイナリを返すワーク
\r
3293 * DWORD Size : 最大サイズ
\r
3297 * FFFTP_SUCCESS/FFFTP_FAIL
\r
3298 *----------------------------------------------------------------------------*/
\r
3300 static int ReadBinaryFromReg(void *Handle, char *Name, void *Bin, DWORD Size)
\r
3308 if(TmpRegType == REGTYPE_REG)
\r
3311 // if(RegQueryValueEx(Handle, Name, NULL, NULL, (BYTE *)Bin, &Size) == ERROR_SUCCESS)
\r
3312 if(RegQueryValueEx(((REGDATATBL_REG *)Handle)->hKey, Name, NULL, NULL, (BYTE *)Bin, &Size) == ERROR_SUCCESS)
\r
3313 Sts = FFFTP_SUCCESS;
\r
3317 if((Pos = ScanValue(Handle, Name)) != NULL)
\r
3319 Size = min1(Size, strlen(Pos));
\r
3320 Size = StrReadIn(Pos, Size, Bin);
\r
3321 Sts = FFFTP_SUCCESS;
\r
3325 if(Sts == FFFTP_SUCCESS)
\r
3327 if(EncryptSettings == YES)
\r
3329 if(TmpRegType == REGTYPE_REG)
\r
3330 strcpy(Path, ((REGDATATBL_REG *)Handle)->KeyName);
\r
3332 strcpy(Path, ((REGDATATBL *)Handle)->KeyName);
\r
3333 strcat(Path, "\\");
\r
3334 strcat(Path, Name);
\r
3335 UnmaskSettingsData(Path, strlen(Path), Bin, Size, NO);
\r
3336 CalculateSettingsDataChecksum(Bin, Size);
\r
3343 /*----- バイナリを書き込む ----------------------------------------------------
\r
3346 * void *Handle : ハンドル
\r
3348 * void *Bin : バイナリ
\r
3353 * FFFTP_SUCCESS/FFFTP_FAIL
\r
3354 *----------------------------------------------------------------------------*/
\r
3356 static int WriteBinaryToReg(void *Handle, char *Name, void *Bin, int Len)
\r
3364 if(EncryptSettings == YES)
\r
3366 if(TmpRegType == REGTYPE_REG)
\r
3367 strcpy(Path, ((REGDATATBL_REG *)Handle)->KeyName);
\r
3369 strcpy(Path, ((REGDATATBL *)Handle)->KeyName);
\r
3370 strcat(Path, "\\");
\r
3371 strcat(Path, Name);
\r
3372 MaskSettingsData(Path, strlen(Path), Bin, Len, NO);
\r
3374 if(TmpRegType == REGTYPE_REG)
\r
3376 // RegSetValueEx(Handle, Name, 0, REG_BINARY, (CONST BYTE *)Bin, Len);
\r
3377 RegSetValueEx(((REGDATATBL_REG *)Handle)->hKey, Name, 0, REG_BINARY, (CONST BYTE *)Bin, Len);
\r
3380 Pos = (REGDATATBL *)Handle;
\r
3381 Data = Pos->ValTbl + Pos->ValLen;
\r
3382 strcpy(Data, Name);
\r
3383 strcat(Data, "=");
\r
3384 Pos->ValLen += strlen(Data);
\r
3385 Data = Pos->ValTbl + Pos->ValLen;
\r
3386 Pos->ValLen += StrCatOut(Bin, Len, Data) + 1;
\r
3389 if(EncryptSettings == YES)
\r
3391 UnmaskSettingsData(Path, strlen(Path), Bin, Len, NO);
\r
3392 CalculateSettingsDataChecksum(Bin, Len);
\r
3394 return(FFFTP_SUCCESS);
\r
3398 /*----- 文字列をバッファに追加書き込みする ------------------------------------
\r
3402 * int len : 文字列の長さ
\r
3403 * char *Dst : 書き込みするバッファ
\r
3407 *----------------------------------------------------------------------------*/
\r
3409 static int StrCatOut(char *Src, int Len, char *Dst)
\r
3413 Dst += strlen(Dst);
\r
3415 for(; Len > 0; Len--)
\r
3423 else if((*Src >= 0x20) && (*Src <= 0x7E))
\r
3430 sprintf(Dst, "\\%02X", *(unsigned char *)Src);
\r
3441 /*----- 文字列をバッファに読み込む --------------------------------------------
\r
3446 * char *Dst : 書き込みするバッファ
\r
3450 *----------------------------------------------------------------------------*/
\r
3452 static int StrReadIn(char *Src, int Max, char *Dst)
\r
3458 while(*Src != NUL)
\r
3470 sscanf(Src, "%02x", &Tmp);
\r
3486 /*----- 値を検索する ----------------------------------------------------------
\r
3489 * char *Handle : ハンドル
\r
3494 * NULL=指定の名前の値が見つからない
\r
3495 *----------------------------------------------------------------------------*/
\r
3497 static char *ScanValue(void *Handle, char *Name)
\r
3505 Pos = Cur->ValTbl;
\r
3506 while(Pos < (Cur->ValTbl + Cur->ValLen))
\r
3508 if((strncmp(Name, Pos, strlen(Name)) == 0) &&
\r
3509 (*(Pos + strlen(Name)) == '='))
\r
3511 Ret = Pos + strlen(Name) + 1;
\r
3514 Pos += strlen(Pos) + 1;
\r
3520 /*----------- パスワードの妥当性を確認する ------------------------------------
\r
3523 * char *Password: パスワード文字列
\r
3524 * char *HashStr: SHA-1ハッシュ文字列
\r
3530 *----------------------------------------------------------------------------*/
\r
3532 //int CheckPasswordValidity( char* Password, int length, const char* HashStr )
\r
3533 int CheckPasswordValidity( char* Password, int length, const char* HashStr, int StretchCount )
\r
3535 char Buf[MAX_PASSWORD_LEN + 32];
\r
3541 const char* p = HashStr;
\r
3543 /* 空文字列は一致したことにする */
\r
3544 if( HashStr[0] == NUL ) return 1;
\r
3546 /* Hashをチェックするする*/
\r
3547 if( strlen(HashStr) != 40 ) return 2;
\r
3550 for( i = 0; i < 5; i++ ){
\r
3552 for( j = 0; j < 8; j++ ){
\r
3553 if( *p < 0x40 || 0x40 + 15 < *p ){
\r
3556 decode = (decode << 4 ) + (*p - 0x40);
\r
3559 hash1[i] = decode;
\r
3562 /* Password をハッシュする */
\r
3563 sha_memory( Password, length, hash2 );
\r
3564 for(i = 0; i < StretchCount; i++)
\r
3566 memcpy(&Buf[0], &hash2, 20);
\r
3567 memcpy(&Buf[20], Password, length);
\r
3568 sha_memory(Buf, 20 + length, hash2);
\r
3571 if( memcmp( (char*)hash1, (char*)hash2, sizeof( hash1 )) == 0 ){
\r
3577 /*----------- パスワードの妥当性チェックのための文字列を作成する ------------
\r
3580 * char *Password: パスワード文字列
\r
3581 * char *Str: SHA-1ハッシュ文字列格納場所 (41bytes以上)
\r
3585 *----------------------------------------------------------------------------*/
\r
3587 //void CreatePasswordHash( char* Password, int length, char* HashStr )
\r
3588 void CreatePasswordHash( char* Password, int length, char* HashStr, int StretchCount )
\r
3590 char Buf[MAX_PASSWORD_LEN + 32];
\r
3593 unsigned char *p = (unsigned char *)HashStr;
\r
3595 sha_memory( Password, length, hash );
\r
3596 for(i = 0; i < StretchCount; i++)
\r
3598 memcpy(&Buf[0], &hash, 20);
\r
3599 memcpy(&Buf[20], Password, length);
\r
3600 sha_memory(Buf, 20 + length, hash);
\r
3603 for( i = 0; i < 5; i++ ){
\r
3604 ulong rest = hash[i];
\r
3605 for( j = 0; j < 8; j++ ){
\r
3606 *p++ = (unsigned char)((rest & 0xf0000000) >> 28) + '@';
\r
3613 void SetHashSalt( DWORD salt )
\r
3616 // unsigned char* pos = &SecretKey[strlen(SecretKey) + 1];
\r
3617 unsigned char c[4];
\r
3618 unsigned char* pos = &c[0];
\r
3619 *pos++ = ( salt >> 24 ) & 0xff;
\r
3620 *pos++ = ( salt >> 16 ) & 0xff;
\r
3621 *pos++ = ( salt >> 8 ) & 0xff;
\r
3622 *pos++ = ( salt ) & 0xff;
\r
3624 // SecretKeyLength = strlen( SecretKey ) + 5;
\r
3625 SetHashSalt1(&c, 4);
\r
3629 void SetHashSalt1(void* Salt, int Length)
\r
3634 p = &SecretKey[strlen(SecretKey) + 1];
\r
3635 memcpy(p, Salt, Length);
\r
3636 SecretKeyLength = (int)strlen(SecretKey) + 1 + Length;
\r
3639 SecretKeyLength = (int)strlen(SecretKey) + 1;
\r
3643 /*----------- 乱数生成をする -------------------------------------------------
\r
3648 * ランダムな値:コンパイラVS2005/動作環境WinXP以上では rand_s から取得する
\r
3649 *----------------------------------------------------------------------------*/
\r
3650 DWORD GetRandamDWORDValue(void)
\r
3654 #ifdef _CRT_RAND_S
\r
3655 errno_t errnoRand_s;
\r
3656 errnoRand_s = rand_s(&rndValue);
\r
3657 errorCode = (0 != errnoRand_s ? 1 : 0);
\r
3661 if(0 != errorCode){
\r
3662 #ifdef USE_RANDAM_C_RAND
\r
3663 rndValue = rand() | (rand() << 16);
\r
3665 /* rand() のかわりに、SHA-1とパフォーマンスカウンタを用いる */
\r
3666 ulong shaValue[5];
\r
3667 LARGE_INTEGER Counter;
\r
3669 if(0 == IsRndSourceInit){
\r
3671 HANDLE CurProcHandle;
\r
3672 HANDLE CurThreadHandle;
\r
3674 if(DuplicateHandle(GetCurrentProcess(), GetCurrentProcess(), GetCurrentProcess(),
\r
3675 &CurProcHandle, 0, FALSE, DUPLICATE_SAME_ACCESS))
\r
3677 CloseHandle(CurProcHandle);
\r
3679 if(DuplicateHandle(GetCurrentProcess(), GetCurrentThread(), GetCurrentProcess(),
\r
3680 &CurThreadHandle, 0, FALSE, DUPLICATE_SAME_ACCESS))
\r
3682 CloseHandle(CurThreadHandle);
\r
3685 /* _WIN64 では64bitだが、その場合はrand_sが大抵利用可能なのでここでは32bitのみ用いる */
\r
3686 RndSource[0] = (ulong)CurProcHandle;
\r
3687 RndSource[1] = (ulong)CurThreadHandle;
\r
3688 RndSource[2] = (ulong)GetTickCount();
\r
3689 RndSource[3] = (ulong)timeGetTime();
\r
3690 RndSource[4] = 0; /* カウントアップ */
\r
3691 RndSource[5] = RndSource[3] + 1;
\r
3692 IsRndSourceInit = 1;
\r
3695 RndSource[5] += 0x00010010;
\r
3696 if(QueryPerformanceCounter(&Counter)){
\r
3697 RndSource[6] = Counter.LowPart;
\r
3698 RndSource[7] = Counter.HighPart;
\r
3699 RndSource[8] = (ulong)rand();
\r
3701 RndSource[6] = (ulong)timeGetTime();
\r
3702 RndSource[7] = (ulong)rand();
\r
3703 RndSource[8] = (ulong)rand();
\r
3706 sha_memory((char *)RndSource, sizeof(RndSource), shaValue);
\r
3707 rndValue = shaValue[0] ^ shaValue[1] ^ shaValue[2] ^ shaValue[3] ^ shaValue[4];
\r
3714 void GetMaskWithHMACSHA1(DWORD Nonce, const char* Salt, int SaltLength, void* pHash)
\r
3716 BYTE Key[FMAX_PATH*2+1];
\r
3719 for(i = 0; i < 16; i++)
\r
3722 Nonce *= 1566083941;
\r
3723 Nonce = _byteswap_ulong(Nonce);
\r
3724 memcpy(&Key[i * 4], &Nonce, 4);
\r
3726 memcpy(&Key[64], Salt, SaltLength);
\r
3727 memcpy(&Key[64 + SaltLength], SecretKey, SecretKeyLength);
\r
3728 sha_memory((char*)&Key, 64 + SaltLength + SecretKeyLength, Hash);
\r
3729 // sha.cはビッグエンディアンのため
\r
3730 for(i = 0; i < 5; i++)
\r
3731 Hash[i] = _byteswap_ulong(Hash[i]);
\r
3732 memcpy(&Key[0], &Hash, 20);
\r
3733 memset(&Key[20], 0, 44);
\r
3734 for(i = 0; i < 64; i++)
\r
3736 sha_memory((char*)&Key, 64, Hash);
\r
3737 // sha.cはビッグエンディアンのため
\r
3738 for(i = 0; i < 5; i++)
\r
3739 Hash[i] = _byteswap_ulong(Hash[i]);
\r
3740 memcpy(&Key[64], &Hash, 20);
\r
3741 for(i = 0; i < 64; i++)
\r
3743 sha_memory((char*)&Key, 84, Hash);
\r
3744 // sha.cはビッグエンディアンのため
\r
3745 for(i = 0; i < 5; i++)
\r
3746 Hash[i] = _byteswap_ulong(Hash[i]);
\r
3747 memcpy(pHash, &Hash, 20);
\r
3750 void MaskSettingsData(const char* Salt, int SaltLength, void* Data, DWORD Size, int EscapeZero)
\r
3756 for(i = 0; i < Size; i++)
\r
3759 GetMaskWithHMACSHA1(i, Salt, SaltLength, &Mask);
\r
3760 if(EscapeZero == NO || (p[i] != 0 && p[i] != Mask[i % 20]))
\r
3761 p[i] ^= Mask[i % 20];
\r
3765 void UnmaskSettingsData(const char* Salt, int SaltLength, void* Data, DWORD Size, int EscapeZero)
\r
3767 MaskSettingsData(Salt, SaltLength, Data, Size, EscapeZero);
\r
3770 void CalculateSettingsDataChecksum(void* Data, DWORD Size)
\r
3775 sha_memory((char*)Data, Size, Hash);
\r
3776 // sha.cはビッグエンディアンのため
\r
3777 for(i = 0; i < 5; i++)
\r
3778 Hash[i] = _byteswap_ulong(Hash[i]);
\r
3779 memcpy(&Mask, &Hash, 20);
\r
3780 for(i = 0; i < 20; i++)
\r
3781 EncryptSettingsChecksum[i] ^= Mask[i];
\r
3785 int IsRegAvailable()
\r
3790 SetRegType(REGTYPE_REG);
\r
3791 if(OpenReg("FFFTP", &h) == FFFTP_SUCCESS)
\r
3799 int IsIniAvailable()
\r
3804 SetRegType(REGTYPE_INI);
\r
3805 if(OpenReg("FFFTP", &h) == FFFTP_SUCCESS)
\r
3814 int ReadSettingsVersion()
\r
3820 SetRegType(REGTYPE_INI);
\r
3821 if((i = OpenReg("FFFTP", &hKey3)) != FFFTP_SUCCESS)
\r
3823 if(AskForceIni() == NO)
\r
3825 SetRegType(REGTYPE_REG);
\r
3826 i = OpenReg("FFFTP", &hKey3);
\r
3829 Version = INT_MAX;
\r
3830 if(i == FFFTP_SUCCESS)
\r
3832 ReadIntValueFromReg(hKey3, "Version", &Version);
\r
3838 // FileZilla XML形式エクスポート対応
\r
3839 void SaveSettingsToFileZillaXml()
\r
3841 char Fname[FMAX_PATH+1];
\r
3843 TIME_ZONE_INFORMATION tzi;
\r
3847 char Tmp[FMAX_PATH+1];
\r
3850 strcpy(Fname, "FileZilla.xml");
\r
3851 if(SelectFile(GetMainHwnd(), Fname, MSGJPN286, MSGJPN356, "xml", OFN_EXTENSIONDIFFERENT | OFN_OVERWRITEPROMPT, 1) == TRUE)
\r
3853 if((f = fopen(Fname, "wt")) != NULL)
\r
3855 fputs("<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\" ?>\n", f);
\r
3856 fputs("<FileZilla3>\n", f);
\r
3857 fputs("<Servers>\n", f);
\r
3858 GetTimeZoneInformation(&tzi);
\r
3861 while(CopyHostFromList(i, &Host) == FFFTP_SUCCESS)
\r
3863 while((Host.Level & SET_LEVEL_MASK) < Level)
\r
3865 fputs("</Folder>\n", f);
\r
3868 if(Host.Level & SET_LEVEL_GROUP)
\r
3870 fputs("<Folder expanded=\"1\">\n", f);
\r
3871 fprintf(f, "%s
\n", Host.HostName);
\r
3876 fputs("<Server>\n", f);
\r
3877 fprintf(f, "<Host>%s</Host>\n", Host.HostAdrs);
\r
3878 fprintf(f, "<Port>%d</Port>\n", Host.Port);
\r
3879 if(Host.UseNoEncryption == YES)
\r
3880 fprintf(f, "<Protocol>%s</Protocol>\n", "0");
\r
3881 else if(Host.UseFTPES == YES)
\r
3882 fprintf(f, "<Protocol>%s</Protocol>\n", "4");
\r
3883 else if(Host.UseFTPIS == YES)
\r
3884 fprintf(f, "<Protocol>%s</Protocol>\n", "3");
\r
3886 fprintf(f, "<Protocol>%s</Protocol>\n", "0");
\r
3887 fprintf(f, "<Type>%s</Type>\n", "0");
\r
3888 fprintf(f, "<User>%s</User>\n", Host.UserName);
\r
3889 fprintf(f, "<Pass>%s</Pass>\n", Host.PassWord);
\r
3890 fprintf(f, "<Account>%s</Account>\n", Host.Account);
\r
3891 if(Host.Anonymous == YES || strlen(Host.UserName) == 0)
\r
3892 fprintf(f, "<Logontype>%s</Logontype>\n", "0");
\r
3894 fprintf(f, "<Logontype>%s</Logontype>\n", "1");
\r
3895 fprintf(f, "<TimezoneOffset>%d</TimezoneOffset>\n", tzi.Bias + Host.TimeZone * 60);
\r
3896 if(Host.Pasv == YES)
\r
3897 fprintf(f, "<PasvMode>%s</PasvMode>\n", "MODE_PASSIVE");
\r
3899 fprintf(f, "<PasvMode>%s</PasvMode>\n", "MODE_ACTIVE");
\r
3900 fprintf(f, "<MaximumMultipleConnections>%d</MaximumMultipleConnections>\n", Host.MaxThreadCount);
\r
3901 switch(Host.NameKanjiCode)
\r
3904 fprintf(f, "<EncodingType>%s</EncodingType>\n", "Custom");
\r
3905 fprintf(f, "<CustomEncoding>%s</CustomEncoding>\n", "Shift_JIS");
\r
3909 fprintf(f, "<EncodingType>%s</EncodingType>\n", "Auto");
\r
3912 fprintf(f, "<EncodingType>%s</EncodingType>\n", "Custom");
\r
3913 fprintf(f, "<CustomEncoding>%s</CustomEncoding>\n", "EUC-JP");
\r
3915 case KANJI_SMB_HEX:
\r
3917 fprintf(f, "<EncodingType>%s</EncodingType>\n", "Auto");
\r
3919 case KANJI_SMB_CAP:
\r
3921 fprintf(f, "<EncodingType>%s</EncodingType>\n", "Auto");
\r
3924 fprintf(f, "<EncodingType>%s</EncodingType>\n", "UTF-8");
\r
3926 case KANJI_UTF8HFSX:
\r
3928 fprintf(f, "<EncodingType>%s</EncodingType>\n", "Auto");
\r
3931 fprintf(f, "<EncodingType>%s</EncodingType>\n", "Auto");
\r
3934 if(Host.FireWall == YES)
\r
3935 fprintf(f, "<BypassProxy>%s</BypassProxy>\n", "0");
\r
3937 fprintf(f, "<BypassProxy>%s</BypassProxy>\n", "1");
\r
3938 fprintf(f, "<Name>%s</Name>\n", Host.HostName);
\r
3939 fprintf(f, "<LocalDir>%s</LocalDir>\n", Host.LocalInitDir);
\r
3940 if(strchr(Host.RemoteInitDir, '\\') != NULL)
\r
3942 fputs("<RemoteDir>", f);
\r
3944 strcpy(Tmp, Host.RemoteInitDir);
\r
3946 while(*p1 != '\0')
\r
3948 while(*p1 == '\\')
\r
3952 if((p2 = strchr(p1, '\\')) != NULL)
\r
3958 p2 = strchr(p1, '\0');
\r
3960 fprintf(f, " %d %s", _mbslen(p1), p1);
\r
3963 fputs("</RemoteDir>\n", f);
\r
3965 else if(strchr(Host.RemoteInitDir, '/') != NULL)
\r
3967 fputs("<RemoteDir>", f);
\r
3969 strcpy(Tmp, Host.RemoteInitDir);
\r
3971 while(*p1 != '\0')
\r
3977 if((p2 = strchr(p1, '/')) != NULL)
\r
3983 p2 = strchr(p1, '\0');
\r
3985 fprintf(f, " %d %s", _mbslen(p1), p1);
\r
3988 fputs("</RemoteDir>\n", f);
\r
3991 fprintf(f, "<RemoteDir>%s</RemoteDir>\n", Host.RemoteInitDir);
\r
3992 if(Host.SyncMove == YES)
\r
3993 fprintf(f, "<SyncBrowsing>%s</SyncBrowsing>\n", "1");
\r
3995 fprintf(f, "<SyncBrowsing>%s</SyncBrowsing>\n", "0");
\r
3996 fprintf(f, "%s
\n", Host.HostName);
\r
3997 fputs("</Server>\n", f);
\r
4003 fputs("</Folder>\n", f);
\r
4006 fputs("</Servers>\n", f);
\r
4008 // fputs("<Settings>\n", f);
\r
4009 // fputs("</Settings>\n", f);
\r
4010 fputs("</FileZilla3>\n", f);
\r
4014 MessageBox(GetMainHwnd(), MSGJPN357, "FFFTP", MB_OK | MB_ICONERROR);
\r