|
|
|
/**
|
|
|
|
* 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 TQt library by Trolltech AS, Norway (or with modified versions
|
|
|
|
* of TQt that use the same license as TQt), 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
|
|
|
|
* TQt. 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(
|
|
|
|
TDEIO::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 );
|
|
|
|
TDEIO::Scheduler::assignJobToSlave( slave, job );
|
|
|
|
return job;
|
|
|
|
}
|
|
|
|
|
|
|
|
QuotaJobs::GetQuotarootJob::GetQuotarootJob( const KURL& url,
|
|
|
|
const TQByteArray &packedArgs,
|
|
|
|
bool showProgressInfo )
|
|
|
|
: TDEIO::SimpleJob( url, TDEIO::CMD_SPECIAL, packedArgs, showProgressInfo )
|
|
|
|
{
|
|
|
|
connect( this, TQT_SIGNAL(infoMessage(TDEIO::Job*,const TQString&)),
|
|
|
|
TQT_SLOT(slotInfoMessage(TDEIO::Job*,const TQString&)) );
|
|
|
|
}
|
|
|
|
|
|
|
|
void QuotaJobs::GetQuotarootJob::slotInfoMessage( TDEIO::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(
|
|
|
|
TDEIO::Slave* slave, const KURL& url )
|
|
|
|
{
|
|
|
|
GetStorageQuotaJob* job = new GetStorageQuotaJob( slave, url );
|
|
|
|
return job;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
QuotaJobs::GetStorageQuotaJob::GetStorageQuotaJob( TDEIO::Slave* slave, const KURL& url )
|
|
|
|
: TDEIO::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&)));
|
|
|
|
TDEIO::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"
|