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
56 static void SaveStr(HKEY hKey, char *Key, char *Str, char *DefaultStr);
\r
57 static void SaveIntNum(HKEY hKey, char *Key, int Num, int DefaultNum);
\r
58 static void MakeFontData(LOGFONT Font, HFONT hFont, char *Buf);
\r
59 static int RestoreFontData(char *Str, LOGFONT *Font);
\r
61 static void EncodePassword(char *Str, char *Buf);
\r
62 static void EncodePasswordOriginal(char *Str, char *Buf);
\r
63 static void EncodePassword2(char *Str, char *Buf, const char *Key);
\r
64 static void EncodePassword3(char *Str, char *Buf, const char *Key);
\r
66 static void DecodePassword(char *Str, char *Buf);
\r
67 static void DecodePasswordOriginal(char *Str, char *Buf);
\r
68 static void DecodePassword2(char *Str, char *Buf, const char *Key);
\r
69 static void DecodePassword3(char *Str, char *Buf, const char *Key);
\r
70 static int CreateAesKey(unsigned char *AesKey, const char* Key);
\r
72 static void SetRegType(int Type);
\r
73 static int OpenReg(char *Name, void **Handle);
\r
74 static int CreateReg(char *Name, void **Handle);
\r
75 static int CloseReg(void *Handle);
\r
76 static int OpenSubKey(void *Parent, char *Name, void **Handle);
\r
77 static int CreateSubKey(void *Parent, char *Name, void **Handle);
\r
78 static int CloseSubKey(void *Handle);
\r
79 static int DeleteSubKey(void *Handle, char *Name);
\r
80 static int DeleteValue(void *Handle, char *Name);
\r
81 static int ReadIntValueFromReg(void *Handle, char *Name, int *Value);
\r
82 static int WriteIntValueToReg(void *Handle, char *Name, int Value);
\r
83 static int ReadStringFromReg(void *Handle, char *Name, char *Str, DWORD Size);
\r
84 static int WriteStringToReg(void *Handle, char *Name, char *Str);
\r
85 static int ReadMultiStringFromReg(void *Handle, char *Name, char *Str, DWORD Size);
\r
86 static int WriteMultiStringToReg(void *Handle, char *Name, char *Str);
\r
87 static int ReadBinaryFromReg(void *Handle, char *Name, void *Bin, DWORD Size);
\r
88 static int WriteBinaryToReg(void *Handle, char *Name, void *Bin, int Len);
\r
90 static int StrCatOut(char *Src, int Len, char *Dst);
\r
91 static int StrReadIn(char *Src, int Max, char *Dst);
\r
93 int CheckPasswordValidity( char* Password, int length, const char* HashStr );
\r
94 void CreatePasswordHash( char* Password, int length, char* HashStr );
\r
95 void SetHashSalt( DWORD salt );
\r
97 DWORD GetRandamDWRODValue(void);
\r
99 /* 2010.01.30 genta 追加 */
\r
100 static char SecretKey[FMAX_PATH+1];
\r
101 static int SecretKeyLength;
\r
102 static int IsMasterPasswordError = PASSWORD_OK;
\r
104 static int IsRndSourceInit = 0;
\r
105 static ulong RndSource[9];
\r
108 static int IniKanjiCode = KANJI_NOCNV;
\r
110 /*===== 外部参照 =====*/
\r
113 extern int WinPosX;
\r
114 extern int WinPosY;
\r
115 extern int WinWidth;
\r
116 extern int WinHeight;
\r
117 extern int LocalWidth;
\r
118 extern int TaskHeight;
\r
119 extern int LocalTabWidth[4];
\r
120 extern int RemoteTabWidth[6];
\r
121 extern char UserMailAdrs[USER_MAIL_LEN+1];
\r
122 extern char ViewerName[VIEWERS][FMAX_PATH+1];
\r
123 extern HFONT ListFont;
\r
124 extern LOGFONT ListLogFont;
\r
125 extern int LocalFileSort;
\r
126 extern int LocalDirSort;
\r
127 extern int RemoteFileSort;
\r
128 extern int RemoteDirSort;
\r
129 extern int TransMode;
\r
130 extern int ConnectOnStart;
\r
131 extern int DebugConsole;
\r
132 extern int SaveWinPos;
\r
133 extern char AsciiExt[ASCII_EXT_LEN+1];
\r
134 extern int RecvMode;
\r
135 extern int SendMode;
\r
136 extern int MoveMode;
\r
137 extern int ListType;
\r
138 extern int CacheEntry;
\r
139 extern int CacheSave;
\r
140 extern char DefaultLocalPath[FMAX_PATH+1];
\r
141 extern int SaveTimeStamp;
\r
142 extern int FindMode;
\r
143 extern int DotFile;
\r
144 extern int DclickOpen;
\r
145 extern SOUNDFILE Sound[SOUND_TYPES];
\r
146 extern int FnameCnv;
\r
147 extern int ConnectAndSet;
\r
148 extern int TimeOut;
\r
150 extern int RegType;
\r
151 extern char FwallHost[HOST_ADRS_LEN+1];
\r
152 extern char FwallUser[USER_NAME_LEN+1];
\r
153 extern char FwallPass[PASSWORD_LEN+1];
\r
154 extern int FwallPort;
\r
155 extern int FwallType;
\r
156 extern int FwallDefault;
\r
157 extern int FwallSecurity;
\r
158 extern int FwallResolv;
\r
159 extern int FwallLower;
\r
160 extern int FwallDelimiter;
\r
161 extern int PasvDefault;
\r
162 extern char MirrorNoTrn[MIRROR_LEN+1];
\r
163 extern char MirrorNoDel[MIRROR_LEN+1];
\r
164 extern int MirrorFnameCnv;
\r
165 //extern int MirrorFolderCnv;
\r
166 extern int RasClose;
\r
167 extern int RasCloseNotify;
\r
168 extern int FileHist;
\r
169 extern char DefAttrList[DEFATTRLIST_LEN+1];
\r
170 extern SIZE HostDlgSize;
\r
171 extern SIZE BmarkDlgSize;
\r
172 extern SIZE MirrorDlgSize;
\r
174 extern int SortSave;
\r
175 extern char TmpPath[FMAX_PATH+1];
\r
176 extern int QuickAnonymous;
\r
177 extern int PassToHist;
\r
178 extern int VaxSemicolon;
\r
179 extern int SendQuit;
\r
180 extern int NoRasControl;
\r
181 extern int SuppressSave;
\r
183 extern int UpExistMode;
\r
184 extern int ExistMode;
\r
185 extern int DispIgnoreHide;
\r
186 extern int DispDrives;
\r
187 extern int MirUpDelNotify;
\r
188 extern int MirDownDelNotify;
\r
190 extern int FolderAttr;
\r
191 extern int FolderAttrNum;
\r
194 extern BYTE CertificateCacheHash[MAX_CERT_CACHE_HASH][20];
\r
195 extern BYTE SSLRootCAFileHash[20];
\r
197 extern int DispFileIcon;
\r
199 /*----- マスタパスワードの設定 ----------------------------------------------
\r
202 * const char* Password : マスターパスワード
\r
206 *----------------------------------------------------------------------------*/
\r
207 void SetMasterPassword( const char* Password )
\r
209 ZeroMemory( SecretKey, MAX_PASSWORD_LEN + 12 );
\r
210 if( Password != NULL ){
\r
211 strncpy( SecretKey, Password, MAX_PASSWORD_LEN );
\r
214 strcpy( SecretKey, DEFAULT_PASSWORD );
\r
216 SecretKeyLength = strlen( SecretKey );
\r
218 /* 未検証なので,初期状態はOKにする (強制再設定→保存にを可能にする)*/
\r
219 IsMasterPasswordError = PASSWORD_OK;
\r
222 /*----- マスタパスワードの状態取得 ----------------------------------------------
\r
229 * PASSWORD_UNMATCH : パスワード不一致
\r
230 * BAD_PASSWORD_HASH : パスワード確認失敗
\r
231 *----------------------------------------------------------------------------*/
\r
232 int GetMasterPasswordStatus(void)
\r
234 return IsMasterPasswordError;
\r
237 /*----- レジストリ/INIファイルのマスターパスワードの検証を行う ------------
\r
244 *----------------------------------------------------------------------------*/
\r
246 int ValidateMasterPassword(void)
\r
251 SetRegType(REGTYPE_INI);
\r
252 if((i = OpenReg("FFFTP", &hKey3)) != FFFTP_SUCCESS)
\r
254 if(AskForceIni() == NO)
\r
256 SetRegType(REGTYPE_REG);
\r
257 i = OpenReg("FFFTP", &hKey3);
\r
260 if(i == FFFTP_SUCCESS){
\r
264 if( ReadIntValueFromReg(hKey3, "CredentialSalt", &salt)){
\r
265 SetHashSalt( salt );
\r
267 if( ReadStringFromReg(hKey3, "CredentialCheck", checkbuf, sizeof( checkbuf )) == FFFTP_SUCCESS ){
\r
268 switch( CheckPasswordValidity( SecretKey, SecretKeyLength, checkbuf ) ){
\r
269 case 0: /* not match */
\r
270 IsMasterPasswordError = PASSWORD_UNMATCH;
\r
272 case 1: /* match */
\r
273 IsMasterPasswordError = PASSWORD_OK;
\r
275 case 2: /* invalid hash */
\r
277 IsMasterPasswordError = BAD_PASSWORD_HASH;
\r
287 /*----- レジストリ/INIファイルに設定値を保存 ---------------------------------
\r
294 *----------------------------------------------------------------------------*/
\r
296 void SaveRegistory(void)
\r
302 // char Str[FMAX_PATH+1];
\r
303 char Str[PRIVATE_KEY_LEN*4+1];
\r
304 char Buf[FMAX_PATH+1];
\r
307 HOSTDATA DefaultHost;
\r
310 HISTORYDATA DefaultHist;
\r
312 if( GetMasterPasswordStatus() == PASSWORD_UNMATCH ){
\r
313 /* 2010.01.30 genta: マスターパスワードが不一致の場合は不用意に上書きしない */
\r
317 SetRegType(RegType);
\r
318 if(CreateReg("FFFTP", &hKey3) == FFFTP_SUCCESS)
\r
321 int salt = GetTickCount();
\r
323 WriteIntValueToReg(hKey3, "Version", VER_NUM);
\r
324 WriteIntValueToReg(hKey3, "CredentialSalt", salt);
\r
326 SetHashSalt( salt );
\r
327 /* save password hash */
\r
328 CreatePasswordHash( SecretKey, SecretKeyLength, buf );
\r
329 WriteStringToReg(hKey3, "CredentialCheck", buf);
\r
331 if(CreateSubKey(hKey3, "Options", &hKey4) == FFFTP_SUCCESS)
\r
333 WriteIntValueToReg(hKey4, "NoSave", SuppressSave);
\r
335 if(SuppressSave != YES)
\r
337 WriteIntValueToReg(hKey4, "WinPosX", WinPosX);
\r
338 WriteIntValueToReg(hKey4, "WinPosY", WinPosY);
\r
339 WriteIntValueToReg(hKey4, "WinWidth", WinWidth);
\r
340 WriteIntValueToReg(hKey4, "WinHeight", WinHeight);
\r
341 WriteIntValueToReg(hKey4, "LocalWidth", LocalWidth);
\r
342 WriteIntValueToReg(hKey4, "TaskHeight", TaskHeight);
\r
343 WriteBinaryToReg(hKey4, "LocalColm", LocalTabWidth, sizeof(LocalTabWidth));
\r
344 WriteBinaryToReg(hKey4, "RemoteColm", RemoteTabWidth, sizeof(RemoteTabWidth));
\r
345 WriteIntValueToReg(hKey4, "SwCmd", Sizing);
\r
347 WriteStringToReg(hKey4, "UserMail", UserMailAdrs);
\r
348 WriteStringToReg(hKey4, "Viewer", ViewerName[0]);
\r
349 WriteStringToReg(hKey4, "Viewer2", ViewerName[1]);
\r
350 WriteStringToReg(hKey4, "Viewer3", ViewerName[2]);
\r
352 WriteIntValueToReg(hKey4, "TrType", TransMode);
\r
353 WriteIntValueToReg(hKey4, "Recv", RecvMode);
\r
354 WriteIntValueToReg(hKey4, "Send", SendMode);
\r
355 WriteIntValueToReg(hKey4, "Move", MoveMode);
\r
356 WriteStringToReg(hKey4, "Path", DefaultLocalPath);
\r
357 WriteIntValueToReg(hKey4, "Time", SaveTimeStamp);
\r
358 WriteIntValueToReg(hKey4, "EOF", RmEOF);
\r
359 WriteIntValueToReg(hKey4, "Scolon", VaxSemicolon);
\r
361 WriteIntValueToReg(hKey4, "RecvEx", ExistMode);
\r
362 WriteIntValueToReg(hKey4, "SendEx", UpExistMode);
\r
364 WriteIntValueToReg(hKey4, "LFsort", LocalFileSort);
\r
365 WriteIntValueToReg(hKey4, "LDsort", LocalDirSort);
\r
366 WriteIntValueToReg(hKey4, "RFsort", RemoteFileSort);
\r
367 WriteIntValueToReg(hKey4, "RDsort", RemoteDirSort);
\r
368 WriteIntValueToReg(hKey4, "SortSave", SortSave);
\r
370 WriteIntValueToReg(hKey4, "ListType", ListType);
\r
371 WriteIntValueToReg(hKey4, "Cache", CacheEntry);
\r
372 WriteIntValueToReg(hKey4, "CacheSave", CacheSave);
\r
373 WriteIntValueToReg(hKey4, "DotFile", DotFile);
\r
374 WriteIntValueToReg(hKey4, "Dclick", DclickOpen);
\r
376 WriteIntValueToReg(hKey4, "ConS", ConnectOnStart);
\r
377 WriteIntValueToReg(hKey4, "OldDlg", ConnectAndSet);
\r
378 WriteIntValueToReg(hKey4, "RasClose", RasClose);
\r
379 WriteIntValueToReg(hKey4, "RasNotify", RasCloseNotify);
\r
380 WriteIntValueToReg(hKey4, "Qanony", QuickAnonymous);
\r
381 WriteIntValueToReg(hKey4, "PassHist", PassToHist);
\r
382 WriteIntValueToReg(hKey4, "SendQuit", SendQuit);
\r
383 WriteIntValueToReg(hKey4, "NoRas", NoRasControl);
\r
385 WriteIntValueToReg(hKey4, "Debug", DebugConsole);
\r
386 WriteIntValueToReg(hKey4, "WinPos", SaveWinPos);
\r
387 WriteIntValueToReg(hKey4, "RegExp", FindMode);
\r
388 WriteIntValueToReg(hKey4, "Reg", RegType);
\r
390 WriteMultiStringToReg(hKey4, "AsciiFile", AsciiExt);
\r
391 WriteIntValueToReg(hKey4, "LowUp", FnameCnv);
\r
392 WriteIntValueToReg(hKey4, "Tout", TimeOut);
\r
394 WriteMultiStringToReg(hKey4, "NoTrn", MirrorNoTrn);
\r
395 WriteMultiStringToReg(hKey4, "NoDel", MirrorNoDel);
\r
396 WriteIntValueToReg(hKey4, "MirFile", MirrorFnameCnv);
\r
397 WriteIntValueToReg(hKey4, "MirUNot", MirUpDelNotify);
\r
398 WriteIntValueToReg(hKey4, "MirDNot", MirDownDelNotify);
\r
400 MakeFontData(ListLogFont, ListFont, Str);
\r
401 WriteStringToReg(hKey4, "ListFont", Str);
\r
402 WriteIntValueToReg(hKey4, "ListHide", DispIgnoreHide);
\r
403 WriteIntValueToReg(hKey4, "ListDrv", DispDrives);
\r
405 WriteStringToReg(hKey4, "FwallHost", FwallHost);
\r
406 WriteStringToReg(hKey4, "FwallUser", FwallUser);
\r
407 EncodePassword(FwallPass, Str);
\r
408 WriteStringToReg(hKey4, "FwallPass", Str);
\r
409 WriteIntValueToReg(hKey4, "FwallPort", FwallPort);
\r
410 WriteIntValueToReg(hKey4, "FwallType", FwallType);
\r
411 WriteIntValueToReg(hKey4, "FwallDef", FwallDefault);
\r
412 WriteIntValueToReg(hKey4, "FwallSec", FwallSecurity);
\r
413 WriteIntValueToReg(hKey4, "PasvDef", PasvDefault);
\r
414 WriteIntValueToReg(hKey4, "FwallRes", FwallResolv);
\r
415 WriteIntValueToReg(hKey4, "FwallLow", FwallLower);
\r
416 WriteIntValueToReg(hKey4, "FwallDel", FwallDelimiter);
\r
418 WriteIntValueToReg(hKey4, "SndConSw", Sound[SND_CONNECT].On);
\r
419 WriteIntValueToReg(hKey4, "SndTrnSw", Sound[SND_TRANS].On);
\r
420 WriteIntValueToReg(hKey4, "SndErrSw", Sound[SND_ERROR].On);
\r
421 WriteStringToReg(hKey4, "SndCon", Sound[SND_CONNECT].Fname);
\r
422 WriteStringToReg(hKey4, "SndTrn", Sound[SND_TRANS].Fname);
\r
423 WriteStringToReg(hKey4, "SndErr", Sound[SND_ERROR].Fname);
\r
425 WriteMultiStringToReg(hKey4, "DefAttr", DefAttrList);
\r
428 // GetTempPath(FMAX_PATH, Str);
\r
429 GetAppTempPath(Str);
\r
431 SaveStr(hKey4, "Tmp", TmpPath, Str);
\r
433 WriteBinaryToReg(hKey4, "Hdlg", &HostDlgSize, sizeof(SIZE));
\r
434 WriteBinaryToReg(hKey4, "Bdlg", &BmarkDlgSize, sizeof(SIZE));
\r
435 WriteBinaryToReg(hKey4, "Mdlg", &MirrorDlgSize, sizeof(SIZE));
\r
437 WriteIntValueToReg(hKey4, "FAttrSw", FolderAttr);
\r
438 WriteIntValueToReg(hKey4, "FAttr", FolderAttrNum);
\r
440 WriteIntValueToReg(hKey4, "HistNum", FileHist);
\r
442 /* Ver1.54a以前の形式のヒストリデータは削除 */
\r
443 DeleteValue(hKey4, "Hist");
\r
446 CopyDefaultHistory(&DefaultHist);
\r
448 for(i = AskHistoryNum(); i > 0; i--)
\r
450 if(GetHistoryByNum(i-1, &Hist) == FFFTP_SUCCESS)
\r
452 sprintf(Str, "History%d", n);
\r
453 if(CreateSubKey(hKey4, Str, &hKey5) == FFFTP_SUCCESS)
\r
455 SaveStr(hKey5, "HostAdrs", Hist.HostAdrs, DefaultHist.HostAdrs);
\r
456 SaveStr(hKey5, "UserName", Hist.UserName, DefaultHist.UserName);
\r
457 SaveStr(hKey5, "Account", Hist.Account, DefaultHist.Account);
\r
458 SaveStr(hKey5, "LocalDir", Hist.LocalInitDir, NULL);
\r
459 SaveStr(hKey5, "RemoteDir", Hist.RemoteInitDir, DefaultHist.RemoteInitDir);
\r
460 SaveStr(hKey5, "Chmod", Hist.ChmodCmd, DefaultHist.ChmodCmd);
\r
461 SaveStr(hKey5, "Nlst", Hist.LsName, DefaultHist.LsName);
\r
462 SaveStr(hKey5, "Init", Hist.InitCmd, DefaultHist.InitCmd);
\r
463 EncodePassword(Hist.PassWord, Str);
\r
464 SaveStr(hKey5, "Password", Str, DefaultHist.PassWord);
\r
465 SaveIntNum(hKey5, "Port", Hist.Port, DefaultHist.Port);
\r
466 SaveIntNum(hKey5, "Kanji", Hist.KanjiCode, DefaultHist.KanjiCode);
\r
467 SaveIntNum(hKey5, "KanaCnv", Hist.KanaCnv, DefaultHist.KanaCnv);
\r
468 SaveIntNum(hKey5, "NameKanji", Hist.NameKanjiCode, DefaultHist.NameKanjiCode);
\r
469 SaveIntNum(hKey5, "NameKana", Hist.NameKanaCnv, DefaultHist.NameKanaCnv);
\r
470 SaveIntNum(hKey5, "Pasv", Hist.Pasv, DefaultHist.Pasv);
\r
471 SaveIntNum(hKey5, "Fwall", Hist.FireWall, DefaultHist.FireWall);
\r
472 SaveIntNum(hKey5, "List", Hist.ListCmdOnly, DefaultHist.ListCmdOnly);
\r
473 SaveIntNum(hKey5, "NLST-R", Hist.UseNLST_R, DefaultHist.UseNLST_R);
\r
474 SaveIntNum(hKey5, "Tzone", Hist.TimeZone, DefaultHist.TimeZone);
\r
475 SaveIntNum(hKey5, "Type", Hist.HostType, DefaultHist.HostType);
\r
476 SaveIntNum(hKey5, "Sync", Hist.SyncMove, DefaultHist.SyncMove);
\r
477 SaveIntNum(hKey5, "Fpath", Hist.NoFullPath, DefaultHist.NoFullPath);
\r
478 WriteBinaryToReg(hKey5, "Sort", &Hist.Sort, sizeof(Hist.Sort));
\r
479 SaveIntNum(hKey5, "Secu", Hist.Security, DefaultHist.Security);
\r
480 WriteIntValueToReg(hKey5, "TrType", Hist.Type);
\r
481 SaveIntNum(hKey5, "Dial", Hist.Dialup, DefaultHist.Dialup);
\r
482 SaveIntNum(hKey5, "UseIt", Hist.DialupAlways, DefaultHist.DialupAlways);
\r
483 SaveIntNum(hKey5, "Notify", Hist.DialupNotify, DefaultHist.DialupNotify);
\r
484 SaveStr(hKey5, "DialTo", Hist.DialEntry, DefaultHist.DialEntry);
\r
486 SaveIntNum(hKey5, "NoEncryption", Hist.UseNoEncryption, DefaultHist.UseNoEncryption);
\r
487 SaveIntNum(hKey5, "FTPES", Hist.UseFTPES, DefaultHist.UseFTPES);
\r
488 SaveIntNum(hKey5, "FTPIS", Hist.UseFTPIS, DefaultHist.UseFTPIS);
\r
489 SaveIntNum(hKey5, "SFTP", Hist.UseSFTP, DefaultHist.UseSFTP);
\r
490 EncodePassword(Hist.PrivateKey, Str);
\r
491 SaveStr(hKey5, "PKey", Str, DefaultHist.PrivateKey);
\r
493 SaveIntNum(hKey5, "ThreadCount", Hist.MaxThreadCount, DefaultHist.MaxThreadCount);
\r
494 SaveIntNum(hKey5, "ReuseCmdSkt", Hist.ReuseCmdSkt, DefaultHist.ReuseCmdSkt);
\r
496 SaveIntNum(hKey5, "MLSD", Hist.UseMLSD, DefaultHist.UseMLSD);
\r
498 SaveIntNum(hKey5, "NetType", Hist.NetType, DefaultHist.NetType);
\r
500 SaveIntNum(hKey5, "Noop", Hist.NoopInterval, DefaultHist.NoopInterval);
\r
502 SaveIntNum(hKey5, "ErrMode", Hist.TransferErrorMode, DefaultHist.TransferErrorMode);
\r
503 SaveIntNum(hKey5, "ErrNotify", Hist.TransferErrorNotify, DefaultHist.TransferErrorNotify);
\r
505 CloseSubKey(hKey5);
\r
510 WriteIntValueToReg(hKey4, "SavedHist", n);
\r
512 /* 余分なヒストリがあったら削除 */
\r
513 for(; n < 999; n++)
\r
515 sprintf(Str, "History%d", n);
\r
516 if(DeleteSubKey(hKey4, Str) != FFFTP_SUCCESS)
\r
521 CopyDefaultHost(&DefaultHost);
\r
523 while(CopyHostFromList(i, &Host) == FFFTP_SUCCESS)
\r
525 sprintf(Str, "Host%d", i);
\r
526 if(CreateSubKey(hKey4, Str, &hKey5) == FFFTP_SUCCESS)
\r
528 // SaveIntNum(hKey5, "Set", Host.Level, DefaultHost.Level);
\r
529 WriteIntValueToReg(hKey5, "Set", Host.Level);
\r
530 SaveStr(hKey5, "HostName", Host.HostName, DefaultHost.HostName);
\r
531 if((Host.Level & SET_LEVEL_GROUP) == 0)
\r
533 SaveStr(hKey5, "HostAdrs", Host.HostAdrs, DefaultHost.HostAdrs);
\r
534 SaveStr(hKey5, "UserName", Host.UserName, DefaultHost.UserName);
\r
535 SaveStr(hKey5, "Account", Host.Account, DefaultHost.Account);
\r
536 SaveStr(hKey5, "LocalDir", Host.LocalInitDir, NULL);
\r
537 SaveStr(hKey5, "RemoteDir", Host.RemoteInitDir, DefaultHost.RemoteInitDir);
\r
538 SaveStr(hKey5, "Chmod", Host.ChmodCmd, DefaultHost.ChmodCmd);
\r
539 SaveStr(hKey5, "Nlst", Host.LsName, DefaultHost.LsName);
\r
540 SaveStr(hKey5, "Init", Host.InitCmd, DefaultHost.InitCmd);
\r
542 if(Host.Anonymous == NO)
\r
543 EncodePassword(Host.PassWord, Str);
\r
545 strcpy(Str, DefaultHost.PassWord);
\r
546 SaveStr(hKey5, "Password", Str, DefaultHost.PassWord);
\r
548 SaveIntNum(hKey5, "Port", Host.Port, DefaultHost.Port);
\r
549 SaveIntNum(hKey5, "Anonymous", Host.Anonymous, DefaultHost.Anonymous);
\r
550 SaveIntNum(hKey5, "Kanji", Host.KanjiCode, DefaultHost.KanjiCode);
\r
551 SaveIntNum(hKey5, "KanaCnv", Host.KanaCnv, DefaultHost.KanaCnv);
\r
552 SaveIntNum(hKey5, "NameKanji", Host.NameKanjiCode, DefaultHost.NameKanjiCode);
\r
553 SaveIntNum(hKey5, "NameKana", Host.NameKanaCnv, DefaultHost.NameKanaCnv);
\r
554 SaveIntNum(hKey5, "Pasv", Host.Pasv, DefaultHost.Pasv);
\r
555 SaveIntNum(hKey5, "Fwall", Host.FireWall, DefaultHost.FireWall);
\r
556 SaveIntNum(hKey5, "List", Host.ListCmdOnly, DefaultHost.ListCmdOnly);
\r
557 SaveIntNum(hKey5, "NLST-R", Host.UseNLST_R, DefaultHost.UseNLST_R);
\r
558 SaveIntNum(hKey5, "Last", Host.LastDir, DefaultHost.LastDir);
\r
559 SaveIntNum(hKey5, "Tzone", Host.TimeZone, DefaultHost.TimeZone);
\r
560 SaveIntNum(hKey5, "Type", Host.HostType, DefaultHost.HostType);
\r
561 SaveIntNum(hKey5, "Sync", Host.SyncMove, DefaultHost.SyncMove);
\r
562 SaveIntNum(hKey5, "Fpath", Host.NoFullPath, DefaultHost.NoFullPath);
\r
563 WriteBinaryToReg(hKey5, "Sort", &Host.Sort, sizeof(Host.Sort));
\r
564 SaveIntNum(hKey5, "Secu", Host.Security, DefaultHost.Security);
\r
566 WriteMultiStringToReg(hKey5, "Bmarks", Host.BookMark);
\r
568 SaveIntNum(hKey5, "Dial", Host.Dialup, DefaultHost.Dialup);
\r
569 SaveIntNum(hKey5, "UseIt", Host.DialupAlways, DefaultHost.DialupAlways);
\r
570 SaveIntNum(hKey5, "Notify", Host.DialupNotify, DefaultHost.DialupNotify);
\r
571 SaveStr(hKey5, "DialTo", Host.DialEntry, DefaultHost.DialEntry);
\r
573 SaveIntNum(hKey5, "NoEncryption", Host.UseNoEncryption, DefaultHost.UseNoEncryption);
\r
574 SaveIntNum(hKey5, "FTPES", Host.UseFTPES, DefaultHost.UseFTPES);
\r
575 SaveIntNum(hKey5, "FTPIS", Host.UseFTPIS, DefaultHost.UseFTPIS);
\r
576 SaveIntNum(hKey5, "SFTP", Host.UseSFTP, DefaultHost.UseSFTP);
\r
577 EncodePassword(Host.PrivateKey, Str);
\r
578 SaveStr(hKey5, "PKey", Str, DefaultHost.PrivateKey);
\r
580 SaveIntNum(hKey5, "ThreadCount", Host.MaxThreadCount, DefaultHost.MaxThreadCount);
\r
581 SaveIntNum(hKey5, "ReuseCmdSkt", Host.ReuseCmdSkt, DefaultHost.ReuseCmdSkt);
\r
583 SaveIntNum(hKey5, "MLSD", Host.UseMLSD, DefaultHost.UseMLSD);
\r
585 SaveIntNum(hKey5, "NetType", Host.NetType, DefaultHost.NetType);
\r
587 SaveIntNum(hKey5, "Noop", Host.NoopInterval, DefaultHost.NoopInterval);
\r
589 SaveIntNum(hKey5, "ErrMode", Host.TransferErrorMode, DefaultHost.TransferErrorMode);
\r
590 SaveIntNum(hKey5, "ErrNotify", Host.TransferErrorNotify, DefaultHost.TransferErrorNotify);
\r
592 CloseSubKey(hKey5);
\r
596 WriteIntValueToReg(hKey4, "SetNum", i);
\r
598 /* 余分なホストの設定があったら削除 */
\r
599 for(; i < 998; i++)
\r
601 sprintf(Str, "Host%d", i);
\r
602 if(DeleteSubKey(hKey4, Str) != FFFTP_SUCCESS)
\r
606 if((i = AskCurrentHost()) == HOSTNUM_NOENTRY)
\r
608 WriteIntValueToReg(hKey4, "CurSet", i);
\r
611 WriteBinaryToReg(hKey4, "CertCacheHash", &CertificateCacheHash, sizeof(CertificateCacheHash));
\r
613 StrCatOut((char*)&SSLRootCAFileHash, sizeof(SSLRootCAFileHash), Buf);
\r
614 EncodePassword(Buf, Str);
\r
615 WriteStringToReg(hKey4, "RootCertHash", Str);
\r
617 WriteIntValueToReg(hKey4, "ListIcon", DispFileIcon);
\r
619 CloseSubKey(hKey4);
\r
626 /*----- レジストリ/INIファイルから設定値を呼び出す ---------------------------
\r
628 * この関数を複数回呼び出すと,ホスト設定が追加される.
\r
636 *----------------------------------------------------------------------------*/
\r
638 int LoadRegistory(void)
\r
646 // char Str[256]; /* ASCII_EXT_LENより大きい事 */
\r
647 char Str[PRIVATE_KEY_LEN*4+1];
\r
648 char Buf[FMAX_PATH+1];
\r
658 SetRegType(REGTYPE_INI);
\r
659 if((i = OpenReg("FFFTP", &hKey3)) != FFFTP_SUCCESS)
\r
661 if(AskForceIni() == NO)
\r
663 SetRegType(REGTYPE_REG);
\r
664 i = OpenReg("FFFTP", &hKey3);
\r
668 if(i == FFFTP_SUCCESS)
\r
670 // char checkbuf[48];
\r
674 ReadIntValueFromReg(hKey3, "Version", &Version);
\r
677 IniKanjiCode = KANJI_SJIS;
\r
679 if(OpenSubKey(hKey3, "Options", &hKey4) == FFFTP_SUCCESS)
\r
681 ReadIntValueFromReg(hKey4, "WinPosX", &WinPosX);
\r
682 ReadIntValueFromReg(hKey4, "WinPosY", &WinPosY);
\r
683 ReadIntValueFromReg(hKey4, "WinWidth", &WinWidth);
\r
684 ReadIntValueFromReg(hKey4, "WinHeight", &WinHeight);
\r
685 ReadIntValueFromReg(hKey4, "LocalWidth", &LocalWidth);
\r
687 LocalWidth = max1(0, LocalWidth);
\r
688 ReadIntValueFromReg(hKey4, "TaskHeight", &TaskHeight);
\r
690 TaskHeight = max1(0, TaskHeight);
\r
691 ReadBinaryFromReg(hKey4, "LocalColm", &LocalTabWidth, sizeof(LocalTabWidth));
\r
692 ReadBinaryFromReg(hKey4, "RemoteColm", &RemoteTabWidth, sizeof(RemoteTabWidth));
\r
693 ReadIntValueFromReg(hKey4, "SwCmd", &Sizing);
\r
695 ReadStringFromReg(hKey4, "UserMail", UserMailAdrs, USER_MAIL_LEN+1);
\r
696 ReadStringFromReg(hKey4, "Viewer", ViewerName[0], FMAX_PATH+1);
\r
697 ReadStringFromReg(hKey4, "Viewer2", ViewerName[1], FMAX_PATH+1);
\r
698 ReadStringFromReg(hKey4, "Viewer3", ViewerName[2], FMAX_PATH+1);
\r
700 ReadIntValueFromReg(hKey4, "TrType", &TransMode);
\r
701 ReadIntValueFromReg(hKey4, "Recv", &RecvMode);
\r
702 ReadIntValueFromReg(hKey4, "Send", &SendMode);
\r
703 ReadIntValueFromReg(hKey4, "Move", &MoveMode);
\r
704 ReadStringFromReg(hKey4, "Path", DefaultLocalPath, FMAX_PATH+1);
\r
705 ReadIntValueFromReg(hKey4, "Time", &SaveTimeStamp);
\r
706 ReadIntValueFromReg(hKey4, "EOF", &RmEOF);
\r
707 ReadIntValueFromReg(hKey4, "Scolon", &VaxSemicolon);
\r
709 ReadIntValueFromReg(hKey4, "RecvEx", &ExistMode);
\r
710 ReadIntValueFromReg(hKey4, "SendEx", &UpExistMode);
\r
712 ReadIntValueFromReg(hKey4, "LFsort", &LocalFileSort);
\r
713 ReadIntValueFromReg(hKey4, "LDsort", &LocalDirSort);
\r
714 ReadIntValueFromReg(hKey4, "RFsort", &RemoteFileSort);
\r
715 ReadIntValueFromReg(hKey4, "RDsort", &RemoteDirSort);
\r
716 ReadIntValueFromReg(hKey4, "SortSave", &SortSave);
\r
718 ReadIntValueFromReg(hKey4, "ListType", &ListType);
\r
719 ReadIntValueFromReg(hKey4, "Cache", &CacheEntry);
\r
720 ReadIntValueFromReg(hKey4, "CacheSave", &CacheSave);
\r
721 ReadIntValueFromReg(hKey4, "DotFile", &DotFile);
\r
722 ReadIntValueFromReg(hKey4, "Dclick", &DclickOpen);
\r
724 ReadIntValueFromReg(hKey4, "ConS", &ConnectOnStart);
\r
725 ReadIntValueFromReg(hKey4, "OldDlg", &ConnectAndSet);
\r
726 ReadIntValueFromReg(hKey4, "RasClose", &RasClose);
\r
727 ReadIntValueFromReg(hKey4, "RasNotify", &RasCloseNotify);
\r
728 ReadIntValueFromReg(hKey4, "Qanony", &QuickAnonymous);
\r
729 ReadIntValueFromReg(hKey4, "PassHist", &PassToHist);
\r
730 ReadIntValueFromReg(hKey4, "SendQuit", &SendQuit);
\r
731 ReadIntValueFromReg(hKey4, "NoRas", &NoRasControl);
\r
733 ReadIntValueFromReg(hKey4, "Debug", &DebugConsole);
\r
734 ReadIntValueFromReg(hKey4, "WinPos", &SaveWinPos);
\r
735 ReadIntValueFromReg(hKey4, "RegExp", &FindMode);
\r
736 ReadIntValueFromReg(hKey4, "Reg", &RegType);
\r
738 if(ReadMultiStringFromReg(hKey4, "AsciiFile", AsciiExt, ASCII_EXT_LEN+1) == FFFTP_FAIL)
\r
740 /* 旧ASCIIモードの拡張子の設定を新しいものに変換 */
\r
741 ReadStringFromReg(hKey4, "Ascii", Str, ASCII_EXT_LEN+1);
\r
742 memset(AsciiExt, NUL, ASCII_EXT_LEN+1);
\r
746 if((Pos2 = strchr(Pos, ';')) == NULL)
\r
747 Pos2 = strchr(Pos, NUL);
\r
748 if((Pos2 - Pos) > 0)
\r
750 if((StrMultiLen(AsciiExt) + (Pos2 - Pos) + 2) >= ASCII_EXT_LEN)
\r
752 strcpy(AsciiExt + StrMultiLen(AsciiExt), "*.");
\r
753 strncpy(AsciiExt + StrMultiLen(AsciiExt) - 1, Pos, (Pos2 - Pos));
\r
761 ReadIntValueFromReg(hKey4, "LowUp", &FnameCnv);
\r
762 ReadIntValueFromReg(hKey4, "Tout", &TimeOut);
\r
764 ReadMultiStringFromReg(hKey4, "NoTrn", MirrorNoTrn, MIRROR_LEN+1);
\r
765 ReadMultiStringFromReg(hKey4, "NoDel", MirrorNoDel, MIRROR_LEN+1);
\r
766 ReadIntValueFromReg(hKey4, "MirFile", &MirrorFnameCnv);
\r
767 ReadIntValueFromReg(hKey4, "MirUNot", &MirUpDelNotify);
\r
768 ReadIntValueFromReg(hKey4, "MirDNot", &MirDownDelNotify);
\r
770 if(ReadStringFromReg(hKey4, "ListFont", Str, 256) == FFFTP_SUCCESS)
\r
772 if(RestoreFontData(Str, &ListLogFont) == FFFTP_SUCCESS)
\r
773 ListFont = CreateFontIndirect(&ListLogFont);
\r
775 ReadIntValueFromReg(hKey4, "ListHide", &DispIgnoreHide);
\r
776 ReadIntValueFromReg(hKey4, "ListDrv", &DispDrives);
\r
778 ReadStringFromReg(hKey4, "FwallHost", FwallHost, HOST_ADRS_LEN+1);
\r
779 ReadStringFromReg(hKey4, "FwallUser", FwallUser, USER_NAME_LEN+1);
\r
780 ReadStringFromReg(hKey4, "FwallPass", Str, 255);
\r
781 DecodePassword(Str, FwallPass);
\r
782 ReadIntValueFromReg(hKey4, "FwallPort", &FwallPort);
\r
783 ReadIntValueFromReg(hKey4, "FwallType", &FwallType);
\r
784 ReadIntValueFromReg(hKey4, "FwallDef", &FwallDefault);
\r
785 ReadIntValueFromReg(hKey4, "FwallSec", &FwallSecurity);
\r
786 ReadIntValueFromReg(hKey4, "PasvDef", &PasvDefault);
\r
787 ReadIntValueFromReg(hKey4, "FwallRes", &FwallResolv);
\r
788 ReadIntValueFromReg(hKey4, "FwallLow", &FwallLower);
\r
789 ReadIntValueFromReg(hKey4, "FwallDel", &FwallDelimiter);
\r
791 ReadIntValueFromReg(hKey4, "SndConSw", &Sound[SND_CONNECT].On);
\r
792 ReadIntValueFromReg(hKey4, "SndTrnSw", &Sound[SND_TRANS].On);
\r
793 ReadIntValueFromReg(hKey4, "SndErrSw", &Sound[SND_ERROR].On);
\r
794 ReadStringFromReg(hKey4, "SndCon", Sound[SND_CONNECT].Fname, FMAX_PATH+1);
\r
795 ReadStringFromReg(hKey4, "SndTrn", Sound[SND_TRANS].Fname, FMAX_PATH+1);
\r
796 ReadStringFromReg(hKey4, "SndErr", Sound[SND_ERROR].Fname, FMAX_PATH+1);
\r
798 ReadMultiStringFromReg(hKey4, "DefAttr", DefAttrList, DEFATTRLIST_LEN+1);
\r
800 ReadStringFromReg(hKey4, "Tmp", TmpPath, FMAX_PATH+1);
\r
802 ReadBinaryFromReg(hKey4, "Hdlg", &HostDlgSize, sizeof(SIZE));
\r
803 ReadBinaryFromReg(hKey4, "Bdlg", &BmarkDlgSize, sizeof(SIZE));
\r
804 ReadBinaryFromReg(hKey4, "Mdlg", &MirrorDlgSize, sizeof(SIZE));
\r
806 ReadIntValueFromReg(hKey4, "FAttrSw", &FolderAttr);
\r
807 ReadIntValueFromReg(hKey4, "FAttr", &FolderAttrNum);
\r
809 ReadIntValueFromReg(hKey4, "NoSave", &SuppressSave);
\r
811 ReadIntValueFromReg(hKey4, "HistNum", &FileHist);
\r
812 // ReadMultiStringFromReg(hKey4, "Hist", Hist, (FMAX_PATH+1)*HISTORY_MAX+1);
\r
816 ReadIntValueFromReg(hKey4, "SavedHist", &Sets);
\r
818 for(i = 0; i < Sets; i++)
\r
820 sprintf(Str, "History%d", i);
\r
821 if(OpenSubKey(hKey4, Str, &hKey5) == FFFTP_SUCCESS)
\r
823 CopyDefaultHistory(&Hist);
\r
825 ReadStringFromReg(hKey5, "HostAdrs", Hist.HostAdrs, HOST_ADRS_LEN+1);
\r
826 ReadStringFromReg(hKey5, "UserName", Hist.UserName, USER_NAME_LEN+1);
\r
827 ReadStringFromReg(hKey5, "Account", Hist.Account, ACCOUNT_LEN+1);
\r
828 ReadStringFromReg(hKey5, "LocalDir", Hist.LocalInitDir, INIT_DIR_LEN+1);
\r
829 ReadStringFromReg(hKey5, "RemoteDir", Hist.RemoteInitDir, INIT_DIR_LEN+1);
\r
830 ReadStringFromReg(hKey5, "Chmod", Hist.ChmodCmd, CHMOD_CMD_LEN+1);
\r
831 ReadStringFromReg(hKey5, "Nlst", Hist.LsName, NLST_NAME_LEN+1);
\r
832 ReadStringFromReg(hKey5, "Init", Hist.InitCmd, INITCMD_LEN+1);
\r
833 ReadIntValueFromReg(hKey5, "Port", &Hist.Port);
\r
834 ReadIntValueFromReg(hKey5, "Kanji", &Hist.KanjiCode);
\r
835 ReadIntValueFromReg(hKey5, "KanaCnv", &Hist.KanaCnv);
\r
836 ReadIntValueFromReg(hKey5, "NameKanji", &Hist.NameKanjiCode);
\r
837 ReadIntValueFromReg(hKey5, "NameKana", &Hist.NameKanaCnv);
\r
838 ReadIntValueFromReg(hKey5, "Pasv", &Hist.Pasv);
\r
839 ReadIntValueFromReg(hKey5, "Fwall", &Hist.FireWall);
\r
840 ReadIntValueFromReg(hKey5, "List", &Hist.ListCmdOnly);
\r
841 ReadIntValueFromReg(hKey5, "NLST-R", &Hist.UseNLST_R);
\r
842 ReadIntValueFromReg(hKey5, "Tzone", &Hist.TimeZone);
\r
843 ReadIntValueFromReg(hKey5, "Type", &Hist.HostType);
\r
844 ReadIntValueFromReg(hKey5, "Sync", &Hist.SyncMove);
\r
845 ReadIntValueFromReg(hKey5, "Fpath", &Hist.NoFullPath);
\r
846 ReadBinaryFromReg(hKey5, "Sort", &Hist.Sort, sizeof(Hist.Sort));
\r
847 ReadIntValueFromReg(hKey5, "Secu", &Hist.Security);
\r
848 ReadIntValueFromReg(hKey5, "TrType", &Hist.Type);
\r
850 ReadStringFromReg(hKey5, "Password", Str, 255);
\r
851 DecodePassword(Str, Hist.PassWord);
\r
852 ReadIntValueFromReg(hKey5, "Dial", &Hist.Dialup);
\r
853 ReadIntValueFromReg(hKey5, "UseIt", &Hist.DialupAlways);
\r
854 ReadIntValueFromReg(hKey5, "Notify", &Hist.DialupNotify);
\r
855 ReadStringFromReg(hKey5, "DialTo", Hist.DialEntry, RAS_NAME_LEN+1);
\r
857 ReadIntValueFromReg(hKey5, "NoEncryption", &Hist.UseNoEncryption);
\r
858 ReadIntValueFromReg(hKey5, "FTPES", &Hist.UseFTPES);
\r
859 ReadIntValueFromReg(hKey5, "FTPIS", &Hist.UseFTPIS);
\r
860 ReadIntValueFromReg(hKey5, "SFTP", &Hist.UseSFTP);
\r
862 ReadStringFromReg(hKey5, "PKey", Str, PRIVATE_KEY_LEN*4+1);
\r
863 DecodePassword(Str, Hist.PrivateKey);
\r
865 ReadIntValueFromReg(hKey5, "ThreadCount", &Hist.MaxThreadCount);
\r
866 ReadIntValueFromReg(hKey5, "ReuseCmdSkt", &Hist.ReuseCmdSkt);
\r
868 ReadIntValueFromReg(hKey5, "MLSD", &Hist.UseMLSD);
\r
870 ReadIntValueFromReg(hKey5, "NetType", &Hist.NetType);
\r
872 ReadIntValueFromReg(hKey5, "Noop", &Hist.NoopInterval);
\r
874 ReadIntValueFromReg(hKey5, "ErrMode", &Hist.TransferErrorMode);
\r
875 ReadIntValueFromReg(hKey5, "ErrNotify", &Hist.TransferErrorNotify);
\r
877 CloseSubKey(hKey5);
\r
878 AddHistoryToHistory(&Hist);
\r
884 ReadIntValueFromReg(hKey4, "SetNum", &Sets);
\r
886 for(i = 0; i < Sets; i++)
\r
888 sprintf(Str, "Host%d", i);
\r
889 if(OpenSubKey(hKey4, Str, &hKey5) == FFFTP_SUCCESS)
\r
891 CopyDefaultHost(&Host);
\r
893 // SourceForge.JPによるフォーク
\r
894 // if(Version < VER_NUM)
\r
898 Host.ListCmdOnly = NO;
\r
900 // 1.97b以前はデフォルトでShift_JIS
\r
902 Host.NameKanjiCode = KANJI_SJIS;
\r
903 ReadIntValueFromReg(hKey5, "Set", &Host.Level);
\r
905 ReadStringFromReg(hKey5, "HostName", Host.HostName, HOST_NAME_LEN+1);
\r
906 ReadStringFromReg(hKey5, "HostAdrs", Host.HostAdrs, HOST_ADRS_LEN+1);
\r
907 ReadStringFromReg(hKey5, "UserName", Host.UserName, USER_NAME_LEN+1);
\r
908 ReadStringFromReg(hKey5, "Account", Host.Account, ACCOUNT_LEN+1);
\r
909 ReadStringFromReg(hKey5, "LocalDir", Host.LocalInitDir, INIT_DIR_LEN+1);
\r
910 ReadStringFromReg(hKey5, "RemoteDir", Host.RemoteInitDir, INIT_DIR_LEN+1);
\r
911 ReadStringFromReg(hKey5, "Chmod", Host.ChmodCmd, CHMOD_CMD_LEN+1);
\r
912 ReadStringFromReg(hKey5, "Nlst", Host.LsName, NLST_NAME_LEN+1);
\r
913 ReadStringFromReg(hKey5, "Init", Host.InitCmd, INITCMD_LEN+1);
\r
914 ReadIntValueFromReg(hKey5, "Port", &Host.Port);
\r
915 ReadIntValueFromReg(hKey5, "Anonymous", &Host.Anonymous);
\r
916 ReadIntValueFromReg(hKey5, "Kanji", &Host.KanjiCode);
\r
917 // 1.98b以前のUTF-8はBOMあり
\r
920 if(Host.KanjiCode == KANJI_UTF8N)
\r
921 Host.KanjiCode = KANJI_UTF8BOM;
\r
923 ReadIntValueFromReg(hKey5, "KanaCnv", &Host.KanaCnv);
\r
924 ReadIntValueFromReg(hKey5, "NameKanji", &Host.NameKanjiCode);
\r
925 ReadIntValueFromReg(hKey5, "NameKana", &Host.NameKanaCnv);
\r
926 ReadIntValueFromReg(hKey5, "Pasv", &Host.Pasv);
\r
927 ReadIntValueFromReg(hKey5, "Fwall", &Host.FireWall);
\r
928 ReadIntValueFromReg(hKey5, "List", &Host.ListCmdOnly);
\r
929 ReadIntValueFromReg(hKey5, "NLST-R", &Host.UseNLST_R);
\r
930 ReadIntValueFromReg(hKey5, "Last", &Host.LastDir);
\r
931 ReadIntValueFromReg(hKey5, "Tzone", &Host.TimeZone);
\r
932 ReadIntValueFromReg(hKey5, "Type", &Host.HostType);
\r
933 ReadIntValueFromReg(hKey5, "Sync", &Host.SyncMove);
\r
934 ReadIntValueFromReg(hKey5, "Fpath", &Host.NoFullPath);
\r
935 ReadBinaryFromReg(hKey5, "Sort", &Host.Sort, sizeof(Host.Sort));
\r
936 ReadIntValueFromReg(hKey5, "Secu", &Host.Security);
\r
937 if(Host.Anonymous != YES)
\r
940 ReadStringFromReg(hKey5, "Password", Str, 255);
\r
941 DecodePassword(Str, Host.PassWord);
\r
944 strcpy(Host.PassWord, UserMailAdrs);
\r
946 ReadMultiStringFromReg(hKey5, "Bmarks", Host.BookMark, BOOKMARK_SIZE);
\r
948 ReadIntValueFromReg(hKey5, "Dial", &Host.Dialup);
\r
949 ReadIntValueFromReg(hKey5, "UseIt", &Host.DialupAlways);
\r
950 ReadIntValueFromReg(hKey5, "Notify", &Host.DialupNotify);
\r
951 ReadStringFromReg(hKey5, "DialTo", Host.DialEntry, RAS_NAME_LEN+1);
\r
953 ReadIntValueFromReg(hKey5, "NoEncryption", &Host.UseNoEncryption);
\r
954 ReadIntValueFromReg(hKey5, "FTPES", &Host.UseFTPES);
\r
955 ReadIntValueFromReg(hKey5, "FTPIS", &Host.UseFTPIS);
\r
956 ReadIntValueFromReg(hKey5, "SFTP", &Host.UseSFTP);
\r
958 ReadStringFromReg(hKey5, "PKey", Str, PRIVATE_KEY_LEN*4+1);
\r
959 DecodePassword(Str, Host.PrivateKey);
\r
961 ReadIntValueFromReg(hKey5, "ThreadCount", &Host.MaxThreadCount);
\r
962 ReadIntValueFromReg(hKey5, "ReuseCmdSkt", &Host.ReuseCmdSkt);
\r
963 // 1.98d以前で同時接続数が1より大きい場合はソケットの再利用なし
\r
966 if(Host.MaxThreadCount > 1)
\r
967 Host.ReuseCmdSkt = NO;
\r
970 ReadIntValueFromReg(hKey5, "MLSD", &Host.UseMLSD);
\r
972 ReadIntValueFromReg(hKey5, "NetType", &Host.NetType);
\r
974 ReadIntValueFromReg(hKey5, "Noop", &Host.NoopInterval);
\r
976 ReadIntValueFromReg(hKey5, "ErrMode", &Host.TransferErrorMode);
\r
977 ReadIntValueFromReg(hKey5, "ErrNotify", &Host.TransferErrorNotify);
\r
979 CloseSubKey(hKey5);
\r
981 AddHostToList(&Host, -1, Host.Level);
\r
985 ReadIntValueFromReg(hKey4, "CurSet", &Sets);
\r
986 SetCurrentHost(Sets);
\r
989 ReadBinaryFromReg(hKey4, "CertCacheHash", &CertificateCacheHash, sizeof(CertificateCacheHash));
\r
990 ReadStringFromReg(hKey4, "RootCertHash", Str, PRIVATE_KEY_LEN*4+1);
\r
991 DecodePassword(Str, Buf);
\r
992 StrReadIn(Buf, sizeof(SSLRootCAFileHash), (char*)&SSLRootCAFileHash);
\r
994 ReadIntValueFromReg(hKey4, "ListIcon", &DispFileIcon);
\r
996 CloseSubKey(hKey4);
\r
1002 /*===== 最初の起動時(設定が無い) =====*/
\r
1005 strcpy(UserMailAdrs, "");
\r
1007 if(InputDialogBox(mailadrs_dlg, HWND_DESKTOP, NULL, Str, USER_MAIL_LEN+1, &i, IDH_HELP_TOPIC_0000001) == YES)
\r
1008 strcpy(UserMailAdrs, Str);
\r
1010 for(i = 0; i < SAMPLE_HOSTS; i++)
\r
1012 CopyDefaultHost(&Host);
\r
1013 Host.Level = Sample[i].Level;
\r
1014 strcpy(Host.PassWord, UserMailAdrs);
\r
1015 strcpy(Host.HostName, Sample[i].HostName);
\r
1016 strcpy(Host.HostAdrs, Sample[i].HostAdrs);
\r
1017 strcpy(Host.UserName, "anonymous");
\r
1018 AddHostToList(&Host, -1, Host.Level);
\r
1026 /*----- 隠しドライブ情報を取得 ------------------------------------------------
\r
1034 *----------------------------------------------------------------------------*/
\r
1036 DWORD LoadHideDriveListRegistory(void)
\r
1049 if(RegOpenKeyEx(HKEY_CURRENT_USER, "Software", 0, KEY_READ, &hKey1) == ERROR_SUCCESS)
\r
1051 if(RegOpenKeyEx(hKey1, "Microsoft", 0, KEY_READ, &hKey2) == ERROR_SUCCESS)
\r
1053 if(RegOpenKeyEx(hKey2, "Windows", 0, KEY_READ, &hKey3) == ERROR_SUCCESS)
\r
1055 if(RegOpenKeyEx(hKey3, "CurrentVersion", 0, KEY_READ, &hKey4) == ERROR_SUCCESS)
\r
1057 if(RegOpenKeyEx(hKey4, "Policies", 0, KEY_READ, &hKey5) == ERROR_SUCCESS)
\r
1059 if(RegOpenKeyEx(hKey5, "Explorer", 0, KEY_READ, &hKey6) == ERROR_SUCCESS)
\r
1061 Size = sizeof(DWORD);
\r
1062 RegQueryValueEx(hKey6, "NoDrives", NULL, &Type, (BYTE *)&Ret, &Size);
\r
1063 RegCloseKey(hKey6);
\r
1065 RegCloseKey(hKey5);
\r
1067 RegCloseKey(hKey4);
\r
1069 RegCloseKey(hKey3);
\r
1071 RegCloseKey(hKey2);
\r
1073 RegCloseKey(hKey1);
\r
1079 /*----- レジストリの設定値をクリア --------------------------------------------
\r
1086 *----------------------------------------------------------------------------*/
\r
1088 void ClearRegistory(void)
\r
1097 if(RegCreateKeyEx(HKEY_CURRENT_USER, "Software\\Sota", 0, "", REG_OPTION_NON_VOLATILE, KEY_CREATE_SUB_KEY, NULL, &hKey2, &Dispos) == ERROR_SUCCESS)
\r
1099 if(RegCreateKeyEx(hKey2, "FFFTP", 0, "", REG_OPTION_NON_VOLATILE, KEY_WRITE, NULL, &hKey3, &Dispos) == ERROR_SUCCESS)
\r
1101 if(RegCreateKeyEx(hKey3, "Options", 0, "", REG_OPTION_NON_VOLATILE, KEY_WRITE, NULL, &hKey4, &Dispos) == ERROR_SUCCESS)
\r
1105 sprintf(Str, "Host%d", i);
\r
1106 if(RegDeleteKey(hKey4, Str) != ERROR_SUCCESS)
\r
1111 sprintf(Str, "History%d", i);
\r
1112 if(RegDeleteKey(hKey4, Str) != ERROR_SUCCESS)
\r
1115 RegCloseKey(hKey4);
\r
1117 RegDeleteKey(hKey3, "Options");
\r
1118 RegCloseKey(hKey3);
\r
1120 RegDeleteKey(hKey2, "FFFTP");
\r
1121 RegCloseKey(hKey2);
\r
1127 /*----- 設定をファイルに保存 --------------------------------------------------
\r
1134 *----------------------------------------------------------------------------*/
\r
1136 void SaveSettingsToFile(void)
\r
1138 char Tmp[FMAX_PATH*2];
\r
1139 char Fname[FMAX_PATH+1];
\r
1140 // 任意のコードが実行されるバグ修正
\r
1141 char CurDir[FMAX_PATH+1];
\r
1142 char SysDir[FMAX_PATH+1];
\r
1144 if(RegType == REGTYPE_REG)
\r
1146 strcpy(Fname, "FFFTP.reg");
\r
1147 if(SelectFile(GetMainHwnd(), Fname, MSGJPN286, MSGJPN287, "reg", OFN_EXTENSIONDIFFERENT | OFN_OVERWRITEPROMPT, 1) == TRUE)
\r
1149 sprintf(Tmp, "/e \x22%s\x22 HKEY_CURRENT_USER\\Software\\sota\\FFFTP", Fname);
\r
1150 // 任意のコードが実行されるバグ修正
\r
1151 // if(ShellExecute(NULL, "open", "regedit", Tmp, ".", SW_SHOW) <= (HINSTANCE)32)
\r
1153 // MessageBox(NULL, MSGJPN285, "FFFTP", MB_OK);
\r
1155 if(GetCurrentDirectory(FMAX_PATH, CurDir) > 0)
\r
1157 if(GetSystemDirectory(SysDir, FMAX_PATH) > 0)
\r
1159 if(SetCurrentDirectory(SysDir))
\r
1161 if(ShellExecute(NULL, "open", "regedit", Tmp, NULL, SW_SHOW) <= (HINSTANCE)32)
\r
1163 MessageBox(NULL, MSGJPN285, "FFFTP", MB_OK);
\r
1165 SetCurrentDirectory(CurDir);
\r
1173 strcpy(Fname, "FFFTP-Backup.ini");
\r
1174 if(SelectFile(GetMainHwnd(), Fname, MSGJPN286, MSGJPN288, "ini", OFN_EXTENSIONDIFFERENT | OFN_OVERWRITEPROMPT, 1) == TRUE)
\r
1176 CopyFile(AskIniFilePath(), Fname, FALSE);
\r
1183 /*----- 設定をファイルから復元 ------------------------------------------------
\r
1189 * int ロードしたかどうか (YES/NO)
\r
1190 *----------------------------------------------------------------------------*/
\r
1192 int LoadSettingsFromFile(void)
\r
1195 char Tmp[FMAX_PATH*2];
\r
1196 char Fname[FMAX_PATH+1];
\r
1197 // 任意のコードが実行されるバグ修正
\r
1198 char CurDir[FMAX_PATH+1];
\r
1199 char SysDir[FMAX_PATH+1];
\r
1202 strcpy(Fname, "");
\r
1203 if(SelectFile(GetMainHwnd(), Fname, MSGJPN291, MSGJPN290, "", OFN_FILEMUSTEXIST, 0) == TRUE)
\r
1205 if((strlen(Fname) >= 5) && (_stricmp(&Fname[strlen(Fname)-4], ".reg") == 0))
\r
1207 sprintf(Tmp, "\x22%s\x22", Fname);
\r
1208 // 任意のコードが実行されるバグ修正
\r
1209 // if(ShellExecute(NULL, "open", "regedit", Tmp, ".", SW_SHOW) <= (HINSTANCE)32)
\r
1211 // MessageBox(NULL, MSGJPN285, "FFFTP", MB_OK);
\r
1216 // /* レジストリエディタが終了するのを待つ */
\r
1217 // WaitForSingleObject(Info.hProcess, INFINITE);
\r
1219 if(GetCurrentDirectory(FMAX_PATH, CurDir) > 0)
\r
1221 if(GetSystemDirectory(SysDir, FMAX_PATH) > 0)
\r
1223 if(SetCurrentDirectory(SysDir))
\r
1225 if(ShellExecute(NULL, "open", "regedit", Tmp, NULL, SW_SHOW) <= (HINSTANCE)32)
\r
1227 MessageBox(NULL, MSGJPN285, "FFFTP", MB_OK);
\r
1232 /* レジストリエディタが終了するのを待つ */
\r
1233 // WaitForSingleObject(Info.hProcess, INFINITE);
\r
1235 SetCurrentDirectory(CurDir);
\r
1240 else if((strlen(Fname) >= 5) && (_stricmp(&Fname[strlen(Fname)-4], ".ini") == 0))
\r
1242 CopyFile(Fname, AskIniFilePath(), FALSE);
\r
1246 MessageBox(NULL, MSGJPN293, "FFFTP", MB_OK);
\r
1254 /*----- レジストリ/INIファイルに文字列をセーブ --------------------------------
\r
1257 * HKEY hKey : レジストリキー
\r
1259 * char *Str : セーブする文字列
\r
1260 * char *DefaultStr : デフォルトの文字列
\r
1266 * 文字列がデフォルトの文字列と同じならセーブしない
\r
1267 *----------------------------------------------------------------------------*/
\r
1269 static void SaveStr(HKEY hKey, char *Key, char *Str, char *DefaultStr)
\r
1271 if((DefaultStr != NULL) && (strcmp(Str, DefaultStr) == 0))
\r
1272 DeleteValue(hKey, Key);
\r
1274 WriteStringToReg(hKey, Key, Str);
\r
1280 /*----- レジストリ/INIファイルに数値(INT)をセーブ -----------------------------
\r
1283 * HKEY hKey : レジストリキー
\r
1285 * int Num : セーブする値
\r
1286 * int DefaultNum : デフォルトの値
\r
1292 * 数値がデフォルトの値と同じならセーブしない
\r
1293 *----------------------------------------------------------------------------*/
\r
1295 static void SaveIntNum(HKEY hKey, char *Key, int Num, int DefaultNum)
\r
1297 if(Num == DefaultNum)
\r
1298 DeleteValue(hKey, Key);
\r
1300 WriteIntValueToReg(hKey, Key, Num);
\r
1306 /*----- LOGFONTデータを文字列に変換する ---------------------------------------
\r
1309 * LOGFONT Font : フォントデータ
\r
1310 * HFONT hFont : フォントのハンドル
\r
1311 * NULL = デフォルトのフォント
\r
1312 * char *Buf : バッファ
\r
1316 *----------------------------------------------------------------------------*/
\r
1318 static void MakeFontData(LOGFONT Font, HFONT hFont, char *Buf)
\r
1322 sprintf(Buf, "%d %d %d %d %d %d %d %d %d %d %d %d %d %s",
\r
1323 Font.lfHeight, Font.lfWidth, Font.lfEscapement, Font.lfOrientation,
\r
1324 Font.lfWeight, Font.lfItalic, Font.lfUnderline, Font.lfStrikeOut,
\r
1325 Font.lfCharSet, Font.lfOutPrecision, Font.lfClipPrecision,
\r
1326 Font.lfQuality, Font.lfPitchAndFamily, Font.lfFaceName);
\r
1331 /*----- 文字列をLOGFONTデータに変換する ---------------------------------------
\r
1335 * LOGFONT *Font : フォントデータ
\r
1339 * FFFTP_SUCCESS/FFFTP_FAIL=変換できない
\r
1340 *----------------------------------------------------------------------------*/
\r
1342 static int RestoreFontData(char *Str, LOGFONT *Font)
\r
1348 if(sscanf(Str, "%d %d %d %d %d %d %d %d %d %d %d %d %d",
\r
1349 &(Font->lfHeight), &(Font->lfWidth), &(Font->lfEscapement), &(Font->lfOrientation),
\r
1350 &(Font->lfWeight), &(Font->lfItalic), &(Font->lfUnderline), &(Font->lfStrikeOut),
\r
1351 &(Font->lfCharSet), &(Font->lfOutPrecision), &(Font->lfClipPrecision),
\r
1352 &(Font->lfQuality), &(Font->lfPitchAndFamily)) == 13)
\r
1354 for(i = 13; i > 0; i--)
\r
1356 if((Str = strchr(Str, ' ')) == NULL)
\r
1362 strcpy(Font->lfFaceName, Str);
\r
1363 Sts = FFFTP_SUCCESS;
\r
1367 if(Sts == FFFTP_FAIL)
\r
1368 memset(Font, NUL, sizeof(LOGFONT));
\r
1373 /*----- パスワードを暗号化する ------------------------------------------------
\r
1376 * char *Str : パスワード
\r
1377 * char *Buf : 暗号化したパスワードを格納するバッファ
\r
1381 *----------------------------------------------------------------------------*/
\r
1382 static void EncodePassword(char *Str, char *Buf)
\r
1384 EncodePassword3( Str, Buf, SecretKey );
\r
1387 /*----- パスワードを暗号化する(オリジナルアルゴリズム) ------------------
\r
1390 * char *Str : パスワード
\r
1391 * char *Buf : 暗号化したパスワードを格納するバッファ
\r
1395 *----------------------------------------------------------------------------*/
\r
1397 static void EncodePasswordOriginal(char *Str, char *Buf)
\r
1399 unsigned char *Get;
\r
1400 unsigned char *Put;
\r
1404 srand((unsigned)time(NULL));
\r
1406 Get = (unsigned char *)Str;
\r
1407 Put = (unsigned char *)Buf;
\r
1409 if( *Get == NUL ){
\r
1419 while(*Get != NUL)
\r
1422 Ch = ((int)*Get++) << Rnd;
\r
1423 Ch = (unsigned char)Ch | (unsigned char)(Ch >> 8);
\r
1424 *Put++ = 0x40 | ((Rnd & 0x3) << 4) | (Ch & 0xF);
\r
1425 *Put++ = 0x40 | ((Ch >> 4) & 0xF);
\r
1426 if((*(Put-2) & 0x1) != 0)
\r
1427 *Put++ = (rand() % 62) + 0x40;
\r
1433 /*----- パスワードを暗号化する(オリジナルアルゴリズム^Key) ----------------
\r
1436 * char *Str : パスワード
\r
1437 * char *Buf : 暗号化したパスワードを格納するバッファ
\r
1438 * const char *Key : 暗号化キー
\r
1442 *----------------------------------------------------------------------------*/
\r
1444 static void EncodePassword2(char *Str, char *Buf, const char* Key)
\r
1446 unsigned char *Get;
\r
1447 unsigned char *Put;
\r
1451 /* 2010.01.31 genta Key */
\r
1452 unsigned char *KeyHead = (unsigned char *)Key;
\r
1453 unsigned char *KeyEnd = KeyHead + strlen(KeyHead);
\r
1454 unsigned char *KeyCurrent = KeyHead;
\r
1456 srand((unsigned)time(NULL));
\r
1458 Get = (unsigned char *)Str;
\r
1459 Put = (unsigned char *)Buf;
\r
1461 if( *Get == NUL ){
\r
1471 while(*Get != NUL)
\r
1474 Ch = ((int)(*Get++ ^ *KeyCurrent)) << Rnd;
\r
1475 Ch = (unsigned char)Ch | (unsigned char)(Ch >> 8);
\r
1476 *Put++ = 0x40 | ((Rnd & 0x3) << 4) | (Ch & 0xF);
\r
1477 *Put++ = 0x40 | ((Ch >> 4) & 0xF);
\r
1478 if((*(Put-2) & 0x1) != 0)
\r
1479 *Put++ = (rand() % 62) + 0x40;
\r
1481 /* 2010.01.31 genta Key */
\r
1482 if( ++KeyCurrent == KeyEnd ){
\r
1483 KeyCurrent = KeyHead;
\r
1490 /*----- パスワードを暗号化する(AES) ------------------------------------------
\r
1493 * char *Str : パスワード
\r
1494 * char *Buf : 暗号化したパスワードを格納するバッファ
\r
1495 * const char *Key : 暗号化キー
\r
1499 *----------------------------------------------------------------------------*/
\r
1501 static void EncodePassword3(char *Str, char *Buf, const char *Key)
\r
1503 unsigned char *Put;
\r
1504 unsigned char *AesEncBuf;
\r
1505 unsigned char *StrPadBuf;
\r
1508 size_t StrPadIndex;
\r
1510 size_t EncBufIndex;
\r
1512 int RandByteCount;
\r
1513 unsigned char AesKey[32];
\r
1514 unsigned char AesCbcIv[AES_BLOCK_SIZE];
\r
1515 aes_encrypt_ctx Ctx;
\r
1519 Put = (unsigned char *)Buf;
\r
1520 StrLen = strlen(Str);
\r
1521 StrPadLen = ((StrLen + AES_BLOCK_SIZE - 1) / AES_BLOCK_SIZE) * AES_BLOCK_SIZE;
\r
1524 // StrPadLen = min1(StrPadLen, AES_BLOCK_SIZE * 2);
\r
1525 StrPadLen = max1(StrPadLen, AES_BLOCK_SIZE * 2);
\r
1527 if((StrPadBuf = malloc(StrPadLen)) != NULL)
\r
1529 if((AesEncBuf = malloc(StrPadLen)) != NULL)
\r
1534 strncpy(StrPadBuf, Str, StrPadLen);
\r
1536 /* PAD部分を乱数で埋める StrPad[StrLen](が有効な場合) は NUL */
\r
1537 for(StrPadIndex = StrLen + 1; StrPadIndex < StrPadLen;)
\r
1539 RandValue = GetRandamDWRODValue();
\r
1540 for(RandByteCount = 0; RandByteCount < 4; RandByteCount++)
\r
1542 if(StrPadIndex < StrPadLen)
\r
1544 StrPadBuf[StrPadIndex++] = (unsigned char)(RandValue & 0xff);
\r
1551 for(IvIndex = 0; IvIndex < AES_BLOCK_SIZE;)
\r
1553 RandValue = GetRandamDWRODValue();
\r
1554 for(RandByteCount = 0; RandByteCount < 4; RandByteCount++)
\r
1556 if(IvIndex < AES_BLOCK_SIZE)
\r
1558 AesCbcIv[IvIndex++] = (unsigned char)(RandValue & 0xff);
\r
1566 for(IvIndex = 0; IvIndex < AES_BLOCK_SIZE; IvIndex++)
\r
1568 sprintf(Put, "%02x", AesCbcIv[IvIndex]);
\r
1573 if(CreateAesKey(AesKey, Key) == FFFTP_SUCCESS)
\r
1575 aes_encrypt_key(AesKey, 32, &Ctx);
\r
1577 if(aes_cbc_encrypt(StrPadBuf, AesEncBuf, StrPadLen, AesCbcIv, &Ctx) == EXIT_SUCCESS)
\r
1579 for(EncBufIndex = 0; EncBufIndex < StrPadLen; EncBufIndex++)
\r
1581 sprintf(Put, "%02x", AesEncBuf[EncBufIndex]);
\r
1588 if(FALSE == PutState)
\r
1600 /*----- パスワードの暗号化を解く ----------------------------------------------
\r
1603 * char *Str : 暗号化したパスワード
\r
1604 * char *Buf : パスワードを格納するバッファ
\r
1608 *----------------------------------------------------------------------------*/
\r
1610 static void DecodePassword(char *Str, char *Buf)
\r
1612 unsigned char *Get;
\r
1613 unsigned char *Put;
\r
1615 Get = (unsigned char *)Str;
\r
1616 Put = (unsigned char *)Buf;
\r
1618 if( *Get == NUL ){
\r
1621 else if( 0x40 <= *Get && *Get < 0x80 ){
\r
1622 /* Original algorithm */
\r
1623 DecodePasswordOriginal( Str, Buf );
\r
1625 else if( strncmp( Get, "0A", 2 ) == 0 ){
\r
1626 DecodePasswordOriginal( Str + 2, Buf );
\r
1628 else if( strncmp( Get, "0B", 2 ) == 0 ){
\r
1629 DecodePassword2( Str + 2, Buf, SecretKey );
\r
1631 else if( strncmp( Get, "0C", 2 ) == 0 ){
\r
1632 DecodePassword3( Str + 2, Buf, SecretKey );
\r
1635 // unknown encoding
\r
1641 /*----- パスワードの暗号化を解く(オリジナルアルゴリズム) -------------------
\r
1644 * char *Str : 暗号化したパスワード
\r
1645 * char *Buf : パスワードを格納するバッファ
\r
1649 *----------------------------------------------------------------------------*/
\r
1650 static void DecodePasswordOriginal(char *Str, char *Buf)
\r
1652 unsigned char *Get;
\r
1653 unsigned char *Put;
\r
1657 Get = (unsigned char *)Str;
\r
1658 Put = (unsigned char *)Buf;
\r
1660 while(*Get != NUL)
\r
1662 Rnd = ((unsigned int)*Get >> 4) & 0x3;
\r
1663 Ch = (*Get & 0xF) | ((*(Get+1) & 0xF) << 4);
\r
1665 if((*Get & 0x1) != 0)
\r
1669 Ch = (Ch & 0xFF) | ((Ch >> 8) & 0xFF);
\r
1676 /*----- パスワードの暗号化を解く(オリジナルアルゴリズム^Key) -------------------
\r
1679 * char *Str : 暗号化したパスワード
\r
1680 * char *Buf : パスワードを格納するバッファ
\r
1681 * const char *Key : 暗号化キー
\r
1685 *----------------------------------------------------------------------------*/
\r
1686 static void DecodePassword2(char *Str, char *Buf, const char* Key)
\r
1690 unsigned char *Get = (unsigned char *)Str;
\r
1691 unsigned char *Put = (unsigned char *)Buf;
\r
1693 /* 2010.01.31 genta Key */
\r
1694 unsigned char *KeyHead = (unsigned char *)Key;
\r
1695 unsigned char *KeyEnd = KeyHead + strlen(KeyHead);
\r
1696 unsigned char *KeyCurrent = KeyHead;
\r
1698 while(*Get != NUL)
\r
1700 Rnd = ((unsigned int)*Get >> 4) & 0x3;
\r
1701 Ch = (*Get & 0xF) | ((*(Get+1) & 0xF) << 4);
\r
1703 if((*Get & 0x1) != 0)
\r
1707 Ch = (Ch & 0xFF) | ((Ch >> 8) & 0xFF);
\r
1708 *Put++ = Ch ^ *KeyCurrent;
\r
1710 /* 2010.01.31 genta Key */
\r
1711 if( ++KeyCurrent == KeyEnd ){
\r
1712 KeyCurrent = KeyHead;
\r
1719 /*----- パスワードの暗号化を解く(AES) ---------------------------------------
\r
1722 * char *Str : 暗号化したパスワード
\r
1723 * char *Buf : パスワードを格納するバッファ
\r
1724 * const char *Key : 暗号化キー
\r
1728 *----------------------------------------------------------------------------*/
\r
1730 static void DecodePassword3(char *Str, char *Buf, const char *Key)
\r
1733 unsigned char *EncBuf;
\r
1736 size_t EncBufIndex;
\r
1738 unsigned char AesKey[32];
\r
1739 unsigned char AesCbcIv[AES_BLOCK_SIZE];
\r
1740 aes_decrypt_ctx Ctx;
\r
1745 StrLen = strlen(Str);
\r
1747 if(AES_BLOCK_SIZE * 2 + 1 < StrLen)
\r
1750 EncBufLen = (StrLen - 1 ) / 2 - AES_BLOCK_SIZE;
\r
1751 if((EncBuf = malloc(EncBufLen)) != NULL)
\r
1753 for(IvIndex = 0; IvIndex < AES_BLOCK_SIZE; IvIndex++)
\r
1755 AesCbcIv[IvIndex] = hex2bin(*Get++) << 4;
\r
1756 AesCbcIv[IvIndex] |= hex2bin(*Get++);
\r
1761 if(CreateAesKey(AesKey, Key) == FFFTP_SUCCESS)
\r
1763 aes_decrypt_key(AesKey, 32, &Ctx);
\r
1765 for(EncBufIndex = 0; EncBufIndex < EncBufLen; EncBufIndex++)
\r
1767 EncBuf[EncBufIndex] = hex2bin(*Get++) << 4;
\r
1768 EncBuf[EncBufIndex] |= hex2bin(*Get++);
\r
1770 if(aes_cbc_decrypt(EncBuf, Buf, EncBufLen, AesCbcIv, &Ctx) == EXIT_SUCCESS)
\r
1772 Buf[EncBufLen] = NUL;
\r
1782 /*----- AES用固定長キーを作成 ----------------------------------------------
\r
1785 * unsigned char *AesKey : AES暗号鍵
\r
1786 * const char *Key : 暗号化キー
\r
1789 * int ステータス (FFFTP_SUCCESS/FFFTP_FAIL)
\r
1791 * SHA-1をもちいて32Byte鍵を生成する
\r
1792 *----------------------------------------------------------------------------*/
\r
1794 static int CreateAesKey(unsigned char *AesKey, const char* Key)
\r
1797 uint32 HashKeyLen;
\r
1798 uint32 results[10];
\r
1803 HashKeyLen = strlen(Key) + 16;
\r
1804 if((HashKey = malloc(HashKeyLen + 1)) == NULL){
\r
1805 return (FFFTP_FAIL);
\r
1808 strcpy(HashKey, Key);
\r
1809 strcat(HashKey, ">g^r=@N7=//z<[`:");
\r
1810 sha_memory((uchar *)HashKey, HashKeyLen, results);
\r
1812 strcpy(HashKey, Key);
\r
1813 strcat(HashKey, "VG77dO1#EyC]$|C@");
\r
1814 sha_memory((uchar *)HashKey, HashKeyLen, results + 5);
\r
1818 while(ResIndex < 8){
\r
1819 for(ByteOffset = 0; ByteOffset < 4; ByteOffset++){
\r
1820 AesKey[KeyIndex++] = (results[ResIndex] >> ByteOffset * 8) & 0xff;
\r
1826 return (FFFTP_SUCCESS);
\r
1830 /*===== レジストリとINIファイルのアクセス処理 ============*/
\r
1833 /*===== INIファイル用のレジストリデータ =====*/
\r
1835 typedef struct regdatatbl {
\r
1836 char KeyName[80+1]; /* キー名 */
\r
1837 char ValTbl[REG_SECT_MAX]; /* 値のテーブル */
\r
1838 int ValLen; /* 値データのバイト数 */
\r
1839 int Mode; /* キーのモード */
\r
1840 struct regdatatbl *Next;
\r
1843 /*===== プロトタイプ =====*/
\r
1845 static BOOL WriteOutRegToFile(REGDATATBL *Pos);
\r
1846 static int ReadInReg(char *Name, REGDATATBL **Handle);
\r
1848 //static int StrCatOut(char *Src, int Len, char *Dst);
\r
1849 //static int StrReadIn(char *Src, int Max, char *Dst);
\r
1850 static char *ScanValue(void *Handle, char *Name);
\r
1853 /*===== ローカルなワーク =====*/
\r
1855 static int TmpRegType;
\r
1859 /*----- レジストリのタイプを設定する ------------------------------------------
\r
1862 * int Type : タイプ (REGTYPE_xxx)
\r
1866 * FFFTP_SUCCESS/FFFTP_FAIL
\r
1867 *----------------------------------------------------------------------------*/
\r
1869 static void SetRegType(int Type)
\r
1871 TmpRegType = Type;
\r
1876 /*----- レジストリ/INIファイルをオープンする(読み込み)-----------------------
\r
1879 * char *Name : レジストリ名
\r
1880 * void **Handle : ハンドルを返すワーク
\r
1884 * FFFTP_SUCCESS/FFFTP_FAIL
\r
1885 *----------------------------------------------------------------------------*/
\r
1887 static int OpenReg(char *Name, void **Handle)
\r
1890 char Tmp[FMAX_PATH+1];
\r
1893 if(TmpRegType == REGTYPE_REG)
\r
1895 strcpy(Tmp, "Software\\Sota\\");
\r
1896 strcat(Tmp, Name);
\r
1897 if(RegOpenKeyEx(HKEY_CURRENT_USER, Tmp, 0, KEY_READ, (HKEY *)Handle) == ERROR_SUCCESS)
\r
1898 Sts = FFFTP_SUCCESS;
\r
1902 if((Sts = ReadInReg(Name, (REGDATATBL **)Handle)) == FFFTP_SUCCESS)
\r
1903 ((REGDATATBL *)(*Handle))->Mode = 0;
\r
1909 /*----- レジストリ/INIファイルを作成する(書き込み)---------------------------
\r
1912 * char *Name : レジストリ名
\r
1913 * void **Handle : ハンドルを返すワーク
\r
1917 * FFFTP_SUCCESS/FFFTP_FAIL
\r
1918 *----------------------------------------------------------------------------*/
\r
1920 static int CreateReg(char *Name, void **Handle)
\r
1923 char Tmp[FMAX_PATH+1];
\r
1927 if(TmpRegType == REGTYPE_REG)
\r
1929 strcpy(Tmp, "Software\\Sota\\");
\r
1930 strcat(Tmp, Name);
\r
1931 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
1932 Sts = FFFTP_SUCCESS;
\r
1936 if((*Handle = malloc(sizeof(REGDATATBL))) != NULL)
\r
1938 strcpy(((REGDATATBL *)(*Handle))->KeyName, Name);
\r
1939 ((REGDATATBL *)(*Handle))->ValLen = 0;
\r
1940 ((REGDATATBL *)(*Handle))->Next = NULL;
\r
1941 ((REGDATATBL *)(*Handle))->Mode = 1;
\r
1942 Sts = FFFTP_SUCCESS;
\r
1949 /*----- レジストリ/INIファイルをクローズする ----------------------------------
\r
1952 * void *Handle : ハンドル
\r
1956 * FFFTP_SUCCESS/FFFTP_FAIL
\r
1957 *----------------------------------------------------------------------------*/
\r
1959 static int CloseReg(void *Handle)
\r
1965 if(TmpRegType == REGTYPE_REG)
\r
1967 RegCloseKey(Handle);
\r
1970 if((Strm = fopen(AskIniFilePath(), "rt")) != NULL)
\r
1973 MoveFileToTrashCan(AskIniFilePath());
\r
1978 if(((REGDATATBL *)Handle)->Mode == 1)
\r
1980 if(WriteOutRegToFile(Handle) == TRUE)
\r
1982 // /* レジストリをクリア */
\r
1983 // ClearRegistory();
\r
1988 while(Pos != NULL)
\r
1995 return(FFFTP_SUCCESS);
\r
1999 /*----- レジストリ情報をINIファイルに書き込む ---------------------------------
\r
2002 * REGDATATBL *Pos : レジストリデータ
\r
2006 *----------------------------------------------------------------------------*/
\r
2008 static BOOL WriteOutRegToFile(REGDATATBL *Pos)
\r
2015 if((Strm = fopen(AskIniFilePath(), "wt")) != NULL)
\r
2017 fprintf(Strm, MSGJPN239);
\r
2018 while(Pos != NULL)
\r
2020 fprintf(Strm, "\n[%s]\n", Pos->KeyName);
\r
2022 Disp = Pos->ValTbl;
\r
2023 while(Disp < (Pos->ValTbl + Pos->ValLen))
\r
2025 fprintf(Strm, "%s\n", Disp);
\r
2026 Disp = Disp + strlen(Disp) + 1;
\r
2034 MessageBox(NULL, MSGJPN240, "FFFTP", MB_OK);
\r
2040 /*----- INIファイルからレジストリ情報を読み込む -------------------------------
\r
2044 * void *Handle : ハンドル
\r
2048 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2049 *----------------------------------------------------------------------------*/
\r
2051 static int ReadInReg(char *Name, REGDATATBL **Handle)
\r
2064 if((Strm = fopen(AskIniFilePath(), "rt")) != NULL)
\r
2066 if((Buf = malloc(REG_SECT_MAX)) != NULL)
\r
2068 while(fgets(Buf, REG_SECT_MAX, Strm) != NULL)
\r
2072 if((Tmp = strchr(Buf, '\n')) != NULL)
\r
2077 if((New = malloc(sizeof(REGDATATBL))) != NULL)
\r
2079 if((Tmp = strchr(Buf, ']')) != NULL)
\r
2081 strcpy(New->KeyName, Buf+1);
\r
2084 Data = New->ValTbl;
\r
2086 if(*Handle == NULL)
\r
2091 while(Pos->Next != NULL)
\r
2096 else if(strlen(Buf) > 0)
\r
2098 strcpy(Data, Buf);
\r
2099 Data += strlen(Buf) + 1;
\r
2100 New->ValLen += strlen(Buf) + 1;
\r
2104 Sts = FFFTP_SUCCESS;
\r
2113 /*----- サブキーをオープンする ------------------------------------------------
\r
2116 * void *Parent : 親のハンドル
\r
2118 * void **Handle : ハンドルを返すワーク
\r
2122 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2123 *----------------------------------------------------------------------------*/
\r
2125 static int OpenSubKey(void *Parent, char *Name, void **Handle)
\r
2132 if(TmpRegType == REGTYPE_REG)
\r
2134 if(RegOpenKeyEx(Parent, Name, 0, KEY_READ, (HKEY *)Handle) == ERROR_SUCCESS)
\r
2135 Sts = FFFTP_SUCCESS;
\r
2139 strcpy(Key, ((REGDATATBL *)Parent)->KeyName);
\r
2140 strcat(Key, "\\");
\r
2141 strcat(Key, Name);
\r
2143 while(Pos != NULL)
\r
2145 if(strcmp(Pos->KeyName, Key) == 0)
\r
2148 Sts = FFFTP_SUCCESS;
\r
2158 /*----- サブキーを作成する ----------------------------------------------------
\r
2161 * void *Parent : 親のハンドル
\r
2163 * void **Handle : ハンドルを返すワーク
\r
2167 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2168 *----------------------------------------------------------------------------*/
\r
2170 static int CreateSubKey(void *Parent, char *Name, void **Handle)
\r
2177 if(TmpRegType == REGTYPE_REG)
\r
2179 if(RegCreateKeyEx(Parent, Name, 0, "", REG_OPTION_NON_VOLATILE, KEY_SET_VALUE, NULL, (HKEY *)Handle, &Dispos) == ERROR_SUCCESS)
\r
2180 Sts = FFFTP_SUCCESS;
\r
2184 if((*Handle = malloc(sizeof(REGDATATBL))) != NULL)
\r
2186 strcpy(((REGDATATBL *)(*Handle))->KeyName, ((REGDATATBL *)Parent)->KeyName);
\r
2187 strcat(((REGDATATBL *)(*Handle))->KeyName, "\\");
\r
2188 strcat(((REGDATATBL *)(*Handle))->KeyName, Name);
\r
2190 ((REGDATATBL *)(*Handle))->ValLen = 0;
\r
2191 ((REGDATATBL *)(*Handle))->Next = NULL;
\r
2193 Pos = (REGDATATBL *)Parent;
\r
2194 while(Pos->Next != NULL)
\r
2196 Pos->Next = *Handle;
\r
2197 Sts = FFFTP_SUCCESS;
\r
2204 /*----- サブキーをクローズする ------------------------------------------------
\r
2207 * void *Handle : ハンドル
\r
2211 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2212 *----------------------------------------------------------------------------*/
\r
2214 static int CloseSubKey(void *Handle)
\r
2216 if(TmpRegType == REGTYPE_REG)
\r
2217 RegCloseKey(Handle);
\r
2222 return(FFFTP_SUCCESS);
\r
2226 /*----- サブキーを削除する ----------------------------------------------------
\r
2229 * void *Handle : ハンドル
\r
2234 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2235 *----------------------------------------------------------------------------*/
\r
2237 static int DeleteSubKey(void *Handle, char *Name)
\r
2242 if(TmpRegType == REGTYPE_REG)
\r
2244 if(RegDeleteKey(Handle, Name) == ERROR_SUCCESS)
\r
2245 Sts = FFFTP_SUCCESS;
\r
2255 /*----- 値を削除する ----------------------------------------------------------
\r
2258 * void *Handle : ハンドル
\r
2263 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2264 *----------------------------------------------------------------------------*/
\r
2266 static int DeleteValue(void *Handle, char *Name)
\r
2271 if(TmpRegType == REGTYPE_REG)
\r
2273 if(RegDeleteValue(Handle, Name) == ERROR_SUCCESS)
\r
2274 Sts = FFFTP_SUCCESS;
\r
2284 /*----- INT値を読み込む -------------------------------------------------------
\r
2287 * void *Handle : ハンドル
\r
2289 * int *Value : INT値を返すワーク
\r
2293 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2294 *----------------------------------------------------------------------------*/
\r
2296 static int ReadIntValueFromReg(void *Handle, char *Name, int *Value)
\r
2303 if(TmpRegType == REGTYPE_REG)
\r
2305 Size = sizeof(int);
\r
2306 if(RegQueryValueEx(Handle, Name, NULL, NULL, (BYTE *)Value, &Size) == ERROR_SUCCESS)
\r
2307 Sts = FFFTP_SUCCESS;
\r
2311 if((Pos = ScanValue(Handle, Name)) != NULL)
\r
2313 *Value = atoi(Pos);
\r
2314 Sts = FFFTP_SUCCESS;
\r
2321 /*----- INT値を書き込む -------------------------------------------------------
\r
2324 * void *Handle : ハンドル
\r
2326 * int Value : INT値
\r
2330 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2331 *----------------------------------------------------------------------------*/
\r
2333 static int WriteIntValueToReg(void *Handle, char *Name, int Value)
\r
2339 if(TmpRegType == REGTYPE_REG)
\r
2340 RegSetValueEx(Handle, Name, 0, REG_DWORD, (CONST BYTE *)&Value, sizeof(int));
\r
2343 Pos = (REGDATATBL *)Handle;
\r
2344 Data = Pos->ValTbl + Pos->ValLen;
\r
2345 strcpy(Data, Name);
\r
2346 strcat(Data, "=");
\r
2347 sprintf(Tmp, "%d", Value);
\r
2348 strcat(Data, Tmp);
\r
2349 Pos->ValLen += strlen(Data) + 1;
\r
2351 return(FFFTP_SUCCESS);
\r
2355 /*----- 文字列を読み込む ------------------------------------------------------
\r
2358 * void *Handle : ハンドル
\r
2360 * char *Str : 文字列を返すワーク
\r
2361 * DWORD Size : 最大サイズ
\r
2365 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2366 *----------------------------------------------------------------------------*/
\r
2368 static int ReadStringFromReg(void *Handle, char *Name, char *Str, DWORD Size)
\r
2378 if(TmpRegType == REGTYPE_REG)
\r
2380 if(RegQueryValueEx(Handle, Name, NULL, NULL, (BYTE *)Str, &Size) == ERROR_SUCCESS)
\r
2382 if(*(Str + Size - 1) != NUL)
\r
2383 *(Str + Size) = NUL;
\r
2384 Sts = FFFTP_SUCCESS;
\r
2389 if((Pos = ScanValue(Handle, Name)) != NULL)
\r
2392 // Size = min1(Size-1, strlen(Pos));
\r
2393 // Size = StrReadIn(Pos, Size, Str);
\r
2394 // *(Str + Size) = NUL;
\r
2395 // Sts = FFFTP_SUCCESS;
\r
2396 switch(IniKanjiCode)
\r
2399 TempSize = min1(Size-1, strlen(Pos));
\r
2400 TempSize = StrReadIn(Pos, TempSize, Str);
\r
2401 *(Str + TempSize) = NUL;
\r
2402 Sts = FFFTP_SUCCESS;
\r
2403 if(!CheckStringM(Str))
\r
2405 // UTF-8ではない可能性がある
\r
2408 if(pa0 = AllocateStringA(Size * 4))
\r
2410 if(pw0 = AllocateStringW(Size * 4 * 4))
\r
2412 TempSize = min1((Size * 4) - 1, strlen(Pos));
\r
2413 TempSize = StrReadIn(Pos, TempSize, pa0);
\r
2414 *(pa0 + TempSize) = NUL;
\r
2415 AtoW(pw0, Size * 4 * 4, pa0, -1);
\r
2416 WtoM(Str, Size, pw0, -1);
\r
2417 TerminateStringM(Str, Size);
\r
2418 Sts = FFFTP_SUCCESS;
\r
2419 FreeDuplicatedString(pw0);
\r
2421 FreeDuplicatedString(pa0);
\r
2431 /*----- 文字列を書き込む ------------------------------------------------------
\r
2434 * void *Handle : ハンドル
\r
2440 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2441 *----------------------------------------------------------------------------*/
\r
2443 static int WriteStringToReg(void *Handle, char *Name, char *Str)
\r
2448 if(TmpRegType == REGTYPE_REG)
\r
2449 RegSetValueEx(Handle, Name, 0, REG_SZ, (CONST BYTE *)Str, strlen(Str)+1);
\r
2452 Pos = (REGDATATBL *)Handle;
\r
2453 Data = Pos->ValTbl + Pos->ValLen;
\r
2454 strcpy(Data, Name);
\r
2455 strcat(Data, "=");
\r
2456 Pos->ValLen += strlen(Data);
\r
2457 Data = Pos->ValTbl + Pos->ValLen;
\r
2458 Pos->ValLen += StrCatOut(Str, strlen(Str), Data) + 1;
\r
2460 return(FFFTP_SUCCESS);
\r
2464 /*----- マルチ文字列を読み込む ------------------------------------------------
\r
2467 * void *Handle : ハンドル
\r
2469 * char *Str : 文字列を返すワーク
\r
2470 * DWORD Size : 最大サイズ
\r
2474 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2475 *----------------------------------------------------------------------------*/
\r
2477 static int ReadMultiStringFromReg(void *Handle, char *Name, char *Str, DWORD Size)
\r
2487 if(TmpRegType == REGTYPE_REG)
\r
2489 if(RegQueryValueEx(Handle, Name, NULL, NULL, (BYTE *)Str, &Size) == ERROR_SUCCESS)
\r
2491 if(*(Str + Size - 1) != NUL)
\r
2492 *(Str + Size) = NUL;
\r
2493 Sts = FFFTP_SUCCESS;
\r
2498 if((Pos = ScanValue(Handle, Name)) != NULL)
\r
2501 // Size = min1(Size-1, strlen(Pos));
\r
2502 // Size = StrReadIn(Pos, Size, Str);
\r
2503 // *(Str + Size) = NUL;
\r
2504 // Sts = FFFTP_SUCCESS;
\r
2505 switch(IniKanjiCode)
\r
2508 TempSize = min1(Size - 2, strlen(Pos));
\r
2509 TempSize = StrReadIn(Pos, TempSize, Str);
\r
2510 *(Str + TempSize) = NUL;
\r
2511 *(Str + TempSize + 1) = NUL;
\r
2512 Sts = FFFTP_SUCCESS;
\r
2513 if(!CheckMultiStringM(Str))
\r
2515 // UTF-8ではない可能性がある
\r
2518 if(pa0 = AllocateStringA(Size * 4))
\r
2520 if(pw0 = AllocateStringW(Size * 4 * 4))
\r
2522 TempSize = min1((Size * 4) - 2, strlen(Pos));
\r
2523 TempSize = StrReadIn(Pos, TempSize, pa0);
\r
2524 *(pa0 + TempSize) = NUL;
\r
2525 *(pa0 + TempSize + 1) = NUL;
\r
2526 AtoWMultiString(pw0, Size * 4 * 4, pa0);
\r
2527 WtoMMultiString(Str, Size, pw0);
\r
2528 TerminateStringM(Str, Size);
\r
2529 TerminateStringM(Str, Size - 1);
\r
2530 Sts = FFFTP_SUCCESS;
\r
2531 FreeDuplicatedString(pw0);
\r
2533 FreeDuplicatedString(pa0);
\r
2543 /*----- マルチ文字列を書き込む ------------------------------------------------
\r
2546 * void *Handle : ハンドル
\r
2552 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2553 *----------------------------------------------------------------------------*/
\r
2555 static int WriteMultiStringToReg(void *Handle, char *Name, char *Str)
\r
2560 if(TmpRegType == REGTYPE_REG)
\r
2561 RegSetValueEx(Handle, Name, 0, REG_MULTI_SZ, (CONST BYTE *)Str, StrMultiLen(Str)+1);
\r
2564 Pos = (REGDATATBL *)Handle;
\r
2565 Data = Pos->ValTbl + Pos->ValLen;
\r
2566 strcpy(Data, Name);
\r
2567 strcat(Data, "=");
\r
2568 Pos->ValLen += strlen(Data);
\r
2569 Data = Pos->ValTbl + Pos->ValLen;
\r
2570 Pos->ValLen += StrCatOut(Str, StrMultiLen(Str), Data) + 1;
\r
2572 return(FFFTP_SUCCESS);
\r
2576 /*----- バイナリを読み込む-----------------------------------------------------
\r
2579 * void *Handle : ハンドル
\r
2581 * void *Bin : バイナリを返すワーク
\r
2582 * DWORD Size : 最大サイズ
\r
2586 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2587 *----------------------------------------------------------------------------*/
\r
2589 static int ReadBinaryFromReg(void *Handle, char *Name, void *Bin, DWORD Size)
\r
2595 if(TmpRegType == REGTYPE_REG)
\r
2597 if(RegQueryValueEx(Handle, Name, NULL, NULL, (BYTE *)Bin, &Size) == ERROR_SUCCESS)
\r
2598 Sts = FFFTP_SUCCESS;
\r
2602 if((Pos = ScanValue(Handle, Name)) != NULL)
\r
2604 Size = min1(Size, strlen(Pos));
\r
2605 Size = StrReadIn(Pos, Size, Bin);
\r
2606 Sts = FFFTP_SUCCESS;
\r
2613 /*----- バイナリを書き込む ----------------------------------------------------
\r
2616 * void *Handle : ハンドル
\r
2618 * void *Bin : バイナリ
\r
2623 * FFFTP_SUCCESS/FFFTP_FAIL
\r
2624 *----------------------------------------------------------------------------*/
\r
2626 static int WriteBinaryToReg(void *Handle, char *Name, void *Bin, int Len)
\r
2631 if(TmpRegType == REGTYPE_REG)
\r
2632 RegSetValueEx(Handle, Name, 0, REG_BINARY, (CONST BYTE *)Bin, Len);
\r
2635 Pos = (REGDATATBL *)Handle;
\r
2636 Data = Pos->ValTbl + Pos->ValLen;
\r
2637 strcpy(Data, Name);
\r
2638 strcat(Data, "=");
\r
2639 Pos->ValLen += strlen(Data);
\r
2640 Data = Pos->ValTbl + Pos->ValLen;
\r
2641 Pos->ValLen += StrCatOut(Bin, Len, Data) + 1;
\r
2643 return(FFFTP_SUCCESS);
\r
2647 /*----- 文字列をバッファに追加書き込みする ------------------------------------
\r
2651 * int len : 文字列の長さ
\r
2652 * char *Dst : 書き込みするバッファ
\r
2656 *----------------------------------------------------------------------------*/
\r
2658 static int StrCatOut(char *Src, int Len, char *Dst)
\r
2662 Dst += strlen(Dst);
\r
2664 for(; Len > 0; Len--)
\r
2672 else if((*Src >= 0x20) && (*Src <= 0x7E))
\r
2679 sprintf(Dst, "\\%02X", *(unsigned char *)Src);
\r
2690 /*----- 文字列をバッファに読み込む --------------------------------------------
\r
2695 * char *Dst : 書き込みするバッファ
\r
2699 *----------------------------------------------------------------------------*/
\r
2701 static int StrReadIn(char *Src, int Max, char *Dst)
\r
2707 while(*Src != NUL)
\r
2719 sscanf(Src, "%02x", &Tmp);
\r
2735 /*----- 値を検索する ----------------------------------------------------------
\r
2738 * char *Handle : ハンドル
\r
2743 * NULL=指定の名前の値が見つからない
\r
2744 *----------------------------------------------------------------------------*/
\r
2746 static char *ScanValue(void *Handle, char *Name)
\r
2754 Pos = Cur->ValTbl;
\r
2755 while(Pos < (Cur->ValTbl + Cur->ValLen))
\r
2757 if((strncmp(Name, Pos, strlen(Name)) == 0) &&
\r
2758 (*(Pos + strlen(Name)) == '='))
\r
2760 Ret = Pos + strlen(Name) + 1;
\r
2763 Pos += strlen(Pos) + 1;
\r
2769 /*----------- パスワードの妥当性を確認する ------------------------------------
\r
2772 * char *Password: パスワード文字列
\r
2773 * char *HashStr: SHA-1ハッシュ文字列
\r
2779 *----------------------------------------------------------------------------*/
\r
2780 int CheckPasswordValidity( char* Password, int length, const char* HashStr )
\r
2787 const char* p = HashStr;
\r
2789 /* 空文字列は一致したことにする */
\r
2790 if( HashStr[0] == NUL ) return 1;
\r
2792 /* Hashをチェックするする*/
\r
2793 if( strlen(HashStr) != 40 ) return 2;
\r
2796 for( i = 0; i < 5; i++ ){
\r
2798 for( j = 0; j < 8; j++ ){
\r
2799 if( *p < 0x40 || 0x40 + 15 < *p ){
\r
2802 decode = (decode << 4 ) + (*p - 0x40);
\r
2805 hash1[i] = decode;
\r
2808 /* Password をハッシュする */
\r
2809 sha_memory( Password, length, hash2 );
\r
2811 if( memcmp( (char*)hash1, (char*)hash2, sizeof( hash1 )) == 0 ){
\r
2817 /*----------- パスワードの妥当性チェックのための文字列を作成する ------------
\r
2820 * char *Password: パスワード文字列
\r
2821 * char *Str: SHA-1ハッシュ文字列格納場所 (41bytes以上)
\r
2825 *----------------------------------------------------------------------------*/
\r
2826 void CreatePasswordHash( char* Password, int length, char* HashStr )
\r
2830 unsigned char *p = (unsigned char *)HashStr;
\r
2832 sha_memory( Password, length, hash );
\r
2834 for( i = 0; i < 5; i++ ){
\r
2835 ulong rest = hash[i];
\r
2836 for( j = 0; j < 8; j++ ){
\r
2837 *p++ = (unsigned char)((rest & 0xf0000000) >> 28) + '@';
\r
2844 void SetHashSalt( DWORD salt )
\r
2846 unsigned char* pos = &SecretKey[strlen(SecretKey) + 1];
\r
2847 *pos++ = ( salt >> 24 ) & 0xff;
\r
2848 *pos++ = ( salt >> 16 ) & 0xff;
\r
2849 *pos++ = ( salt >> 8 ) & 0xff;
\r
2850 *pos++ = ( salt ) & 0xff;
\r
2852 SecretKeyLength = strlen( SecretKey ) + 5;
\r
2855 /*----------- 乱数生成をする -------------------------------------------------
\r
2860 * ランダムな値:コンパイラVS2005/動作環境WinXP以上では rand_s から取得する
\r
2861 *----------------------------------------------------------------------------*/
\r
2862 DWORD GetRandamDWRODValue(void)
\r
2866 #ifdef _CRT_RAND_S
\r
2867 errno_t errnoRand_s;
\r
2868 errnoRand_s = rand_s(&rndValue);
\r
2869 errorCode = (0 != errnoRand_s ? 1 : 0);
\r
2873 if(0 != errorCode){
\r
2874 #ifdef USE_RANDAM_C_RAND
\r
2875 rndValue = rand() | (rand() << 16);
\r
2877 /* rand() のかわりに、SHA-1とパフォーマンスカウンタを用いる */
\r
2878 ulong shaValue[5];
\r
2879 LARGE_INTEGER Counter;
\r
2881 if(0 == IsRndSourceInit){
\r
2883 HANDLE CurProcHandle;
\r
2884 HANDLE CurThreadHandle;
\r
2886 if(DuplicateHandle(GetCurrentProcess(), GetCurrentProcess(), GetCurrentProcess(),
\r
2887 &CurProcHandle, 0, FALSE, DUPLICATE_SAME_ACCESS))
\r
2889 CloseHandle(CurProcHandle);
\r
2891 if(DuplicateHandle(GetCurrentProcess(), GetCurrentThread(), GetCurrentProcess(),
\r
2892 &CurThreadHandle, 0, FALSE, DUPLICATE_SAME_ACCESS))
\r
2894 CloseHandle(CurThreadHandle);
\r
2897 /* _WIN64 では64bitだが、その場合はrand_sが大抵利用可能なのでここでは32bitのみ用いる */
\r
2898 RndSource[0] = (ulong)CurProcHandle;
\r
2899 RndSource[1] = (ulong)CurThreadHandle;
\r
2900 RndSource[2] = (ulong)GetTickCount();
\r
2901 RndSource[3] = (ulong)timeGetTime();
\r
2902 RndSource[4] = 0; /* カウントアップ */
\r
2903 RndSource[5] = RndSource[3] + 1;
\r
2904 IsRndSourceInit = 1;
\r
2907 RndSource[5] += 0x00010010;
\r
2908 if(QueryPerformanceCounter(&Counter)){
\r
2909 RndSource[6] = Counter.LowPart;
\r
2910 RndSource[7] = Counter.HighPart;
\r
2911 RndSource[8] = (ulong)rand();
\r
2913 RndSource[6] = (ulong)timeGetTime();
\r
2914 RndSource[7] = (ulong)rand();
\r
2915 RndSource[8] = (ulong)rand();
\r
2918 sha_memory((char *)RndSource, sizeof(RndSource), shaValue);
\r
2919 rndValue = shaValue[0] ^ shaValue[1] ^ shaValue[2] ^ shaValue[3] ^ shaValue[4];
\r