EvEmu  0.8.4
11 September 2021
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
SlashService.cpp
Go to the documentation of this file.
1 /*
2  ------------------------------------------------------------------------------------
3  LICENSE:
4  ------------------------------------------------------------------------------------
5  This file is part of EVEmu: EVE Online Server Emulator
6  Copyright 2006 - 2021 The EVEmu Team
7  For the latest information visit https://evemu.dev
8  ------------------------------------------------------------------------------------
9  This program is free software; you can redistribute it and/or modify it under
10  the terms of the GNU Lesser General Public License as published by the Free Software
11  Foundation; either version 2 of the License, or (at your option) any later
12  version.
13 
14  This program is distributed in the hope that it will be useful, but WITHOUT
15  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
16  FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
17 
18  You should have received a copy of the GNU Lesser General Public License along with
19  this program; if not, write to the Free Software Foundation, Inc., 59 Temple
20  Place - Suite 330, Boston, MA 02111-1307, USA, or go to
21  http://www.gnu.org/copyleft/lesser.txt.
22  ------------------------------------------------------------------------------------
23  Author: Zhur
24 */
25 
26 
27 #include "eve-server.h"
28 
29 #include "PyServiceCD.h"
31 #include "admin/SlashService.h"
32 
33 
35 
37 : PyService(mgr, "slash"),
38  m_dispatch(new Dispatcher(this)),
39  m_commandDispatch(cd)
40 {
41  _SetCallDispatcher(m_dispatch);
42 
44 }
45 
47  delete m_dispatch;
48 }
49 
50 PyResult SlashService::Handle_SlashCmd( PyCallArgs& call )
51 {
52  if (is_log_enabled(COMMAND__DUMP)) {
53  sLog.White("SlashService::Handle_SlashCmd()", "size=%u", call.tuple->size());
54  call.Dump(COMMAND__DUMP);
55  }
56  Call_SingleStringArg arg;
57  if (!arg.Decode(&call.tuple)) {
58  codelog(SERVICE__ERROR, "%s: Failed to decode arguments.", GetName());
59  return nullptr;
60  }
61 
62  return SlashCommand( call.client, arg.arg );
63 }
64 
66 {
67  if ((client->GetAccountRole() & Acct::Role::SLASH) != Acct::Role::SLASH) {
68  _log( COMMAND__ERROR, "%s: Client '%s' used a slash command but does not have Acct::Role::SLASH.", GetName(), client->GetName() );
69  throw CustomError ("You need to have Acct::Role::SLASH to execute commands.");
70  }
71 
72  return m_commandDispatch->Execute( client, command.c_str() );
73 }
74 
75 /*(258713, `Role GMH needed`)
76  * (258714, `Role GML needed`)
77  */
int64 GetAccountRole() const
Definition: Client.h:118
Dispatcher *const m_dispatch
virtual ~SlashService()
#define _log(type, fmt,...)
Definition: logsys.h:124
size_t size() const
Definition: PyRep.h:591
PyResult Execute(Client *from, const char *msg)
PyCallable_Make_InnerDispatcher(SlashService) SlashService
const char * GetName() const
Definition: PyService.h:54
Advanced version of UserError that allows to send a full custom message.
Definition: PyExceptions.h:453
#define is_log_enabled(type)
Definition: logsys.h:78
#define sLog
Evaluates to a NewLog instance.
Definition: LogNew.h:250
#define codelog(type, fmt,...)
Definition: logsys.h:128
CommandDispatcher *const m_commandDispatch
Definition: SlashService.h:43
const char * GetName() const
Definition: Client.h:94
Client *const client
Definition: PyCallable.h:49
#define PyCallable_REG_CALL(c, m)
Definition: PyServiceCD.h:78
Definition: Client.h:66
PyResult SlashCommand(Client *client, std::string command)
Dispatcher *const m_dispatch
Definition: SlashService.h:41
void Dump(LogType type) const
Definition: PyCallable.cpp:81
PyTuple * tuple
Definition: PyCallable.h:50