summaryrefslogtreecommitdiff
path: root/include/modules/away.h
blob: e70b598cf51a4dd86f1e52895e8b2748d58e608d (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
/*
 * InspIRCd -- Internet Relay Chat Daemon
 *
 *   Copyright (C) 2018 Sadie Powell <sadie@witchery.services>
 *
 * This file is part of InspIRCd.  InspIRCd 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 <http://www.gnu.org/licenses/>.
 */


#pragma once

#include "event.h"

namespace Away
{
	class EventListener;
	class EventProvider;
}

class Away::EventListener
	: public Events::ModuleEventListener
{
 protected:
	EventListener(Module* mod)
		: ModuleEventListener(mod, "event/away")
	{
	}

 public:
	/** Called when a user wishes to mark themselves as away.
	 * @param user The user who is going away.
	 * @param message The away message that the user set.
	 * @return Either MOD_RES_ALLOW to allow the user to mark themself as away, MOD_RES_DENY to
	 *         disallow the user to mark themself as away, or MOD_RES_PASSTHRU to let another module
	 *         handle the event.
	 */
	virtual ModResult OnUserPreAway(LocalUser* user, std::string& message)
	{
		return MOD_RES_PASSTHRU;
	}

	/** Called when a user wishes to mark themselves as back.
	 * @param user The user who is going away.
	 * @param message The away message that the user set.
	 * @return Either MOD_RES_ALLOW to allow the user to mark themself as back, MOD_RES_DENY to
	 *         disallow the user to mark themself as back, or MOD_RES_PASSTHRU to let another module
	 *         handle the event.
	 */
	virtual ModResult OnUserPreBack(LocalUser* user)
	{
		return MOD_RES_PASSTHRU;
	}

	/** Called when a user has marked themself as away.
	 * @param user The user who has gone away.
	 */
	virtual void OnUserAway(User* user) = 0;

	/** Called when a user has returned from being away.
	 * @param user The user who has returned from being away.
	 */
	virtual void OnUserBack(User* user) = 0;
};

class Away::EventProvider
	: public Events::ModuleEventProvider
{
 public:
	EventProvider(Module* mod)
		: ModuleEventProvider(mod, "event/away")
	{
	}
};