shockjiang | a5ae48c | 2014-07-27 23:21:41 -0700 | [diff] [blame] | 1 | /* |
| 2 | * rr-mgr.cpp |
| 3 | * |
| 4 | * Created on: 23 Jul, 2014 |
| 5 | * Author: shock |
| 6 | */ |
| 7 | |
| 8 | #include "rr-mgr.hpp" |
| 9 | |
| 10 | namespace ndn { |
shockjiang | 99ad389 | 2014-08-03 14:56:13 -0700 | [diff] [blame] | 11 | namespace ndns { |
shockjiang | a5ae48c | 2014-07-27 23:21:41 -0700 | [diff] [blame] | 12 | RRMgr::RRMgr(Zone& zone, Query& query, Response& response) |
| 13 | : m_count(0U) |
| 14 | , m_zone(zone) |
| 15 | , m_query(query) |
| 16 | , m_response(response) |
| 17 | { |
| 18 | |
| 19 | } |
| 20 | |
shockjiang | 99ad389 | 2014-08-03 14:56:13 -0700 | [diff] [blame] | 21 | RRMgr::~RRMgr() |
| 22 | { |
shockjiang | a5ae48c | 2014-07-27 23:21:41 -0700 | [diff] [blame] | 23 | // TODO Auto-generated destructor stub |
| 24 | } |
| 25 | |
shockjiang | 99ad389 | 2014-08-03 14:56:13 -0700 | [diff] [blame] | 26 | int RRMgr::count() |
shockjiang | a5ae48c | 2014-07-27 23:21:41 -0700 | [diff] [blame] | 27 | { |
| 28 | std::string sql; |
shockjiang | 99ad389 | 2014-08-03 14:56:13 -0700 | [diff] [blame] | 29 | sql = "SELECT count(*) FROM rrs INNER JOIN rrsets ON rrs.rrset_id=rrsets.id"; |
shockjiang | a5ae48c | 2014-07-27 23:21:41 -0700 | [diff] [blame] | 30 | sql += " WHERE rrsets.zone_id="; |
| 31 | sql += std::to_string(m_zone.getId()); |
| 32 | sql += " AND "; |
| 33 | sql += "rrsets.type=\'"; |
| 34 | sql += RR::toString(m_query.getRrType()); |
| 35 | sql += "\' AND "; |
| 36 | sql += "rrsets.label LIKE\'"; |
shockjiang | 99ad389 | 2014-08-03 14:56:13 -0700 | [diff] [blame] | 37 | sql += m_query.getRrLabel().toUri() + "/%\'"; |
shockjiang | a5ae48c | 2014-07-27 23:21:41 -0700 | [diff] [blame] | 38 | |
shockjiang | 99ad389 | 2014-08-03 14:56:13 -0700 | [diff] [blame] | 39 | std::cout << "sql=" << sql << std::endl; |
shockjiang | a5ae48c | 2014-07-27 23:21:41 -0700 | [diff] [blame] | 40 | this->execute(sql, static_callback_countRr, this); |
| 41 | |
shockjiang | 99ad389 | 2014-08-03 14:56:13 -0700 | [diff] [blame] | 42 | if (this->getStatus() == DBMgr::DBError) { |
shockjiang | a5ae48c | 2014-07-27 23:21:41 -0700 | [diff] [blame] | 43 | return -1; |
| 44 | } |
| 45 | |
| 46 | return this->m_count; |
| 47 | } |
shockjiang | 99ad389 | 2014-08-03 14:56:13 -0700 | [diff] [blame] | 48 | int RRMgr::callback_countRr(int argc, char **argv, char **azColName) |
shockjiang | a5ae48c | 2014-07-27 23:21:41 -0700 | [diff] [blame] | 49 | { |
| 50 | this->addResultNum(); |
| 51 | |
shockjiang | 99ad389 | 2014-08-03 14:56:13 -0700 | [diff] [blame] | 52 | std::cout << this->getResultNum() << "th result: " << "count=" << argv[0] |
| 53 | << std::endl; |
shockjiang | a5ae48c | 2014-07-27 23:21:41 -0700 | [diff] [blame] | 54 | m_count = std::atoi(argv[0]); |
| 55 | return 0; |
| 56 | } |
| 57 | |
| 58 | int RRMgr::lookup() |
| 59 | { |
| 60 | std::string sql; |
| 61 | |
shockjiang | 99ad389 | 2014-08-03 14:56:13 -0700 | [diff] [blame] | 62 | sql = |
| 63 | "SELECT rrs.ttl, rrs.rrdata, rrs.id FROM rrs INNER JOIN rrsets ON rrs.rrset_id=rrsets.id"; |
shockjiang | a5ae48c | 2014-07-27 23:21:41 -0700 | [diff] [blame] | 64 | sql += " WHERE rrsets.zone_id="; |
| 65 | sql += std::to_string(m_zone.getId()); |
| 66 | sql += " AND "; |
| 67 | sql += "rrsets.type=\'"; |
| 68 | sql += RR::toString(m_query.getRrType()); |
| 69 | sql += "\' AND "; |
| 70 | sql += "rrsets.label=\'"; |
shockjiang | 99ad389 | 2014-08-03 14:56:13 -0700 | [diff] [blame] | 71 | sql += m_query.getRrLabel().toUri() + "\'"; |
shockjiang | a5ae48c | 2014-07-27 23:21:41 -0700 | [diff] [blame] | 72 | sql += " ORDER BY rrs.id"; |
| 73 | |
shockjiang | 99ad389 | 2014-08-03 14:56:13 -0700 | [diff] [blame] | 74 | std::cout << "sql=" << sql << std::endl; |
shockjiang | a5ae48c | 2014-07-27 23:21:41 -0700 | [diff] [blame] | 75 | this->execute(sql, static_callback_getRr, this); |
| 76 | |
shockjiang | 99ad389 | 2014-08-03 14:56:13 -0700 | [diff] [blame] | 77 | if (this->getStatus() == DBMgr::DBError) { |
shockjiang | a5ae48c | 2014-07-27 23:21:41 -0700 | [diff] [blame] | 78 | return -1; |
| 79 | } |
| 80 | |
| 81 | //m_response.setQueryName(m_query.getAuthorityZone()); |
| 82 | return 0; |
| 83 | } |
| 84 | |
| 85 | int RRMgr::callback_getRr(int argc, char **argv, char **azColName) |
| 86 | { |
| 87 | this->addResultNum(); |
shockjiang | 99ad389 | 2014-08-03 14:56:13 -0700 | [diff] [blame] | 88 | if (argc < 1) { |
| 89 | this->setErr( |
| 90 | "No RRType=" + RR::toString(m_query.getRrType()) + " and label=" |
| 91 | + m_query.getRrLabel().toUri() + " and zone=" |
| 92 | + m_zone.getAuthorizedName().toUri()); |
shockjiang | a5ae48c | 2014-07-27 23:21:41 -0700 | [diff] [blame] | 93 | return 0; |
| 94 | } |
| 95 | |
shockjiang | 99ad389 | 2014-08-03 14:56:13 -0700 | [diff] [blame] | 96 | std::cout << this->getResultNum() << "th result: " << "id=" << argv[2] |
| 97 | << " ttl=" << argv[0] << " rrdata=" << argv[1] << std::endl; |
shockjiang | a5ae48c | 2014-07-27 23:21:41 -0700 | [diff] [blame] | 98 | |
| 99 | m_response.setFreshness(time::milliseconds(std::atoi(argv[0]))); |
| 100 | |
| 101 | m_response.addRr(std::atoi(argv[2]), argv[1]); |
| 102 | //std::cout<<"after add a Rr: current size="<<m_response.getRrs().size()<<std::endl; |
| 103 | //m_response.setFreshness(time::milliseconds(std::atoi(argv[0]))); |
| 104 | return 0; |
| 105 | } |
| 106 | |
shockjiang | 99ad389 | 2014-08-03 14:56:13 -0700 | [diff] [blame] | 107 | } //namespace ndnsn |
shockjiang | a5ae48c | 2014-07-27 23:21:41 -0700 | [diff] [blame] | 108 | } /* namespace ndn */ |