// Ryzom - MMORPG Framework
// Copyright (C) 2010 Winch Gate Property Limited
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.
//
// 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 Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see .
#include "stdpch.h"
// Nel Misc
#include "nel/misc/command.h"
#include "nel/misc/file.h"
#include "nel/misc/i_xml.h"
#include "nel/misc/path.h"
#include "game_share/string_manager_sender.h"
#include "game_share/brick_families.h"
#include "game_share/ecosystem.h"
#include "game_share/people.h"
#include "game_share/roles.h"
//#include "game_share/jobs.h"
#include "game_share/skills.h"
#include "game_share/scores.h"
#include "game_share/characteristics.h"
#include "game_share/damage_types.h"
#include "game_share/power_types.h"
#include "input_output_service.h"
#include "string_manager.h"
using namespace NLMISC;
using namespace NLNET;
using namespace std;
using namespace STRING_MANAGER;
NLMISC_COMMAND(smReload, "reload all translation files in string manager", "")
{
SM->reload(&log);
log.displayNL("reload done.");
return true;
}
NLMISC_COMMAND(smReloadEventFactions, "reload event factions", "[]")
{
if (args.size() > 1)
return false;
if (args.size() == 1)
SM->reloadEventFactions(&log, args[0]);
else
SM->reloadEventFactions(&log);
log.displayNL("reload done.");
return true;
}
NLMISC_COMMAND(smClearCache, "clear the string cache in string manager", "")
{
SM->clearCache(&log);
return true;
}
NLMISC_COMMAND(smString, "display a string from the string manager ", "")
{
if (args.size() != 1)
{
return false;
}
uint32 stringId;
NLMISC::fromString(args[0], stringId);
const ucstring &str = SM->getString(stringId);
log.displayNL("String id %u = [%s]", stringId, str.toString().c_str());
return true;
}
// sm_test TEST_ITEM fyros_2h_axe_lvl_01_05.item
NLMISC_COMMAND(smTest, "Send a test dyn string to a client (look at first phrase in phrase_en.txt)", " []")
{
if (args.size() < 2)
return false;
CCharacterInfos *ci = IOS->getCharInfos(args[0]);
if (ci == NULL)
{
// try to find a valid client
log.displayNL("Unknown client '%s' !", args[0].c_str());
return false;
}
uint dynId;
TVectorParamCheck params;
TParam p;
if (args[1] == "TEST_SELF")
{
if (args.size() != 2)
return false;
dynId = sendStringToClient(ci->DataSetIndex, "TEST_SELF", params, &IosLocalSender);
}
else
{
if (args.size() != 3)
return false;
if (args[1] == "TEST_ITEM")
{
// try to retreive the sheet id
NLMISC::CSheetId sid(args[2]);
if (sid != NLMISC::CSheetId::Unknown)
{
p.Type = STRING_MANAGER::item;
p.SheetId = sid;
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_ITEM", params, &IosLocalSender);
}
else
{
log.displayNL("Unknown item %s", args[2].c_str());
return true;
}
}
else if (args[1] == "TEST_PLAYER")
{
// try to retreive the player infos
CCharacterInfos *other = IOS->getCharInfos(args[2]);
if (other)
{
p.Type = STRING_MANAGER::player;
p.setEId( other->EntityId );
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_PLAYER", params, &IosLocalSender);
}
else
{
log.displayNL("Unknown player name '%s'", args[2].c_str());
}
}
else if (args[1] == "TEST_ENTITY")
{
// try to retreive the player infos
// CCharacterInfos *other = IOS->getCharInfos(args[2]);
CEntityId eid(args[2]);
if (eid != CEntityId::Unknown)
{
p.Type = STRING_MANAGER::entity;
p.setEId( eid );
// for some obscure reason, GCC 3.2.3 fail internaly to compile the push_back !
// so, I replaced the push_back with a resize + affectation.
params.resize(1);
params[0] = p;
// params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_ENTITY", params, &IosLocalSender);
}
else
{
log.displayNL("Can't make entity ID from '%s'", args[2].c_str());
}
}
else if (args[1] == "TEST_SBRICK")
{
NLMISC::CSheetId sid(args[2]);
// BRICK_FAMILIES::TBrickFamily brick = BRICK_FAMILIES::toSBrickFamily(args[2]);
// if (brick != BRICK_FAMILIES::Unknown)
if (sid != CSheetId::Unknown )
{
p.Type = STRING_MANAGER::sbrick;
p.SheetId = sid;
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_SBRICK", params, &IosLocalSender);
}
else
{
log.displayNL("Unknown sbrick '%s'", args[2].c_str());
return true;
}
}
else if (args[1] == "TEST_ECO")
{
ECOSYSTEM::EECosystem eco = ECOSYSTEM::stringToEcosystem(args[2]);
if (eco != ECOSYSTEM::unknown)
{
p.Type = STRING_MANAGER::ecosystem;
p.Enum = eco;
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_ECO", params, &IosLocalSender);
}
else
{
log.displayNL("Unknown ecosystem %s", args[2].c_str());
return true;
}
}
else if (args[1] == "TEST_CREATURE_MODEL")
{
std::string sheetName = args[2];
CSheetId sid(sheetName);
// EGSPD::CPeople::TPeople people = EGSPD::CPeople::fromString(args[1]);
if (sid != CSheetId::Unknown)
{
p.Type = STRING_MANAGER::creature_model;
p.SheetId = sid;
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_CREATURE_MODEL", params, &IosLocalSender);
}
else
{
log.displayNL("Unknown creature model '%s'", args[2].c_str());
return true;
}
}
else if (args[1] == "TEST_RACE")
{
//RACES::TRace race = RACES::toRaceId(args[1]);
EGSPD::CPeople::TPeople people = EGSPD::CPeople::fromString(args[2]);
if (people != EGSPD::CPeople::EndPeople)
{
p.Type = STRING_MANAGER::race;
p.Enum = people;
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_RACE", params, &IosLocalSender);
}
else
{
log.displayNL("Unknown race %s", args[2].c_str());
return true;
}
}
/* else if (args[1] == "TEST_CAREER")
{
ROLES::ERole career = ROLES::toRoleId(args[2]);
if (career != ROLES::role_unknown)
{
p.Type = STRING_MANAGER::career;
p.Enum = career;
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_CAREER", params, &IosLocalSender);
}
else
{
log.displayNL("Unknown career %s", args[2].c_str());
return true;
}
}
*/
/* else if (args[1] == "TEST_JOB")
{
JOBS::TJob job = JOBS::toJob(args[2]);
if (job != JOBS::Unknown)
{
p.Type = STRING_MANAGER::job;
p.Enum = job;
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_JOB", params, &IosLocalSender);
}
else
{
log.displayNL("Unknown job %s", args[2].c_str());
return true;
}
}
*/
else if (args[1] == "TEST_SKILL")
{
SKILLS::ESkills skill = SKILLS::toSkill(args[2]);
if (skill != SKILLS::unknown)
{
p.Type = STRING_MANAGER::skill;
p.Enum = skill;
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_SKILL", params, &IosLocalSender);
}
else
{
log.displayNL("Unknown skill %s", args[2].c_str());
return true;
}
}
else if (args[1] == "TEST_BODYPART")
{
BODY::TBodyPart bodyPart = BODY::toBodyPart(args[2]);
if (bodyPart != BODY::UnknownBodyPart)
{
p.Type = STRING_MANAGER::body_part;
p.Enum = bodyPart;
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_BODYPART", params, &IosLocalSender);
}
else
{
log.displayNL("Unknown body part %s", args[2].c_str());
return true;
}
}
else if (args[1] == "TEST_SCORE")
{
SCORES::TScores score = SCORES::toScore(args[2]);
if (score != SCORES::unknown)
{
p.Type = STRING_MANAGER::score;
p.Enum = score;
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_SCORE", params, &IosLocalSender);
}
else
{
log.displayNL("Unknown score %s", args[2].c_str());
return true;
}
}
else if (args[1] == "TEST_CHARAC")
{
CHARACTERISTICS::TCharacteristics charac = CHARACTERISTICS::toCharacteristic(args[2]);
if (charac != CHARACTERISTICS::Unknown)
{
p.Type = STRING_MANAGER::characteristic;
p.Enum = charac;
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_CHARAC", params, &IosLocalSender);
}
else
{
log.displayNL("Unknown characteristic %s", args[2].c_str());
return true;
}
}
else if (args[1] == "TEST_DAMAGE_TYPE")
{
DMGTYPE::EDamageType damageType = DMGTYPE::stringToDamageType(args[2]);
if (damageType != DMGTYPE::UNDEFINED)
{
p.Type = STRING_MANAGER::damage_type;
p.Enum = damageType;
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_DAMAGE_TYPE", params, &IosLocalSender);
}
else
{
log.displayNL("Unknown damage type %s", args[2].c_str());
return true;
}
}
else if (args[1] == "TEST_SPHRASE")
{
NLMISC::CSheetId sid(args[2]);
if (sid != NLMISC::CSheetId::Unknown)
{
p.Type = STRING_MANAGER::sphrase;
p.SheetId = sid;
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_SPHRASE", params, &IosLocalSender);
}
else
{
log.displayNL("Unknown sphrase Id %s", args[2].c_str());
return true;
}
}
else if (args[1] == "TEST_DYN_STRING")
{
uint32 id;
NLMISC::fromString(args[2], id);
p.Type = STRING_MANAGER::dyn_string_id;
p.StringId = id;
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_DYN_STRING", params, &IosLocalSender);
}
else if (args[1] == "TEST_STRING")
{
uint32 id;
NLMISC::fromString(args[2], id);
p.Type = STRING_MANAGER::string_id;
p.StringId = id;
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_STRING", params, &IosLocalSender);
}
else if (args[1] == "TEST_BOT_NAME")
{
if (args.size() < 3)
{
log.displayNL("Mission bot name as parameter !");
return true;
}
else
{
p.Type = STRING_MANAGER::bot_name;
p.Identifier = args[2];
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_BOT_NAME", params, &IosLocalSender);
}
}
else if (args[1] == "TEST_POWER_TYPE")
{
POWERS::TPowerType powerType = POWERS::toPowerType(args[2]);
if (powerType != POWERS::UnknownType)
{
p.Type = STRING_MANAGER::power_type;
p.Enum = powerType;
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_POWER_TYPE", params, &IosLocalSender);
}
else
{
log.displayNL("Unknown power type %s", args[2].c_str());
return true;
}
}
else if (args[1] == "TEST_LITERAL")
{
ucstring str = args[2];
p.Type = STRING_MANAGER::literal;
p.Literal = str;
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_LITERAL", params, &IosLocalSender);
}
else if (args[1] == "TEST_TITLE")
{
ucstring str = args[2];
p.Type = STRING_MANAGER::title;
p.Identifier = str.toString();
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_TITLE", params, &IosLocalSender);
}
else if (args[1] == "TEST_EVENT_FACTION")
{
ucstring str = args[2];
p.Type = STRING_MANAGER::event_faction;
p.Identifier = str.toString();
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_EVENT_FACTION", params, &IosLocalSender);
}
else if (args[1] == "TEST_CLASSIFICATION_TYPE")
{
EGSPD::CClassificationType::TClassificationType type = EGSPD::CClassificationType::fromString(args[2]);
if (type != EGSPD::CClassificationType::Unknown)
{
p.Type = STRING_MANAGER::classification_type;
p.Enum = type;
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_CLASSIFICATION_TYPE", params, &IosLocalSender);
}
else
{
log.displayNL("Unknown classification type %s", args[2].c_str());
return true;
}
}
else if (args[1] == "TEST_OUTPOST_WORD")
{
NLMISC::CSheetId sid(args[2]);
if (sid != CSheetId::Unknown )
{
p.Type = STRING_MANAGER::outpost;
p.SheetId = sid;
params.push_back(p);
dynId = sendStringToClient(ci->DataSetIndex, "TEST_OUTPOST_WORD", params, &IosLocalSender);
}
else
{
log.displayNL("Unknown sbrick '%s'", args[2].c_str());
return true;
}
}
else
{
log.displayNL("Unknow parameter %s", args[2].c_str());
return false;
}
}
log.displayNL("Dyn string send to client %s with ID = %u", args[0].c_str(), dynId);
return true;
}
NLMISC_COMMAND(sysCmd, "Run preprogrammed system command(s)","commands are in the SystemCmd config variable")
{
CConfigFile::CVar *sysCmds = IService::getInstance()->ConfigFile.getVarPtr("SystemCmd");
if (sysCmds != NULL)
{
for (uint i=0; isize(); ++i)
{
string cmd = sysCmds->asString(i);
log.displayNL("Invoking system command '%s'...", cmd.c_str());
int ret = system(cmd.c_str());
log.displayNL(" command returned %d", ret);
}
}
else
{
log.displayNL("Variable SystemCmd not found !");
}
return true;
}
//-----------------------------------------------
// 'mute'
//
//-----------------------------------------------
NLMISC_COMMAND(mute,"Mute or unmute a player. the player can be muted for a fixed period of time","[]")
{
if( args.size() == 0 )
{
return false;
}
sint32 delay = -1;
if( args.size() > 1 )
{
NLMISC::fromString(args[1], delay);
}
CCharacterInfos * charInfos = IOS->getCharInfos( args[0] );
if( charInfos != NULL )
{
try
{
IOS->getChatManager().getClient(charInfos->DataSetIndex).mute( delay );
}
catch(const Exception &e)
{
nlwarning(" %s",e.what());
}
}
else
{
nlwarning("(mute) No infos about the character %s",args[0].c_str());
}
return true;
} // mode //
//-----------------------------------------------
// 'remove'
//
//-----------------------------------------------
NLMISC_COMMAND(remove,"remove an entity from","")
{
if( args.size() < 1 )
{
return false;
}
CCharacterInfos * charInfos = IOS->getCharInfos( args[0] );
if( charInfos )
{
IOS->removeEntity( charInfos->DataSetIndex);
}
else
{
nlwarning(" Entity %s is not in the IOS",args[0].c_str());
return false;
}
return true;
}
/*
NLMISC_COMMAND(genImpulsion,"generate a fake impulsion, used to debug the CActionGeneric on the FS","")
{
if( args.size() != 1 )
{
return false;
}
CEntityId id;
CMessage msgout( "IMPULSION_ID" );
msgout.serial( id );
CBitMemStream stream;
uint count;
NLMISC::fromString(args[0], count);
uint8 val = 0xAC;
for (uint i = 0; i < count; i++)
stream.serial (val);
//vector &v = stream.bufferAsVector();
msgout.serialBufferWithSize ((uint8*)stream.buffer(), stream.length());
//const uint16 frontEndId = _Id.DynamicId;
sendMessageViaMirror ("FS", msgout);
return true;
}
*/
NLMISC_COMMAND(display,"display","")
{
IOS->display(log);
return true;
}
NLMISC_COMMAND( displayChatClients, "Display the list of clients", "" )
{
IOS->getChatManager().displayChatClients(log);
return true;
}
NLMISC_COMMAND( displayChatGroups, "Display the list of chat groups, optionally, display universe chat group and/or player audience groups", "[universe] [player]" )
{
bool displayUniverse = false;
bool playerAudience = false;
vector params = args;
while (!params.empty())
{
if (params[0] == "universe")
displayUniverse = true;
else if (params[0] == "player")
playerAudience = true;
else
{
log.displayNL("syntax error: invalid parameter '%s'", params[0].c_str());
return false;
}
params.erase(params.begin());
}
IOS->getChatManager().displayChatGroups(log, displayUniverse, playerAudience);
return true;
}
NLMISC_COMMAND( displayChatAudience, "Display the current chat dynamic audience for a player, optionally, force the update", " [update]" )
{
bool update = false;
if (args.size() < 1)
return false;
CEntityId eid = CEntityId(args[0]);
if (args.size() >= 2 && args[1] == "update")
update = true;
IOS->getChatManager().displayChatAudience(log, eid, update);
return true;
}
//-----------------------------------------------
// 'showChat'
//
//-----------------------------------------------
NLMISC_COMMAND(showChat,"show or hide chat messages","")
{
ShowChat = !ShowChat;
return true;
} // showChat //