/* */ #include "Sqlite3CookieParser.h" #include #include "DlAbortEx.h" #include "util.h" #include "StringFormat.h" #include "A2STR.h" #ifndef HAVE_SQLITE3_OPEN_V2 # include "File.h" #endif // !HAVE_SQLITE3_OPEN_V2 namespace aria2 { Sqlite3CookieParser::Sqlite3CookieParser(const std::string& filename):db_(0) { int ret; #ifdef HAVE_SQLITE3_OPEN_V2 ret = sqlite3_open_v2(filename.c_str(), &db_, SQLITE_OPEN_READONLY, 0); #else // !HAVE_SQLITE3_OPEN_V2 if(!File(filename).isFile()) { return; } ret = sqlite3_open(filename.c_str(), &db_); #endif // !HAVE_SQLITE3_OPEN_V2 if(SQLITE_OK != ret) { sqlite3_close(db_); db_ = 0; } } Sqlite3CookieParser::~Sqlite3CookieParser() { sqlite3_close(db_); } static std::string toString(const char* str) { if(str) { return str; } else { return A2STR::NIL; } } static int cookieRowMapper(void* data, int rowIndex, char** values, char** names) { try { std::vector& cookies = *reinterpret_cast*>(data); int64_t expireDate = util::parseLLInt(toString(values[3])); // TODO assuming time_t is int32_t... if(expireDate > INT32_MAX) { expireDate = INT32_MAX; } Cookie c(toString(values[4]), // name toString(values[5]), // value expireDate, // expires toString(values[1]), // path toString(values[0]), // domain strcmp(toString(values[2]).c_str(), "1") == 0 ? true:false //secure ); if(!util::startsWith(values[0], A2STR::DOT_C)) { c.markOriginServerOnly(); } if(c.good()) { cookies.push_back(c); } } catch(RecoverableException& e) { //failed to parse expiry. } return 0; } void Sqlite3CookieParser::parse(std::vector& cookies) { if(!db_) { throw DL_ABORT_EX(StringFormat("SQLite3 database is not opened.").str()); } std::vector tcookies; char* sqlite3ErrMsg = 0; int ret = sqlite3_exec(db_, getQuery().c_str(), cookieRowMapper, &tcookies, &sqlite3ErrMsg); std::string errMsg; if(sqlite3ErrMsg) { errMsg = sqlite3ErrMsg; sqlite3_free(sqlite3ErrMsg); } if(SQLITE_OK != ret) { throw DL_ABORT_EX(StringFormat("Failed to read SQLite3 database: %s", errMsg.c_str()).str()); } cookies.swap(tcookies); } } // namespace aria2