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.
tdepim/kmail/quotajobs.cpp

148 lines
5.2 KiB

/**
* quotajobs.cpp
*
* Copyright (c) 2006 Till Adam <adam@kde.org>
*
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; version 2 of the License
*
* 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
* In addition, as a special exception, the copyright holders give
* permission to link the code of this program with any edition of
* the Qt library by Trolltech AS, Norway (or with modified versions
* of Qt that use the same license as Qt), and distribute linked
* combinations including the two. You must obey the GNU General
* Public License in all respects for all of the code used other than
* Qt. If you modify this file, you may extend this exception to
* your version of the file, but you are not obligated to do so. If
* you do not wish to do so, delete this exception statement from
* your version.
*/
#include "quotajobs.h"
#include <kio/scheduler.h>
#include <kdebug.h>
using namespace KMail;
QuotaJobs::GetQuotarootJob* QuotaJobs::getQuotaroot(
KIO::Slave* slave, const KURL& url )
{
TQByteArray packedArgs;
TQDataStream stream( packedArgs, IO_WriteOnly );
stream << (int)'Q' << (int)'R' << url;
GetQuotarootJob* job = new GetQuotarootJob( url, packedArgs, false );
KIO::Scheduler::assignJobToSlave( slave, job );
return job;
}
QuotaJobs::GetQuotarootJob::GetQuotarootJob( const KURL& url,
const TQByteArray &packedArgs,
bool showProgressInfo )
: KIO::SimpleJob( url, KIO::CMD_SPECIAL, packedArgs, showProgressInfo )
{
connect( this, TQT_SIGNAL(infoMessage(KIO::Job*,const TQString&)),
TQT_SLOT(slotInfoMessage(KIO::Job*,const TQString&)) );
}
void QuotaJobs::GetQuotarootJob::slotInfoMessage( KIO::Job*, const TQString& str )
{
// Parse the result
TQStringList results = TQStringList::split("\r", str);
TQStringList roots;
QuotaInfoList quotas;
if ( results.size() > 0 ) {
// the first line is the available roots
roots = TQStringList::split(" ", results.front() );
results.pop_front();
// the rest are pairs of root -> list of triplets
while ( results.size() > 0 ) {
TQString root = results.front(); results.pop_front();
// and the quotas
if ( results.size() > 0 ) {
TQStringList triplets = TQStringList::split(" ", results.front() );
results.pop_front();
while ( triplets.size() > 0 ) {
// there's always three, the label, current and max values
TQString name = triplets.front(); triplets.pop_front();
TQString current = triplets.front(); triplets.pop_front();
TQString max = triplets.front(); triplets.pop_front();
QuotaInfo info( name, root, current, max );
quotas.append( info );
}
}
}
}
if ( !quotas.isEmpty() ) {
emit quotaInfoReceived( quotas );
}
emit quotaRootResult( roots );
}
QuotaJobs::GetStorageQuotaJob* QuotaJobs::getStorageQuota(
KIO::Slave* slave, const KURL& url )
{
GetStorageQuotaJob* job = new GetStorageQuotaJob( slave, url );
return job;
}
QuotaJobs::GetStorageQuotaJob::GetStorageQuotaJob( KIO::Slave* slave, const KURL& url )
: KIO::Job( false )
{
TQByteArray packedArgs;
TQDataStream stream( packedArgs, IO_WriteOnly );
stream << (int)'Q' << (int)'R' << url;
QuotaJobs::GetQuotarootJob *job =
new QuotaJobs::GetQuotarootJob( url, packedArgs, false );
connect(job, TQT_SIGNAL(quotaInfoReceived(const QuotaInfoList&)),
TQT_SLOT(slotQuotaInfoReceived(const QuotaInfoList&)));
connect(job, TQT_SIGNAL(quotaRootResult(const TQStringList&)),
TQT_SLOT(slotQuotarootResult(const TQStringList&)));
KIO::Scheduler::assignJobToSlave( slave, job );
addSubjob( job );
}
void QuotaJobs::GetStorageQuotaJob::slotQuotarootResult( const TQStringList& roots )
{
Q_UNUSED(roots); // we only support one for now
if ( !mStorageQuotaInfo.isValid() && !error() ) {
// No error, so the account supports quota, but no usable info
// was transmitted => no quota set on the folder. Make the info
// valid, bit leave it empty.
mStorageQuotaInfo.setName( "STORAGE" );
}
if ( mStorageQuotaInfo.isValid() )
emit storageQuotaResult( mStorageQuotaInfo );
}
void QuotaJobs::GetStorageQuotaJob::slotQuotaInfoReceived( const QuotaInfoList& infos )
{
QuotaInfoList::ConstIterator it( infos.begin() );
while ( it != infos.end() ) {
// FIXME we only use the first storage quota, for now
if ( it->name() == "STORAGE" && !mStorageQuotaInfo.isValid() ) {
mStorageQuotaInfo = *it;
}
++it;
}
}
QuotaInfo QuotaJobs::GetStorageQuotaJob::storageQuotaInfo() const
{
return mStorageQuotaInfo;
}
#include "quotajobs.moc"