/** * 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"