2018-05-21 12:23:52 -04:00
|
|
|
/*******************************************************************************
|
|
|
|
* bitdht/bdaccount.cc *
|
|
|
|
* *
|
|
|
|
* BitDHT: An Flexible DHT library. *
|
|
|
|
* *
|
|
|
|
* Copyright 2011 by Robert Fernie <bitdht@lunamutt.com> *
|
|
|
|
* *
|
|
|
|
* This program is free software: you can redistribute it and/or modify *
|
|
|
|
* it under the terms of the GNU Affero General Public License as *
|
|
|
|
* published by the Free Software Foundation, either version 3 of the *
|
|
|
|
* License, or (at your option) any later version. *
|
|
|
|
* *
|
|
|
|
* 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 Affero General Public License for more details. *
|
|
|
|
* *
|
|
|
|
* You should have received a copy of the GNU Affero General Public License *
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>. *
|
|
|
|
* *
|
|
|
|
*******************************************************************************/
|
2011-06-29 06:46:11 -04:00
|
|
|
|
|
|
|
#include "bitdht/bdaccount.h"
|
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
#include <iostream>
|
|
|
|
#include <iomanip>
|
|
|
|
|
|
|
|
|
|
|
|
#define LPF_FACTOR (0.90)
|
|
|
|
|
|
|
|
bdAccount::bdAccount()
|
|
|
|
:mNoStats(BDACCOUNT_NUM_ENTRIES),
|
|
|
|
mCountersOut(BDACCOUNT_NUM_ENTRIES), mCountersRecv(BDACCOUNT_NUM_ENTRIES),
|
|
|
|
mLpfOut(BDACCOUNT_NUM_ENTRIES), mLpfRecv(BDACCOUNT_NUM_ENTRIES),
|
|
|
|
mLabel(BDACCOUNT_NUM_ENTRIES)
|
|
|
|
{
|
|
|
|
|
|
|
|
mLabel[BDACCOUNT_MSG_OUTOFDATEPING] = "OUTOFDATEPING ";
|
|
|
|
mLabel[BDACCOUNT_MSG_PING] = "PING ";
|
|
|
|
mLabel[BDACCOUNT_MSG_PONG] = "PONG ";
|
|
|
|
mLabel[BDACCOUNT_MSG_QUERYNODE] = "QUERYNODE ";
|
|
|
|
mLabel[BDACCOUNT_MSG_QUERYHASH] = "QUERYHASH ";
|
|
|
|
mLabel[BDACCOUNT_MSG_REPLYFINDNODE] = "REPLYFINDNODE ";
|
|
|
|
mLabel[BDACCOUNT_MSG_REPLYQUERYHASH] = "REPLYQUERYHASH ";
|
|
|
|
|
|
|
|
mLabel[BDACCOUNT_MSG_POSTHASH] = "POSTHASH ";
|
|
|
|
mLabel[BDACCOUNT_MSG_REPLYPOSTHASH] = "REPLYPOSTHASH ";
|
|
|
|
|
|
|
|
mLabel[BDACCOUNT_MSG_CONNECTREQUEST] = "CONNECTREQUEST ";
|
|
|
|
mLabel[BDACCOUNT_MSG_CONNECTREPLY] = "CONNECTREPLY ";
|
|
|
|
mLabel[BDACCOUNT_MSG_CONNECTSTART] = "CONNECTSTART ";
|
|
|
|
mLabel[BDACCOUNT_MSG_CONNECTACK] = "CONNECTACK ";
|
|
|
|
|
|
|
|
resetStats();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void bdAccount::incCounter(uint32_t idx, bool out)
|
|
|
|
{
|
2011-11-22 08:16:03 -05:00
|
|
|
if ((signed) idx > mNoStats-1)
|
2011-06-29 06:46:11 -04:00
|
|
|
{
|
|
|
|
std::cerr << "bdAccount::incCounter() Invalid Index";
|
|
|
|
std::cerr << std::endl;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (out)
|
|
|
|
{
|
|
|
|
mCountersOut[idx]++;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
mCountersRecv[idx]++;
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void bdAccount::doStats()
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
for(i = 0; i < mNoStats; i++)
|
|
|
|
{
|
|
|
|
mLpfOut[i] *= (LPF_FACTOR) ;
|
|
|
|
mLpfOut[i] += (1.0 - LPF_FACTOR) * mCountersOut[i];
|
|
|
|
|
|
|
|
mLpfRecv[i] *= (LPF_FACTOR) ;
|
|
|
|
mLpfRecv[i] += (1.0 - LPF_FACTOR) * mCountersRecv[i];
|
|
|
|
}
|
|
|
|
resetCounters();
|
|
|
|
}
|
|
|
|
|
|
|
|
void bdAccount::printStats(std::ostream &out)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
out << " Send Recv: ";
|
|
|
|
out << std::endl;
|
|
|
|
for(i = 0; i < mNoStats; i++)
|
|
|
|
{
|
|
|
|
|
|
|
|
out << "Send" << mLabel[i] << " : " << std::setw(10) << mLpfOut[i];
|
|
|
|
out << " ";
|
|
|
|
out << "Recv" << mLabel[i] << " : " << std::setw(10) << mLpfRecv[i];
|
|
|
|
out << std::endl;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void bdAccount::resetCounters()
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
for(i = 0; i < mNoStats; i++)
|
|
|
|
{
|
|
|
|
mCountersOut[i] = 0;
|
|
|
|
mCountersRecv[i] = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void bdAccount::resetStats()
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
for(i = 0; i < mNoStats; i++)
|
|
|
|
{
|
|
|
|
mLpfOut[i] = 0;
|
|
|
|
mLpfRecv[i] = 0;
|
|
|
|
}
|
|
|
|
resetCounters();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|