You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdebase/kcontrol/tdeio/kmanualproxydlg.cpp

498 lines
15 KiB

/*
kmanualproxydlg.cpp - Proxy configuration dialog
Copyright (C) 2001-2004 Dawit Alemayehu <adawit@kde.org>
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public
License (GPL) version 2 as published by the Free Software
Foundation.
This library 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
Library General Public License for more details.
You should have received a copy of the GNU General Public License
along with this library; see the file COPYING.LIB. If not, write to
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA.
*/
#include <tqlabel.h>
#include <tqlayout.h>
#include <tqspinbox.h>
#include <tqcheckbox.h>
#include <tqwhatsthis.h>
#include <tqpushbutton.h>
#include <kdebug.h>
#include <tdelocale.h>
#include <knuminput.h>
#include <tdelistbox.h>
#include <klineedit.h>
#include <kicontheme.h>
#include <kurifilter.h>
#include <tdemessagebox.h>
#include <kiconloader.h>
#include <kinputdialog.h>
#include <tdeio/ioslave_defaults.h>
#include "manualproxy_ui.h"
#include "kmanualproxydlg.h"
KManualProxyDlg::KManualProxyDlg( TQWidget* parent, const char* name )
:KProxyDialogBase( parent, name, true,
i18n("Manual Proxy Configuration") )
{
mDlg = new ManualProxyDlgUI (this);
setMainWidget( mDlg );
mDlg->pbCopyDown->setPixmap( BarIcon("down", TDEIcon::SizeSmall) );
TQSizePolicy sizePolicy( TQSizePolicy::Fixed, TQSizePolicy::Fixed,
mDlg->pbCopyDown->sizePolicy().hasHeightForWidth() );
mDlg->pbCopyDown->setSizePolicy( sizePolicy );
init();
}
void KManualProxyDlg::init()
{
mDlg->sbHttp->setRange( 0, MAX_PORT_VALUE );
mDlg->sbHttps->setRange( 0, MAX_PORT_VALUE );
mDlg->sbFtp->setRange( 0, MAX_PORT_VALUE );
connect( mDlg->pbNew, TQT_SIGNAL( clicked() ), TQT_SLOT( newPressed() ) );
connect( mDlg->pbChange, TQT_SIGNAL( clicked() ), TQT_SLOT( changePressed() ) );
connect( mDlg->pbDelete, TQT_SIGNAL( clicked() ), TQT_SLOT( deletePressed() ) );
connect( mDlg->pbDeleteAll, TQT_SIGNAL( clicked() ), TQT_SLOT( deleteAllPressed() ) );
connect( mDlg->lbExceptions, TQT_SIGNAL(selectionChanged()), TQT_SLOT(updateButtons()) );
connect( mDlg->lbExceptions, TQT_SIGNAL(doubleClicked (TQListBoxItem *)), TQT_SLOT(changePressed()));
connect( mDlg->cbSameProxy, TQT_SIGNAL( toggled(bool) ), TQT_SLOT( sameProxy(bool) ) );
connect( mDlg->pbCopyDown, TQT_SIGNAL( clicked() ), TQT_SLOT( copyDown() ) );
connect( mDlg->leHttp, TQT_SIGNAL(textChanged(const TQString&)), TQT_SLOT(textChanged(const TQString&)) );
connect( mDlg->sbHttp, TQT_SIGNAL(valueChanged(int)), TQT_SLOT(valueChanged (int)) );
}
void KManualProxyDlg::setProxyData( const KProxyData &data )
{
KURL url;
// Set the HTTP proxy...
if (!isValidURL(data.proxyList["http"], &url))
mDlg->sbHttp->setValue( DEFAULT_PROXY_PORT );
else
{
int port = url.port();
if ( port <= 0 )
port = DEFAULT_PROXY_PORT;
url.setPort( 0 );
mDlg->leHttp->setText( url.url() );
mDlg->sbHttp->setValue( port );
}
bool useSameProxy = (!mDlg->leHttp->text().isEmpty () &&
data.proxyList["http"] == data.proxyList["https"] &&
data.proxyList["http"] == data.proxyList["ftp"]);
mDlg->cbSameProxy->setChecked ( useSameProxy );
if ( useSameProxy )
{
mDlg->leHttps->setText ( mDlg->leHttp->text() );
mDlg->leFtp->setText ( mDlg->leHttp->text() );
mDlg->sbHttps->setValue( mDlg->sbHttp->value() );
mDlg->sbFtp->setValue( mDlg->sbHttp->value() );
sameProxy ( true );
}
else
{
// Set the HTTPS proxy...
if( !isValidURL( data.proxyList["https"], &url ) )
mDlg->sbHttps->setValue( DEFAULT_PROXY_PORT );
else
{
int port = url.port();
if ( port <= 0 )
port = DEFAULT_PROXY_PORT;
url.setPort( 0 );
mDlg->leHttps->setText( url.url() );
mDlg->sbHttps->setValue( port );
}
// Set the FTP proxy...
if( !isValidURL( data.proxyList["ftp"], &url ) )
mDlg->sbFtp->setValue( DEFAULT_PROXY_PORT );
else
{
int port = url.port();
if ( port <= 0 )
port = DEFAULT_PROXY_PORT;
url.setPort( 0 );
mDlg->leFtp->setText( url.url() );
mDlg->sbFtp->setValue( port );
}
}
TQStringList::ConstIterator it = data.noProxyFor.begin();
for( ; it != data.noProxyFor.end(); ++it )
{
// "no_proxy" is a keyword used by the environment variable
// based configuration. We ignore it here as it is not applicable...
if ((*it).lower() != "no_proxy" && !(*it).isEmpty())
{
// Validate the NOPROXYFOR entries and use only hostnames if the entry is
// a valid or legitimate URL. NOTE: needed to catch manual manipulation
// of the proxy config files...
if( isValidURL( *it ) || ((*it).length() >= 3 && (*it).startsWith(".")) )
mDlg->lbExceptions->insertItem( *it );
}
}
mDlg->cbReverseProxy->setChecked( data.useReverseProxy );
}
const KProxyData KManualProxyDlg::data() const
{
KProxyData data;
if (!m_bHasValidData)
return data;
data.proxyList["http"] = urlFromInput( mDlg->leHttp, mDlg->sbHttp );
if ( mDlg->cbSameProxy->isChecked () )
{
data.proxyList["https"] = data.proxyList["http"];
data.proxyList["ftp"] = data.proxyList["http"];
}
else
{
data.proxyList["https"] = urlFromInput( mDlg->leHttps, mDlg->sbHttps );
data.proxyList["ftp"] = urlFromInput( mDlg->leFtp, mDlg->sbFtp );
}
if ( mDlg->lbExceptions->count() )
{
TQListBoxItem* item = mDlg->lbExceptions->firstItem();
for( ; item != 0L; item = item->next() )
data.noProxyFor << item->text();
}
data.type = KProtocolManager::ManualProxy;
data.useReverseProxy = mDlg->cbReverseProxy->isChecked();
return data;
}
void KManualProxyDlg::sameProxy( bool enable )
{
mDlg->leHttps->setEnabled (!enable );
mDlg->leFtp->setEnabled (!enable );
mDlg->sbHttps->setEnabled (!enable );
mDlg->sbFtp->setEnabled (!enable );
mDlg->pbCopyDown->setEnabled( !enable );
if (enable)
{
mOldFtpText = mDlg->leFtp->text();
mOldHttpsText = mDlg->leHttps->text();
mOldFtpPort = mDlg->sbFtp->value();
mOldHttpsPort = mDlg->sbHttps->value();
int port = mDlg->sbHttp->value();
TQString text = mDlg->leHttp->text();
mDlg->leFtp->setText (text);
mDlg->leHttps->setText (text);
mDlg->sbFtp->setValue (port);
mDlg->sbHttps->setValue (port);
if (mDlg->lbHttps->font().bold())
setHighLight( mDlg->lbHttps, false );
if (mDlg->lbFtp->font().bold())
setHighLight( mDlg->lbFtp, false );
}
else
{
mDlg->leFtp->setText (mOldFtpText);
mDlg->leHttps->setText (mOldHttpsText);
mDlg->sbFtp->setValue (mOldFtpPort);
mDlg->sbHttps->setValue (mOldHttpsPort);
}
}
bool KManualProxyDlg::validate()
{
KURL filteredURL;
unsigned short count = 0;
if ( isValidURL( mDlg->leHttp->text(), &filteredURL ) )
{
mDlg->leHttp->setText( filteredURL.url() );
count++;
}
else
setHighLight( mDlg->lbHttp, true );
if ( !mDlg->cbSameProxy->isChecked () )
{
if ( isValidURL( mDlg->leHttps->text(), &filteredURL ) )
{
mDlg->leHttps->setText( filteredURL.url() );
count++;
}
else
setHighLight( mDlg->lbHttps, true );
if ( isValidURL( mDlg->leFtp->text(), &filteredURL ) )
{
mDlg->leFtp->setText( filteredURL.url() );
count++;
}
else
setHighLight( mDlg->lbFtp, true );
}
if ( count == 0 )
{
showErrorMsg( i18n("Invalid Proxy Setting"),
i18n("One or more of the specified proxy settings are "
"invalid. The incorrect entries are highlighted.") );
}
return (count > 0);
}
void KManualProxyDlg::textChanged(const TQString& text)
{
if (!mDlg->cbSameProxy->isChecked())
return;
mDlg->leFtp->setText( text );
mDlg->leHttps->setText( text );
}
void KManualProxyDlg::valueChanged(int value)
{
if (!mDlg->cbSameProxy->isChecked())
return;
mDlg->sbFtp->setValue (value);
mDlg->sbHttps->setValue (value);
}
void KManualProxyDlg::copyDown()
{
int action = -1;
if ( !mDlg->leHttp->text().isEmpty() )
action += 4;
else if ( !mDlg->leHttps->text().isEmpty() )
action += 3;
switch ( action )
{
case 3:
mDlg->leHttps->setText( mDlg->leHttp->text() );
mDlg->sbHttps->setValue( mDlg->sbHttp->value() );
mDlg->leFtp->setText( mDlg->leHttp->text() );
mDlg->sbFtp->setValue( mDlg->sbHttp->value() );
break;
case 2:
mDlg->leFtp->setText( mDlg->leHttps->text() );
mDlg->sbFtp->setValue( mDlg->sbHttps->value() );
break;
case 1:
case 0:
default:
break;
}
}
void KManualProxyDlg::slotOk()
{
//tqDebug("m_bHasValidData: %s" , m_bHasValidData ? "true" : "false");
if ( m_bHasValidData || validate() )
{
KDialogBase::slotOk();
m_bHasValidData = true;
}
}
bool KManualProxyDlg::handleDuplicate( const TQString& site )
{
TQListBoxItem* item = mDlg->lbExceptions->firstItem();
while ( item != 0 )
{
if ( item->text().findRev( site ) != -1 &&
item != mDlg->lbExceptions->selectedItem() )
{
TQString msg = i18n("You entered a duplicate address. "
"Please try again.");
TQString details = i18n("<qt><center><b>%1</b></center> "
"is already in the list.</qt>").arg(site);
KMessageBox::detailedError( this, msg, details, i18n("Duplicate Entry") );
return true;
}
item = item->next();
}
return false;
}
void KManualProxyDlg::newPressed()
{
TQString result;
if( getException(result, i18n("New Exception")) && !handleDuplicate(result) )
mDlg->lbExceptions->insertItem( result );
}
void KManualProxyDlg::changePressed()
{
TQString result;
if( getException( result, i18n("Change Exception"),
mDlg->lbExceptions->currentText() ) &&
!handleDuplicate( result ) )
mDlg->lbExceptions->changeItem( result, mDlg->lbExceptions->currentItem() );
}
void KManualProxyDlg::deletePressed()
{
mDlg->lbExceptions->removeItem( mDlg->lbExceptions->currentItem() );
mDlg->lbExceptions->setSelected( mDlg->lbExceptions->currentItem(), true );
updateButtons();
}
void KManualProxyDlg::deleteAllPressed()
{
mDlg->lbExceptions->clear();
updateButtons();
}
void KManualProxyDlg::updateButtons()
{
bool hasItems = mDlg->lbExceptions->count() > 0;
bool itemSelected = (hasItems && mDlg->lbExceptions->selectedItem()!=0);
mDlg->pbDeleteAll->setEnabled( hasItems );
mDlg->pbDelete->setEnabled( itemSelected );
mDlg->pbChange->setEnabled( itemSelected );
}
TQString KManualProxyDlg::urlFromInput(const KLineEdit* edit,
const TQSpinBox* spin) const
{
if (!edit)
return TQString::null;
KURL u( edit->text() );
if (spin)
u.setPort( spin->value() );
return u.url();
}
bool KManualProxyDlg::isValidURL( const TQString& _url, KURL* result ) const
{
KURL url (_url);
TQStringList filters;
filters << "tdeshorturifilter" << "localdomainurifilter";
// If the typed URL is malformed, and the filters cannot filter it
// then it must be an invalid entry.
if( !(url.isValid() || KURIFilter::self()->filterURI(url, filters)) &&
!url.hasHost() )
return false;
TQString host (url.host());
// We only check for a relevant subset of characters that are
// not allowed in <authority> component of a URL.
if ( host.contains ('*') || host.contains (' ') || host.contains ('?') )
return false;
if ( result )
*result = url;
return true;
}
void KManualProxyDlg::showErrorMsg( const TQString& caption,
const TQString& message )
{
TQString cap( caption );
TQString msg( message );
if ( cap.isNull() )
cap = i18n("Invalid Entry");
if ( msg.isNull() )
msg = i18n("The address you have entered is not valid.");
TQString details = i18n("<qt>Make sure none of the addresses or URLs you "
"specified contain invalid or wildcard characters "
"such as spaces, asterisks (*), or question marks(?).<p>"
"<u>Examples of VALID entries:</u><br/>"
"<code>http://mycompany.com, 192.168.10.1, "
"mycompany.com, localhost, http://localhost</code><p>"
"<u>Examples of INVALID entries:</u><br/>"
"<code>http://my company.com, http:/mycompany,com "
"file:/localhost</code></qt>");
KMessageBox::detailedError( this, msg, details, cap );
}
bool KManualProxyDlg::getException ( TQString& result,
const TQString& caption,
const TQString& value )
{
TQString label;
// Specify the appropriate message...
if ( mDlg->cbReverseProxy->isChecked() )
label = i18n("Enter the URL or address that should use the above proxy "
"settings:");
else
label = i18n("Enter the address or URL that should be excluded from "
"using the above proxy settings:");
TQString whatsThis = i18n("<qt>Enter a valid address or url.<p>"
"<b><u>NOTE:</u></b> Wildcard matching such as "
"<code>*.kde.org</code> is not supported. If you want "
"to match any host in the <code>.kde.org</code> domain, "
"then simply enter <code>.kde.org</code></qt>");
bool ok;
result = KInputDialog::text( caption, label, value, &ok, 0, 0, 0,
TQString::null, whatsThis );
// If the user pressed cancel, do nothing...
if (!ok)
return false;
// If the typed URL is malformed, and the filters cannot filter it
// then it must be an invalid entry,
if( isValidURL(result) || (result.length() >= 3 && result.startsWith(".")))
return true;
showErrorMsg();
return false;
}
#include "kmanualproxydlg.moc"