summaryrefslogtreecommitdiff
path: root/modules/hostserv/request.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'modules/hostserv/request.cpp')
-rw-r--r--modules/hostserv/request.cpp16
1 files changed, 15 insertions, 1 deletions
diff --git a/modules/hostserv/request.cpp b/modules/hostserv/request.cpp
index 3cc2b1aa9..dcaed4913 100644
--- a/modules/hostserv/request.cpp
+++ b/modules/hostserv/request.cpp
@@ -212,6 +212,13 @@ class CommandHSRequest : public Command
return;
}
+ unsigned int max_vhosts = Config->GetModule("hostserv/main")->Get<unsigned int>("max_vhosts");
+ if (max_vhosts && max_vhosts >= u->Account()->GetRefs<HostServ::VHost *>().size())
+ {
+ source.Reply(_("You already has the maximum number of vhosts allowed (\002{0}\002)."), max_vhosts);
+ return;
+ }
+
HostRequest *req = u->Account()->GetRef<HostRequest *>();
if (req != nullptr)
req->Delete(); // delete old request
@@ -265,7 +272,14 @@ class CommandHSActivate : public Command
HostRequest *req = na->GetAccount()->GetRef<HostRequest *>();
if (!req)
{
- source.Reply(_("\002{0}\002 does not have a pending vhost request."), na->GetNick());
+ source.Reply(_("\002{0}\002 does not have a pending vhost request."), na->GetAccount()->GetDisplay());
+ return;
+ }
+
+ unsigned int max_vhosts = Config->GetModule("hostserv/main")->Get<unsigned int>("max_vhosts");
+ if (max_vhosts && max_vhosts >= na->GetAccount()->GetRefs<HostServ::VHost *>().size())
+ {
+ source.Reply(_("\002{0}\002 already has the maximum number of vhosts allowed (\002{1}\002)."), na->GetAccount()->GetDisplay(), max_vhosts);
return;
}