* ---------------------------------------------------
*/
-#ifndef __USERS_H__
-#define __USERS_H__
+#ifndef USERS_H
+#define USERS_H
#include "socket.h"
#include "inspsocket.h"
*/
unsigned int pingtime;
- /** (Optional) Password for this line
- */
- std::string pass;
-
- /** (Optional) Hash Method for this line
- */
- std::string hash;
-
/** Maximum size of sendq for users in this class (bytes)
* Users cannot send commands if they go over this limit
*/
*/
unsigned long maxglobal;
- /** Max channels for this class
+ /** True if max connections for this class is hit and a warning is wanted
*/
- unsigned int maxchans;
+ bool maxconnwarn;
- /** Port number this connect class applies to
+ /** Max channels for this class
*/
- int port;
+ unsigned int maxchans;
/** How many users may be in this connect class before they are refused?
* (0 = no limit = default)
/** Update the settings in this block to match the given block */
void Update(const ConnectClass* newSettings);
-
const std::string& GetName() { return name; }
- const std::string& GetPass() { return pass; }
const std::string& GetHost() { return host; }
- const int GetPort() { return port; }
/** Returns the registration timeout
*/
*/
unsigned int GetPenaltyThreshold()
{
- return (penaltythreshold ? penaltythreshold : 10);
+ return penaltythreshold ? penaltythreshold : (fakelag ? 10 : 20);
}
unsigned int GetCommandRate()
return commandrate ? commandrate : 1000;
}
- /** Returusn the maximum number of local sessions
+ /** Return the maximum number of local sessions
*/
unsigned long GetMaxLocal()
{
*/
unsigned int quitting:1;
+ /** Recursion fix: user is out of SendQ and will be quit as soon as possible.
+ * This can't be handled normally because QuitUser itself calls Write on other
+ * users, which could trigger their SendQ to overrun.
+ */
+ unsigned int quitting_sendq:1;
+
/** This is true if the user matched an exception (E:Line). It is used to save time on ban checks.
*/
unsigned int exempt:1;
void AddWriteBuf(const std::string &data);
};
+typedef unsigned int already_sent_t;
+
class CoreExport LocalUser : public User
{
/** A list of channels the user has a pending invite to.
*/
unsigned int CommandFloodPenalty;
+ static already_sent_t already_sent_id;
+ already_sent_t already_sent;
+
/** Stored reverse lookup from res_forward. Should not be used after resolution.
*/
std::string stored_host;
* @return True if the user can set or unset this mode.
*/
bool HasModePermission(unsigned char mode, ModeType type);
-
- inline int GetFd() { return eh.GetFd(); }
};
class CoreExport RemoteUser : public User
class CoreExport UserResolver : public Resolver
{
private:
- /** User this class is 'attached' to.
- */
- LocalUser* bound_user;
- /** File descriptor teh lookup is bound to
- */
- int bound_fd;
+ /** UUID we are looking up */
+ std::string uuid;
/** True if the lookup is forward, false if is a reverse lookup
*/
bool fwd;