1/*
2 Copyright (c) 2009 Andras Mantia <amantia@kde.org>
3
4 This library is free software; you can redistribute it and/or modify it
5 under the terms of the GNU Library General Public License as published by
6 the Free Software Foundation; either version 2 of the License, or (at your
7 option) any later version.
8
9 This library is distributed in the hope that it will be useful, but WITHOUT
10 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
12 License for more details.
13
14 You should have received a copy of the GNU Library General Public License
15 along with this library; see the file COPYING.LIB. If not, write to the
16 Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
17 02110-1301, USA.
18*/
19
20#include "quotajobbase.h"
21#include "quotajobbase_p.h"
22#include "message_p.h"
23#include "session_p.h"
24
25#include <KDE/KLocalizedString>
26#include <KDE/KDebug>
27
28using namespace KIMAP;
29
30QMap<QByteArray, QPair<qint64, qint64> > QuotaJobBasePrivate::readQuota( const Message::Part &content )
31{
32 QMap<QByteArray, QPair<qint64, qint64> > quotaMap;
33 QList<QByteArray> quotas = content.toList();
34
35 int i = 0;
36 while ( i < quotas.size() - 2 ) {
37 QByteArray resource = quotas[i].toUpper();
38 qint64 usage = quotas[i+1].toInt();
39 qint64 limit = quotas[i+2].toInt();
40 quotaMap[resource] = qMakePair( usage, limit );
41 i += 3;
42 }
43
44 return quotaMap;
45}
46
47QuotaJobBase::QuotaJobBase( Session *session )
48 : Job( *new QuotaJobBasePrivate( session, i18n( "QuotaJobBase" ) ) )
49{
50}
51
52QuotaJobBase::QuotaJobBase( JobPrivate &dd )
53 : Job( dd )
54{
55}
56
57QuotaJobBase::~QuotaJobBase()
58{
59}
60
61qint64 QuotaJobBase::usage(const QByteArray& resource)
62{
63 Q_D( QuotaJobBase );
64
65 QByteArray r = resource.toUpper();
66
67 if ( d->quota.contains( r ) ) {
68 return d->quota[r].first;
69 }
70 return -1;
71}
72
73qint64 QuotaJobBase::limit(const QByteArray& resource)
74{
75 Q_D( QuotaJobBase );
76
77 QByteArray r = resource.toUpper();
78
79 if ( d->quota.contains( r ) ) {
80 return d->quota[r].second;
81 }
82 return -1;
83}
84