Vidalia  0.3.1
Public Types | Public Member Functions | Private Member Functions | Private Attributes | List of all members
RouterDescriptor Class Reference

#include <RouterDescriptor.h>

Public Types

enum  RouterStatus { Online, Hibernating, Offline }
 

Public Member Functions

 RouterDescriptor ()
 
 RouterDescriptor (QStringList descriptor)
 
QString name () const
 
QHostAddress ip () const
 
quint16 orPort () const
 
quint16 dirPort () const
 
QString id () const
 
QString platform () const
 
quint64 uptime () const
 
QString contact () const
 
QDateTime published () const
 
QString fingerprint () const
 
quint64 averageBandwidth () const
 
quint64 burstBandwidth () const
 
quint64 observedBandwidth () const
 
bool online () const
 
bool offline () const
 
bool hibernating () const
 
bool isEmpty ()
 
QString status ()
 
QString location () const
 
void setLocation (QString location)
 
void setOffline (bool offline)
 

Private Member Functions

void parseDescriptor (QStringList descriptor)
 

Private Attributes

RouterStatus _status
 
QString _id
 
QString _name
 
QString _fingerprint
 
QString _platform
 
QString _contact
 
QHostAddress _ip
 
quint16 _orPort
 
quint16 _dirPort
 
QDateTime _published
 
quint64 _uptime
 
quint64 _avgBandwidth
 
quint64 _burstBandwidth
 
quint64 _observedBandwidth
 
QString _location
 

Detailed Description

Definition at line 26 of file RouterDescriptor.h.

Member Enumeration Documentation

◆ RouterStatus

Possible router states.

Enumerator
Online 

Router is online and reachable.

Hibernating 

Router is currently hibernating.

Offline 

Router is unresponsive.

Definition at line 32 of file RouterDescriptor.h.

Constructor & Destructor Documentation

◆ RouterDescriptor() [1/2]

RouterDescriptor::RouterDescriptor ( )
inline

Default constructor.

Definition at line 39 of file RouterDescriptor.h.

◆ RouterDescriptor() [2/2]

RouterDescriptor::RouterDescriptor ( QStringList  descriptor)

Constructor.

Constructor. Just assigns the ID and determines whether the router is responsive or not based on the presence of a "!" at the start of the ID. See tor-spec.txt for details.

Definition at line 24 of file RouterDescriptor.cpp.

References _status, Online, and parseDescriptor().

Member Function Documentation

◆ averageBandwidth()

quint64 RouterDescriptor::averageBandwidth ( ) const
inline

Returns the average bandwidth for this router.

Definition at line 64 of file RouterDescriptor.h.

References _avgBandwidth.

Referenced by TorMapWidget::addRouter(), RouterDescriptorView::display(), and RouterListItem::update().

◆ burstBandwidth()

quint64 RouterDescriptor::burstBandwidth ( ) const
inline

Returns the burst bandwidth for this router.

Definition at line 66 of file RouterDescriptor.h.

References _burstBandwidth.

Referenced by TorMapWidget::addRouter(), RouterDescriptorView::display(), and RouterListItem::update().

◆ contact()

QString RouterDescriptor::contact ( ) const
inline

Returns the router's contact information.

Definition at line 58 of file RouterDescriptor.h.

References _contact.

Referenced by RouterInfoDialog::setRouterInfo().

◆ dirPort()

quint16 RouterDescriptor::dirPort ( ) const
inline

Returns the router's DirPort.

Definition at line 50 of file RouterDescriptor.h.

References _dirPort.

◆ fingerprint()

QString RouterDescriptor::fingerprint ( ) const
inline

Returns the fingerprint for this router.

Definition at line 62 of file RouterDescriptor.h.

References _fingerprint.

◆ hibernating()

bool RouterDescriptor::hibernating ( ) const
inline

Returns true if this router is hibernating.

Definition at line 74 of file RouterDescriptor.h.

References _status, and Hibernating.

Referenced by RouterInfoDialog::setRouterInfo(), and RouterListItem::update().

◆ id()

QString RouterDescriptor::id ( ) const
inline

Returns the router's ID.

Definition at line 52 of file RouterDescriptor.h.

References _id.

Referenced by TorMapImageView::addRouter(), TorMapWidget::addRouter(), RouterListWidget::addRouter(), and RouterListItem::id().

◆ ip()

QHostAddress RouterDescriptor::ip ( ) const
inline

Returns the router's IP address.

Definition at line 46 of file RouterDescriptor.h.

References _ip.

Referenced by NetViewer::addRouter(), RouterDescriptorView::display(), and RouterInfoDialog::setRouterInfo().

◆ isEmpty()

bool RouterDescriptor::isEmpty ( )
inline

Returns true if the router has neither a nickname or an ID.

Definition at line 76 of file RouterDescriptor.h.

References _id, and _name.

Referenced by RouterDescriptorView::display(), NetViewer::loadNetworkStatus(), and NetViewer::newDescriptors().

◆ location()

QString RouterDescriptor::location ( ) const
inline

Returns geographic location information for this router. Note that this information is NOT part of the Tor directory protocol, but can be determined out of band and set using setLocation().

Definition at line 83 of file RouterDescriptor.h.

References _location.

Referenced by RouterDescriptorView::display(), and setLocation().

◆ name()

QString RouterDescriptor::name ( ) const
inline

◆ observedBandwidth()

quint64 RouterDescriptor::observedBandwidth ( ) const
inline

Returns the observed bandwidth for this router.

Definition at line 68 of file RouterDescriptor.h.

References _observedBandwidth.

Referenced by TorMapWidget::addRouter(), RouterDescriptorView::display(), RouterInfoDialog::setRouterInfo(), and RouterListItem::update().

◆ offline()

bool RouterDescriptor::offline ( ) const
inline

Returns true if this router is unresponsive.

Definition at line 72 of file RouterDescriptor.h.

References _status, and Offline.

Referenced by RouterDescriptorView::display(), setOffline(), and RouterListItem::update().

◆ online()

bool RouterDescriptor::online ( ) const
inline

Returns true if this router is online and responsive.

Definition at line 70 of file RouterDescriptor.h.

References _status, and Online.

◆ orPort()

quint16 RouterDescriptor::orPort ( ) const
inline

Returns the router's ORPort.

Definition at line 48 of file RouterDescriptor.h.

References _orPort.

◆ parseDescriptor()

void RouterDescriptor::parseDescriptor ( QStringList  descriptor)
private

Parses this router's descriptor for relevant information.

Definition at line 32 of file RouterDescriptor.cpp.

References _avgBandwidth, _burstBandwidth, _contact, _dirPort, _fingerprint, _id, _ip, _name, _observedBandwidth, _orPort, _platform, _published, _status, _uptime, and Hibernating.

Referenced by RouterDescriptor().

◆ platform()

QString RouterDescriptor::platform ( ) const
inline

Returns the platform on which this router is running.

Definition at line 54 of file RouterDescriptor.h.

References _platform.

Referenced by RouterDescriptorView::display(), RouterInfoDialog::setRouterInfo(), and RouterListItem::update().

◆ published()

QDateTime RouterDescriptor::published ( ) const
inline

Returns the date and time the router was published.

Definition at line 60 of file RouterDescriptor.h.

References _published.

Referenced by RouterDescriptorView::display(), and RouterInfoDialog::setRouterInfo().

◆ setLocation()

void RouterDescriptor::setLocation ( QString  location)
inline

Sets geographic location information for this router.

Definition at line 85 of file RouterDescriptor.h.

References _location, and location().

Referenced by RouterListItem::setLocation().

◆ setOffline()

void RouterDescriptor::setOffline ( bool  offline)
inline

Sets the descriptors status to Offline if offline is true.

Definition at line 87 of file RouterDescriptor.h.

References _status, Offline, offline(), and Online.

◆ status()

QString RouterDescriptor::status ( )

Returns a string representation of the status of this router.

Definition at line 73 of file RouterDescriptor.cpp.

References _status, Hibernating, and Online.

Referenced by RouterDescriptorView::display().

◆ uptime()

quint64 RouterDescriptor::uptime ( ) const
inline

Returns the length of time this router has been up.

Definition at line 56 of file RouterDescriptor.h.

References _uptime.

Referenced by RouterDescriptorView::display(), and RouterInfoDialog::setRouterInfo().

Member Data Documentation

◆ _avgBandwidth

quint64 RouterDescriptor::_avgBandwidth
private

Average bandwidth.

Definition at line 104 of file RouterDescriptor.h.

Referenced by averageBandwidth(), and parseDescriptor().

◆ _burstBandwidth

quint64 RouterDescriptor::_burstBandwidth
private

Burst bandwidth.

Definition at line 105 of file RouterDescriptor.h.

Referenced by burstBandwidth(), and parseDescriptor().

◆ _contact

QString RouterDescriptor::_contact
private

Router operator contact information.

Definition at line 98 of file RouterDescriptor.h.

Referenced by contact(), and parseDescriptor().

◆ _dirPort

quint16 RouterDescriptor::_dirPort
private

Router's DirPort.

Definition at line 101 of file RouterDescriptor.h.

Referenced by dirPort(), and parseDescriptor().

◆ _fingerprint

QString RouterDescriptor::_fingerprint
private

Router's fingerprint.

Definition at line 96 of file RouterDescriptor.h.

Referenced by fingerprint(), and parseDescriptor().

◆ _id

QString RouterDescriptor::_id
private

Router's descriptor ID.

Definition at line 94 of file RouterDescriptor.h.

Referenced by id(), isEmpty(), and parseDescriptor().

◆ _ip

QHostAddress RouterDescriptor::_ip
private

Router's IP address.

Definition at line 99 of file RouterDescriptor.h.

Referenced by ip(), and parseDescriptor().

◆ _location

QString RouterDescriptor::_location
private

Geographic location information.

Definition at line 107 of file RouterDescriptor.h.

Referenced by location(), and setLocation().

◆ _name

QString RouterDescriptor::_name
private

The router's name.

Definition at line 95 of file RouterDescriptor.h.

Referenced by isEmpty(), name(), and parseDescriptor().

◆ _observedBandwidth

quint64 RouterDescriptor::_observedBandwidth
private

Observed bandwidth.

Definition at line 106 of file RouterDescriptor.h.

Referenced by observedBandwidth(), and parseDescriptor().

◆ _orPort

quint16 RouterDescriptor::_orPort
private

Router's ORPort.

Definition at line 100 of file RouterDescriptor.h.

Referenced by orPort(), and parseDescriptor().

◆ _platform

QString RouterDescriptor::_platform
private

Platform on which router is running.

Definition at line 97 of file RouterDescriptor.h.

Referenced by parseDescriptor(), and platform().

◆ _published

QDateTime RouterDescriptor::_published
private

Date router descriptor was published.

Definition at line 102 of file RouterDescriptor.h.

Referenced by parseDescriptor(), and published().

◆ _status

RouterStatus RouterDescriptor::_status
private

Availability status of this router.

Definition at line 93 of file RouterDescriptor.h.

Referenced by hibernating(), offline(), online(), parseDescriptor(), RouterDescriptor(), setOffline(), and status().

◆ _uptime

quint64 RouterDescriptor::_uptime
private

Time the router has been online.

Definition at line 103 of file RouterDescriptor.h.

Referenced by parseDescriptor(), and uptime().


The documentation for this class was generated from the following files: