ZNC trunk
Loading...
Searching...
No Matches
znc.h
Go to the documentation of this file.
1/*
2 * Copyright (C) 2004-2025 ZNC, see the NOTICE file for details.
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef ZNC_H
18#define ZNC_H
19
20#include <znc/zncconfig.h>
21#include <znc/Client.h>
22#include <znc/Modules.h>
23#include <znc/Socket.h>
24#include <znc/Listener.h>
25#include <znc/Translation.h>
26#include <mutex>
27#include <map>
28#include <list>
29
30class CListener;
31class CUser;
32class CIRCNetwork;
33class CConnectQueueTimer;
34class CConfigWriteTimer;
35class CConfig;
36class CFile;
37
38class CZNC : private CCoreTranslationMixin {
39 public:
42
43 CZNC(const CZNC&) = delete;
44 CZNC& operator=(const CZNC&) = delete;
45
54
56 void Loop();
57 bool WritePidFile(int iPid);
60 bool IsHostAllowed(const CString& sHostMask) const;
61 // This returns false if there are too many anonymous connections from this
62 // ip
63 bool AllowConnectionFrom(const CString& sIP) const;
64 void InitDirs(const CString& sArgvPath, const CString& sDataDir);
65 bool OnBoot();
66 CString ExpandConfigPath(const CString& sConfigFile,
67 bool bAllowMkDir = true);
68 bool WriteNewConfig(const CString& sConfigFile);
70 bool ParseConfig(const CString& sConfig, CString& sError);
71 bool RehashConfig(CString& sError);
72 void BackupConfigOnce(const CString& sSuffix);
74 static CString GetTag(bool bIncludeVersion = true, bool bHTML = false);
80 bool AddBindHost(const CString& sHost) { return false; }
82 bool RemBindHost(const CString& sHost) { return false; }
84 bool AddTrustedProxy(const CString& sHost);
85 bool RemTrustedProxy(const CString& sHost);
88 void Broadcast(const CString& sMessage, bool bAdminOnly = false,
89 CUser* pSkipUser = nullptr, CClient* pSkipClient = nullptr);
90 void AddBytesRead(unsigned long long u) { m_uBytesRead += u; }
91 void AddBytesWritten(unsigned long long u) { m_uBytesWritten += u; }
92 unsigned long long BytesRead() const { return m_uBytesRead; }
93 unsigned long long BytesWritten() const { return m_uBytesWritten; }
94
95 // Traffic fun
96 typedef std::pair<unsigned long long, unsigned long long> TrafficStatsPair;
97 typedef std::map<CString, TrafficStatsPair> TrafficStatsMap;
98 // Returns a map which maps user names to <traffic in, traffic out>
99 // while also providing the traffic of all users together, traffic which
100 // couldn't be accounted to any particular user and the total traffic
101 // generated through ZNC.
103 TrafficStatsPair& ZNC,
104 TrafficStatsPair& Total);
106 TrafficStatsPair& Total);
107
108 // Authenticate a user.
109 // The result is passed back via callbacks to CAuthBase.
110 void AuthUser(std::shared_ptr<CAuthBase> AuthClass);
111
112 // Setters
114 std::lock_guard<std::mutex> guard(m_mutexConfigState);
115 m_eConfigState = e;
116 }
117 void SetSkinName(const CString& s) { m_sSkinName = s; }
118 void SetStatusPrefix(const CString& s) {
119 m_sStatusPrefix = (s.empty()) ? "*" : s;
120 }
121 void SetMaxBufferSize(unsigned int i) { m_uiMaxBufferSize = i; }
122 void SetAnonIPLimit(unsigned int i) { m_uiAnonIPLimit = i; }
123 void SetServerThrottle(unsigned int i) {
124 m_sConnectThrottle.SetTTL(i * 1000);
125 }
127 void SetHideVersion(bool b) { m_bHideVersion = b; }
129 void SetConnectDelay(unsigned int i);
130 void SetSSLCiphers(const CString& sCiphers) { m_sSSLCiphers = sCiphers; }
131 bool SetSSLProtocols(const CString& sProtocols);
132 void SetSSLCertFile(const CString& sFile) { m_sSSLCertFile = sFile; }
133 void SetConfigWriteDelay(unsigned int i) { m_uiConfigWriteDelay = i; }
134 // !Setters
135
136 // Getters
138 std::lock_guard<std::mutex> guard(m_mutexConfigState);
139 return m_eConfigState;
140 }
142 const CSockManager& GetManager() const { return m_Manager; }
144 CString GetSkinName() const { return m_sSkinName; }
145 const CString& GetStatusPrefix() const { return m_sStatusPrefix; }
146 const CString& GetCurPath() const;
147 const CString& GetHomePath() const;
148 const CString& GetZNCPath() const;
149 CString GetConfPath(bool bAllowMkDir = true) const;
155 const CString& GetConfigFile() const { return m_sConfigFile; }
158 const VCString& GetBindHosts() const { return m_vsBindHosts; }
160 const std::vector<CListener*>& GetListeners() const {
161 return m_vpListeners;
162 }
163 time_t TimeStarted() const { return m_TimeStarted; }
164 unsigned int GetMaxBufferSize() const { return m_uiMaxBufferSize; }
165 unsigned int GetAnonIPLimit() const { return m_uiAnonIPLimit; }
166 unsigned int GetServerThrottle() const {
167 return m_sConnectThrottle.GetTTL() / 1000;
168 }
169 unsigned int GetConnectDelay() const { return m_uiConnectDelay; }
171 bool GetHideVersion() const { return m_bHideVersion; }
180 unsigned int GetConfigWriteDelay() const { return m_uiConfigWriteDelay; }
181 // !Getters
182
183 // Static allocator
184 static void CreateInstance();
185 static CZNC& Get();
186 static void DestroyInstance();
187 CUser* FindUser(const CString& sUsername);
188 CModule* FindModule(const CString& sModName, const CString& sUsername);
189 CModule* FindModule(const CString& sModName, CUser* pUser);
190
198 bool UpdateModule(const CString& sModule);
199
200 bool DeleteUser(const CString& sUsername);
201 bool AddUser(CUser* pUser, CString& sErrorRet, bool bStartup = false);
202 const std::map<CString, CUser*>& GetUserMap() const { return (m_msUsers); }
203
204 // Listener yummy
205 CListener* FindListener(u_short uPort, const CString& BindHost,
206 EAddrType eAddr);
209 bool AddTCPListener(unsigned short uPort, const CString& sBindHost,
210 const CString& sURIPrefix, bool bSSL, EAddrType eAddr,
211 CListener::EAcceptType eAccept, CString& sError);
212 bool AddUnixListener(const CString& sPath, const CString& sURIPrefix, bool bSSL,
213 CListener::EAcceptType eAccept, CString& sError);
215
216 // For backwards-compatibility TODO: Remove
218 bool AddListener(unsigned short uPort, const CString& sBindHost,
219 const CString& sURIPrefix, bool bSSL, EAddrType eAddr,
220 CListener::EAcceptType eAccept, CString& sError) {
221 return AddTCPListener(uPort, sBindHost, sURIPrefix, bSSL, eAddr, eAccept, sError);
222 }
223
224 // Message of the Day
225 void SetMotd(const CString& sMessage) {
226 ClearMotd();
227 AddMotd(sMessage);
228 }
229 void AddMotd(const CString& sMessage) {
230 if (!sMessage.empty()) {
231 m_vsMotd.push_back(sMessage);
232 }
233 }
234 void ClearMotd() { m_vsMotd.clear(); }
235 const VCString& GetMotd() const { return m_vsMotd; }
236 // !MOTD
237
239 m_sConnectThrottle.AddItem(sName, true);
240 }
242 bool* b = m_sConnectThrottle.GetItem(sName);
243 return (b && *b);
244 }
245
247 std::list<CIRCNetwork*>& GetConnectionQueue() { return m_lpConnectQueue; }
248
249 // This creates a CConnectQueueTimer if we haven't got one yet
252
255
258 bool IsForcingEncoding() const;
259 CString FixupEncoding(const CString& sEncoding) const;
260
261 // Never call this unless you are CConnectQueueTimer::~CConnectQueueTimer()
262 void LeakConnectQueueTimer(CConnectQueueTimer* pTimer);
263
265
266 static void DumpConfig(const CConfig* Config);
267
268 private:
269 static CString FormatBindError();
270
271 CFile* InitPidFile();
272
273 bool ReadConfig(CConfig& config, CString& sError);
274 bool LoadGlobal(CConfig& config, CString& sError);
275 bool LoadUsers(CConfig& config, CString& sError);
276 bool LoadListeners(CConfig& config, CString& sError);
277 void UnloadRemovedModules(const MCString& msModules);
278
279 bool HandleUserDeletion();
280 CString MakeConfigHeader();
281 bool AddListener(const CString& sLine, CString& sError);
282 bool AddListener(CConfig* pConfig, CString& sError);
283 bool CheckSslAndPemFile(bool bSSL, CString& sError);
284 bool FinishAddingListener(CListener* pListener, CString& sError);
285
286 protected:
288
291
292 std::vector<CListener*> m_vpListeners;
293 std::map<CString, CUser*> m_msUsers;
294 std::map<CString, CUser*> m_msDelUsers;
296
299
309 VCString m_vsBindHosts; // TODO: remove (deprecated in 1.7.0)
315 unsigned int m_uiConnectDelay;
316 unsigned int m_uiAnonIPLimit;
317 unsigned int m_uiMaxBufferSize;
320 unsigned long long m_uBytesRead;
321 unsigned long long m_uBytesWritten;
322 std::list<CIRCNetwork*> m_lpConnectQueue;
323 CConnectQueueTimer* m_pConnectQueueTimer;
324 unsigned int m_uiConnectPaused;
325 unsigned int m_uiForceEncoding;
332 CConfigWriteTimer* m_pConfigTimer;
333};
334
335#endif // !ZNC_H
EAddrType
Definition Socket.h:77
std::set< CString > SCString
Definition ZNCString.h:37
std::vector< CString > VCString
Definition ZNCString.h:38
Definition Client.h:99
Definition Config.h:36
Definition Translation.h:103
Definition FileUtils.h:30
Definition IRCNetwork.h:40
Definition Listener.h:28
EAcceptType
Definition Listener.h:30
The base class for your own ZNC modules.
Definition Modules.h:420
Definition Modules.h:1532
Definition Socket.h:80
String class that is used inside ZNC.
Definition ZNCString.h:50
Definition User.h:38
Definition znc.h:38
bool WritePemFile()
CUser * FindUser(const CString &sUsername)
void Loop()
bool AddListener(unsigned short uPort, const CString &sBindHost, const CString &sURIPrefix, bool bSSL, EAddrType eAddr, CListener::EAcceptType eAccept, CString &sError)
Definition znc.h:218
unsigned int m_uiForceEncoding
Definition znc.h:325
void SetSkinName(const CString &s)
Definition znc.h:117
bool m_bProtectWebSessions
Definition znc.h:327
CTranslationDomainRefHolder m_Translation
Definition znc.h:330
void SetAuthOnlyViaModule(bool b)
Definition znc.h:128
const CString & GetConfigFile() const
Definition znc.h:155
CModule * FindModule(const CString &sModName, CUser *pUser)
unsigned int m_uiConnectPaused
Definition znc.h:324
unsigned int m_uDisabledSSLProtocols
Definition znc.h:318
void ClearMotd()
Definition znc.h:234
CString GetSSLProtocols() const
Definition znc.h:174
CString m_sSkinName
Definition znc.h:301
bool AddUnixListener(const CString &sPath, const CString &sURIPrefix, bool bSSL, CListener::EAcceptType eAccept, CString &sError)
void Broadcast(const CString &sMessage, bool bAdminOnly=false, CUser *pSkipUser=nullptr, CClient *pSkipClient=nullptr)
TrafficStatsMap GetNetworkTrafficStats(const CString &sUsername, TrafficStatsPair &Total)
const VCString & GetBindHosts() const
Definition znc.h:158
void SetAnonIPLimit(unsigned int i)
Definition znc.h:122
CString GetKeyLocation() const
unsigned long long BytesWritten() const
Definition znc.h:93
std::vector< CListener * > m_vpListeners
Definition znc.h:292
CListener * FindListener(u_short uPort, const CString &BindHost, EAddrType eAddr)
CListener * FindUnixListener(const CString &sPath)
const CString & GetStatusPrefix() const
Definition znc.h:145
CString m_sStatusPrefix
Definition znc.h:302
void AddServerThrottle(CString sName)
Definition znc.h:238
CString GetSSLCertFile() const
Definition znc.h:178
void SetProtectWebSessions(bool b)
Definition znc.h:126
CString m_sZNCPath
Definition znc.h:298
void AddNetworkToQueue(CIRCNetwork *pNetwork)
void ResumeConnectQueue()
TrafficStatsMap GetTrafficStats(TrafficStatsPair &Users, TrafficStatsPair &ZNC, TrafficStatsPair &Total)
CModules & GetModules()
Definition znc.h:143
void LeakConnectQueueTimer(CConnectQueueTimer *pTimer)
CString GetSkinName() const
Definition znc.h:144
bool OnBoot()
unsigned int m_uiAnonIPLimit
Definition znc.h:316
void ForceEncoding()
void AuthUser(std::shared_ptr< CAuthBase > AuthClass)
enum ConfigState GetConfigState()
Definition znc.h:137
CSockManager m_Manager
Definition znc.h:295
bool AllowConnectionFrom(const CString &sIP) const
CString FixupEncoding(const CString &sEncoding) const
CString GetSSLCiphers() const
Definition znc.h:173
CConnectQueueTimer * m_pConnectQueueTimer
Definition znc.h:323
unsigned int m_uiMaxBufferSize
Definition znc.h:317
bool AddListener(CListener *)
static CString GetCompileOptionsString()
void SetServerThrottle(unsigned int i)
Definition znc.h:123
TCacheMap< CString > m_sConnectThrottle
Definition znc.h:326
bool WritePidFile(int iPid)
bool ParseConfig(const CString &sConfig, CString &sError)
void SetSSLCiphers(const CString &sCiphers)
Definition znc.h:130
time_t m_TimeStarted
Definition znc.h:287
unsigned int m_uiConfigWriteDelay
Definition znc.h:331
const CString & GetZNCPath() const
CString GetModPath() const
unsigned int GetServerThrottle() const
Definition znc.h:166
void DeleteUsers()
unsigned int m_uiConnectDelay
Definition znc.h:315
CZNC & operator=(const CZNC &)=delete
static CString GetTag(bool bIncludeVersion=true, bool bHTML=false)
CModule * FindModule(const CString &sModName, const CString &sUsername)
bool GetAuthOnlyViaModule() const
Definition znc.h:172
std::map< CString, TrafficStatsPair > TrafficStatsMap
Definition znc.h:97
bool RehashConfig(CString &sError)
bool AddTrustedProxy(const CString &sHost)
void AddMotd(const CString &sMessage)
Definition znc.h:229
unsigned int GetMaxBufferSize() const
Definition znc.h:164
bool m_bHideVersion
Definition znc.h:328
time_t TimeStarted() const
Definition znc.h:163
bool AddBindHost(const CString &sHost)
Definition znc.h:80
const CString & GetCurPath() const
CString m_sSSLProtocols
Definition znc.h:308
void SetConnectDelay(unsigned int i)
void DisableConnectQueue()
bool AddUser(CUser *pUser, CString &sErrorRet, bool bStartup=false)
unsigned int GetConfigWriteDelay() const
Definition znc.h:180
CString m_sSSLCiphers
Definition znc.h:307
std::list< CIRCNetwork * > & GetConnectionQueue()
Definition znc.h:247
void SetConfigWriteDelay(unsigned int i)
Definition znc.h:133
bool RemTrustedProxy(const CString &sHost)
void ClearBindHosts()
Definition znc.h:78
VCString m_vsMotd
Definition znc.h:311
std::mutex m_mutexConfigState
Definition znc.h:290
CFile * m_pLockFile
Definition znc.h:314
CZNC(const CZNC &)=delete
SCString m_ssServerCapBlacklist
Definition znc.h:313
VCString m_vsTrustedProxies
Definition znc.h:310
unsigned int GetConnectDelay() const
Definition znc.h:169
CString GetUptime() const
void SetStatusPrefix(const CString &s)
Definition znc.h:118
bool DeletePidFile()
CString m_sSSLDHParamFile
Definition znc.h:306
VCString m_vsBindHosts
Definition znc.h:309
ConfigState
Definition znc.h:46
@ ECONFIG_NEED_QUIT
Definition znc.h:52
@ ECONFIG_NOTHING
Definition znc.h:47
@ ECONFIG_NEED_REHASH
Definition znc.h:48
@ ECONFIG_NEED_VERBOSE_WRITE
Definition znc.h:50
@ ECONFIG_NEED_WRITE
Definition znc.h:49
@ ECONFIG_DELAYED_WRITE
Definition znc.h:51
std::pair< unsigned long long, unsigned long long > TrafficStatsPair
Definition znc.h:96
bool GetProtectWebSessions() const
Definition znc.h:170
CString GetDHParamLocation() const
void SetSSLCertFile(const CString &sFile)
Definition znc.h:132
bool DelListener(CListener *)
const SCString & GetServerCapBlacklist() const
Definition znc.h:87
static void CreateInstance()
void InitDirs(const CString &sArgvPath, const CString &sDataDir)
const std::map< CString, CUser * > & GetUserMap() const
Definition znc.h:202
static CString GetVersion()
static void DumpConfig(const CConfig *Config)
CString GetConfPath(bool bAllowMkDir=true) const
bool WaitForChildLock()
void EnableConnectQueue()
std::map< CString, CUser * > m_msUsers
Definition znc.h:293
void AddBytesRead(unsigned long long u)
Definition znc.h:90
Csock::EDisableProtocol GetDisabledSSLProtocols() const
Definition znc.h:175
void SetMaxBufferSize(unsigned int i)
Definition znc.h:121
const CSockManager & GetManager() const
Definition znc.h:142
CModules * m_pModules
Definition znc.h:319
unsigned long long m_uBytesRead
Definition znc.h:320
SCString m_ssClientCapBlacklist
Definition znc.h:312
bool WriteNewConfig(const CString &sConfigFile)
bool DeleteUser(const CString &sUsername)
CString m_sSSLCertFile
Definition znc.h:304
CSockManager & GetManager()
Definition znc.h:141
CString m_sSSLKeyFile
Definition znc.h:305
std::map< CString, CUser * > m_msDelUsers
Definition znc.h:294
void DisableConfigTimer()
CString GetPemLocation() const
CString m_sConfigFile
Definition znc.h:300
CString m_sCurPath
Definition znc.h:297
bool RemBindHost(const CString &sHost)
Definition znc.h:82
bool GetServerThrottle(CString sName)
Definition znc.h:241
static void DestroyInstance()
std::list< CIRCNetwork * > m_lpConnectQueue
Definition znc.h:322
bool GetHideVersion() const
Definition znc.h:171
void UnforceEncoding()
void SetHideVersion(bool b)
Definition znc.h:127
CConfigWriteTimer * m_pConfigTimer
Definition znc.h:332
bool SetSSLProtocols(const CString &sProtocols)
void AddBytesWritten(unsigned long long u)
Definition znc.h:91
unsigned long long BytesRead() const
Definition znc.h:92
bool IsHostAllowed(const CString &sHostMask) const
bool m_bAuthOnlyViaModule
Definition znc.h:329
void BackupConfigOnce(const CString &sSuffix)
const VCString & GetMotd() const
Definition znc.h:235
void PauseConnectQueue()
CString m_sPidFile
Definition znc.h:303
void SetMotd(const CString &sMessage)
Definition znc.h:225
bool IsForcingEncoding() const
void SetConfigState(enum ConfigState e)
Definition znc.h:113
const VCString & GetTrustedProxies() const
Definition znc.h:159
const SCString & GetClientCapBlacklist() const
Definition znc.h:86
static VCString GetAvailableSSLProtocols()
static CZNC & Get()
bool UpdateModule(const CString &sModule)
Reload a module everywhere.
const std::vector< CListener * > & GetListeners() const
Definition znc.h:160
bool WriteConfig()
const CString & GetHomePath() const
CString ExpandConfigPath(const CString &sConfigFile, bool bAllowMkDir=true)
CString GetUserPath() const
unsigned int GetAnonIPLimit() const
Definition znc.h:165
enum ConfigState m_eConfigState
Definition znc.h:289
bool AddTCPListener(unsigned short uPort, const CString &sBindHost, const CString &sURIPrefix, bool bSSL, EAddrType eAddr, CListener::EAcceptType eAccept, CString &sError)
void ClearTrustedProxies()
unsigned long long m_uBytesWritten
Definition znc.h:321
EDisableProtocol
Definition Csocket.h:627
A dictionary for strings.
Definition ZNCString.h:577
Insert an object with a time-to-live and check later if it still exists.
Definition Utils.h:292
void AddItem(const K &Item)
This function adds an item to the cache using the default time-to-live value.
Definition Utils.h:302
unsigned int GetTTL() const
Definition Utils.h:400
void SetTTL(unsigned int u)
Definition Utils.h:397
V * GetItem(const K &Item)
Performs a Cleanup() and returns a pointer to the object, or nullptr.
Definition Utils.h:350
Definition Translation.h:62