/* FTP File YM plugin Copyright (C) 2007-2010 Jan Holub This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation version 2 of the License. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ #include "stdafx.h" ServerList *ServerList::instance = nullptr; ServerList &ftpList = ServerList::getInstance(); extern Options &opt; void ServerList::init() { for (int i = 0; i < FTP_COUNT; i++) { ServerList::FTP *ftp = new ServerList::FTP(i); ftpList.add(ftp); } } void ServerList::deinit() { for (UINT i = 0; i < ftpList.size(); i++) delete ftpList[i]; delete this; } void ServerList::saveToDb() const { ServerList::FTP *ftp = ftpList.getSelected(); char buff[256]; mir_snprintf(buff, "Password%d", opt.selected); DB::setAStringF(0, MODULE, buff, opt.selected, ftp->m_szPass); DB::setStringF(0, MODULE, "Name%d", opt.selected, ftp->m_stzName); DB::setAStringF(0, MODULE, "Server%d", opt.selected, ftp->m_szServer); DB::setAStringF(0, MODULE, "User%d", opt.selected, ftp->m_szUser); DB::setAStringF(0, MODULE, "Url%d", opt.selected, ftp->m_szUrl); DB::setAStringF(0, MODULE, "Dir%d", opt.selected, ftp->m_szDir); DB::setAStringF(0, MODULE, "Chmod%d", opt.selected, ftp->m_szChmod); DB::setWordF(0, MODULE, "FtpProto%d", opt.selected, ftp->m_ftpProto); DB::setWordF(0, MODULE, "Port%d", opt.selected, ftp->m_iPort); DB::setByteF(0, MODULE, "Passive%d", opt.selected, ftp->m_bPassive); DB::setByteF(0, MODULE, "Enabled%d", opt.selected, ftp->m_bEnabled); db_set_b(0, MODULE, "Selected", opt.selected); db_set_b(0, MODULE, "Default", opt.defaultFTP); } ServerList::FTP::FTP(int index) { CMStringA frmt; frmt.Format("Name%d", index); ptrA Name(db_get_sa(NULL, MODULE, frmt)); if (Name) mir_snwprintf(m_stzName, TranslateT("FTP Server %d"), index + 1); frmt.Format("Password%d", index); ptrA Pass(db_get_sa(NULL, MODULE, frmt)); if (Pass) strncpy_s(m_szPass, Pass, _TRUNCATE); frmt.Format("Server%d", index); ptrA Server(db_get_sa(NULL, MODULE, frmt)); if (Server) strncpy_s(m_szServer, Server, _TRUNCATE); frmt.Format("User%d", index); ptrA User(db_get_sa(NULL, MODULE, frmt)); if (User) strncpy_s(m_szUser, User, _TRUNCATE); frmt.Format("Url%d", index); ptrA Url(db_get_sa(NULL, MODULE, frmt)); if (Url) strncpy_s(m_szUrl, Url, _TRUNCATE); frmt.Format("Dir%d", index); ptrA Dir(db_get_sa(NULL, MODULE, frmt)); if (Dir) strncpy_s(m_szDir, Dir, _TRUNCATE); frmt.Format("Chmod%d", index); ptrA Chmod(db_get_sa(NULL, MODULE, frmt)); if (Chmod) strncpy_s(m_szChmod, Chmod, _TRUNCATE); m_ftpProto = (FTP::EProtoType)DB::getWordF(0, MODULE, "FtpProto%d", index, FTP::FT_STANDARD); m_iPort = DB::getWordF(0, MODULE, "Port%d", index, 21); m_bPassive = DB::getByteF(0, MODULE, "Passive%d", index, 0) ? true : false; m_bEnabled = DB::getByteF(0, MODULE, "Enabled%d", index, 0) ? true : false; } ServerList::FTP* ServerList::getSelected() const { return ftpList[opt.selected]; } bool ServerList::FTP::isValid() const { return (m_bEnabled && m_szServer[0] && m_szUser[0] && m_szPass[0] && m_szUrl[0]) ? true : false; } char* ServerList::FTP::getProtoString() const { switch (m_ftpProto) { case FT_STANDARD: case FT_SSL_EXPLICIT: return "ftp://"; case FT_SSL_IMPLICIT: return "ftps://"; case FT_SSH: return "sftp://"; } return nullptr; }