summaryrefslogtreecommitdiff
path: root/src/core/ms_check.c
blob: b2968c3d53f92cb3e42716feca6bb7822689b130 (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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/* MemoServ core functions
 *
 * (C) 2003-2010 Anope Team
 * Contact us at team@anope.org
 *
 * Please read COPYING and README for further details.
 *
 * Based on the original code of Epona by Lara.
 * Based on the original code of Services by Andy Church.
 *
 * $Id$
 *
 */
/*************************************************************************/

#include "module.h"

class CommandMSCheck : public Command
{
 public:
	CommandMSCheck() : Command("CHECK", 1, 1)
	{
	}

	CommandReturn Execute(User *u, const std::vector<ci::string> &params)
	{
		NickAlias *na = NULL;
		MemoInfo *mi = NULL;
		int i, found = 0;
		const char *recipient = params[0].c_str();
		struct tm *tm;
		char timebuf[64];

		if (!u->IsRecognized())
		{
			notice_lang(Config.s_MemoServ, u, NICK_IDENTIFY_REQUIRED, Config.s_NickServ);
			return MOD_CONT;
		}
		else if (!(na = findnick(recipient)))
		{
			notice_lang(Config.s_MemoServ, u, NICK_X_NOT_REGISTERED, recipient);
			return MOD_CONT;
		}

		if ((na->HasFlag(NS_FORBIDDEN)))
		{
			notice_lang(Config.s_MemoServ, u, NICK_X_FORBIDDEN, recipient);
			return MOD_CONT;
		}

		mi = &na->nc->memos;

		/* Okay, I know this looks strange but we wanna get the LAST memo, so we
			have to loop backwards */

		for (i = mi->memos.size() - 1; i >= 0; --i)
		{
			if (!stricmp(mi->memos[i]->sender.c_str(), u->Account()->display))
			{
				found = 1; /* Yes, we've found the memo */

				tm = localtime(&mi->memos[i]->time);
				strftime_lang(timebuf, sizeof(timebuf), u, STRFTIME_DATE_TIME_FORMAT, tm);

				if (mi->memos[i]->HasFlag(MF_UNREAD))
					notice_lang(Config.s_MemoServ, u, MEMO_CHECK_NOT_READ, na->nick, timebuf);
				else
					notice_lang(Config.s_MemoServ, u, MEMO_CHECK_READ, na->nick, timebuf);
				break;
			}
		}

		if (!found)
			notice_lang(Config.s_MemoServ, u, MEMO_CHECK_NO_MEMO, na->nick);

		return MOD_CONT;
	}

	bool OnHelp(User *u, const ci::string &subcommand)
	{
		notice_help(Config.s_MemoServ, u, MEMO_HELP_CHECK);
		return true;
	}

	void OnSyntaxError(User *u, const ci::string &subcommand)
	{
		syntax_error(Config.s_MemoServ, u, "CHECK", MEMO_CHECK_SYNTAX);
	}
};

class MSCheck : public Module
{
 public:
	MSCheck(const std::string &modname, const std::string &creator) : Module(modname, creator)
	{
		this->SetAuthor("Anope");
		this->SetVersion("$Id$");
		this->SetType(CORE);
		this->AddCommand(MEMOSERV, new CommandMSCheck());

		ModuleManager::Attach(I_OnMemoServHelp, this);
	}
	void OnMemoServHelp(User *u)
	{
		notice_lang(Config.s_MemoServ, u, MEMO_HELP_CMD_CHECK);
	}
};

MODULE_INIT(MSCheck)