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
110
111
112
113
|
/*
* Anope IRC Services
*
* Copyright (C) 2003-2017 Anope Team <team@anope.org>
*
* This file is part of Anope. Anope 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.
*
* 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, see see <http://www.gnu.org/licenses/>.
*/
#include "module.h"
#include "modules/memoserv.h"
class CommandMSCancel : public Command
{
public:
CommandMSCancel(Module *creator) : Command(creator, "memoserv/cancel", 1, 1)
{
this->SetDesc(_("Cancel the last memo you sent"));
this->SetSyntax(_("{\037user\037 | \037channel\037}"));
}
void Execute(CommandSource &source, const std::vector<Anope::string> ¶ms) override
{
if (Anope::ReadOnly)
{
source.Reply(_("Services are in read-only mode."));
return;
}
const Anope::string &nname = params[0];
bool ischan, isregistered;
MemoServ::MemoInfo *mi = MemoServ::service->GetMemoInfo(nname, ischan, isregistered, false);
if (!isregistered)
{
if (ischan)
source.Reply(_("Channel \002{0}\002 isn't registered."), nname);
else
source.Reply(_("\002{0}\002 isn't registered."), nname);
return;
}
if (mi == nullptr)
return;
ChanServ::Channel *ci = NULL;
NickServ::Nick *na = NULL;
if (ischan)
{
ci = ChanServ::Find(nname);
if (ci == nullptr)
return;
}
else
{
na = NickServ::FindNick(nname);
if (na == nullptr)
return;
}
auto memos = mi->GetMemos();
for (int i = memos.size() - 1; i >= 0; --i)
{
MemoServ::Memo *m = memos[i];
if (!m->GetUnread())
continue;
NickServ::Nick *sender = NickServ::FindNick(m->GetSender());
if (sender && sender->GetAccount() == source.GetAccount())
{
EventManager::Get()->Dispatch(&MemoServ::Event::MemoDel::OnMemoDel, ischan ? ci->GetName() : na->GetAccount()->GetDisplay(), mi, m);
mi->Del(i);
source.Reply(_("Your last memo to \002{0}\002 has been cancelled."), ischan ? ci->GetName() : na->GetAccount()->GetDisplay());
return;
}
}
source.Reply(_("No memo was cancelable."));
}
bool OnHelp(CommandSource &source, const Anope::string &subcommand) override
{
source.Reply(_("Cancels the last memo you sent to \037user\037, provided it has not yet been read."));
return true;
}
};
class MSCancel : public Module
{
CommandMSCancel commandmscancel;
public:
MSCancel(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator, VENDOR)
, commandmscancel(this)
{
}
};
MODULE_INIT(MSCancel)
|