TorSettings Class Reference

#include <TorSettings.h>

Inheritance diagram for TorSettings:
AbstractTorSettings VSettings

List of all members.

Public Types

enum  AuthenticationMethod { NullAuth, CookieAuth, PasswordAuth, UnknownAuth }

Public Member Functions

 TorSettings (TorControl *torControl=0)
bool apply (QString *errmsg=0)
QString getExecutable () const
void setExecutable (const QString &torExecutable)
QString getDataDirectory () const
void setDataDirectory (const QString &dataDir)
QString getTorrc () const
void setTorrc (const QString &torrc)
QHostAddress getControlAddress () const
void setControlAddress (const QHostAddress &addr)
quint16 getControlPort () const
void setControlPort (quint16 port)
QString getControlPassword () const
void setControlPassword (const QString &password)
bool useRandomPassword () const
void setUseRandomPassword (bool useRandomPassword)
AuthenticationMethod getAuthenticationMethod () const
void setAuthenticationMethod (AuthenticationMethod method)
QList< quint16 > getWarnPlaintextPorts () const
void setWarnPlaintextPorts (const QList< quint16 > &ports)
QList< quint16 > getRejectPlaintextPorts () const
void setRejectPlaintextPorts (const QList< quint16 > &ports)

Static Public Member Functions

static QString randomPassword ()
static QString hashPassword (const QString &password)

Private Member Functions

AuthenticationMethod toAuthenticationMethod (const QString &authMethod) const
QString toString (AuthenticationMethod type) const

Detailed Description

Manages Tor-specific settings, such as location, command-line arguments, and control interface information.

Definition at line 27 of file TorSettings.h.


Member Enumeration Documentation

Available Tor authentication methods.

Enumerator:
NullAuth 

No authentication.

CookieAuth 

Use a "magic" cookie for authentication.

PasswordAuth 

Use a hashed password for authentication.

UnknownAuth 

Unknown authentication method.

Definition at line 33 of file TorSettings.h.


Constructor & Destructor Documentation

TorSettings::TorSettings ( TorControl torControl = 0  ) 

Member Function Documentation

bool TorSettings::apply ( QString *  errmsg = 0  )  [virtual]
TorSettings::AuthenticationMethod TorSettings::getAuthenticationMethod (  )  const
QHostAddress TorSettings::getControlAddress (  )  const

Get Tor's control interface address.

Get the address or hostname used to connect to Tor

Definition at line 182 of file TorSettings.cpp.

References AbstractTorSettings::localValue(), and SETTING_CONTROL_ADDR.

Referenced by MainWindow::connectFailed(), AdvancedPage::load(), MainWindow::start(), and MainWindow::started().

QString TorSettings::getControlPassword (  )  const

Returns the plaintext (i.e., not hashed) control password used when authenticating to Tor.

Definition at line 212 of file TorSettings.cpp.

References AbstractTorSettings::localValue(), and SETTING_CONTROL_PASSWORD.

Referenced by apply(), MainWindow::authenticate(), AdvancedPage::load(), and MainWindow::start().

quint16 TorSettings::getControlPort (  )  const

Get the control port.

Get the control port used to connect to Tor

Definition at line 197 of file TorSettings.cpp.

References SETTING_CONTROL_PORT, and AbstractTorSettings::value().

Referenced by MainWindow::connectFailed(), AdvancedPage::load(), MainWindow::start(), and MainWindow::started().

QString TorSettings::getDataDirectory (  )  const
QString TorSettings::getExecutable (  )  const

Gets the name and path of Tor's executable.

Returns a fully-qualified path to Tor's executable, including the executable name.

Definition at line 145 of file TorSettings.cpp.

References VSettings::defaultValue(), AbstractTorSettings::localValue(), and SETTING_TOR_EXECUTABLE.

Referenced by GeneralPage::load(), and MainWindow::start().

QList< quint16 > TorSettings::getRejectPlaintextPorts (  )  const

Returns the current list of ports that will cause Tor to reject the connection when the user tries to connect to one of them.

Definition at line 301 of file TorSettings.cpp.

References SETTING_REJECT_PLAINTEXT_PORTS, and AbstractTorSettings::value().

Referenced by MainWindow::warnDangerousPort().

QString TorSettings::getTorrc (  )  const

Gets the torrc to use when starting Tor.

Returns the torrc that will be used when starting Tor.

Definition at line 162 of file TorSettings.cpp.

References TorControl::getInfo(), TorControl::isConnected(), AbstractTorSettings::localValue(), SETTING_TORRC, AbstractTorSettings::torControl(), and toString().

Referenced by AdvancedPage::load(), AdvancedPage::save(), and MainWindow::start().

QList< quint16 > TorSettings::getWarnPlaintextPorts (  )  const

Returns the current list of ports that will cause Tor to issue a warning when the user tries to connect to one of them.

Definition at line 274 of file TorSettings.cpp.

References SETTING_WARN_PLAINTEXT_PORTS, and AbstractTorSettings::value().

Referenced by MainWindow::warnDangerousPort().

QString TorSettings::hashPassword ( const QString &  password  )  [static]

Returns the hash of password as given by the command "tor --hash-password foo".

Definition at line 365 of file TorSettings.cpp.

References base16_encode(), crypto_rand_bytes(), and crypto_secret_to_key().

Referenced by apply(), and MainWindow::start().

QString TorSettings::randomPassword (  )  [static]

Generates a random control password consisting of PASSWORD_LEN characters.

Definition at line 357 of file TorSettings.cpp.

References crypto_rand_string(), and PASSWORD_LEN.

Referenced by apply(), and MainWindow::start().

void TorSettings::setAuthenticationMethod ( AuthenticationMethod  method  ) 

Sets the authentication method used when starting Tor to method.

Definition at line 266 of file TorSettings.cpp.

References SETTING_AUTH_METHOD, AbstractTorSettings::setValue(), and toString().

Referenced by MainWindow::authenticationFailed(), and AdvancedPage::save().

void TorSettings::setControlAddress ( const QHostAddress &  addr  ) 

Set Tor's control interface address.

Set the address or hostname used to connect to Tor

Definition at line 190 of file TorSettings.cpp.

References SETTING_CONTROL_ADDR, and AbstractTorSettings::setValue().

Referenced by AdvancedPage::save().

void TorSettings::setControlPassword ( const QString &  password  ) 

Sets the control password used when starting Tor with HashedControlPassword to password.

Definition at line 220 of file TorSettings.cpp.

References SETTING_CONTROL_PASSWORD, and AbstractTorSettings::setValue().

Referenced by MainWindow::authenticationFailed(), and AdvancedPage::save().

void TorSettings::setControlPort ( quint16  port  ) 

Set the control port.

Set the control port used to connect to Tor

Definition at line 204 of file TorSettings.cpp.

References SETTING_CONTROL_PORT, and AbstractTorSettings::setValue().

Referenced by AdvancedPage::save().

void TorSettings::setDataDirectory ( const QString &  dataDirectory  ) 

Sets the location to use for Tor's data directory.

Sets the location to use as Tor's data directory.

Definition at line 137 of file TorSettings.cpp.

References SETTING_DATA_DIRECTORY, and AbstractTorSettings::setValue().

Referenced by AdvancedPage::save().

void TorSettings::setExecutable ( const QString &  torExecutable  ) 

Sets the name and path of Tor's executable.

Sets the location and name of Tor's executable to the given string.

Definition at line 155 of file TorSettings.cpp.

References SETTING_TOR_EXECUTABLE, and AbstractTorSettings::setValue().

Referenced by GeneralPage::save().

void TorSettings::setRejectPlaintextPorts ( const QList< quint16 > &  ports  ) 

Sets the list of ports that will cause Tor to reject the connection when the user tries to connect to one of them.

Definition at line 316 of file TorSettings.cpp.

References SETTING_REJECT_PLAINTEXT_PORTS, and AbstractTorSettings::setValue().

Referenced by MainWindow::warnDangerousPort().

void TorSettings::setTorrc ( const QString &  torrc  ) 

Sets the torrc to use when starting Tor.

Sets the torrc that will be used when starting Tor.

Parameters:
torrc The torrc to use.

Definition at line 175 of file TorSettings.cpp.

References SETTING_TORRC, and AbstractTorSettings::setValue().

Referenced by AdvancedPage::save().

void TorSettings::setUseRandomPassword ( bool  useRandomPassword  ) 

Sets whether or not to generate and use a random control password each time Tor is started.

Definition at line 236 of file TorSettings.cpp.

References SETTING_USE_RANDOM_PASSWORD, and AbstractTorSettings::setValue().

Referenced by MainWindow::authenticationFailed(), and AdvancedPage::save().

void TorSettings::setWarnPlaintextPorts ( const QList< quint16 > &  ports  ) 

Sets the list of ports that will cause Tor to issue a warning when the user tries to connect to one of them.

Definition at line 289 of file TorSettings.cpp.

References SETTING_WARN_PLAINTEXT_PORTS, and AbstractTorSettings::setValue().

Referenced by MainWindow::warnDangerousPort().

TorSettings::AuthenticationMethod TorSettings::toAuthenticationMethod ( const QString &  authMethod  )  const [private]

Returns the AuthenticationMethod enum value for the string description of the authentication method given in authMethod.

Definition at line 343 of file TorSettings.cpp.

References CookieAuth, NullAuth, PasswordAuth, toString(), and UnknownAuth.

Referenced by apply(), and getAuthenticationMethod().

QString TorSettings::toString ( AuthenticationMethod  method  )  const [private]

Returns the string description of the authentication method specified by method. The authentication method string is stored in Vidalia's configuration file.

Definition at line 329 of file TorSettings.cpp.

References CookieAuth, NullAuth, and PasswordAuth.

Referenced by apply(), getAuthenticationMethod(), getDataDirectory(), getTorrc(), setAuthenticationMethod(), toAuthenticationMethod(), and TorSettings().

bool TorSettings::useRandomPassword (  )  const

Returns true if a new, random control password is to be used each time Tor is started.

Definition at line 228 of file TorSettings.cpp.

References AbstractTorSettings::localValue(), and SETTING_USE_RANDOM_PASSWORD.

Referenced by apply(), AdvancedPage::load(), and MainWindow::start().


The documentation for this class was generated from the following files:
Generated on Mon Aug 30 22:58:57 2010 for Vidalia by  doxygen 1.6.3