summaryrefslogtreecommitdiffstats
path: root/libmail/smapstatus.C
blob: f441a03d0b36549d7d9e1827fda916783d8cd129 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
/*
** Copyright 2003, Double Precision Inc.
**
** See COPYING for distribution information.
*/
#include "smap.H"
#include "smapstatus.H"
#include <sstream>

using namespace std;

////////////////////////////////////////////////////////////////////////
//
// STATUS

const char *mail::smapSTATUS::getName()
{
	return "STATUS";
}

mail::smapSTATUS::smapSTATUS(string pathArg,
			     mail::callback::folderInfo &infoCallbackArg,
			     mail::callback &callbackArg)
	: path(pathArg), infoCallback(infoCallbackArg)
{
	defaultCB= &callbackArg;
}

mail::smapSTATUS::~smapSTATUS()
{
}

void mail::smapSTATUS::installed(imap &imapAccount)
{
	vector<string> words;

	path2words(path, words);

	vector<string>::iterator b=words.begin(), e=words.end();

	string pstr="";

	while (b != e)
	{
		pstr += " ";
		pstr += imapAccount.quoteSMAP( *b );
		b++;
	}


	imapAccount.imapcmd("", (infoCallback.fastInfo
				 ? "STATUS CHEAP":"STATUS FULL")
			    + pstr + "\n");
}

bool mail::smapSTATUS::processLine(imap &imapAccount,
				 vector<const char *> &words)
{
	if (words.size() >= 2 && strcmp(words[0], "*") == 0 &&
	    strcasecmp(words[1], "STATUS") == 0)
	{
		vector<const char *>::iterator b=words.begin() + 2;

		while (b != words.end())
		{
			const char *c= *b++;

			if (strncasecmp(c, "EXISTS=", 7) == 0)
			{
				string s=c+7;
				istringstream i(s);

				i >> infoCallback.messageCount;
			}
			else if (strncasecmp(c, "UNSEEN=", 7) == 0)
			{
				string s=c+7;
				istringstream i(s);

				i >> infoCallback.unreadCount;
			}
		}
		return true;
	}
	return smapHandler::processLine(imapAccount, words);
}