// 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 //