Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- #include "stdafx.h"
- #ifdef __FreeBSD__
- #include <md5.h>
- #else
- #include "../../libthecore/include/xmd5.h"
- #endif
- #include "utils.h"
- #include "config.h"
- #include "desc_client.h"
- #include "desc_manager.h"
- #include "char.h"
- #include "char_manager.h"
- #include "motion.h"
- #include "packet.h"
- #include "affect.h"
- #include "pvp.h"
- #include "start_position.h"
- #include "party.h"
- #include "guild_manager.h"
- #include "p2p.h"
- #include "dungeon.h"
- #include "messenger_manager.h"
- #include "war_map.h"
- #include "questmanager.h"
- #include "item_manager.h"
- #include "monarch.h"
- #include "mob_manager.h"
- #include "dev_log.h"
- #include "item.h"
- #include "arena.h"
- #include "buffer_manager.h"
- #include "unique_item.h"
- #include "threeway_war.h"
- #include "log.h"
- #include "../../common/VnumHelper.h"
- #ifdef __AUCTION__
- #include "auction_manager.h"
- #endif
- #include "../../common/service.h"
- #ifdef __NEW_SKILLTREE__
- #include "constants.h"
- #endif
- #ifdef ENABLE_MOUNT_COSTUME_SYSTEM
- #include "MountSystem.h"
- #endif
- extern int g_server_id;
- extern int g_nPortalLimitTime;
- ACMD(do_user_horse_ride)
- {
- if (ch->IsObserverMode())
- return;
- if (ch->IsDead() || ch->IsStun())
- return;
- if (ch->IsHorseRiding() == false)
- {
- // ˘¬ˇíAI ¨ú¨ˇ˘ĄN ˘ĄU˘¬ˇÍAˇíˇĆIAˇí A˘¬ˇĆiAO˘ĄU.
- if (ch->GetMountVnum())
- {
- LPITEM item = ch->GetWear(WEAR_COSTUME_MOUNT);
- if (item && item->IsRideItem())
- ch->UnequipItem(item);
- if (ch->UnEquipSpecialRideUniqueItem())
- {
- ch->RemoveAffect(AFFECT_MOUNT);
- ch->RemoveAffect(AFFECT_MOUNT_BONUS);
- }
- //ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("AI©öI AˇíˇĆIAˇí AI˘ŻeA©¬AO˘ĄI˘ĄU."));
- return;
- }
- if (ch->GetQuestFlag("HORSE.CHECKER") && get_global_time() < ch->GetQuestFlag("HORSE.CHECKER"))
- {
- ch->ChatPacket(CHAT_TYPE_INFO, "<Kon> Odczekaj %d sekund.", (ch->GetQuestFlag("HORSE.CHECKER") - get_global_time()) % 180);
- return;
- }
- if (ch->GetHorse() == NULL)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("¸»Ŕ» ¸ŐŔú ĽŇČŻÇŘÁÖĽĽżä."));
- return;
- }
- ch->SetQuestFlag("HORSE.CHECKER", get_global_time() + 3);
- ch->StartRiding();
- }
- else
- {
- ch->StopRiding();
- }
- }
- ACMD(do_user_horse_back)
- {
- if (ch->GetHorse() != NULL)
- {
- if (ch->GetQuestFlag("HORSE.CHECKER") && get_global_time() < ch->GetQuestFlag("HORSE.CHECKER"))
- {
- ch->ChatPacket(CHAT_TYPE_INFO, "<Kon> Odczekaj %d sekund.", (ch->GetQuestFlag("HORSE.CHECKER") - get_global_time()) % 180);
- return;
- }
- ch->SetQuestFlag("HORSE.CHECKER", get_global_time() + 3);
- ch->HorseSummon(false);
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("¸»Ŕ» µą·Áş¸łÂ˝Ŕ´Ď´Ů."));
- }
- else if (ch->IsHorseRiding() == true)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("¸»żˇĽ ¸ŐŔú ł»·Áľß ÇŐ´Ď´Ů."));
- }
- else
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("¸»Ŕ» ¸ŐŔú ĽŇČŻÇŘÁÖĽĽżä."));
- }
- }
- ACMD(do_user_horse_feed)
- {
- // °łŔλóÁˇŔ» ż¬ »óĹÂżˇĽ´Â ¸» ¸ÔŔ̸¦ ÁŮ Ľö ľř´Ů.
- if (ch->GetMyShop())
- return;
- if (ch->GetHorse() == NULL)
- {
- if (ch->IsHorseRiding() == false)
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("¸»Ŕ» ¸ŐŔú ĽŇČŻÇŘÁÖĽĽżä."));
- else
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("¸»Ŕ» Ĺş »óĹÂżˇĽ´Â ¸ÔŔ̸¦ ÁŮ Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- DWORD dwFood = ch->GetHorseGrade() + 50054 - 1;
- if (ch->CountSpecifyItem(dwFood) > 0)
- {
- ch->RemoveSpecifyItem(dwFood, 1);
- ch->FeedHorse();
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("¸»żˇ°Ô %s%s ÁÖľú˝Ŕ´Ď´Ů."),
- ITEM_MANAGER::instance().GetTable(dwFood)->szLocaleName,
- g_iUseLocale ? "" : under_han(ITEM_MANAGER::instance().GetTable(dwFood)->szLocaleName) ? LC_TEXT("Ŕ»") : LC_TEXT("¸¦"));
- }
- else
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("%s ľĆŔĚĹŰŔĚ ÇĘżäÇŐ´Ď´Ů"), ITEM_MANAGER::instance().GetTable(dwFood)->szLocaleName);
- }
- }
- #define MAX_REASON_LEN 128
- EVENTINFO(TimedEventInfo)
- {
- DynamicCharacterPtr ch;
- int subcmd;
- int left_second;
- char szReason[MAX_REASON_LEN];
- TimedEventInfo()
- : ch()
- , subcmd( 0 )
- , left_second( 0 )
- {
- ::memset( szReason, 0, MAX_REASON_LEN );
- }
- };
- struct SendDisconnectFunc
- {
- void operator () (LPDESC d)
- {
- if (d->GetCharacter())
- {
- if (d->GetCharacter()->GetGMLevel() == GM_PLAYER)
- d->GetCharacter()->ChatPacket(CHAT_TYPE_COMMAND, "quit Shutdown(SendDisconnectFunc)");
- }
- }
- };
- struct DisconnectFunc
- {
- void operator () (LPDESC d)
- {
- if (d->GetType() == DESC_TYPE_CONNECTOR)
- return;
- if (d->IsPhase(PHASE_P2P))
- return;
- if (d->GetCharacter())
- d->GetCharacter()->Disconnect("Shutdown(DisconnectFunc)");
- d->SetPhase(PHASE_CLOSE);
- }
- };
- EVENTINFO(shutdown_event_data)
- {
- int seconds;
- shutdown_event_data()
- : seconds( 0 )
- {
- }
- };
- EVENTFUNC(shutdown_event)
- {
- shutdown_event_data* info = dynamic_cast<shutdown_event_data*>( event->info );
- if ( info == NULL )
- {
- sys_err( "shutdown_event> <Factor> Null pointer" );
- return 0;
- }
- int * pSec = & (info->seconds);
- if (*pSec < 0)
- {
- sys_log(0, "shutdown_event sec %d", *pSec);
- if (--*pSec == -10)
- {
- const DESC_MANAGER::DESC_SET & c_set_desc = DESC_MANAGER::instance().GetClientSet();
- std::for_each(c_set_desc.begin(), c_set_desc.end(), DisconnectFunc());
- return passes_per_sec;
- }
- else if (*pSec < -10)
- return 0;
- return passes_per_sec;
- }
- else if (*pSec == 0)
- {
- const DESC_MANAGER::DESC_SET & c_set_desc = DESC_MANAGER::instance().GetClientSet();
- std::for_each(c_set_desc.begin(), c_set_desc.end(), SendDisconnectFunc());
- g_bNoMoreClient = true;
- --*pSec;
- return passes_per_sec;
- }
- else
- {
- char buf[64];
- snprintf(buf, sizeof(buf), LC_TEXT("ĽË´ŮżîŔĚ %dĂĘ ł˛ľŇ˝Ŕ´Ď´Ů."), *pSec);
- SendNotice(buf);
- --*pSec;
- return passes_per_sec;
- }
- }
- void Shutdown(int iSec)
- {
- if (g_bNoMoreClient)
- {
- thecore_shutdown();
- return;
- }
- CWarMapManager::instance().OnShutdown();
- char buf[64];
- snprintf(buf, sizeof(buf), LC_TEXT("%dĂĘ ČÄ °ÔŔÓŔĚ ĽË´Ůżî µË´Ď´Ů."), iSec);
- SendNotice(buf);
- shutdown_event_data* info = AllocEventInfo<shutdown_event_data>();
- info->seconds = iSec;
- event_create(shutdown_event, info, 1);
- }
- ACMD(do_shutdown)
- {
- if (!ch->IsGM())
- return;
- if (NULL == ch)
- {
- sys_err("Accept shutdown command from %s.", ch->GetName());
- }
- TPacketGGShutdown p;
- p.bHeader = HEADER_GG_SHUTDOWN;
- P2P_MANAGER::instance().Send(&p, sizeof(TPacketGGShutdown));
- Shutdown(10);
- }
- EVENTFUNC(timed_event)
- {
- TimedEventInfo * info = dynamic_cast<TimedEventInfo *>( event->info );
- if ( info == NULL )
- {
- sys_err( "timed_event> <Factor> Null pointer" );
- return 0;
- }
- LPCHARACTER ch = info->ch;
- if (ch == NULL) { // <Factor>
- return 0;
- }
- LPDESC d = ch->GetDesc();
- if (info->left_second <= 0)
- {
- ch->m_pkTimedEvent = NULL;
- if (true == LC_IsEurope() || true == LC_IsYMIR() || true == LC_IsKorea())
- {
- switch (info->subcmd)
- {
- case SCMD_LOGOUT:
- case SCMD_QUIT:
- case SCMD_PHASE_SELECT:
- {
- TPacketNeedLoginLogInfo acc_info;
- acc_info.dwPlayerID = ch->GetDesc()->GetAccountTable().id;
- db_clientdesc->DBPacket( HEADER_GD_VALID_LOGOUT, 0, &acc_info, sizeof(acc_info) );
- LogManager::instance().DetailLoginLog( false, ch );
- }
- break;
- }
- }
- switch (info->subcmd)
- {
- case SCMD_LOGOUT:
- if (d)
- d->SetPhase(PHASE_CLOSE);
- break;
- case SCMD_QUIT:
- ch->ChatPacket(CHAT_TYPE_COMMAND, "quit");
- break;
- case SCMD_PHASE_SELECT:
- {
- ch->Disconnect("timed_event - SCMD_PHASE_SELECT");
- if (d)
- {
- d->SetPhase(PHASE_SELECT);
- }
- }
- break;
- }
- return 0;
- }
- else
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("%dĂĘ ł˛ľŇ˝Ŕ´Ď´Ů."), info->left_second);
- --info->left_second;
- }
- return PASSES_PER_SEC(1);
- }
- #ifdef __NEW_SKILLTREE__
- ACMD (do_stat_skill)//tree
- {
- if (!ch)
- return;
- char arg1[256];
- one_argument (argument, arg1, sizeof(arg1));
- if (!*arg1)
- return;
- DWORD dwBonus = atoi(arg1);
- if (ch->GetPoint(POINT_SKILL_TREE) <= 0)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, "Nie masz punktów umiejętności!");
- return;
- }
- if (ch->GetPoint(dwBonus) > 15)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, "Masz już tę umiejętność na najwyższym poziomie!");
- return;
- }
- if (ch->IsDead())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, "Nie możesz użyć skilla, jeśli nie żyjesz!");
- return;
- }
- bool bCanSkill = false;
- for (int i = POINT_SKILL_TREE_SKILL1; i <= POINT_SKILL_TREE_SKILL5; i++)
- {
- if (dwBonus == i)
- {
- bCanSkill = true;
- break;
- }
- }
- if (!bCanSkill)
- return;
- int old = ch->GetPoint(dwBonus);
- DWORD affect = NULL;
- if (dwBonus == POINT_SKILL_TREE_SKILL1)
- {
- affect = AFFECT_SKILL_TREE_SKILL1;
- }
- else if (dwBonus == POINT_SKILL_TREE_SKILL2)
- {
- affect = AFFECT_SKILL_TREE_SKILL2;
- }
- else if (dwBonus == POINT_SKILL_TREE_SKILL3)
- {
- affect = AFFECT_SKILL_TREE_SKILL3;
- }
- else if (dwBonus == POINT_SKILL_TREE_SKILL4)
- {
- affect = AFFECT_SKILL_TREE_SKILL4;
- }
- else if (dwBonus == POINT_SKILL_TREE_SKILL5)
- {
- affect = AFFECT_SKILL_TREE_SKILL5;
- }
- TSkillTreeSkill* skill = &map_skill_tree[dwBonus];
- if (!skill)
- return;
- ch->PointChange(POINT_SKILL_TREE, -1);
- ch->PointChange(dwBonus, 1);
- CAffect* pkAffect = ch->FindAffect(affect);
- if (pkAffect)
- ch->RemoveAffect(pkAffect);
- ch->AddAffect(affect, aApplyInfo[skill->apply].bPointType, (skill->step_add*ch->GetPoint(dwBonus)), 0, INFINITE_AFFECT_DURATION, 0, true);
- ch->ChatPacket(CHAT_TYPE_COMMAND, "RefreshSkillTree ");
- }
- #endif
- ACMD(do_cmd)
- {
- /* RECALL_DELAY
- if (ch->m_pkRecallEvent != NULL)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("ĂëĽŇ µÇľú˝Ŕ´Ď´Ů."));
- event_cancel(&ch->m_pkRecallEvent);
- return;
- }
- // END_OF_RECALL_DELAY */
- if (ch->m_pkTimedEvent)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("ĂëĽŇ µÇľú˝Ŕ´Ď´Ů."));
- event_cancel(&ch->m_pkTimedEvent);
- return;
- }
- switch (subcmd)
- {
- case SCMD_LOGOUT:
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("·Î±×ŔΠȸéŔ¸·Î µąľĆ °©´Ď´Ů. Ŕá˝Ă¸¸ ±â´Ů¸®ĽĽżä."));
- break;
- case SCMD_QUIT:
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("°ÔŔÓŔ» Áľ·á ÇŐ´Ď´Ů. Ŕá˝Ă¸¸ ±â´Ů¸®ĽĽżä."));
- break;
- case SCMD_PHASE_SELECT:
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("Äł¸ŻĹ͸¦ ŔüČŻ ÇŐ´Ď´Ů. Ŕá˝Ă¸¸ ±â´Ů¸®ĽĽżä."));
- break;
- }
- int nExitLimitTime = 10;
- if (ch->IsHack(false, true, nExitLimitTime) &&
- false == CThreeWayWar::instance().IsSungZiMapIndex(ch->GetMapIndex()) &&
- (!ch->GetWarMap() || ch->GetWarMap()->GetType() == GUILD_WAR_TYPE_FLAG))
- {
- return;
- }
- switch (subcmd)
- {
- case SCMD_LOGOUT:
- case SCMD_QUIT:
- case SCMD_PHASE_SELECT:
- {
- TimedEventInfo* info = AllocEventInfo<TimedEventInfo>();
- {
- if (ch->IsPosition(POS_FIGHTING))
- info->left_second = 10;
- else
- info->left_second = 3;
- }
- info->ch = ch;
- info->subcmd = subcmd;
- strlcpy(info->szReason, argument, sizeof(info->szReason));
- ch->m_pkTimedEvent = event_create(timed_event, info, 1);
- }
- break;
- }
- }
- ACMD(do_mount)
- {
- /*
- char arg1[256];
- struct action_mount_param param;
- // ŔĚąĚ Ĺ¸°í ŔÖŔ¸¸é
- if (ch->GetMountingChr())
- {
- char arg2[256];
- two_arguments(argument, arg1, sizeof(arg1), arg2, sizeof(arg2));
- if (!*arg1 || !*arg2)
- return;
- param.x = atoi(arg1);
- param.y = atoi(arg2);
- param.vid = ch->GetMountingChr()->GetVID();
- param.is_unmount = true;
- float distance = DISTANCE_SQRT(param.x - (DWORD) ch->GetX(), param.y - (DWORD) ch->GetY());
- if (distance > 600.0f)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("Á» ´ő °ˇ±îŔĚ °ˇĽ ł»¸®ĽĽżä."));
- return;
- }
- action_enqueue(ch, ACTION_TYPE_MOUNT, ¶m, 0.0f, true);
- return;
- }
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- return;
- LPCHARACTER tch = CHARACTER_MANAGER::instance().Find(atoi(arg1));
- if (!tch->IsNPC() || !tch->IsMountable())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("°Ĺ±âżˇ´Â Ĺ» Ľö ľřľîżä."));
- return;
- }
- float distance = DISTANCE_SQRT(tch->GetX() - ch->GetX(), tch->GetY() - ch->GetY());
- if (distance > 600.0f)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("Á» ´ő °ˇ±îŔĚ °ˇĽ ŸĽĽżä."));
- return;
- }
- param.vid = tch->GetVID();
- param.is_unmount = false;
- action_enqueue(ch, ACTION_TYPE_MOUNT, ¶m, 0.0f, true);
- */
- }
- ACMD(do_fishing)
- {
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- return;
- ch->SetRotation(atof(arg1));
- ch->fishing();
- }
- ACMD(do_console)
- {
- ch->ChatPacket(CHAT_TYPE_COMMAND, "ConsoleEnable");
- }
- ACMD(do_restart)
- {
- if (false == ch->IsDead())
- {
- ch->ChatPacket(CHAT_TYPE_COMMAND, "CloseRestartWindow");
- ch->StartRecoveryEvent();
- return;
- }
- if (NULL == ch->m_pkDeadEvent)
- return;
- int iTimeToDead = (event_time(ch->m_pkDeadEvent) / passes_per_sec);
- if (subcmd != SCMD_RESTART_TOWN && (!ch->GetWarMap() || ch->GetWarMap()->GetType() == GUILD_WAR_TYPE_FLAG))
- {
- if (!test_server)
- {
- if (ch->IsHack())
- {
- //ĽşÁö ¸ĘŔĎ°ćżěżˇ´Â ĂĽĹ© ÇĎÁö ľĘ´Â´Ů.
- if (false == CThreeWayWar::instance().IsSungZiMapIndex(ch->GetMapIndex()))
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("ľĆÁ÷ Ŕç˝ĂŔŰ ÇŇ Ľö ľř˝Ŕ´Ď´Ů. (%dĂĘ ł˛Ŕ˝)"), iTimeToDead - (180 - g_nPortalLimitTime));
- return;
- }
- }
- if (iTimeToDead > 179)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("ľĆÁ÷ Ŕç˝ĂŔŰ ÇŇ Ľö ľř˝Ŕ´Ď´Ů. (%dĂĘ ł˛Ŕ˝)"), iTimeToDead - 170);
- return;
- }
- }
- }
- //PREVENT_HACK
- //DESC : â°í, ±łČŻ â ČÄ Ć÷Ĺ»Ŕ» »çżëÇĎ´Â ąö±×żˇ ŔĚżëµÉĽö ŔÖľîĽ
- // ÄđŸŔÓŔ» Ăß°ˇ
- if (subcmd == SCMD_RESTART_TOWN)
- {
- if (ch->IsHack())
- {
- //±ćµĺ¸Ę, ĽşÁö¸ĘżˇĽ´Â ĂĽĹ© ÇĎÁö ľĘ´Â´Ů.
- if ((!ch->GetWarMap() || ch->GetWarMap()->GetType() == GUILD_WAR_TYPE_FLAG) ||
- false == CThreeWayWar::instance().IsSungZiMapIndex(ch->GetMapIndex()))
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("ľĆÁ÷ Ŕç˝ĂŔŰ ÇŇ Ľö ľř˝Ŕ´Ď´Ů. (%dĂĘ ł˛Ŕ˝)"), iTimeToDead - (180 - g_nPortalLimitTime));
- return;
- }
- }
- if (iTimeToDead > 179)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("ľĆÁ÷ ¸¶Ŕ»żˇĽ Ŕç˝ĂŔŰ ÇŇ Ľö ľř˝Ŕ´Ď´Ů. (%d ĂĘ ł˛Ŕ˝)"), iTimeToDead - 173);
- return;
- }
- }
- //END_PREVENT_HACK
- ch->ChatPacket(CHAT_TYPE_COMMAND, "CloseRestartWindow");
- ch->GetDesc()->SetPhase(PHASE_GAME);
- ch->SetPosition(POS_STANDING);
- ch->StartRecoveryEvent();
- //FORKED_LOAD
- //DESC: »ď°Ĺ¸® ŔüĹő˝Ă şÎČ°Ŕ» ÇŇ°ćżě ¸ĘŔÇ ŔÔ±¸°ˇ ľĆ´Ń »ď°Ĺ¸® ŔüĹőŔÇ ˝ĂŔŰÁöÁˇŔ¸·Î Ŕ̵żÇĎ°Ô µČ´Ů.
- if (1 == quest::CQuestManager::instance().GetEventFlag("threeway_war"))
- {
- if (subcmd == SCMD_RESTART_TOWN || subcmd == SCMD_RESTART_HERE)
- {
- if (true == CThreeWayWar::instance().IsThreeWayWarMapIndex(ch->GetMapIndex()) &&
- false == CThreeWayWar::instance().IsSungZiMapIndex(ch->GetMapIndex()))
- {
- ch->WarpSet(EMPIRE_START_X(ch->GetEmpire()), EMPIRE_START_Y(ch->GetEmpire()));
- ch->ReviveInvisible(5);
- #ifdef ENABLE_MOUNT_COSTUME_SYSTEM
- ch->CheckMount();
- #endif
- ch->PointChange(POINT_HP, ch->GetMaxHP() - ch->GetHP());
- ch->PointChange(POINT_SP, ch->GetMaxSP() - ch->GetSP());
- return;
- }
- //ĽşÁö
- if (true == CThreeWayWar::instance().IsSungZiMapIndex(ch->GetMapIndex()))
- {
- if (CThreeWayWar::instance().GetReviveTokenForPlayer(ch->GetPlayerID()) <= 0)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("ĽşÁöżˇĽ şÎČ° ±âȸ¸¦ ¸đµÎ ŔŇľú˝Ŕ´Ď´Ů! ¸¶Ŕ»·Î Ŕ̵żÇŐ´Ď´Ů!"));
- ch->WarpSet(EMPIRE_START_X(ch->GetEmpire()), EMPIRE_START_Y(ch->GetEmpire()));
- }
- else
- {
- ch->Show(ch->GetMapIndex(), GetSungziStartX(ch->GetEmpire()), GetSungziStartY(ch->GetEmpire()));
- }
- ch->PointChange(POINT_HP, ch->GetMaxHP() - ch->GetHP());
- ch->PointChange(POINT_SP, ch->GetMaxSP() - ch->GetSP());
- ch->ReviveInvisible(5);
- #ifdef ENABLE_MOUNT_COSTUME_SYSTEM
- ch->CheckMount();
- #endif
- return;
- }
- }
- }
- //END_FORKED_LOAD
- if (ch->GetDungeon())
- ch->GetDungeon()->UseRevive(ch);
- if (ch->GetWarMap() && !ch->IsObserverMode())
- {
- CWarMap * pMap = ch->GetWarMap();
- DWORD dwGuildOpponent = pMap ? pMap->GetGuildOpponent(ch) : 0;
- if (dwGuildOpponent)
- {
- switch (subcmd)
- {
- case SCMD_RESTART_TOWN:
- sys_log(0, "do_restart: restart town");
- PIXEL_POSITION pos;
- if (CWarMapManager::instance().GetStartPosition(ch->GetMapIndex(), ch->GetGuild()->GetID() < dwGuildOpponent ? 0 : 1, pos))
- ch->Show(ch->GetMapIndex(), pos.x, pos.y);
- else
- ch->ExitToSavedLocation();
- ch->PointChange(POINT_HP, ch->GetMaxHP() - ch->GetHP());
- ch->PointChange(POINT_SP, ch->GetMaxSP() - ch->GetSP());
- ch->ReviveInvisible(5);
- #ifdef ENABLE_MOUNT_COSTUME_SYSTEM
- ch->CheckMount();
- #endif
- break;
- case SCMD_RESTART_HERE:
- sys_log(0, "do_restart: restart here");
- ch->RestartAtSamePos();
- //ch->Show(ch->GetMapIndex(), ch->GetX(), ch->GetY());
- ch->PointChange(POINT_HP, ch->GetMaxHP() - ch->GetHP());
- ch->PointChange(POINT_SP, ch->GetMaxSP() - ch->GetSP());
- ch->ReviveInvisible(5);
- #ifdef ENABLE_MOUNT_COSTUME_SYSTEM
- ch->CheckMount();
- #endif
- break;
- }
- return;
- }
- }
- switch (subcmd)
- {
- case SCMD_RESTART_TOWN:
- sys_log(0, "do_restart: restart town");
- PIXEL_POSITION pos;
- if (SECTREE_MANAGER::instance().GetRecallPositionByEmpire(ch->GetMapIndex(), ch->GetEmpire(), pos))
- ch->WarpSet(pos.x, pos.y);
- else
- ch->WarpSet(EMPIRE_START_X(ch->GetEmpire()), EMPIRE_START_Y(ch->GetEmpire()));
- ch->PointChange(POINT_HP, ch->GetMaxHP() - ch->GetHP());
- ch->DeathPenalty(1);
- break;
- case SCMD_RESTART_HERE:
- sys_log(0, "do_restart: restart here");
- ch->RestartAtSamePos();
- //ch->Show(ch->GetMapIndex(), ch->GetX(), ch->GetY());
- ch->PointChange(POINT_HP, ch->GetMaxHP() - ch->GetHP());
- ch->DeathPenalty(0);
- ch->ReviveInvisible(5);
- #ifdef ENABLE_MOUNT_COSTUME_SYSTEM
- ch->CheckMount();
- #endif
- break;
- }
- }
- #define MAX_STAT 128
- ACMD(do_stat_reset)
- {
- ch->PointChange(POINT_STAT_RESET_COUNT, 12 - ch->GetPoint(POINT_STAT_RESET_COUNT));
- }
- ACMD(do_stat_minus)
- {
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- return;
- if (ch->IsPolymorphed())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("µĐ°© Áßżˇ´Â ´É·ÂŔ» żĂ¸± Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- if (ch->GetPoint(POINT_STAT_RESET_COUNT) <= 0)
- return;
- if (!strcmp(arg1, "st"))
- {
- if (ch->GetRealPoint(POINT_ST) <= JobInitialPoints[ch->GetJob()].st)
- return;
- ch->SetRealPoint(POINT_ST, ch->GetRealPoint(POINT_ST) - 1);
- ch->SetPoint(POINT_ST, ch->GetPoint(POINT_ST) - 1);
- ch->ComputePoints();
- ch->PointChange(POINT_ST, 0);
- }
- else if (!strcmp(arg1, "dx"))
- {
- if (ch->GetRealPoint(POINT_DX) <= JobInitialPoints[ch->GetJob()].dx)
- return;
- ch->SetRealPoint(POINT_DX, ch->GetRealPoint(POINT_DX) - 1);
- ch->SetPoint(POINT_DX, ch->GetPoint(POINT_DX) - 1);
- ch->ComputePoints();
- ch->PointChange(POINT_DX, 0);
- }
- else if (!strcmp(arg1, "ht"))
- {
- if (ch->GetRealPoint(POINT_HT) <= JobInitialPoints[ch->GetJob()].ht)
- return;
- ch->SetRealPoint(POINT_HT, ch->GetRealPoint(POINT_HT) - 1);
- ch->SetPoint(POINT_HT, ch->GetPoint(POINT_HT) - 1);
- ch->ComputePoints();
- ch->PointChange(POINT_HT, 0);
- ch->PointChange(POINT_MAX_HP, 0);
- }
- else if (!strcmp(arg1, "iq"))
- {
- if (ch->GetRealPoint(POINT_IQ) <= JobInitialPoints[ch->GetJob()].iq)
- return;
- ch->SetRealPoint(POINT_IQ, ch->GetRealPoint(POINT_IQ) - 1);
- ch->SetPoint(POINT_IQ, ch->GetPoint(POINT_IQ) - 1);
- ch->ComputePoints();
- ch->PointChange(POINT_IQ, 0);
- ch->PointChange(POINT_MAX_SP, 0);
- }
- else
- return;
- ch->PointChange(POINT_STAT, +1);
- ch->PointChange(POINT_STAT_RESET_COUNT, -1);
- ch->ComputePoints();
- }
- ACMD(do_stat)
- {
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- return;
- if (ch->IsPolymorphed())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("µĐ°© Áßżˇ´Â ´É·ÂŔ» żĂ¸± Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- if (ch->GetPoint(POINT_STAT) <= 0)
- return;
- BYTE idx = 0;
- if (!strcmp(arg1, "st"))
- idx = POINT_ST;
- else if (!strcmp(arg1, "dx"))
- idx = POINT_DX;
- else if (!strcmp(arg1, "ht"))
- idx = POINT_HT;
- else if (!strcmp(arg1, "iq"))
- idx = POINT_IQ;
- else
- return;
- if (ch->GetRealPoint(idx) >= MAX_STAT)
- return;
- ch->SetRealPoint(idx, ch->GetRealPoint(idx) + 1);
- ch->SetPoint(idx, ch->GetPoint(idx) + 1);
- ch->ComputePoints();
- ch->PointChange(idx, 0);
- if (idx == POINT_IQ)
- {
- ch->PointChange(POINT_MAX_HP, 0);
- }
- else if (idx == POINT_HT)
- {
- ch->PointChange(POINT_MAX_SP, 0);
- }
- ch->PointChange(POINT_STAT, -1);
- ch->ComputePoints();
- }
- #ifdef ENABLE_PVP_ADVANCED
- #include <string>
- #include <algorithm>
- #include <boost/algorithm/string/replace.hpp>
- const char* m_nDuelTranslate[] = /* You can translate here */
- {
- "[Ty] Pieniądze musza być w liczbach",
- "[Ty] Wprowadzona ilość jest mniejsza niż 0.",
- "[Ty] Wprowadzona kwota jest równa maksymalnej możliwej wartości w ekwipunku.",
- "[Ty] Wprowadzona kwota jest mniejsza niż kwota, którą posiadasz w ekwipunku.",
- "[Ty] Wprowadzona kwota + środki bieżące jest większa niż maksymalna możliwa kwota w ekwipunku.",
- "[Gracz] Wprowadzona kwota + środki bieżące jest większa niż maksymalna możliwa kwota w ekwipunku.",
- "[Gracz] Wprowadzona kwota jest mniejsza niż kwota, którą gracz posiada w ekwipunku.",
- "Jesteś w Pojedynku.",
- "Gracz był już w pojedynku, nie możesz wysłać mu zaproszenia.",
- "Podgląd Ekwipunku Zablokowany.",
- "Podgląd Ekwipunku Zablokowany, Nikt nie będzie wstanie zobaczyć twojego ekwipunku",
- "Podgląd Ekwipunku Odblokowany, Wszyscy będą mogli go zobaczyć.",
- "Podgląd Ekwipunku Odblokowany."
- };
- const char* szTableStaticPvP[] = {BLOCK_CHANGEITEM, BLOCK_BUFF, BLOCK_POTION, BLOCK_RIDE, BLOCK_PET, BLOCK_POLY, BLOCK_PARTY, BLOCK_EXCHANGE_, BET_WINNER, CHECK_IS_FIGHT};
- void Duel_SendMessage(LPCHARACTER ch, const char* msg)
- {
- if (!ch)
- return;
- std::string textLine;
- textLine = msg;
- boost::algorithm::replace_all(textLine, " ", "$");
- char buf[512+1];
- snprintf(buf, sizeof(buf), "BINARY_Duel_SendMessage %s", textLine.c_str());
- ch->ChatPacket(CHAT_TYPE_COMMAND, buf);
- }
- ACMD(do_pvp)
- {
- if (!ch)
- return;
- if (ch->GetArena() != NULL || CArenaManager::instance().IsArenaMap(ch->GetMapIndex()) == true)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("´ë·ĂŔ忡Ľ »çżëÇĎ˝Ç Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- char arg1[256], arg2[256], arg3[256], arg4[256], arg5[256], arg6[256], arg7[256], arg8[256], arg9[256], arg10[256];
- pvp_arguments(argument, arg1, sizeof(arg1), arg2, sizeof(arg2), arg3, sizeof(arg3), arg4, sizeof(arg4), arg5, sizeof(arg5), arg6, sizeof(arg6), arg7, sizeof(arg7), arg8, sizeof(arg8), arg9, sizeof(arg9), arg10, sizeof(arg10));
- DWORD vid = 0;
- str_to_number(vid, arg1);
- LPCHARACTER pkVictim = CHARACTER_MANAGER::instance().Find(vid);
- if (!pkVictim)
- return;
- if (pkVictim->IsNPC())
- return;
- if (pkVictim->GetArena() != NULL)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("???? ??????."));
- return;
- }
- if (ch->GetExchange() || pkVictim->GetExchange())
- {
- CPVPManager::instance().Decline(ch, pkVictim);
- CPVPManager::instance().Decline(pkVictim, ch);
- return;
- }
- if (*arg2 && !strcmp(arg2, "accept"))
- {
- int chA_nBetMoney = ch->GetQuestFlag(szTableStaticPvP[8]);
- int chB_nBetMoney = pkVictim->GetQuestFlag(szTableStaticPvP[8]);
- if ((ch->GetGold() < chA_nBetMoney) || (pkVictim->GetGold() < chB_nBetMoney))
- {
- ch->ChatPacket(CHAT_TYPE_INFO, "<PvP> Can't start duel because something is wrong with bet money.");
- pkVictim->ChatPacket(CHAT_TYPE_INFO, "<PvP> Can't start duel because something is wrong with bet money.");
- CPVPManager::instance().Decline(ch, pkVictim);
- CPVPManager::instance().Decline(pkVictim, ch);
- return;
- }
- ch->SetDuel("IsFight", 1);
- pkVictim->SetDuel("IsFight", 1);
- if (chA_nBetMoney > 0 && chA_nBetMoney > 0)
- {
- ch->PointChange(POINT_GOLD, - chA_nBetMoney, true);
- pkVictim->PointChange(POINT_GOLD, - chB_nBetMoney, true);
- }
- CPVPManager::instance().Insert(ch, pkVictim);
- return;
- }
- int m_BlockChangeItem = 0, m_BlockBuff = 0, m_BlockPotion = 0, m_BlockRide = 0, m_BlockPet = 0, m_BlockPoly = 0, m_BlockParty = 0, m_BlockExchange = 0, m_BetMoney = 0;
- str_to_number(m_BlockChangeItem, arg2);
- str_to_number(m_BlockBuff, arg3);
- str_to_number(m_BlockPotion, arg4);
- str_to_number(m_BlockRide, arg5);
- str_to_number(m_BlockPet, arg6);
- str_to_number(m_BlockPoly, arg7);
- str_to_number(m_BlockParty, arg8);
- str_to_number(m_BlockExchange, arg9);
- str_to_number(m_BetMoney, arg10);
- if (!isdigit(*arg2) && !isdigit(*arg3) && !isdigit(*arg4) && !isdigit(*arg5) && !isdigit(*arg6) && !isdigit(*arg7) && !isdigit(*arg8) && !isdigit(*arg9) && !isdigit(*arg10))
- {
- Duel_SendMessage(ch, m_nDuelTranslate[0]);
- return;
- }
- if (m_BetMoney < 0)
- {
- Duel_SendMessage(ch, m_nDuelTranslate[1]);
- return;
- }
- if (m_BetMoney >= GOLD_MAX)
- {
- Duel_SendMessage(ch, m_nDuelTranslate[2]);
- return;
- }
- if (ch->GetGold() < GOLD_MAX)
- {
- Duel_SendMessage(ch, m_nDuelTranslate[3]);
- return;
- }
- if ((ch->GetGold() + m_BetMoney) > GOLD_MAX)
- {
- Duel_SendMessage(ch, m_nDuelTranslate[4]);
- return;
- }
- if ((pkVictim->GetGold() + m_BetMoney) > GOLD_MAX)
- {
- Duel_SendMessage(ch, m_nDuelTranslate[5]);
- return;
- }
- if (pkVictim->GetGold() < m_BetMoney)
- {
- Duel_SendMessage(ch, m_nDuelTranslate[6]);
- return;
- }
- if (*arg1 && *arg2 && *arg3 && *arg4 && *arg5 && *arg6 && *arg7 && *arg8 && *arg9 && *arg10)
- {
- ch->SetDuel("BlockChangeItem", m_BlockChangeItem); ch->SetDuel("BlockBuff", m_BlockBuff);
- ch->SetDuel("BlockPotion", m_BlockPotion); ch->SetDuel("BlockRide", m_BlockRide);
- ch->SetDuel("BlockPet", m_BlockPet); ch->SetDuel("BlockPoly", m_BlockPoly);
- ch->SetDuel("BlockParty", m_BlockParty); ch->SetDuel("BlockExchange", m_BlockExchange);
- ch->SetDuel("BetMoney", m_BetMoney);
- pkVictim->SetDuel("BlockChangeItem", m_BlockChangeItem); pkVictim->SetDuel("BlockBuff", m_BlockBuff);
- pkVictim->SetDuel("BlockPotion", m_BlockPotion); pkVictim->SetDuel("BlockRide", m_BlockRide);
- pkVictim->SetDuel("BlockPet", m_BlockPet); pkVictim->SetDuel("BlockPoly", m_BlockPoly);
- pkVictim->SetDuel("BlockParty", m_BlockParty); pkVictim->SetDuel("BlockExchange", m_BlockExchange);
- pkVictim->SetDuel("BetMoney", m_BetMoney);
- CPVPManager::instance().Insert(ch, pkVictim);
- }
- }
- ACMD(do_pvp_advanced)
- {
- if (!ch)
- return;
- if (ch->GetArena() != NULL || CArenaManager::instance().IsArenaMap(ch->GetMapIndex()) == true)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("????? ???? ? ????."));
- return;
- }
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- DWORD vid = 0;
- str_to_number(vid, arg1);
- LPCHARACTER pkVictim = CHARACTER_MANAGER::instance().Find(vid);
- if (!pkVictim)
- return;
- if (pkVictim->IsNPC())
- return;
- if (pkVictim->GetArena() != NULL)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("???? ??????."));
- return;
- }
- if (ch->GetQuestFlag(szTableStaticPvP[9]) > 0)
- {
- Duel_SendMessage(ch, m_nDuelTranslate[7]);
- return;
- }
- if (pkVictim->GetQuestFlag(szTableStaticPvP[9]) > 0)
- {
- Duel_SendMessage(ch, m_nDuelTranslate[8]);
- return;
- }
- int statusEq = pkVictim->GetQuestFlag(BLOCK_EQUIPMENT_);
- CGuild * g = pkVictim->GetGuild();
- const char* m_Name = pkVictim->GetName();
- const char* m_GuildName = "-";
- int m_Vid = pkVictim->GetVID();
- int m_Level = pkVictim->GetLevel();
- int m_PlayTime = pkVictim->GetRealPoint(POINT_PLAYTIME);
- int m_MaxHP = pkVictim->GetMaxHP();
- int m_MaxSP = pkVictim->GetMaxSP();
- DWORD m_Race = pkVictim->GetRaceNum();
- if (g)
- {
- ch->ChatPacket(CHAT_TYPE_COMMAND, "BINARY_Duel_GetInfo %d %s %s %d %d %d %d %d", m_Vid, m_Name, g->GetName(), m_Level, m_Race, m_PlayTime, m_MaxHP, m_MaxSP);
- if (statusEq < 1)
- pkVictim->SendEquipment(ch);
- }
- else
- ch->ChatPacket(CHAT_TYPE_COMMAND, "BINARY_Duel_GetInfo %d %s %s %d %d %d %d %d", m_Vid, m_Name, m_GuildName, m_Level, m_Race, m_PlayTime, m_MaxHP, m_MaxSP);
- if (statusEq < 1)
- pkVictim->SendEquipment(ch);
- }
- ACMD(do_decline_pvp)
- {
- if (!ch)
- return;
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- return;
- DWORD vid = 0;
- str_to_number(vid, arg1);
- LPCHARACTER pkVictim = CHARACTER_MANAGER::instance().Find(vid);
- if (!pkVictim)
- return;
- if (pkVictim->IsNPC())
- return;
- CPVPManager::instance().Decline(ch, pkVictim);
- }
- ACMD(do_block_equipment)
- {
- if (!ch)
- return;
- char arg1[256];
- one_argument (argument, arg1, sizeof(arg1));
- if (!ch->IsPC() || NULL == ch)
- return;
- int statusEq = ch->GetQuestFlag(BLOCK_EQUIPMENT_);
- if (!strcmp(arg1, "BLOCK"))
- {
- if (statusEq > 0)
- {
- Duel_SendMessage(ch, m_nDuelTranslate[9]);
- return;
- }
- else
- ch->SetQuestFlag(BLOCK_EQUIPMENT_, 1);
- Duel_SendMessage(ch, m_nDuelTranslate[10]);
- }
- if (!strcmp(arg1, "UNBLOCK"))
- {
- if (statusEq == 0)
- {
- Duel_SendMessage(ch, m_nDuelTranslate[12]);
- return;
- }
- else
- ch->SetQuestFlag(BLOCK_EQUIPMENT_, 0);
- Duel_SendMessage(ch, m_nDuelTranslate[11]);
- }
- }
- #endif
- ACMD(do_guildskillup)
- {
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- return;
- if (!ch->GetGuild())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<±ćµĺ> ±ćµĺżˇ ĽÓÇŘŔÖÁö ľĘ˝Ŕ´Ď´Ů."));
- return;
- }
- CGuild* g = ch->GetGuild();
- TGuildMember* gm = g->GetMember(ch->GetPlayerID());
- if (gm->grade == GUILD_LEADER_GRADE)
- {
- DWORD vnum = 0;
- str_to_number(vnum, arg1);
- g->SkillLevelUp(vnum);
- }
- else
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<±ćµĺ> ±ćµĺ ˝şĹł ·ąş§Ŕ» şŻ°ćÇŇ ±ÇÇŃŔĚ ľř˝Ŕ´Ď´Ů."));
- }
- }
- ACMD(do_skillup)
- {
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- return;
- DWORD vnum = 0;
- str_to_number(vnum, arg1);
- if (true == ch->CanUseSkill(vnum))
- {
- ch->SkillLevelUp(vnum);
- }
- else
- {
- switch(vnum)
- {
- case SKILL_HORSE_WILDATTACK:
- case SKILL_HORSE_CHARGE:
- case SKILL_HORSE_ESCAPE:
- case SKILL_HORSE_WILDATTACK_RANGE:
- case SKILL_7_A_ANTI_TANHWAN:
- case SKILL_7_B_ANTI_AMSEOP:
- case SKILL_7_C_ANTI_SWAERYUNG:
- case SKILL_7_D_ANTI_YONGBI:
- case SKILL_8_A_ANTI_GIGONGCHAM:
- case SKILL_8_B_ANTI_YEONSA:
- case SKILL_8_C_ANTI_MAHWAN:
- case SKILL_8_D_ANTI_BYEURAK:
- case SKILL_ADD_HP:
- case SKILL_RESIST_PENETRATE:
- ch->SkillLevelUp(vnum);
- break;
- }
- }
- }
- //
- // @version 05/06/20 Bang2ni - Äż¸Çµĺ Ăł¸® Delegate to CHARACTER class
- //
- ACMD(do_safebox_close)
- {
- ch->CloseSafebox();
- }
- //
- // @version 05/06/20 Bang2ni - Äż¸Çµĺ Ăł¸® Delegate to CHARACTER class
- //
- ACMD(do_safebox_password)
- {
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- ch->ReqSafeboxLoad(arg1);
- }
- ACMD(do_safebox_change_password)
- {
- char arg1[256];
- char arg2[256];
- two_arguments(argument, arg1, sizeof(arg1), arg2, sizeof(arg2));
- if (!*arg1 || strlen(arg1)>6)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<â°í> Ŕ߸řµČ ľĎČŁ¸¦ ŔÔ·ÂÇĎĽĚ˝Ŕ´Ď´Ů."));
- return;
- }
- if (!*arg2 || strlen(arg2)>6)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<â°í> Ŕ߸řµČ ľĎČŁ¸¦ ŔÔ·ÂÇĎĽĚ˝Ŕ´Ď´Ů."));
- return;
- }
- if (LC_IsBrazil() == true)
- {
- for (int i = 0; i < 6; ++i)
- {
- if (arg2[i] == '\0')
- break;
- if (isalpha(arg2[i]) == false)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<â°í> şńąĐąřČŁ´Â żµą®ŔÚ¸¸ °ˇ´ÉÇŐ´Ď´Ů."));
- return;
- }
- }
- }
- TSafeboxChangePasswordPacket p;
- p.dwID = ch->GetDesc()->GetAccountTable().id;
- strlcpy(p.szOldPassword, arg1, sizeof(p.szOldPassword));
- strlcpy(p.szNewPassword, arg2, sizeof(p.szNewPassword));
- db_clientdesc->DBPacket(HEADER_GD_SAFEBOX_CHANGE_PASSWORD, ch->GetDesc()->GetHandle(), &p, sizeof(p));
- }
- ACMD(do_mall_password)
- {
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1 || strlen(arg1) > 6)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<â°í> Ŕ߸řµČ ľĎČŁ¸¦ ŔÔ·ÂÇĎĽĚ˝Ŕ´Ď´Ů."));
- return;
- }
- int iPulse = thecore_pulse();
- if (ch->GetMall())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<â°í> â°í°ˇ ŔĚąĚ ż·ÁŔÖ˝Ŕ´Ď´Ů."));
- return;
- }
- if (iPulse - ch->GetMallLoadTime() < passes_per_sec * 10) // 10ĂĘżˇ ÇŃąř¸¸ żäĂ» °ˇ´É
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<â°í> â°í¸¦ ´ÝŔşÁö 10ĂĘ ľČżˇ´Â ż Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- ch->SetMallLoadTime(iPulse);
- TSafeboxLoadPacket p;
- p.dwID = ch->GetDesc()->GetAccountTable().id;
- strlcpy(p.szLogin, ch->GetDesc()->GetAccountTable().login, sizeof(p.szLogin));
- strlcpy(p.szPassword, arg1, sizeof(p.szPassword));
- db_clientdesc->DBPacket(HEADER_GD_MALL_LOAD, ch->GetDesc()->GetHandle(), &p, sizeof(p));
- }
- ACMD(do_mall_close)
- {
- if (ch->GetMall())
- {
- ch->SetMallLoadTime(thecore_pulse());
- ch->CloseMall();
- ch->Save();
- }
- }
- ACMD(do_ungroup)
- {
- if (!ch->GetParty())
- return;
- if (!CPartyManager::instance().IsEnablePCParty())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<ĆÄĆĽ> Ľąö ą®Á¦·Î ĆÄĆĽ °ü·Ă Ăł¸®¸¦ ÇŇ Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- if (ch->GetDungeon())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<ĆÄĆĽ> ´řŔü ľČżˇĽ´Â ĆÄĆĽżˇĽ łŞ°Ą Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- LPPARTY pParty = ch->GetParty();
- if (pParty->GetMemberCount() == 2)
- {
- // party disband
- CPartyManager::instance().DeleteParty(pParty);
- }
- else
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<ĆÄĆĽ> ĆÄĆĽżˇĽ łŞ°ˇĽĚ˝Ŕ´Ď´Ů."));
- //pParty->SendPartyRemoveOneToAll(ch);
- pParty->Quit(ch->GetPlayerID());
- //pParty->SendPartyRemoveAllToOne(ch);
- }
- }
- #ifdef GIFT_SYSTEM
- #include "db.h"
- #include <string>
- #include <boost/algorithm/string.hpp>
- ACMD(do_gift_show)
- {
- ch->ChatPacket(CHAT_TYPE_COMMAND, "gift_show");
- }
- bool GetGift(LPCHARACTER ch, DWORD id,bool all=false)
- {
- char szSockets[1024] = { '\0' };
- char *tempSockets = szSockets;
- for (int i = 0; i < ITEM_SOCKET_MAX_NUM; i++)
- {
- tempSockets += sprintf(tempSockets, "socket%d", i);
- if (i<ITEM_SOCKET_MAX_NUM - 1)
- tempSockets += sprintf(tempSockets, ",");
- }
- char szAttrs[1024] = { '\0' };
- char *tempAttrs = szAttrs;
- for (int i = 0; i < ITEM_ATTRIBUTE_MAX_NUM; i++)
- {
- if (i < 7)
- tempAttrs += sprintf(tempAttrs, "attrtype%d,attrvalue%d", i, i);
- else
- tempAttrs += sprintf(tempAttrs, "applytype%d,applyvalue%d", i - 7, i - 7);
- if (i<ITEM_ATTRIBUTE_MAX_NUM - 1)
- tempAttrs += sprintf(tempAttrs, ",");
- }
- char query[8192];
- if (!all)
- snprintf(query, sizeof(query), "SELECT id,vnum,count,%s,%s from player_gift where id='%d' and owner_id=%d and status='WAIT'", szSockets, szAttrs, id, ch->GetPlayerID());
- else
- snprintf(query, sizeof(query), "SELECT id,vnum,count,%s,%s from player_gift where owner_id=%d and status='WAIT'", szSockets, szAttrs, ch->GetPlayerID());
- SQLMsg * pkMsg(DBManager::instance().DirectQuery(query));
- SQLResult * pRes = pkMsg->Get();
- if (pRes->uiNumRows > 0)
- {
- ch->SetQuestFlag("gift.time", get_global_time()+(1*pRes->uiNumRows)+2);
- MYSQL_ROW row;
- bool force = false;
- while ((row = mysql_fetch_row(pRes->pSQLResult)) != NULL)
- {
- DWORD vnum, socket[ITEM_SOCKET_MAX_NUM], attr[ITEM_ATTRIBUTE_MAX_NUM][2];
- int col = 0;
- long long count = 0;
- str_to_number(id, row[col++]);
- str_to_number(vnum, row[col++]);
- str_to_number(count, row[col++]);
- if (vnum == 1)
- {
- #ifndef FULL_YANG
- long long nTotalMoney = ch->GetGold()+count;
- if (GOLD_MAX <= nTotalMoney)
- {
- sys_err("[OVERFLOW_GOLD] Overflow (GOLD_MAX) id %u name %s", ch->GetPlayerID(), ch->GetName());
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("20ľď łÉŔ» ĂĘ°úÇĎż© »óÁˇŔ» żĽö°ˇ ľř˝Ŕ´Ď´Ů"));
- return true;
- }
- #endif
- #ifdef FULL_YANG_OWN
- ch->ChangeGold(count);
- #else
- ch->PointChange(POINT_GOLD, count, false);
- #endif
- }
- else {
- if (force)
- continue;
- for (int s = 0; s < ITEM_SOCKET_MAX_NUM; s++)
- str_to_number(socket[s], row[col++]);
- for (int a = 0; a < ITEM_ATTRIBUTE_MAX_NUM; a++)
- {
- str_to_number(attr[a][0], row[col++]);
- str_to_number(attr[a][1], row[col++]);
- }
- LPITEM item = ITEM_MANAGER::instance().CreateItem(vnum, count, 0, true);
- if (item)
- {
- for (int s = 0; s < ITEM_SOCKET_MAX_NUM; s++)
- item->SetSocket(s, socket[s], false);
- item->ClearAttribute();
- for (int a = 0; a < ITEM_ATTRIBUTE_MAX_NUM; a++)
- item->SetForceAttribute(a, attr[a][0], attr[a][1]);
- if (item->IsDragonSoul())
- {
- int iEmptyPos = ch->GetEmptyDragonSoulInventory(item);
- if (iEmptyPos != -1)
- {
- item->AddToCharacter(ch, TItemPos(DRAGON_SOUL_INVENTORY, iEmptyPos));
- }
- else
- {
- M2_DESTROY_ITEM(item);
- if (!ch->DragonSoul_IsQualified())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, "<Gift> %s #3", LC_TEXT( "UNKNOW_ERROR"));
- force = true;
- continue;
- }
- else {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT( "INVENTORY_FULL_ERROR"));
- force = true;
- continue;
- }
- }
- }
- else
- {
- int iEmptyPos = ch->GetEmptyInventory(item->GetSize());
- if (iEmptyPos != -1)
- {
- item->AddToCharacter(ch, TItemPos(INVENTORY, iEmptyPos));
- }
- else
- {
- M2_DESTROY_ITEM(item);
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT( "INVENTORY_FULL_ERROR"));
- force = true;
- continue;
- }
- }
- }
- else
- {
- ch->ChatPacket(CHAT_TYPE_INFO, "<Gift> %s #4", LC_TEXT( "UNKNOW_ERROR"));
- force = true;
- continue;
- }
- }
- DBManager::instance().DirectQuery("UPDATE player_gift SET status='OK',date_get=NOW() where id=%d;", id);
- }
- if (force)
- return true;
- if (all)
- ch->ChatPacket(CHAT_TYPE_INFO,LC_TEXT("GIFT_ADD_ALL_SUCCESS"));
- else
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT( "GIFT_ADD_SUCCESS"));
- ch->SetQuestFlag("gift.time", get_global_time()+2);
- return true;
- }
- return false;
- }
- ACMD(do_gift_get)
- {
- if(ch->GetQuestFlag("gift.time") > get_global_time())
- return;
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- bool full = !isdigit(*arg1);
- DWORD id;
- str_to_number(id, arg1);
- if (GetGift(ch, id,full))
- {
- ch->RefreshGift();
- ch->LoadGiftPage(ch->GetLastGiftPage());
- }
- }
- ACMD(do_gift_refresh)
- {
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- {
- if (ch->GetGiftPages() > 0)
- ch->ChatPacket(CHAT_TYPE_COMMAND, "gift_info %d", ch->GetGiftPages());
- }
- else{
- int page;
- str_to_number(page, arg1);
- ch->LoadGiftPage(page);
- }
- }
- #endif
- #ifdef OFFLINE_SHOP
- void DeleteShop(DWORD id)
- {
- CharacterVectorInteractor i;
- if (CHARACTER_MANAGER::instance().GetCharactersByRaceNum(30000, i))
- {
- CharacterVectorInteractor::iterator it = i.begin();
- while (it != i.end()) {
- LPCHARACTER pc = *it++;
- if (pc)
- if (pc->GetRaceNum() == 30000 && pc->GetPrivShop() == id) {
- pc->DeleteMyShop();
- return;
- }
- }
- }
- TPacketShopClose packet;
- packet.shop_id = id;
- packet.pid = 0;
- db_clientdesc->DBPacket(HEADER_GD_SHOP_CLOSE, 0, &packet, sizeof(packet));
- }
- ACMD(do_close_shop)
- {
- #ifdef ACCOUNT_SHIELD
- if (ch->IsBlockAccount())
- return;
- #endif
- if (ch->IsObserverMode() || ch->GetExchange())
- return;
- DWORD id;
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- {
- ch->CloseMyShop();
- }else{
- str_to_number(id, arg1);
- char pid[4096];
- sprintf(pid, "and player_id=%d", ch->GetPlayerID());
- if (id > 0)
- {
- SQLMsg * pkMsg(DBManager::instance().DirectQuery("SELECT player_id,channel from player_shop WHERE id = %d %s", id, (ch->GetGMLevel() >= SHOP_GM_PRIVILEGES ? "" : pid)));
- SQLResult * pRes = pkMsg->Get();
- if (pRes->uiNumRows > 0)
- DeleteShop(id);
- }
- }
- }
- #include "banword.h"
- ACMD(do_set_name_shop)
- {
- #ifdef ACCOUNT_SHIELD
- if (ch->IsBlockAccount())
- return;
- #endif
- if (ch->IsObserverMode() || ch->GetExchange())
- return;
- DWORD id;
- char arg1[256];
- char arg2[256];
- two_arguments(argument, arg1, sizeof(arg1), arg2, sizeof(arg2));
- if (!*arg1 || !*arg2)
- return;
- str_to_number(id, arg1);
- char pid[4096];
- sprintf(pid, "and player_id=%d", ch->GetPlayerID());
- std::string m_stShopSign(arg2);
- boost::algorithm::replace_all(m_stShopSign, "\\", " ");
- boost::algorithm::replace_all(m_stShopSign, "%", "%%");
- if (m_stShopSign.length()>SHOP_SIGN_MAX_LEN)
- m_stShopSign.resize(SHOP_SIGN_MAX_LEN);
- if (m_stShopSign.length()<1) {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("şńĽÓľîłŞ Ŕşľî°ˇ Ć÷ÇÔµČ »óÁˇ Ŕ̸§Ŕ¸·Î »óÁˇŔ» ż Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- #ifdef STRING_PROTECTION
- if (CBanwordManager::instance().CheckString(m_stShopSign.c_str(), m_stShopSign.length()) != "")
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("şńĽÓľîłŞ Ŕşľî°ˇ Ć÷ÇÔµČ »óÁˇ Ŕ̸§Ŕ¸·Î »óÁˇŔ» ż Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- #else
- if (CBanwordManager::instance().CheckString(m_stShopSign.c_str(), m_stShopSign.length()))
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("şńĽÓľîłŞ Ŕşľî°ˇ Ć÷ÇÔµČ »óÁˇ Ŕ̸§Ŕ¸·Î »óÁˇŔ» ż Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- #endif
- if (id>0)
- {
- SQLMsg * pkMsg(DBManager::instance().DirectQuery("SELECT id,player_id,channel from player_shop WHERE id = %d %s", id, (ch->GetGMLevel() >= SHOP_GM_PRIVILEGES ? "" : pid)));
- SQLResult * pRes = pkMsg->Get();
- if (pRes->uiNumRows > 0)
- {
- char szName[256];
- DBManager::instance().EscapeString(szName, 256, m_stShopSign.c_str(), m_stShopSign.length());
- DBManager::Instance().DirectQuery("UPDATE player_shop SET name='%s' WHERE id=%d", szName, id);
- ch->LoadPrivShops();
- CharacterVectorInteractor i;
- if (CHARACTER_MANAGER::instance().GetCharactersByRaceNum(30000, i))
- {
- CharacterVectorInteractor::iterator it = i.begin();
- while (it != i.end()) {
- LPCHARACTER pc = *it++;
- if (pc)
- if (pc->GetMyShop() && pc->GetPrivShop() == id) {
- pc->SetShopSign(m_stShopSign.c_str());
- return;
- }
- }
- }
- TPacketShopName packet;
- packet.shop_id = id;
- strlcpy(packet.szSign, m_stShopSign.c_str(), sizeof(packet.szSign) - 1);
- db_clientdesc->DBPacket(HEADER_GD_SHOP_NAME, 0, &packet, sizeof(packet));
- }
- }
- }
- ACMD(do_shop_refresh)
- {
- ch->SendShops();
- }
- ACMD(do_gowno_yang)
- {
- if (ch->IsObserverMode() || ch->GetExchange())
- return;
- DWORD id;
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- return;
- str_to_number(id, arg1);
- if (*arg1)
- {
- SQLMsg * pkMsg(DBManager::instance().DirectQuery("SELECT gold from player_shop WHERE id = %d and player_id=%d", id,ch->GetPlayerID()));
- SQLResult * pRes = pkMsg->Get();
- if (pRes->uiNumRows>0)
- {
- MYSQL_ROW row;
- while ((row = mysql_fetch_row(pRes->pSQLResult)) != NULL)
- {
- long long gold;
- str_to_number(gold, row[0]);
- if (gold >0)
- {
- #ifndef FULL_YANG
- long long nTotalMoney = ch->GetGold() + gold;
- if (GOLD_MAX <= nTotalMoney)
- {
- sys_err("[OVERFLOW_GOLD] Overflow (GOLD_MAX) id %u name %s", ch->GetPlayerID(), ch->GetName());
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("20ľď łÉŔ» ĂĘ°úÇĎż© »óÁˇŔ» żĽö°ˇ ľř˝Ŕ´Ď´Ů"));
- return;
- }
- #endif
- #ifdef FULL_YANG_OWN
- ch->ChangeGold(gold);
- #else
- ch->PointChange(POINT_GOLD,gold, false);
- #endif
- TPrivShop s = ch->GetPrivShopTable(id);
- s.gold = s.gold - gold;
- s.rest_count = s.item_count - 1;
- ch->UpdatePrivShopTable(s.shop_id, s);
- ch->SendShops();
- DBManager::instance().DirectQuery("UPDATE player_shop SET gold=gold - %lld WHERE id = %d", gold, id);
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("SHOP_YANG_ADD"));
- }
- }
- }
- }
- }
- #include <boost/algorithm/string.hpp>
- ACMD(do_shop_update_item)
- {
- if (ch->IsObserverMode() || ch->GetExchange() || ch->IsOpenSafebox() || ch->GetShopOwner() || ch->IsCubeOpen() || ch->GetMyShop())
- return;
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- return;
- std::vector<std::string> args;
- boost::split(args, arg1, boost::is_any_of("|"));
- if (args.size()<3) {
- return;
- }
- DWORD shop_id;
- str_to_number(shop_id, args[1].c_str());
- bool myShop=false;
- {
- CharacterVectorInteractor i;
- if (CHARACTER_MANAGER::instance().GetCharactersByRaceNum(30000, i))
- {
- CharacterVectorInteractor::iterator it = i.begin();
- while (it != i.end()) {
- LPCHARACTER pc = *it++;
- if (pc)
- if (pc->GetRaceNum() == 30000 && pc->GetPrivShop() == shop_id) {
- myShop=true;
- break;
- }
- }
- }
- }
- if(!myShop)
- {
- SQLMsg * pkMsg(DBManager::instance().DirectQuery("SELECT id from player_shop WHERE id = %d and player_id=%d", shop_id, ch->GetPlayerID()));
- SQLResult * pRes = pkMsg->Get();
- myShop=pRes->uiNumRows>0;
- }
- if (myShop)
- {
- {
- TPacketShopUpdateItem packet;
- packet.shop_id = shop_id;
- packet.shop_locked = true;
- db_clientdesc->DBPacket(HEADER_GD_SHOP_UPDATE_ITEM, 0, &packet, sizeof(packet));
- }
- /*
- /update_shop_item price|%d|%d|%d)
- /update_shop_item remove|%d|%d
- /update_shop_item add|%d|%d|%d|%d|%s
- */
- if (args.size() == 4)
- {
- DWORD item_id;
- str_to_number(item_id, args[2].c_str());
- long long price;
- str_to_number(price, args[3].c_str());
- if (price <= 0 || item_id <= 0)
- return;
- {
- SQLMsg * pkMsg(DBManager::instance().DirectQuery("SELECT id from player_shop_items WHERE id = %d and shop_id=%d", item_id, shop_id));
- SQLResult * pRes = pkMsg->Get();
- if (pRes->uiNumRows > 0)
- DBManager::instance().DirectQuery("UPDATE player_shop_items SET price=%lld WHERE id = %d and shop_id=%d", price, item_id, shop_id);
- }
- }
- else if (args.size() == 3)
- {
- DWORD item_id;
- str_to_number(item_id, args[2].c_str());
- if (item_id <= 0)
- return;
- {
- std::string shop_name(LC_TEXT( "SHOP_NAME"));
- boost::replace_all(shop_name, "#PLAYER_NAME#", ch->GetName());
- boost::replace_all(shop_name, "#ID#", "");
- char szSockets[1024] = { '\0' };
- char *tempSockets = szSockets;
- for (int i = 0; i < ITEM_SOCKET_MAX_NUM; i++)
- {
- tempSockets += sprintf(tempSockets, "socket%d", i);
- if (i<ITEM_SOCKET_MAX_NUM - 1)
- tempSockets += sprintf(tempSockets, ",");
- }
- char szAttrs[1024] = { '\0' };
- char *tempAttrs = szAttrs;
- for (int i = 0; i < ITEM_ATTRIBUTE_MAX_NUM; i++)
- {
- if (i < 7)
- tempAttrs += sprintf(tempAttrs, "attrtype%d,attrvalue%d", i, i);
- else
- tempAttrs += sprintf(tempAttrs, "applytype%d,applyvalue%d", i - 7, i - 7);
- if (i<ITEM_ATTRIBUTE_MAX_NUM - 1)
- tempAttrs += sprintf(tempAttrs, ",");
- }
- SQLMsg * pkMsg(DBManager::instance().DirectQuery("SELECT vnum,count,%s,%s from player_shop_items where shop_id='%d' and id=%d", szSockets,szAttrs,shop_id, item_id));
- SQLResult * pRes = pkMsg->Get();
- if (pRes->uiNumRows>0)
- {
- MYSQL_ROW row;
- while ((row = mysql_fetch_row(pRes->pSQLResult)) != NULL)
- {
- int col = 0;
- char query[8192];
- sprintf(query, "INSERT INTO player_gift SET owner_id=%d,reason='%s',`from`=replace(\"%s\",' ','_'),status='WAIT',date_add=NOW()", ch->GetPlayerID(), LC_TEXT( "SHOP_ITEM_REASON"), shop_name.c_str());
- sprintf(query, "%s, vnum='%s'", query, row[col++]);
- sprintf(query, "%s, count='%s'", query, row[col++]);
- for (int s = 0; s < ITEM_SOCKET_MAX_NUM; s++)
- sprintf(query, "%s, socket%d='%s'", query, s, row[col++]);
- for (int ia = 0; ia < ITEM_ATTRIBUTE_MAX_NUM; ia++)
- {
- if (ia < 7)
- {
- sprintf(query, "%s, attrtype%d='%s'", query, ia, row[col++]);
- sprintf(query, "%s, attrvalue%d='%s'", query, ia, row[col++]);
- }
- else
- {
- sprintf(query, "%s, applytype%d='%s'", query, ia-7,row[col++]);
- sprintf(query, "%s, applyvalue%d='%s'", query, ia-7,row[col++]);
- }
- }
- SQLMsg * pkMsg(DBManager::instance().DirectQuery(query));
- SQLResult * pRes = pkMsg->Get();
- DWORD gift_id = pRes->uiInsertID;
- if (gift_id > 0)
- GetGift(ch, gift_id);
- DBManager::instance().DirectQuery("delete from player_shop_items where id='%d'", item_id);
- DBManager::instance().DirectQuery("UPDATE player_shop SET item_count=item_count-1 WHERE id = %d", shop_id);
- }
- }
- }
- }
- else if (args.size() == 6)
- {
- BYTE display_pos;
- str_to_number(display_pos, args[2].c_str());
- if (display_pos < 0)
- return;
- WORD pos;
- str_to_number(pos, args[3].c_str());
- if (pos < 0)
- return;
- BYTE window_type;
- str_to_number(window_type, args[4].c_str());
- if (window_type < 0)
- return;
- #ifdef ACCE_LENNT_FIX
- if(ch->IsAcceOpen())
- Acce_close(ch);
- #endif
- long long price;
- str_to_number(price, args[5].c_str());
- if (price <= 0)
- return;
- #ifndef FULL_YANG
- {
- long long nTotalMoney=price;
- SQLMsg * pkMsg(DBManager::instance().DirectQuery("SELECT price from player_shop_items where shop_id='%d'", shop_id));
- SQLResult * pRes = pkMsg->Get();
- if (pRes->uiNumRows>0)
- {
- MYSQL_ROW row;
- while ((row = mysql_fetch_row(pRes->pSQLResult)) != NULL)
- {
- long long temp;
- str_to_number(temp,row[0]);
- nTotalMoney+=temp;
- }
- }
- if (GOLD_MAX <= nTotalMoney)
- {
- sys_err("[OVERFLOW_GOLD] Overflow (GOLD_MAX) id %u name %s", ch->GetPlayerID(), ch->GetName());
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("20ľď łÉŔ» ĂĘ°úÇĎż© »óÁˇŔ» żĽö°ˇ ľř˝Ŕ´Ď´Ů"));
- return;
- }
- }
- #endif
- LPITEM item = ch->GetItem(TItemPos(window_type, pos));
- if (item)
- {
- const TItemTable * item_table = item->GetProto();
- if (item_table && (IS_SET(item_table->dwAntiFlags, ITEM_ANTIFLAG_GIVE | ITEM_ANTIFLAG_MYSHOP)))
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT( "ŔŻ·áČ ľĆŔĚĹŰŔş °łŔλóÁˇżˇĽ ĆǸĹÇŇ Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- if (item->IsEquipped())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT( "ŔĺşńÁßŔÎ ľĆŔĚĹŰŔş °łŔλóÁˇżˇĽ ĆǸĹÇŇ Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- if (item->isLocked())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT( "»çżëÁßŔÎ ľĆŔĚĹŰŔş °łŔλóÁˇżˇĽ ĆǸĹÇŇ Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- if (item->GetOwner() != ch)
- {
- return;
- }
- #ifdef SOULBIND_SYSTEM
- if (item->IsSoulBind())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT( "You can't sell in private shop item with soul bind."));
- return;
- }
- #endif
- char query[1024];
- sprintf(query, "INSERT INTO player_shop_items SET");
- sprintf(query, "%s player_id='%d'", query, ch->GetPlayerID());
- sprintf(query, "%s, shop_id='%d'", query, shop_id);
- sprintf(query, "%s, vnum='%d'", query, item->GetVnum());
- sprintf(query, "%s, count='%d'", query, item->GetCount());
- sprintf(query, "%s, price='%lld'", query, price);
- sprintf(query, "%s, display_pos='%u'", query, display_pos);
- for (int s = 0; s < ITEM_SOCKET_MAX_NUM; s++)
- {
- sprintf(query, "%s, socket%d='%ld'", query, s, item->GetSocket(s));
- }
- for (int ia = 0; ia < ITEM_ATTRIBUTE_MAX_NUM; ia++)
- {
- const TPlayerItemAttribute& attr = item->GetAttribute(ia);
- if (ia < 7)
- {
- sprintf(query, "%s, attrtype%d='%u'", query, ia, attr.bType);
- sprintf(query, "%s, attrvalue%d='%d'", query, ia, attr.sValue);
- }
- else
- {
- sprintf(query, "%s, applytype%d='%u'", query, ia-7, attr.bType);
- sprintf(query, "%s, applyvalue%d='%d'", query, ia-7, attr.sValue);
- }
- }
- DBManager::instance().DirectQuery(query);
- ITEM_MANAGER::Instance().RemoveItem(item, "Priv shop");
- DBManager::instance().DirectQuery("UPDATE player_shop SET item_count=item_count +1 WHERE id = %d", shop_id);
- }
- else
- return;
- }
- else
- return;
- ch->LoadPrivShops();
- char buf[32];
- sprintf(buf, "refresh_shop_items %d", shop_id);
- interpret_command(ch, buf, strlen(buf));
- CharacterVectorInteractor i;
- if (CHARACTER_MANAGER::instance().GetCharactersByRaceNum(30000, i))
- {
- CharacterVectorInteractor::iterator it = i.begin();
- while (it != i.end()) {
- LPCHARACTER pc = *it++;
- if (pc)
- if (pc->GetRaceNum() == 30000 && pc->GetPrivShop() == shop_id) {
- pc->UpdateShopItems();
- return;
- }
- }
- }
- TPacketShopUpdateItem packet;
- packet.shop_id = shop_id;
- packet.shop_locked = false;
- db_clientdesc->DBPacket(HEADER_GD_SHOP_UPDATE_ITEM, 0, &packet, sizeof(packet));
- }
- }
- ACMD(do_shop_refresh_items)
- {
- if (ch->IsObserverMode() || ch->GetExchange() || ch->IsOpenSafebox() || ch->GetShopOwner() || ch->IsCubeOpen() || ch->GetMyShop())
- {
- ch->ChatPacket(CHAT_TYPE_COMMAND, "shop_item_clear");
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("You can't edit shop while you have opened normal shop."));
- return;
- }
- DWORD id;
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- return;
- str_to_number(id, arg1);
- char szSockets[1024] = { '\0' };
- char *tempSockets = szSockets;
- for (int i = 0; i < ITEM_SOCKET_MAX_NUM; i++)
- {
- tempSockets += sprintf(tempSockets, "socket%d", i);
- if (i<ITEM_SOCKET_MAX_NUM - 1)
- tempSockets += sprintf(tempSockets, ",");
- }
- char szAttrs[1024] = { '\0' };
- char *tempAttrs = szAttrs;
- for (int i = 0; i < ITEM_ATTRIBUTE_MAX_NUM; i++)
- {
- if (i < 7)
- tempAttrs += sprintf(tempAttrs, "attrtype%d,attrvalue%d", i, i);
- else
- tempAttrs += sprintf(tempAttrs, "applytype%d,applyvalue%d", i - 7, i - 7);
- if (i<ITEM_ATTRIBUTE_MAX_NUM - 1)
- tempAttrs += sprintf(tempAttrs, ",");
- }
- SQLMsg * pkMsg(DBManager::instance().DirectQuery("SELECT id,vnum,count,display_pos,price,%s,%s from player_shop_items where shop_id='%d'", szSockets,szAttrs,id));
- SQLResult * pRes = pkMsg->Get();
- BYTE bItemCount = pRes->uiNumRows;
- std::vector<TShopItemTable *> map_shop;
- ch->ChatPacket(CHAT_TYPE_COMMAND, "shop_item_clear");
- if (bItemCount>0)
- {
- bItemCount = 0;
- MYSQL_ROW row;
- int c = 0;
- while ((row = mysql_fetch_row(pRes->pSQLResult)) != NULL)
- {
- int col = 5;
- char attrs[1024] = { '\0' };
- char sockets[1024] = { '\0' };
- for (int i = 0; i<ITEM_SOCKET_MAX_NUM; i++)
- sprintf(sockets, "%s%s%s", sockets, row[col++], (i<ITEM_SOCKET_MAX_NUM-1 ? "|" : ""));
- //col--;
- for (int i = 0; i<ITEM_ATTRIBUTE_MAX_NUM; i++)
- sprintf(attrs, "%s%s,%s%s", attrs, row[col++], row[col++], (i<ITEM_ATTRIBUTE_MAX_NUM-1 ? "|" : ""));
- ch->ChatPacket(CHAT_TYPE_COMMAND, "shop_item %s#%s#%s#%s#%s#%s#%s", row[0], row[1], row[2], row[3], row[4], sockets, attrs);
- }
- }
- }
- ACMD(do_shop_update)
- {
- if (ch->IsObserverMode() || ch->GetExchange())
- return;
- DWORD id;
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- return;
- str_to_number(id, arg1);
- if (*arg1)
- {
- SQLMsg * pkMsg(DBManager::instance().DirectQuery("SELECT player_id from player_shop WHERE id = %d", id));
- SQLResult * pRes = pkMsg->Get();
- if (pRes->uiNumRows>0)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, "Shop %s has been updated", arg1);
- CharacterVectorInteractor i;
- if (CHARACTER_MANAGER::instance().GetCharactersByRaceNum(30000, i))
- {
- CharacterVectorInteractor::iterator it = i.begin();
- while (it != i.end()) {
- LPCHARACTER pc = *it++;
- if (pc)
- if (pc->GetRaceNum() == 30000 && pc->GetPrivShop() == id) {
- pc->UpdateShopItems();
- return;
- }
- }
- }
- TPacketShopUpdateItem packet;
- packet.shop_id = id;
- db_clientdesc->DBPacket(HEADER_GD_SHOP_UPDATE_ITEM, 0, &packet, sizeof(packet));
- }
- else
- ch->ChatPacket(CHAT_TYPE_INFO, "Shop %s does exists", arg1);
- }
- }
- ACMD(do_shop_delete)
- {
- if (ch->IsObserverMode() || ch->GetExchange())
- return;
- char arg1[256];
- char arg2[256];
- two_arguments(argument, arg1, sizeof(arg1), arg2, sizeof(arg2));
- if (!*arg1 || !*arg2)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, "Usage:");
- ch->ChatPacket(CHAT_TYPE_INFO, "/delete_shop <type> <arg> ");
- ch->ChatPacket(CHAT_TYPE_INFO, "Types:");
- ch->ChatPacket(CHAT_TYPE_INFO, " shopid - Delete shop using ID");
- ch->ChatPacket(CHAT_TYPE_INFO, " player - Delete all player shops by player name");
- ch->ChatPacket(CHAT_TYPE_INFO, "Example:");
- ch->ChatPacket(CHAT_TYPE_INFO, " /delete_shop player Best4ever");
- ch->ChatPacket(CHAT_TYPE_INFO, " /delete_shop shopid 1");
- return;
- }
- if (!strcmp(arg1, "player"))
- {
- SQLMsg * pkMsg(DBManager::instance().DirectQuery("SELECT id from player_shop WHERE player_id=(select id from player where name='%s')", arg2));
- SQLResult * pRes = pkMsg->Get();
- if (pRes->uiNumRows>0)
- {
- MYSQL_ROW row;
- while ((row = mysql_fetch_row(pRes->pSQLResult)) != NULL)
- {
- DWORD id;
- str_to_number(id, row[0]);
- DeleteShop(id);
- }
- }
- else
- ch->ChatPacket(CHAT_TYPE_INFO, "Player %s does have any shop", arg2);
- }
- if (!strcmp(arg1, "shopid"))
- {
- SQLMsg * pkMsg(DBManager::instance().DirectQuery("SELECT id from player_shop WHERE id='%s'", arg2));
- SQLResult * pRes = pkMsg->Get();
- if (pRes->uiNumRows>0)
- {
- MYSQL_ROW row;
- while ((row = mysql_fetch_row(pRes->pSQLResult)) != NULL)
- {
- DWORD id;
- str_to_number(id, arg2);
- DeleteShop(id);
- }
- }
- else
- ch->ChatPacket(CHAT_TYPE_INFO, "Shop %s does exists", arg2);
- }
- }
- #else
- ACMD(do_close_shop)
- {
- if (ch->IsObserverMode())
- return;
- if (ch->GetMyShop())
- {
- ch->CloseMyShop();
- return;
- }
- }
- #endif
- ACMD(do_set_walk_mode)
- {
- ch->SetNowWalking(true);
- ch->SetWalking(true);
- }
- ACMD(do_ch)
- {
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- return;
- int new_ch;
- str_to_number(new_ch, arg1);
- if (!ch)
- ch->ChatPacket(CHAT_TYPE_INFO, "[Change Channel] Kanal jest Offline!");
- return;
- if (ch->GetExchange())
- ch->ChatPacket(CHAT_TYPE_INFO, "[Change Channel] Zamknij okno handlu aby zmienic Channel!");
- return;
- if (ch->IsDead())
- ch->ChatPacket(CHAT_TYPE_INFO, "[Change Channel] Nie zyjesz, nie mozesz zmienic kanalu!");
- return;
- if (ch->GetShop())
- ch->ChatPacket(CHAT_TYPE_INFO, "[Change Channel] Zamknij Okno Handlu aby zmienic Channel!");
- return;
- if (ch->GetMyShop())
- ch->ChatPacket(CHAT_TYPE_INFO, "[Change Channel] Zamknij Okno Handlu aby zmienic Channel!");
- return ;
- if (!ch->IsPC())
- return;
- if( new_ch <1 || new_ch >4)
- return;
- ch->ChannelSwitch(new_ch);
- }
- ACMD(do_set_run_mode)
- {
- ch->SetNowWalking(false);
- ch->SetWalking(false);
- }
- ACMD(do_war)
- {
- //ł» ±ćµĺ Á¤ş¸¸¦ ľňľîżŔ°í
- CGuild * g = ch->GetGuild();
- if (!g)
- return;
- //ŔüŔďÁßŔÎÁö ĂĽĹ©ÇŃąř!
- if (g->UnderAnyWar())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<±ćµĺ> ŔĚąĚ ´Ů¸Ą ŔüŔ£ ÂüŔü Áß ŔÔ´Ď´Ů."));
- return;
- }
- //ĆĶó¸ŢĹ͸¦ µÎąč·Î łŞ´©°í
- char arg1[256], arg2[256];
- unsigned int type = GUILD_WAR_TYPE_FIELD;
- two_arguments(argument, arg1, sizeof(arg1), arg2, sizeof(arg2));
- if (!*arg1)
- return;
- if (*arg2)
- {
- str_to_number(type, arg2);
- if (type >= GUILD_WAR_TYPE_MAX_NUM || type < 0)
- type = GUILD_WAR_TYPE_FIELD;
- }
- //±ćµĺŔÇ ¸¶˝şĹÍ ľĆŔ̵𸦠ľňľîżÂµÚ
- DWORD gm_pid = g->GetMasterPID();
- //¸¶˝şĹÍŔÎÁö ĂĽĹ©(±ćŔüŔş ±ćµĺŔ常ŔĚ °ˇ´É)
- if (gm_pid != ch->GetPlayerID())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<±ćµĺ> ±ćµĺŔüżˇ ´ëÇŃ ±ÇÇŃŔĚ ľř˝Ŕ´Ď´Ů."));
- return;
- }
- //»ó´ë ±ćµĺ¸¦ ľňľîżŔ°í
- CGuild * opp_g = CGuildManager::instance().FindGuildByName(arg1);
- if (!opp_g)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<±ćµĺ> ±×·± ±ćµĺ°ˇ ľř˝Ŕ´Ď´Ů."));
- return;
- }
- //»ó´ë±ćµĺżÍŔÇ »óĹ üũ
- switch (g->GetGuildWarState(opp_g->GetID()))
- {
- case GUILD_WAR_NONE:
- {
- if (opp_g->UnderAnyWar())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<±ćµĺ> »ó´ëąć ±ćµĺ°ˇ ŔĚąĚ ŔüŔď Áß ŔÔ´Ď´Ů."));
- return;
- }
- int iWarPrice = KOR_aGuildWarInfo[type].iWarPrice;
- if (g->GetGuildMoney() < iWarPrice)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<±ćµĺ> Ŕüşń°ˇ şÎÁ·ÇĎż© ±ćµĺŔüŔ» ÇŇ Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- if (opp_g->GetGuildMoney() < iWarPrice)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<±ćµĺ> »ó´ëąć ±ćµĺŔÇ Ŕüşń°ˇ şÎÁ·ÇĎż© ±ćµĺŔüŔ» ÇŇ Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- }
- break;
- case GUILD_WAR_SEND_DECLARE:
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("ŔĚąĚ Ľ±ŔüĆ÷°í ÁßŔÎ ±ćµĺŔÔ´Ď´Ů."));
- return;
- }
- break;
- case GUILD_WAR_RECV_DECLARE:
- {
- if (opp_g->UnderAnyWar())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<±ćµĺ> »ó´ëąć ±ćµĺ°ˇ ŔĚąĚ ŔüŔď Áß ŔÔ´Ď´Ů."));
- g->RequestRefuseWar(opp_g->GetID());
- return;
- }
- }
- break;
- case GUILD_WAR_RESERVE:
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<±ćµĺ> ŔĚąĚ ŔüŔďŔĚ żąľŕµČ ±ćµĺ ŔÔ´Ď´Ů."));
- return;
- }
- break;
- case GUILD_WAR_END:
- return;
- default:
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<±ćµĺ> ŔĚąĚ ŔüŔď ÁßŔÎ ±ćµĺŔÔ´Ď´Ů."));
- g->RequestRefuseWar(opp_g->GetID());
- return;
- }
- if (!g->CanStartWar(type))
- {
- // ±ćµĺŔüŔ» ÇŇ Ľö ŔÖ´Â Á¶°ÇŔ» ¸¸Á·ÇĎÁöľĘ´Â´Ů.
- if (g->GetLadderPoint() == 0)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<±ćµĺ> ·ą´ő ÁˇĽö°ˇ ¸đŔÚ¶óĽ ±ćµĺŔüŔ» ÇŇ Ľö ľř˝Ŕ´Ď´Ů."));
- sys_log(0, "GuildWar.StartError.NEED_LADDER_POINT");
- }
- else if (g->GetMemberCount() < GUILD_WAR_MIN_MEMBER_COUNT)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<±ćµĺ> ±ćµĺŔüŔ» Çϱâ Ŕ§ÇŘĽ± ĂÖĽŇÇŃ %d¸íŔĚ ŔÖľîľß ÇŐ´Ď´Ů."), GUILD_WAR_MIN_MEMBER_COUNT);
- sys_log(0, "GuildWar.StartError.NEED_MINIMUM_MEMBER[%d]", GUILD_WAR_MIN_MEMBER_COUNT);
- }
- else
- {
- sys_log(0, "GuildWar.StartError.UNKNOWN_ERROR");
- }
- return;
- }
- // ÇʵĺŔü ĂĽĹ©¸¸ ÇĎ°í ĽĽĽĽÇŃ ĂĽĹ©´Â »ó´ëąćŔĚ ˝Âł«ÇҶ§ ÇŃ´Ů.
- if (!opp_g->CanStartWar(GUILD_WAR_TYPE_FIELD))
- {
- if (opp_g->GetLadderPoint() == 0)
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<±ćµĺ> »ó´ëąć ±ćµĺŔÇ ·ą´ő ÁˇĽö°ˇ ¸đŔÚ¶óĽ ±ćµĺŔüŔ» ÇŇ Ľö ľř˝Ŕ´Ď´Ů."));
- else if (opp_g->GetMemberCount() < GUILD_WAR_MIN_MEMBER_COUNT)
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<±ćµĺ> »ó´ëąć ±ćµĺŔÇ ±ćµĺżř Ľö°ˇ şÎÁ·ÇĎż© ±ćµĺŔüŔ» ÇŇ Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- do
- {
- if (g->GetMasterCharacter() != NULL)
- break;
- CCI *pCCI = P2P_MANAGER::instance().FindByPID(g->GetMasterPID());
- if (pCCI != NULL)
- break;
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<±ćµĺ> »ó´ëąć ±ćµĺŔÇ ±ćµĺŔĺŔĚ Á˘ĽÓÁßŔĚ ľĆ´Ő´Ď´Ů."));
- g->RequestRefuseWar(opp_g->GetID());
- return;
- } while (false);
- do
- {
- if (opp_g->GetMasterCharacter() != NULL)
- break;
- CCI *pCCI = P2P_MANAGER::instance().FindByPID(opp_g->GetMasterPID());
- if (pCCI != NULL)
- break;
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<±ćµĺ> »ó´ëąć ±ćµĺŔÇ ±ćµĺŔĺŔĚ Á˘ĽÓÁßŔĚ ľĆ´Ő´Ď´Ů."));
- g->RequestRefuseWar(opp_g->GetID());
- return;
- } while (false);
- g->RequestDeclareWar(opp_g->GetID(), type);
- }
- ACMD(do_nowar)
- {
- CGuild* g = ch->GetGuild();
- if (!g)
- return;
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- return;
- DWORD gm_pid = g->GetMasterPID();
- if (gm_pid != ch->GetPlayerID())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<±ćµĺ> ±ćµĺŔüżˇ ´ëÇŃ ±ÇÇŃŔĚ ľř˝Ŕ´Ď´Ů."));
- return;
- }
- CGuild* opp_g = CGuildManager::instance().FindGuildByName(arg1);
- if (!opp_g)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("<±ćµĺ> ±×·± ±ćµĺ°ˇ ľř˝Ŕ´Ď´Ů."));
- return;
- }
- g->RequestRefuseWar(opp_g->GetID());
- }
- ACMD(do_detaillog)
- {
- ch->DetailLog();
- }
- ACMD(do_monsterlog)
- {
- ch->ToggleMonsterLog();
- }
- ACMD(do_pkmode)
- {
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- return;
- BYTE mode = 0;
- str_to_number(mode, arg1);
- if (mode == PK_MODE_PROTECT)
- return;
- if (ch->GetLevel() < PK_PROTECT_LEVEL && mode != 0)
- return;
- ch->SetPKMode(mode);
- }
- ACMD(do_messenger_auth)
- {
- if (ch->GetArena())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("´ë·ĂŔ忡Ľ »çżëÇĎ˝Ç Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- char arg1[256], arg2[256];
- two_arguments(argument, arg1, sizeof(arg1), arg2, sizeof(arg2));
- if (!*arg1 || !*arg2)
- return;
- char answer = LOWER(*arg1);
- if (answer != 'y')
- {
- LPCHARACTER tch = CHARACTER_MANAGER::instance().FindPC(arg2);
- if (tch)
- tch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("%s ´ÔŔ¸·Î şÎĹÍ ÄŁ±¸ µî·ĎŔ» °ĹşÎ ´çÇß˝Ŕ´Ď´Ů."), ch->GetName());
- }
- MessengerManager::instance().AuthToAdd(ch->GetName(), arg2, answer == 'y' ? false : true); // DENY
- }
- #ifdef ENABLE_ONLINE_COMMAND
- ACMD (do_online)
- {
- int mTotalOnline;
- int * mEmpire;
- int mLocal;
- DESC_MANAGER::instance().GetUserCount(mTotalOnline, & mEmpire, mLocal);
- #ifdef ENABLE_ONLINE_COMMAND_BOOST
- int mTotalOnlinePlus = mTotalOnline * ENABLE_ONLINE_COMMAND_BOOST_MULTIPLIER;
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("Online: %d"), mTotalOnlinePlus);
- #else
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("Online: %d"), mTotalOnline);
- #endif
- }
- #endif
- ACMD(do_setblockmode)
- {
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (*arg1)
- {
- BYTE flag = 0;
- str_to_number(flag, arg1);
- ch->SetBlockMode(flag);
- }
- }
- ACMD(do_unmount)
- {
- LPITEM item = ch->GetWear(WEAR_UNIQUE1);
- LPITEM item2 = ch->GetWear(WEAR_UNIQUE2);
- LPITEM item3 = ch->GetWear(WEAR_COSTUME_MOUNT);
- if (item && item->IsRideItem())
- ch->UnequipItem(item);
- if (item2 && item2->IsRideItem())
- ch->UnequipItem(item2);
- if (item3 && item3->IsRideItem())
- ch->UnequipItem(item3);
- if (true == ch->UnEquipSpecialRideUniqueItem())
- {
- ch->RemoveAffect(AFFECT_MOUNT);
- ch->RemoveAffect(AFFECT_MOUNT_BONUS);
- if (ch->IsHorseRiding())
- {
- ch->StopRiding();
- }
- }
- #ifdef ENABLE_MOUNT_COSTUME_SYSTEM
- if(ch->GetWear(WEAR_COSTUME_MOUNT))
- {
- CMountSystem* mountSystem = ch->GetMountSystem();
- LPITEM mount = ch->GetWear(WEAR_COSTUME_MOUNT);
- DWORD mobVnum = 0;
- if (!mountSystem && !mount)
- return;
- #ifdef __CHANGELOOK_SYSTEM__
- if(mount->GetTransmutation())
- {
- const TItemTable* itemTable = ITEM_MANAGER::instance().GetTable(mount->GetTransmutation());
- if (itemTable)
- mobVnum = itemTable->alValues[1];
- else
- mobVnum = mount->GetValue(1);
- }
- else
- mobVnum = mount->GetValue(1);
- #else
- if(mount->GetValue(1) != 0)
- mobVnum = mount->GetValue(1);
- #endif
- if (ch->GetMountVnum())
- {
- if(mountSystem->CountSummoned() == 0)
- {
- mountSystem->Unmount(mobVnum);
- }
- }
- return;
- }
- #endif
- else
- {
- ch->ChatPacket( CHAT_TYPE_INFO, LC_TEXT("ŔÎşĄĹ丮°ˇ ˛Ë Â÷Ľ ł»¸± Ľö ľř˝Ŕ´Ď´Ů."));
- }
- }
- ACMD(do_observer_exit)
- {
- if (ch->IsObserverMode())
- {
- if (ch->GetWarMap())
- ch->SetWarMap(NULL);
- if (ch->GetArena() != NULL || ch->GetArenaObserverMode() == true)
- {
- ch->SetArenaObserverMode(false);
- if (ch->GetArena() != NULL)
- ch->GetArena()->RemoveObserver(ch->GetPlayerID());
- ch->SetArena(NULL);
- ch->WarpSet(ARENA_RETURN_POINT_X(ch->GetEmpire()), ARENA_RETURN_POINT_Y(ch->GetEmpire()));
- }
- else
- {
- ch->ExitToSavedLocation();
- }
- ch->SetObserverMode(false);
- }
- }
- ACMD(do_view_equip)
- {
- if (ch->GetGMLevel() <= GM_PLAYER)
- return;
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (*arg1)
- {
- DWORD vid = 0;
- str_to_number(vid, arg1);
- LPCHARACTER tch = CHARACTER_MANAGER::instance().Find(vid);
- if (!tch)
- return;
- if (!tch->IsPC())
- return;
- /*
- int iSPCost = ch->GetMaxSP() / 3;
- if (ch->GetSP() < iSPCost)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("Á¤˝Ĺ·ÂŔĚ şÎÁ·ÇĎż© ´Ů¸Ą »ç¶÷ŔÇ Ŕĺşń¸¦ şĽ Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- ch->PointChange(POINT_SP, -iSPCost);
- */
- tch->SendEquipment(ch);
- }
- }
- ACMD(do_party_request)
- {
- if (ch->GetArena())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("´ë·ĂŔ忡Ľ »çżëÇĎ˝Ç Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- if (ch->GetParty())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("ŔĚąĚ ĆÄĆĽżˇ ĽÓÇŘ ŔÖŔ¸ąÇ·Î °ˇŔÔ˝ĹĂ»Ŕ» ÇŇ Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- return;
- DWORD vid = 0;
- str_to_number(vid, arg1);
- LPCHARACTER tch = CHARACTER_MANAGER::instance().Find(vid);
- if (tch)
- if (!ch->RequestToParty(tch))
- ch->ChatPacket(CHAT_TYPE_COMMAND, "PartyRequestDenied");
- }
- ACMD(do_party_request_accept)
- {
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- return;
- DWORD vid = 0;
- str_to_number(vid, arg1);
- LPCHARACTER tch = CHARACTER_MANAGER::instance().Find(vid);
- if (tch)
- ch->AcceptToParty(tch);
- }
- ACMD(do_party_request_deny)
- {
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- return;
- DWORD vid = 0;
- str_to_number(vid, arg1);
- LPCHARACTER tch = CHARACTER_MANAGER::instance().Find(vid);
- if (tch)
- ch->DenyToParty(tch);
- }
- ACMD(do_monarch_warpto)
- {
- if (true == LC_IsYMIR() || true == LC_IsKorea())
- return;
- if (!CMonarch::instance().IsMonarch(ch->GetPlayerID(), ch->GetEmpire()))
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("±şÁÖ¸¸ŔĚ »çżë °ˇ´ÉÇŃ ±â´ÉŔÔ´Ď´Ů"));
- return;
- }
- //±şÁÖ ÄđŸŔÓ °Ë»ç
- if (!ch->IsMCOK(CHARACTER::MI_WARP))
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("%d ĂĘ°Ł ÄđŸŔÓŔĚ ŔűżëÁßŔÔ´Ď´Ů."), ch->GetMCLTime(CHARACTER::MI_WARP));
- return;
- }
- //±şÁÖ ¸÷ ĽŇČŻ şńżë
- const int WarpPrice = 10000;
- //±şÁÖ ±ą°í °Ë»ç
- if (!CMonarch::instance().IsMoneyOk(WarpPrice, ch->GetEmpire()))
- {
- int NationMoney = CMonarch::instance().GetMoney(ch->GetEmpire());
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("±ą°íżˇ µ·ŔĚ şÎÁ·ÇŐ´Ď´Ů. ÇöŔç : %u ÇĘżä±Ýľ× : %u"), NationMoney, WarpPrice);
- return;
- }
- int x = 0, y = 0;
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("»çżëąý: warpto <character name>"));
- return;
- }
- LPCHARACTER tch = CHARACTER_MANAGER::instance().FindPC(arg1);
- if (!tch)
- {
- CCI * pkCCI = P2P_MANAGER::instance().Find(arg1);
- if (pkCCI)
- {
- if (pkCCI->bEmpire != ch->GetEmpire())
- {
- ch->ChatPacket (CHAT_TYPE_INFO, LC_TEXT("ŸÁ¦±ą ŔŻŔúżˇ°Ô´Â Ŕ̵żÇŇĽö ľř˝Ŕ´Ď´Ů"));
- return;
- }
- if (pkCCI->bChannel != g_bChannel)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("ÇŘ´ç ŔŻŔú´Â %d äłÎżˇ ŔÖ˝Ŕ´Ď´Ů. (ÇöŔç äłÎ %d)"), pkCCI->bChannel, g_bChannel);
- return;
- }
- if (!IsMonarchWarpZone(pkCCI->lMapIndex))
- {
- ch->ChatPacket (CHAT_TYPE_INFO, LC_TEXT("ÇŘ´ç ÁöżŞŔ¸·Î Ŕ̵żÇŇ Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- PIXEL_POSITION pos;
- if (!SECTREE_MANAGER::instance().GetCenterPositionOfMap(pkCCI->lMapIndex, pos))
- ch->ChatPacket(CHAT_TYPE_INFO, "Cannot find map (index %d)", pkCCI->lMapIndex);
- else
- {
- //ch->ChatPacket(CHAT_TYPE_INFO, "You warp to (%d, %d)", pos.x, pos.y);
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("%s żˇ°Ô·Î Ŕ̵żÇŐ´Ď´Ů"), arg1);
- ch->WarpSet(pos.x, pos.y);
- //±şÁÖ µ· »č°¨
- CMonarch::instance().SendtoDBDecMoney(WarpPrice, ch->GetEmpire(), ch);
- //ÄđŸŔÓ ĂʱâČ
- ch->SetMC(CHARACTER::MI_WARP);
- }
- }
- else if (NULL == CHARACTER_MANAGER::instance().FindPC(arg1))
- {
- ch->ChatPacket(CHAT_TYPE_INFO, "There is no one by that name");
- }
- return;
- }
- else
- {
- if (tch->GetEmpire() != ch->GetEmpire())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("ŸÁ¦±ą ŔŻŔúżˇ°Ô´Â Ŕ̵żÇŇĽö ľř˝Ŕ´Ď´Ů"));
- return;
- }
- if (!IsMonarchWarpZone(tch->GetMapIndex()))
- {
- ch->ChatPacket (CHAT_TYPE_INFO, LC_TEXT("ÇŘ´ç ÁöżŞŔ¸·Î Ŕ̵żÇŇ Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- x = tch->GetX();
- y = tch->GetY();
- }
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("%s żˇ°Ô·Î Ŕ̵żÇŐ´Ď´Ů"), arg1);
- ch->WarpSet(x, y);
- ch->Stop();
- //±şÁÖ µ· »č°¨
- CMonarch::instance().SendtoDBDecMoney(WarpPrice, ch->GetEmpire(), ch);
- //ÄđŸŔÓ ĂʱâČ
- ch->SetMC(CHARACTER::MI_WARP);
- }
- ACMD(do_monarch_transfer)
- {
- if (true == LC_IsYMIR() || true == LC_IsKorea())
- return;
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("»çżëąý: transfer <name>"));
- return;
- }
- if (!CMonarch::instance().IsMonarch(ch->GetPlayerID(), ch->GetEmpire()))
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("±şÁÖ¸¸ŔĚ »çżë °ˇ´ÉÇŃ ±â´ÉŔÔ´Ď´Ů"));
- return;
- }
- //±şÁÖ ÄđŸŔÓ °Ë»ç
- if (!ch->IsMCOK(CHARACTER::MI_TRANSFER))
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("%d ĂĘ°Ł ÄđŸŔÓŔĚ ŔűżëÁßŔÔ´Ď´Ů."), ch->GetMCLTime(CHARACTER::MI_TRANSFER));
- return;
- }
- //±şÁÖ żöÇÁ şńżë
- const int WarpPrice = 10000;
- //±şÁÖ ±ą°í °Ë»ç
- if (!CMonarch::instance().IsMoneyOk(WarpPrice, ch->GetEmpire()))
- {
- int NationMoney = CMonarch::instance().GetMoney(ch->GetEmpire());
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("±ą°íżˇ µ·ŔĚ şÎÁ·ÇŐ´Ď´Ů. ÇöŔç : %u ÇĘżä±Ýľ× : %u"), NationMoney, WarpPrice);
- return;
- }
- LPCHARACTER tch = CHARACTER_MANAGER::instance().FindPC(arg1);
- if (!tch)
- {
- CCI * pkCCI = P2P_MANAGER::instance().Find(arg1);
- if (pkCCI)
- {
- if (pkCCI->bEmpire != ch->GetEmpire())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("´Ů¸Ą Á¦±ą ŔŻŔú´Â ĽŇČŻÇŇ Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- if (pkCCI->bChannel != g_bChannel)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("%s ´ÔŔş %d äłÎżˇ Á˘ĽÓ Áß ŔÔ´Ď´Ů. (ÇöŔç äłÎ: %d)"), arg1, pkCCI->bChannel, g_bChannel);
- return;
- }
- if (!IsMonarchWarpZone(pkCCI->lMapIndex))
- {
- ch->ChatPacket (CHAT_TYPE_INFO, LC_TEXT("ÇŘ´ç ÁöżŞŔ¸·Î Ŕ̵żÇŇ Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- if (!IsMonarchWarpZone(ch->GetMapIndex()))
- {
- ch->ChatPacket (CHAT_TYPE_INFO, LC_TEXT("ÇŘ´ç ÁöżŞŔ¸·Î ĽŇČŻÇŇ Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- TPacketGGTransfer pgg;
- pgg.bHeader = HEADER_GG_TRANSFER;
- strlcpy(pgg.szName, arg1, sizeof(pgg.szName));
- pgg.lX = ch->GetX();
- pgg.lY = ch->GetY();
- P2P_MANAGER::instance().Send(&pgg, sizeof(TPacketGGTransfer));
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("%s ´ÔŔ» ĽŇČŻÇĎż´˝Ŕ´Ď´Ů."), arg1);
- //±şÁÖ µ· »č°¨
- CMonarch::instance().SendtoDBDecMoney(WarpPrice, ch->GetEmpire(), ch);
- //ÄđŸŔÓ ĂʱâČ
- ch->SetMC(CHARACTER::MI_TRANSFER);
- }
- else
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("ŔÔ·ÂÇϽŠŔ̸§Ŕ» °ˇÁř »çżëŔÚ°ˇ ľř˝Ŕ´Ď´Ů."));
- }
- return;
- }
- if (ch == tch)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("ŔÚ˝ĹŔ» ĽŇČŻÇŇ Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- if (tch->GetEmpire() != ch->GetEmpire())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("´Ů¸Ą Á¦±ą ŔŻŔú´Â ĽŇČŻÇŇ Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- if (!IsMonarchWarpZone(tch->GetMapIndex()))
- {
- ch->ChatPacket (CHAT_TYPE_INFO, LC_TEXT("ÇŘ´ç ÁöżŞŔ¸·Î Ŕ̵żÇŇ Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- if (!IsMonarchWarpZone(ch->GetMapIndex()))
- {
- ch->ChatPacket (CHAT_TYPE_INFO, LC_TEXT("ÇŘ´ç ÁöżŞŔ¸·Î ĽŇČŻÇŇ Ľö ľř˝Ŕ´Ď´Ů."));
- return;
- }
- //tch->Show(ch->GetMapIndex(), ch->GetX(), ch->GetY(), ch->GetZ());
- tch->WarpSet(ch->GetX(), ch->GetY(), ch->GetMapIndex());
- //±şÁÖ µ· »č°¨
- CMonarch::instance().SendtoDBDecMoney(WarpPrice, ch->GetEmpire(), ch);
- //ÄđŸŔÓ ĂʱâČ
- ch->SetMC(CHARACTER::MI_TRANSFER);
- }
- ACMD(do_monarch_info)
- {
- if (CMonarch::instance().IsMonarch(ch->GetPlayerID(), ch->GetEmpire()))
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("łŞŔÇ ±şÁÖ Á¤ş¸"));
- TMonarchInfo * p = CMonarch::instance().GetMonarch();
- for (int n = 1; n < 4; ++n)
- {
- if (n == ch->GetEmpire())
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("[%s±şÁÖ] : %s ş¸ŔŻ±Ýľ× %lld "), EMPIRE_NAME(n), p->name[n], p->money[n]);
- else
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("[%s±şÁÖ] : %s "), EMPIRE_NAME(n), p->name[n]);
- }
- }
- else
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("±şÁÖ Á¤ş¸"));
- TMonarchInfo * p = CMonarch::instance().GetMonarch();
- for (int n = 1; n < 4; ++n)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("[%s±şÁÖ] : %s "), EMPIRE_NAME(n), p->name[n]);
- }
- }
- }
- ACMD(do_elect)
- {
- db_clientdesc->DBPacketHeader(HEADER_GD_COME_TO_VOTE, ch->GetDesc()->GetHandle(), 0);
- }
- // LUA_ADD_GOTO_INFO
- struct GotoInfo
- {
- std::string st_name;
- BYTE empire;
- int mapIndex;
- DWORD x, y;
- GotoInfo()
- {
- st_name = "";
- empire = 0;
- mapIndex = 0;
- x = 0;
- y = 0;
- }
- GotoInfo(const GotoInfo& c_src)
- {
- __copy__(c_src);
- }
- void operator = (const GotoInfo& c_src)
- {
- __copy__(c_src);
- }
- void __copy__(const GotoInfo& c_src)
- {
- st_name = c_src.st_name;
- empire = c_src.empire;
- mapIndex = c_src.mapIndex;
- x = c_src.x;
- y = c_src.y;
- }
- };
- extern void BroadcastNotice(const char * c_pszBuf, bool IsBig);
- ACMD(do_monarch_tax)
- {
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, "Usage: monarch_tax <1-50>");
- return;
- }
- // ±şÁÖ °Ë»ç
- if (!ch->IsMonarch())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("±şÁÖ¸¸ŔĚ »çżëÇŇĽö ŔÖ´Â ±â´ÉŔÔ´Ď´Ů"));
- return;
- }
- // ĽĽ±ÝĽłÁ¤
- int tax = 0;
- str_to_number(tax, arg1);
- if (tax < 1 || tax > 50)
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("1-50 »çŔĚŔÇ Ľöġ¸¦ Ľ±ĹĂÇŘÁÖĽĽżä"));
- quest::CQuestManager::instance().SetEventFlag("trade_tax", tax);
- // ±şÁÖżˇ°Ô ¸ŢĽĽÁö ÇĎłŞ
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("ĽĽ±ÝŔĚ %d %·Î ĽłÁ¤µÇľú˝Ŕ´Ď´Ů"));
- // °řÁö
- char szMsg[1024];
- snprintf(szMsg, sizeof(szMsg), "±şÁÖŔÇ ¸íŔ¸·Î ĽĽ±ÝŔĚ %d %% ·Î şŻ°ćµÇľú˝Ŕ´Ď´Ů", tax);
- BroadcastNotice(szMsg);
- snprintf(szMsg, sizeof(szMsg), "ľŐŔ¸·Î´Â °Ĺ·ˇ ±Ýľ×ŔÇ %d %% °ˇ ±ą°í·Î µéľî°ˇ°ÔµË´Ď´Ů.", tax);
- BroadcastNotice(szMsg);
- // ÄđŸŔÓ ĂʱâČ
- ch->SetMC(CHARACTER::MI_TAX);
- }
- static const DWORD cs_dwMonarchMobVnums[] =
- {
- 191, // »ę°ß˝Ĺ
- 192, // Ŕú˝Ĺ
- 193, // żő˝Ĺ
- 194, // ČŁ˝Ĺ
- 391, // ąĚÁ¤
- 392, // ŔşÁ¤
- 393, // ĽĽ¶ű
- 394, // ÁřČń
- 491, // ¸ÍČŻ
- 492, // ş¸żě
- 493, // ±¸ĆĐ
- 494, // ĂßČç
- 591, // şń·ů´Ü´ëŔĺ
- 691, // żő±Í Á·Ŕĺ
- 791, // ąĐ±ł±łÁÖ
- 1304, // ´©··ąü±Í
- 1901, // ±¸ąĚČŁ
- 2091, // ż©żŐ°ĹąĚ
- 2191, // °Ĺ´ë»ç¸·°ĹşĎ
- 2206, // Čż°żŐi
- 0,
- };
- ACMD(do_monarch_mob)
- {
- char arg1[256];
- LPCHARACTER tch;
- one_argument(argument, arg1, sizeof(arg1));
- if (!ch->IsMonarch())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("±şÁÖ¸¸ŔĚ »çżëÇŇĽö ŔÖ´Â ±â´ÉŔÔ´Ď´Ů"));
- return;
- }
- if (!*arg1)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, "Usage: mmob <mob name>");
- return;
- }
- BYTE pcEmpire = ch->GetEmpire();
- BYTE mapEmpire = SECTREE_MANAGER::instance().GetEmpireFromMapIndex(ch->GetMapIndex());
- if (LC_IsYMIR() == true || LC_IsKorea() == true)
- {
- if (mapEmpire != pcEmpire && mapEmpire != 0)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("ŔÚ±ą żµĹ信Ľ¸¸ »çżëÇŇ Ľö ŔÖ´Â ±â´ÉŔÔ´Ď´Ů"));
- return;
- }
- }
- // ±şÁÖ ¸÷ ĽŇČŻ şńżë
- const int SummonPrice = 5000000;
- // ±şÁÖ ÄđŸŔÓ °Ë»ç
- if (!ch->IsMCOK(CHARACTER::MI_SUMMON))
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("%d ĂĘ°Ł ÄđŸŔÓŔĚ ŔűżëÁßŔÔ´Ď´Ů."), ch->GetMCLTime(CHARACTER::MI_SUMMON));
- return;
- }
- // ±şÁÖ ±ą°í °Ë»ç
- if (!CMonarch::instance().IsMoneyOk(SummonPrice, ch->GetEmpire()))
- {
- int NationMoney = CMonarch::instance().GetMoney(ch->GetEmpire());
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("±ą°íżˇ µ·ŔĚ şÎÁ·ÇŐ´Ď´Ů. ÇöŔç : %u ÇĘżä±Ýľ× : %u"), NationMoney, SummonPrice);
- return;
- }
- const CMob * pkMob;
- DWORD vnum = 0;
- if (isdigit(*arg1))
- {
- str_to_number(vnum, arg1);
- if ((pkMob = CMobManager::instance().Get(vnum)) == NULL)
- vnum = 0;
- }
- else
- {
- pkMob = CMobManager::Instance().Get(arg1, true);
- if (pkMob)
- vnum = pkMob->m_table.dwVnum;
- }
- DWORD count;
- // ĽŇČŻ °ˇ´É ¸÷ °Ë»ç
- for (count = 0; cs_dwMonarchMobVnums[count] != 0; ++count)
- if (cs_dwMonarchMobVnums[count] == vnum)
- break;
- if (0 == cs_dwMonarchMobVnums[count])
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("ĽŇČŻÇŇĽö ľř´Â ¸ó˝şĹÍ ŔÔ´Ď´Ů. ĽŇČŻ°ˇ´ÉÇŃ ¸ó˝şĹʹ ȨĆäŔĚÁö¸¦ ÂüÁ¶ÇĎĽĽżä"));
- return;
- }
- tch = CHARACTER_MANAGER::instance().SpawnMobRange(vnum,
- ch->GetMapIndex(),
- ch->GetX() - number(200, 750),
- ch->GetY() - number(200, 750),
- ch->GetX() + number(200, 750),
- ch->GetY() + number(200, 750),
- true,
- pkMob->m_table.bType == CHAR_TYPE_STONE,
- true);
- if (tch)
- {
- // ±şÁÖ µ· »č°¨
- CMonarch::instance().SendtoDBDecMoney(SummonPrice, ch->GetEmpire(), ch);
- // ÄđŸŔÓ ĂʱâČ
- ch->SetMC(CHARACTER::MI_SUMMON);
- }
- }
- static const char* FN_point_string(int apply_number)
- {
- switch (apply_number)
- {
- case POINT_MAX_HP: return LC_TEXT("ĂÖ´ë »ý¸í·Â +%d");
- case POINT_MAX_SP: return LC_TEXT("ĂÖ´ë Á¤˝Ĺ·Â +%d");
- case POINT_HT: return LC_TEXT("ĂĽ·Â +%d");
- case POINT_IQ: return LC_TEXT("Áö´É +%d");
- case POINT_ST: return LC_TEXT("±Ů·Â +%d");
- case POINT_DX: return LC_TEXT("ąÎø +%d");
- case POINT_ATT_SPEED: return LC_TEXT("°ř°ÝĽÓµµ +%d");
- case POINT_MOV_SPEED: return LC_TEXT("Ŕ̵żĽÓµµ %d");
- case POINT_CASTING_SPEED: return LC_TEXT("ÄđŸŔÓ -%d");
- case POINT_HP_REGEN: return LC_TEXT("»ý¸í·Â ȸşą +%d");
- case POINT_SP_REGEN: return LC_TEXT("Á¤˝Ĺ·Â ȸşą +%d");
- case POINT_POISON_PCT: return LC_TEXT("µ¶°ř°Ý %d");
- case POINT_STUN_PCT: return LC_TEXT("˝şĹĎ +%d");
- case POINT_SLOW_PCT: return LC_TEXT("˝˝·Îżě +%d");
- case POINT_CRITICAL_PCT: return LC_TEXT("%d%% Č®·ü·Î ġ¸íŸ °ř°Ý");
- case POINT_RESIST_CRITICAL: return LC_TEXT("»ó´ëŔÇ Äˇ¸íŸ Č®·ü %d%% °¨ĽŇ");
- case POINT_PENETRATE_PCT: return LC_TEXT("%d%% Č®·ü·Î °üĹë °ř°Ý");
- case POINT_RESIST_PENETRATE: return LC_TEXT("»ó´ëŔÇ °üĹë °ř°Ý Č®·ü %d%% °¨ĽŇ");
- case POINT_ATTBONUS_HUMAN: return LC_TEXT("ŔΰŁ·ů ¸ó˝şĹÍ Ĺ¸°Ýġ +%d%%");
- case POINT_ATTBONUS_ANIMAL: return LC_TEXT("µżą°·ů ¸ó˝şĹÍ Ĺ¸°Ýġ +%d%%");
- case POINT_ATTBONUS_ORC: return LC_TEXT("żő±ÍÁ· Ÿ°Ýġ +%d%%");
- case POINT_ATTBONUS_MILGYO: return LC_TEXT("ąĐ±ł·ů Ÿ°Ýġ +%d%%");
- case POINT_ATTBONUS_UNDEAD: return LC_TEXT("˝ĂĂĽ·ů Ÿ°Ýġ +%d%%");
- case POINT_ATTBONUS_DEVIL: return LC_TEXT("ľÇ¸¶·ů Ÿ°Ýġ +%d%%");
- case POINT_STEAL_HP: return LC_TEXT("Ÿ°Ýġ %d%% ¸¦ »ý¸í·ÂŔ¸·Î ČíĽö");
- case POINT_STEAL_SP: return LC_TEXT("Ÿ·Âġ %d%% ¸¦ Á¤˝Ĺ·ÂŔ¸·Î ČíĽö");
- case POINT_MANA_BURN_PCT: return LC_TEXT("%d%% Č®·ü·Î Ÿ°Ý˝Ă »ó´ë Ŕü˝Ĺ·Â ĽŇ¸đ");
- case POINT_DAMAGE_SP_RECOVER: return LC_TEXT("%d%% Č®·ü·Î ÇÇÇؽà Á¤˝Ĺ·Â ȸşą");
- case POINT_BLOCK: return LC_TEXT("ą°¸®Ĺ¸°Ý˝Ă şí·° Č®·ü %d%%");
- case POINT_DODGE: return LC_TEXT("Č° °ř°Ý ȸÇÇ Č®·ü %d%%");
- case POINT_RESIST_SWORD: return LC_TEXT("ÇŃĽŐ°Ë ąćľî %d%%");
- case POINT_RESIST_TWOHAND: return LC_TEXT("ľçĽŐ°Ë ąćľî %d%%");
- case POINT_RESIST_DAGGER: return LC_TEXT("µÎĽŐ°Ë ąćľî %d%%");
- case POINT_RESIST_BELL: return LC_TEXT("ąćżď ąćľî %d%%");
- case POINT_RESIST_FAN: return LC_TEXT("şÎä ąćľî %d%%");
- case POINT_RESIST_BOW: return LC_TEXT("Č°°ř°Ý ŔúÇ× %d%%");
- case POINT_RESIST_FIRE: return LC_TEXT("Čż° ŔúÇ× %d%%");
- case POINT_RESIST_ELEC: return LC_TEXT("Ŕü±â ŔúÇ× %d%%");
- case POINT_RESIST_MAGIC: return LC_TEXT("¸¶ąý ŔúÇ× %d%%");
- case POINT_RESIST_WIND: return LC_TEXT("ąŮ¶÷ ŔúÇ× %d%%");
- case POINT_RESIST_ICE: return LC_TEXT("łĂ±â ŔúÇ× %d%%");
- case POINT_RESIST_EARTH: return LC_TEXT("´ëÁö ŔúÇ× %d%%");
- case POINT_RESIST_DARK: return LC_TEXT("ľîµŇ ŔúÇ× %d%%");
- case POINT_REFLECT_MELEE: return LC_TEXT("Á÷Á˘ Ÿ°Ýġ ąÝ»ç Č®·ü : %d%%");
- case POINT_REFLECT_CURSE: return LC_TEXT("ŔúÁÖ µÇµą¸®±â Č®·ü %d%%");
- case POINT_POISON_REDUCE: return LC_TEXT("µ¶ ŔúÇ× %d%%");
- case POINT_KILL_SP_RECOVER: return LC_TEXT("%d%% Č®·ü·Î ŔűĹđġ˝Ă Á¤˝Ĺ·Â ȸşą");
- case POINT_EXP_DOUBLE_BONUS: return LC_TEXT("%d%% Č®·ü·Î ŔűĹđġ˝Ă °ćÇčġ Ăß°ˇ »ó˝Â");
- case POINT_GOLD_DOUBLE_BONUS: return LC_TEXT("%d%% Č®·ü·Î ŔűĹđġ˝Ă µ· 2ąč µĺ·Ó");
- case POINT_ITEM_DROP_BONUS: return LC_TEXT("%d%% Č®·ü·Î ŔűĹđġ˝Ă ľĆŔĚĹŰ 2ąč µĺ·Ó");
- case POINT_POTION_BONUS: return LC_TEXT("ą°ľŕ »çżë˝Ă %d%% Ľş´É Áő°ˇ");
- case POINT_KILL_HP_RECOVERY: return LC_TEXT("%d%% Č®·ü·Î ŔűĹđġ˝Ă »ý¸í·Â ȸşą");
- // case POINT_IMMUNE_STUN: return LC_TEXT("±âŔýÇĎÁö ľĘŔ˝ %d%%");
- // case POINT_IMMUNE_SLOW: return LC_TEXT("´Ŕ·ÁÁöÁö ľĘŔ˝ %d%%");
- // case POINT_IMMUNE_FALL: return LC_TEXT("łŃľîÁöÁö ľĘŔ˝ %d%%");
- // case POINT_SKILL: return LC_TEXT("");
- // case POINT_BOW_DISTANCE: return LC_TEXT("");
- case POINT_ATT_GRADE_BONUS: return LC_TEXT("°ř°Ý·Â +%d");
- case POINT_DEF_GRADE_BONUS: return LC_TEXT("ąćľî·Â +%d");
- case POINT_MAGIC_ATT_GRADE: return LC_TEXT("¸¶ąý °ř°Ý·Â +%d");
- case POINT_MAGIC_DEF_GRADE: return LC_TEXT("¸¶ąý ąćľî·Â +%d");
- // case POINT_CURSE_PCT: return LC_TEXT("");
- case POINT_MAX_STAMINA: return LC_TEXT("ĂÖ´ë Áö±¸·Â +%d");
- case POINT_ATTBONUS_WARRIOR: return LC_TEXT("ą«»çżˇ°Ô °ÇÔ +%d%%");
- case POINT_ATTBONUS_ASSASSIN: return LC_TEXT("ŔÚ°´żˇ°Ô °ÇÔ +%d%%");
- case POINT_ATTBONUS_SURA: return LC_TEXT("Ľö¶óżˇ°Ô °ÇÔ +%d%%");
- case POINT_ATTBONUS_SHAMAN: return LC_TEXT("ą«´çżˇ°Ô °ÇÔ +%d%%");
- case POINT_ATTBONUS_MONSTER: return LC_TEXT("¸ó˝şĹÍżˇ°Ô °ÇÔ +%d%%");
- case POINT_MALL_ATTBONUS: return LC_TEXT("°ř°Ý·Â +%d%%");
- case POINT_MALL_DEFBONUS: return LC_TEXT("ąćľî·Â +%d%%");
- case POINT_MALL_EXPBONUS: return LC_TEXT("°ćÇčġ %d%%");
- case POINT_MALL_ITEMBONUS: return LC_TEXT("ľĆŔĚĹŰ µĺ·ÓŔ˛ %.1fąč");
- case POINT_MALL_GOLDBONUS: return LC_TEXT("µ· µĺ·ÓŔ˛ %.1fąč");
- case POINT_MAX_HP_PCT: return LC_TEXT("ĂÖ´ë »ý¸í·Â +%d%%");
- case POINT_MAX_SP_PCT: return LC_TEXT("ĂÖ´ë Á¤˝Ĺ·Â +%d%%");
- case POINT_SKILL_DAMAGE_BONUS: return LC_TEXT("˝şĹł µĄąĚÁö %d%%");
- case POINT_NORMAL_HIT_DAMAGE_BONUS: return LC_TEXT("ĆňŸ µĄąĚÁö %d%%");
- case POINT_SKILL_DEFEND_BONUS: return LC_TEXT("˝şĹł µĄąĚÁö ŔúÇ× %d%%");
- case POINT_NORMAL_HIT_DEFEND_BONUS: return LC_TEXT("ĆňŸ µĄąĚÁö ŔúÇ× %d%%");
- // case POINT_PC_BANG_EXP_BONUS: return LC_TEXT("");
- // case POINT_PC_BANG_DROP_BONUS: return LC_TEXT("");
- // case POINT_EXTRACT_HP_PCT: return LC_TEXT("");
- case POINT_RESIST_WARRIOR: return LC_TEXT("ą«»ç°ř°Ýżˇ %d%% ŔúÇ×");
- case POINT_RESIST_ASSASSIN: return LC_TEXT("ŔÚ°´°ř°Ýżˇ %d%% ŔúÇ×");
- case POINT_RESIST_SURA: return LC_TEXT("Ľö¶ó°ř°Ýżˇ %d%% ŔúÇ×");
- case POINT_RESIST_SHAMAN: return LC_TEXT("ą«´ç°ř°Ýżˇ %d%% ŔúÇ×");
- default: return NULL;
- }
- }
- static bool FN_hair_affect_string(LPCHARACTER ch, char *buf, size_t bufsiz)
- {
- if (NULL == ch || NULL == buf)
- return false;
- CAffect* aff = NULL;
- time_t expire = 0;
- struct tm ltm;
- int year, mon, day;
- int offset = 0;
- aff = ch->FindAffect(AFFECT_HAIR);
- if (NULL == aff)
- return false;
- expire = ch->GetQuestFlag("hair.limit_time");
- if (expire < get_global_time())
- return false;
- // set apply string
- offset = snprintf(buf, bufsiz, FN_point_string(aff->bApplyOn), aff->lApplyValue);
- if (offset < 0 || offset >= (int) bufsiz)
- offset = bufsiz - 1;
- localtime_r(&expire, <m);
- year = ltm.tm_year + 1900;
- mon = ltm.tm_mon + 1;
- day = ltm.tm_mday;
- snprintf(buf + offset, bufsiz - offset, LC_TEXT(" (¸¸·áŔĎ : %dłâ %dżů %dŔĎ)"), year, mon, day);
- return true;
- }
- ACMD(do_costume)
- {
- #ifdef __SASH_SYSTEM__
- char buf[768];
- #else
- char buf[512];
- #endif
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- CItem * pBody = ch->GetWear(WEAR_COSTUME_BODY);
- CItem * pHair = ch->GetWear(WEAR_COSTUME_HAIR);
- #ifdef __SASH_SYSTEM__
- CItem * pSash = ch->GetWear(WEAR_COSTUME_SASH);
- #endif
- #ifdef ENABLE_MOUNT_COSTUME_SYSTEM
- CItem* pMount = ch->GetWear(WEAR_COSTUME_MOUNT);
- #endif
- ch->ChatPacket(CHAT_TYPE_INFO, "COSTUME status:");
- if (pBody)
- {
- const char* itemName = pBody->GetName();
- ch->ChatPacket(CHAT_TYPE_INFO, " BODY: %s", itemName);
- if (pBody->IsEquipped() && arg1[0] == 'b')
- ch->UnequipItem(pBody);
- }
- if (pHair)
- {
- const char* itemName = pHair->GetName();
- ch->ChatPacket(CHAT_TYPE_INFO, " HAIR: %s", itemName);
- for (int i = 0; i < pHair->GetAttributeCount(); ++i)
- {
- const TPlayerItemAttribute& attr = pHair->GetAttribute(i);
- if (attr.bType > 0)
- {
- const char * pAttrName = FN_point_string(attr.bType);
- if (pAttrName == NULL)
- continue;
- snprintf(buf, sizeof(buf), FN_point_string(attr.bType), attr.sValue);
- ch->ChatPacket(CHAT_TYPE_INFO, " %s", buf);
- }
- }
- if (pHair->IsEquipped() && arg1[0] == 'h')
- ch->UnequipItem(pHair);
- }
- #ifdef __SASH_SYSTEM__
- if (pSash)
- {
- const char * itemName = pSash->GetName();
- ch->ChatPacket(CHAT_TYPE_INFO, " SASH: %s", itemName);
- for (int i = 0; i < pSash->GetAttributeCount(); ++i)
- {
- const TPlayerItemAttribute& attr = pSash->GetAttribute(i);
- if (attr.bType > 0)
- {
- const char * pAttrName = FN_point_string(attr.bType);
- if (pAttrName == NULL)
- continue;
- snprintf(buf, sizeof(buf), FN_point_string(attr.bType), attr.sValue);
- ch->ChatPacket(CHAT_TYPE_INFO, " %s", buf);
- }
- }
- if (pSash->IsEquipped() && arg1[0] == 's')
- ch->UnequipItem(pSash);
- }
- #endif
- #ifdef ENABLE_MOUNT_COSTUME_SYSTEM
- if (pMount)
- {
- const char* itemName = pMount->GetName();
- ch->ChatPacket(CHAT_TYPE_INFO, " MOUNT : %s", itemName);
- if (pMount->IsEquipped() && arg1[0] == 'm')
- ch->UnequipItem(pMount);
- }
- #endif
- }
- ACMD(do_costum_effect)
- {
- char arg1[256];
- char arg2[256];
- char arg3[256];
- one_argument(two_arguments(argument, arg1, sizeof(arg1), arg2, sizeof(arg2)), arg3, sizeof(arg3));
- if (!*arg1 || !*arg2 || !*arg3)
- return;
- if (ch->IsOpenSafebox() || ch->GetExchange() || ch->GetMyShop() || ch->IsCubeOpen())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("Nie możesz handlować w sklepie z otwartym innym oknem transakcji."));
- return;
- }
- DWORD dwVnum = 0;
- str_to_number(dwVnum, arg1);
- if (dwVnum < 0 || dwVnum >= INVENTORY_MAX_NUM)
- return;
- DWORD dwVnumSlot = 0;
- str_to_number(dwVnumSlot, arg3);
- if (dwVnumSlot < 0 || dwVnumSlot >= INVENTORY_MAX_NUM)
- return;
- int BStat = 0;
- str_to_number(BStat, arg2);
- if (BStat <= 0 || BStat > 7)
- return;
- LPITEM item2 = ch->GetInventoryItem(dwVnumSlot);
- if (!item2 || item2->IsExchanging() || item2->GetVnum() != 50512)
- return;
- LPITEM item = ch->GetInventoryItem(dwVnum);
- if (!item || item->IsExchanging() || item->IsEquipped())
- return;
- if (item->GetType() != ITEM_COSTUME || item->GetSubType() != COSTUME_BODY)
- return;
- item->SetSocket(1, BStat);
- item2->SetCount(item->GetCount() - 1);
- }
- ACMD(do_hair)
- {
- char buf[256];
- if (false == FN_hair_affect_string(ch, buf, sizeof(buf)))
- return;
- ch->ChatPacket(CHAT_TYPE_INFO, buf);
- }
- ACMD(do_inventory)
- {
- int index = 0;
- int count = 1;
- char arg1[256];
- char arg2[256];
- LPITEM item;
- two_arguments(argument, arg1, sizeof(arg1), arg2, sizeof(arg2));
- if (!*arg1)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, "Usage: inventory <start_index> <count>");
- return;
- }
- if (!*arg2)
- {
- index = 0;
- str_to_number(count, arg1);
- }
- else
- {
- str_to_number(index, arg1); index = MIN(index, INVENTORY_MAX_NUM);
- str_to_number(count, arg2); count = MIN(count, INVENTORY_MAX_NUM);
- }
- for (int i = 0; i < count; ++i)
- {
- if (index >= INVENTORY_MAX_NUM)
- break;
- item = ch->GetInventoryItem(index);
- ch->ChatPacket(CHAT_TYPE_INFO, "inventory [%d] = %s",
- index, item ? item->GetName() : "<NONE>");
- ++index;
- }
- }
- //gift notify quest command
- ACMD(do_gift)
- {
- ch->ChatPacket(CHAT_TYPE_COMMAND, "gift");
- }
- ACMD(do_cube)
- {
- if (!ch->CanDoCube())
- return;
- dev_log(LOG_DEB0, "CUBE COMMAND <%s>: %s", ch->GetName(), argument);
- int cube_index = 0, inven_index = 0;
- const char *line;
- char arg1[256], arg2[256], arg3[256];
- line = two_arguments(argument, arg1, sizeof(arg1), arg2, sizeof(arg2));
- one_argument(line, arg3, sizeof(arg3));
- if (0 == arg1[0])
- {
- // print usage
- ch->ChatPacket(CHAT_TYPE_INFO, "Usage: cube open");
- ch->ChatPacket(CHAT_TYPE_INFO, " cube close");
- ch->ChatPacket(CHAT_TYPE_INFO, " cube add <inveltory_index>");
- ch->ChatPacket(CHAT_TYPE_INFO, " cube delete <cube_index>");
- ch->ChatPacket(CHAT_TYPE_INFO, " cube list");
- ch->ChatPacket(CHAT_TYPE_INFO, " cube cancel");
- ch->ChatPacket(CHAT_TYPE_INFO, " cube make [all]");
- return;
- }
- const std::string& strArg1 = std::string(arg1);
- // r_info (request information)
- // /cube r_info ==> (Client -> Server) ÇöŔç NPC°ˇ ¸¸µé Ľö ŔÖ´Â ·ą˝ĂÇÇ żäĂ»
- // (Server -> Client) /cube r_list npcVNUM resultCOUNT 123,1/125,1/128,1/130,5
- //
- // /cube r_info 3 ==> (Client -> Server) ÇöŔç NPC°ˇ ¸¸µéĽö ŔÖ´Â ·ą˝ĂÇÇ Áß 3ąř° ľĆŔĚĹŰŔ» ¸¸µĺ´Â µĄ ÇĘżäÇŃ Á¤ş¸¸¦ żäĂ»
- // /cube r_info 3 5 ==> (Client -> Server) ÇöŔç NPC°ˇ ¸¸µéĽö ŔÖ´Â ·ą˝ĂÇÇ Áß 3ąř° ľĆŔĚĹŰşÎĹÍ ŔĚČÄ 5°łŔÇ ľĆŔĚĹŰŔ» ¸¸µĺ´Â µĄ ÇĘżäÇŃ Ŕç·á Á¤ş¸¸¦ żäĂ»
- // (Server -> Client) /cube m_info startIndex count 125,1|126,2|127,2|123,5&555,5&555,4/120000@125,1|126,2|127,2|123,5&555,5&555,4/120000
- //
- if (strArg1 == "r_info")
- {
- if (0 == arg2[0])
- Cube_request_result_list(ch);
- else
- {
- if (isdigit(*arg2))
- {
- int listIndex = 0, requestCount = 1;
- str_to_number(listIndex, arg2);
- if (0 != arg3[0] && isdigit(*arg3))
- str_to_number(requestCount, arg3);
- Cube_request_material_info(ch, listIndex, requestCount);
- }
- }
- return;
- }
- switch (LOWER(arg1[0]))
- {
- case 'o': // open
- Cube_open(ch);
- break;
- case 'c': // close
- Cube_close(ch);
- break;
- case 'l': // list
- Cube_show_list(ch);
- break;
- case 'a': // add cue_index inven_index
- {
- if (0 == arg2[0] || !isdigit(*arg2) ||
- 0 == arg3[0] || !isdigit(*arg3))
- return;
- str_to_number(cube_index, arg2);
- str_to_number(inven_index, arg3);
- Cube_add_item (ch, cube_index, inven_index);
- }
- break;
- case 'd': // delete
- {
- if (0 == arg2[0] || !isdigit(*arg2))
- return;
- str_to_number(cube_index, arg2);
- Cube_delete_item (ch, cube_index);
- }
- break;
- case 'm': // make
- if (0 != arg2[0])
- {
- while (true == Cube_make(ch))
- dev_log (LOG_DEB0, "cube make success");
- }
- else
- Cube_make(ch);
- break;
- default:
- return;
- }
- }
- ACMD(do_cards)
- {
- const char *line;
- char arg1[256], arg2[256];
- line = two_arguments(argument, arg1, sizeof(arg1), arg2, sizeof(arg2));
- switch (LOWER(arg1[0]))
- {
- case 'o': // open
- if (isdigit(*arg2))
- {
- DWORD safemode;
- str_to_number(safemode, arg2);
- ch->Cards_open(safemode);
- }
- break;
- case 'p': // open
- ch->Cards_pullout();
- break;
- case 'e': // open
- ch->CardsEnd();
- break;
- case 'd': // open
- if (isdigit(*arg2))
- {
- DWORD destroy_index;
- str_to_number(destroy_index, arg2);
- ch->CardsDestroy(destroy_index);
- }
- break;
- case 'a': // open
- if (isdigit(*arg2))
- {
- DWORD accpet_index;
- str_to_number(accpet_index, arg2);
- ch->CardsAccept(accpet_index);
- }
- break;
- case 'r': // open
- if (isdigit(*arg2))
- {
- DWORD restore_index;
- str_to_number(restore_index, arg2);
- ch->CardsRestore(restore_index);
- }
- break;
- default:
- return;
- }
- }
- ACMD(do_in_game_mall)
- {
- if (LC_IsYMIR() == true || LC_IsKorea() == true)
- {
- ch->ChatPacket(CHAT_TYPE_COMMAND, "mall http://calios.eu");
- return;
- }
- if (true == LC_IsTaiwan())
- {
- ch->ChatPacket(CHAT_TYPE_COMMAND, "mall http://calios.eu");
- return;
- }
- // ¤Đ_¤Đ ÄčµµĽąö ľĆŔĚĹ۸ô URL ÇϵĺÄÚµů Ăß°ˇ
- if (true == LC_IsWE_Korea())
- {
- ch->ChatPacket(CHAT_TYPE_COMMAND, "mall http://calios.eu");
- return;
- }
- if (LC_IsJapan() == true)
- {
- ch->ChatPacket(CHAT_TYPE_COMMAND, "mall http://calios.eu");
- return;
- }
- if (LC_IsNewCIBN() == true && test_server)
- {
- ch->ChatPacket(CHAT_TYPE_COMMAND, "mall http://calios.eu");
- return;
- }
- if (LC_IsSingapore() == true)
- {
- ch->ChatPacket(CHAT_TYPE_COMMAND, "mall http://calios.eu");
- return;
- }
- /*
- if (LC_IsCanada() == true)
- {
- ch->ChatPacket(CHAT_TYPE_COMMAND, "mall http://calios.eu");
- return;
- }*/
- if (LC_IsEurope() == true)
- {
- char country_code[3];
- switch (LC_GetLocalType())
- {
- case LC_GERMANY: country_code[0] = 'd'; country_code[1] = 'e'; country_code[2] = '\0'; break;
- case LC_FRANCE: country_code[0] = 'f'; country_code[1] = 'r'; country_code[2] = '\0'; break;
- case LC_ITALY: country_code[0] = 'i'; country_code[1] = 't'; country_code[2] = '\0'; break;
- case LC_SPAIN: country_code[0] = 'e'; country_code[1] = 's'; country_code[2] = '\0'; break;
- case LC_UK: country_code[0] = 'e'; country_code[1] = 'n'; country_code[2] = '\0'; break;
- case LC_TURKEY: country_code[0] = 't'; country_code[1] = 'r'; country_code[2] = '\0'; break;
- case LC_POLAND: country_code[0] = 'p'; country_code[1] = 'l'; country_code[2] = '\0'; break;
- case LC_PORTUGAL: country_code[0] = 'p'; country_code[1] = 't'; country_code[2] = '\0'; break;
- case LC_GREEK: country_code[0] = 'g'; country_code[1] = 'r'; country_code[2] = '\0'; break;
- case LC_RUSSIA: country_code[0] = 'r'; country_code[1] = 'u'; country_code[2] = '\0'; break;
- case LC_DENMARK: country_code[0] = 'd'; country_code[1] = 'k'; country_code[2] = '\0'; break;
- case LC_BULGARIA: country_code[0] = 'b'; country_code[1] = 'g'; country_code[2] = '\0'; break;
- case LC_CROATIA: country_code[0] = 'h'; country_code[1] = 'r'; country_code[2] = '\0'; break;
- case LC_MEXICO: country_code[0] = 'm'; country_code[1] = 'x'; country_code[2] = '\0'; break;
- case LC_ARABIA: country_code[0] = 'a'; country_code[1] = 'e'; country_code[2] = '\0'; break;
- case LC_CZECH: country_code[0] = 'c'; country_code[1] = 'z'; country_code[2] = '\0'; break;
- case LC_ROMANIA: country_code[0] = 'r'; country_code[1] = 'o'; country_code[2] = '\0'; break;
- case LC_HUNGARY: country_code[0] = 'h'; country_code[1] = 'u'; country_code[2] = '\0'; break;
- case LC_NETHERLANDS: country_code[0] = 'n'; country_code[1] = 'l'; country_code[2] = '\0'; break;
- case LC_USA: country_code[0] = 'u'; country_code[1] = 's'; country_code[2] = '\0'; break;
- case LC_CANADA: country_code[0] = 'c'; country_code[1] = 'a'; country_code[2] = '\0'; break;
- default:
- if (test_server == true)
- {
- country_code[0] = 'd'; country_code[1] = 'e'; country_code[2] = '\0';
- }
- break;
- }
- char buf[512+1];
- char sas[33];
- MD5_CTX ctx;
- const char sas_key[] = "GF9001";
- snprintf(buf, sizeof(buf), "%u%u%s", ch->GetPlayerID(), ch->GetAID(), sas_key);
- MD5Init(&ctx);
- MD5Update(&ctx, (const unsigned char *) buf, strlen(buf));
- #ifdef __FreeBSD__
- MD5End(&ctx, sas);
- #else
- static const char hex[] = "0123456789abcdef";
- unsigned char digest[16];
- MD5Final(digest, &ctx);
- int i;
- for (i = 0; i < 16; ++i) {
- sas[i+i] = hex[digest[i] >> 4];
- sas[i+i+1] = hex[digest[i] & 0x0f];
- }
- sas[i+i] = '\0';
- #endif
- snprintf(buf, sizeof(buf), "mall http://%s/ishop?pid=%u&c=%s&sid=%d&sas=%s",
- g_strWebMallURL.c_str(), ch->GetPlayerID(), country_code, g_server_id, sas);
- ch->ChatPacket(CHAT_TYPE_COMMAND, buf);
- }
- }
- // ÁÖ»çŔ§
- ACMD(do_dice)
- {
- sys_err("Wykryto użycie komendy /dice przez: %s", ch->GetName());
- }
- ACMD(do_click_mall)
- {
- ch->ChatPacket(CHAT_TYPE_COMMAND, "ShowMeMallPassword");
- }
- ACMD(do_shop_open)
- {
- if (ch->IsObserverMode() || ch->IsDead() || ch->IsStun() || ch->GetMountVnum() || ch->IsHorseRiding() == true || ch->IsOpenSafebox() || ch->GetShopOwner() || ch->GetMyShop() || ch->IsCubeOpen() || ch->GetExchange())
- {
- return;
- }
- ch->ChatPacket(CHAT_TYPE_COMMAND, "OpenPrivateShop");
- }
- ACMD(do_ride)
- {
- dev_log(LOG_DEB0, "[DO_RIDE] start");
- if (ch->IsDead() || ch->IsStun())
- return;
- if (ch->GetMapIndex() == 113)
- return;
- #ifdef ENABLE_MOUNT_COSTUME_SYSTEM
- if (ch->IsPolymorphed() == true){
- ch->ChatPacket(CHAT_TYPE_INFO, "Nu poti folosi un mount atat timp cat esti transformat.");
- return;
- }
- if(ch->GetWear(WEAR_COSTUME_MOUNT))
- {
- CMountSystem* mountSystem = ch->GetMountSystem();
- LPITEM mount = ch->GetWear(WEAR_COSTUME_MOUNT);
- DWORD mobVnum = 0;
- if (!mountSystem && !mount)
- return;
- #ifdef __CHANGELOOK_SYSTEM__
- if(mount->GetTransmutation())
- {
- const TItemTable* itemTable = ITEM_MANAGER::instance().GetTable(mount->GetTransmutation());
- if (itemTable)
- mobVnum = itemTable->alValues[1];
- else
- mobVnum = mount->GetValue(1);
- }
- else
- mobVnum = mount->GetValue(1);
- #else
- if(mount->GetValue(1) != 0)
- mobVnum = mount->GetValue(1);
- #endif
- if (ch->GetMountVnum())
- {
- if(mountSystem->CountSummoned() == 0)
- {
- mountSystem->Unmount(mobVnum);
- }
- }
- else
- {
- if(mountSystem->CountSummoned() == 1)
- {
- mountSystem->Mount(mobVnum, mount);
- }
- }
- return;
- }
- #endif
- if (ch->IsHorseRiding())
- {
- ch->StopRiding();
- return;
- }
- if (ch->GetHorse() != NULL)
- {
- ch->StartRiding();
- return;
- }
- for (BYTE i=0; i<INVENTORY_MAX_NUM; ++i)
- {
- LPITEM item = ch->GetInventoryItem(i);
- if (NULL == item)
- continue;
- if (item->GetType() == ITEM_COSTUME && item->GetSubType() == COSTUME_MOUNT) {
- ch->UseItem(TItemPos (INVENTORY, i));
- return;
- }
- }
- // Ÿ°ĹłŞ ł»¸± Ľö ľřŔ»¶§
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("¸»Ŕ» ¸ŐŔú ĽŇČŻÇŘÁÖĽĽżä."));
- }
- #ifdef __AUCTION__
- // temp_auction
- ACMD(do_get_item_id_list)
- {
- for (int i = 0; i < INVENTORY_MAX_NUM; i++)
- {
- LPITEM item = ch->GetInventoryItem(i);
- if (item != NULL)
- ch->ChatPacket(CHAT_TYPE_INFO, "name : %s id : %d", item->GetProto()->szName, item->GetID());
- }
- }
- // temp_auction
- ACMD(do_enroll_auction)
- {
- char arg1[256];
- char arg2[256];
- char arg3[256];
- char arg4[256];
- two_arguments (two_arguments(argument, arg1, sizeof(arg1), arg2, sizeof(arg2)), arg3, sizeof(arg3), arg4, sizeof(arg4));
- DWORD item_id = strtoul(arg1, NULL, 10);
- BYTE empire = strtoul(arg2, NULL, 10);
- int bidPrice = strtol(arg3, NULL, 10);
- int immidiatePurchasePrice = strtol(arg4, NULL, 10);
- LPITEM item = ITEM_MANAGER::instance().Find(item_id);
- if (item == NULL)
- return;
- AuctionManager::instance().enroll_auction(ch, item, empire, bidPrice, immidiatePurchasePrice);
- }
- ACMD(do_enroll_wish)
- {
- char arg1[256];
- char arg2[256];
- char arg3[256];
- one_argument (two_arguments(argument, arg1, sizeof(arg1), arg2, sizeof(arg2)), arg3, sizeof(arg3));
- DWORD item_num = strtoul(arg1, NULL, 10);
- BYTE empire = strtoul(arg2, NULL, 10);
- int wishPrice = strtol(arg3, NULL, 10);
- AuctionManager::instance().enroll_wish(ch, item_num, empire, wishPrice);
- }
- ACMD(do_enroll_sale)
- {
- char arg1[256];
- char arg2[256];
- char arg3[256];
- one_argument (two_arguments(argument, arg1, sizeof(arg1), arg2, sizeof(arg2)), arg3, sizeof(arg3));
- DWORD item_id = strtoul(arg1, NULL, 10);
- DWORD wisher_id = strtoul(arg2, NULL, 10);
- int salePrice = strtol(arg3, NULL, 10);
- LPITEM item = ITEM_MANAGER::instance().Find(item_id);
- if (item == NULL)
- return;
- AuctionManager::instance().enroll_sale(ch, item, wisher_id, salePrice);
- }
- // temp_auction
- // packetŔ¸·Î Ĺë˝ĹÇĎ°Ô ÇĎ°í, ŔĚ°Ç »čÁ¦ÇŘľßÇŃ´Ů.
- ACMD(do_get_auction_list)
- {
- char arg1[256];
- char arg2[256];
- char arg3[256];
- two_arguments (one_argument (argument, arg1, sizeof(arg1)), arg2, sizeof(arg2), arg3, sizeof(arg3));
- AuctionManager::instance().get_auction_list (ch, strtoul(arg1, NULL, 10), strtoul(arg2, NULL, 10), strtoul(arg3, NULL, 10));
- }
- //
- //ACMD(do_get_wish_list)
- //{
- // char arg1[256];
- // char arg2[256];
- // char arg3[256];
- // two_arguments (one_argument (argument, arg1, sizeof(arg1)), arg2, sizeof(arg2), arg3, sizeof(arg3));
- //
- // AuctionManager::instance().get_wish_list (ch, strtoul(arg1, NULL, 10), strtoul(arg2, NULL, 10), strtoul(arg3, NULL, 10));
- //}
- ACMD (do_get_my_auction_list)
- {
- char arg1[256];
- char arg2[256];
- two_arguments (argument, arg1, sizeof(arg1), arg2, sizeof(arg2));
- AuctionManager::instance().get_my_auction_list (ch, strtoul(arg1, NULL, 10), strtoul(arg2, NULL, 10));
- }
- ACMD (do_get_my_purchase_list)
- {
- char arg1[256];
- char arg2[256];
- two_arguments (argument, arg1, sizeof(arg1), arg2, sizeof(arg2));
- AuctionManager::instance().get_my_purchase_list (ch, strtoul(arg1, NULL, 10), strtoul(arg2, NULL, 10));
- }
- ACMD (do_auction_bid)
- {
- char arg1[256];
- char arg2[256];
- two_arguments (argument, arg1, sizeof(arg1), arg2, sizeof(arg2));
- AuctionManager::instance().bid (ch, strtoul(arg1, NULL, 10), strtoul(arg2, NULL, 10));
- }
- ACMD (do_auction_impur)
- {
- char arg1[256];
- one_argument (argument, arg1, sizeof(arg1));
- AuctionManager::instance().immediate_purchase (ch, strtoul(arg1, NULL, 10));
- }
- ACMD (do_get_auctioned_item)
- {
- char arg1[256];
- char arg2[256];
- two_arguments (argument, arg1, sizeof(arg1), arg2, sizeof(arg2));
- AuctionManager::instance().get_auctioned_item (ch, strtoul(arg1, NULL, 10), strtoul(arg2, NULL, 10));
- }
- ACMD (do_buy_sold_item)
- {
- char arg1[256];
- char arg2[256];
- one_argument (argument, arg1, sizeof(arg1));
- AuctionManager::instance().get_auctioned_item (ch, strtoul(arg1, NULL, 10), strtoul(arg2, NULL, 10));
- }
- ACMD (do_cancel_auction)
- {
- char arg1[256];
- one_argument (argument, arg1, sizeof(arg1));
- AuctionManager::instance().cancel_auction (ch, strtoul(arg1, NULL, 10));
- }
- ACMD (do_cancel_wish)
- {
- char arg1[256];
- one_argument (argument, arg1, sizeof(arg1));
- AuctionManager::instance().cancel_wish (ch, strtoul(arg1, NULL, 10));
- }
- ACMD (do_cancel_sale)
- {
- char arg1[256];
- one_argument (argument, arg1, sizeof(arg1));
- AuctionManager::instance().cancel_sale (ch, strtoul(arg1, NULL, 10));
- }
- ACMD (do_rebid)
- {
- char arg1[256];
- char arg2[256];
- two_arguments (argument, arg1, sizeof(arg1), arg2, sizeof(arg2));
- AuctionManager::instance().rebid (ch, strtoul(arg1, NULL, 10), strtoul(arg2, NULL, 10));
- }
- ACMD (do_bid_cancel)
- {
- char arg1[256];
- char arg2[256];
- two_arguments (argument, arg1, sizeof(arg1), arg2, sizeof(arg2));
- AuctionManager::instance().bid_cancel (ch, strtoul(arg1, NULL, 10));
- }
- #endif
- struct s_sort {
- bool operator() (LPITEM src, LPITEM dst) { return (src->GetVnum()<dst->GetVnum()); }
- } _sort;
- ACMD(do_sort_inventory)
- {
- std::vector<LPITEM> collectItems;
- std::vector<WORD> oldCells;
- int INVENTORY_MAX_NUM = 180;
- int totalSize = 0;
- for (WORD i = 0; i < INVENTORY_MAX_NUM; ++i)
- {
- LPITEM item = ch->GetInventoryItem(i);
- if (item)
- {
- totalSize += item->GetSize();
- oldCells.push_back(item->GetCell());
- collectItems.push_back(item);
- }
- }
- if (totalSize - 3 >= INVENTORY_MAX_NUM)
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("INVENTORY_FULL_CANNOT_SORT"));
- return;
- }
- std::vector<LPITEM>::iterator it = collectItems.begin(), end = collectItems.end();
- for (; it != end; ++it)
- ((LPITEM)*it)->RemoveFromCharacter();
- std::sort(collectItems.begin(), collectItems.end(), _sort);
- std::vector<LPITEM>::iterator it1 = collectItems.begin(), end1 = collectItems.end();
- for (; it1 != end1; ++it1)
- {
- WORD cell = ch->GetEmptyInventory(((LPITEM)*it1)->GetSize());
- ((LPITEM)*it1)->AddToCharacter(ch, TItemPos(INVENTORY, cell)/*, isNew=false*/);
- }
- }
- ACMD(do_efektimiver)
- {
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (ch->IsDead() || ch->GetHP() <= 0 || !ch->IsPC())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, "Nie możesz tego zrobić.");
- return;
- }
- if (*arg1)
- {
- switch (LOWER(*arg1))
- {
- case 'a'://sarý efekt
- if (!ch->IsAffectFlag(AFFECT_YELLOW)){
- ch->AddAffect(AFFECT_YELLOW, POINT_NONE, 0,AFF_YELLOW, INFINITE_AFFECT_DURATION, 0, false);
- }
- break;
- case 'b'://kahverengi efekt
- if (!ch->IsAffectFlag(AFFECT_BROWN)){
- ch->AddAffect(AFFECT_BROWN, POINT_NONE, 0,AFF_BROWN, INFINITE_AFFECT_DURATION, 0, false);
- }
- break;
- case 'c'://gri efekt
- if (!ch->IsAffectFlag(AFFECT_GREY)){
- ch->AddAffect(AFFECT_GREY, POINT_NONE, 0,AFF_GREY, INFINITE_AFFECT_DURATION, 0, false);
- }
- break;
- case 'd'://turuncu efekt
- if (!ch->IsAffectFlag(AFFECT_ORANGE)){
- ch->AddAffect(AFFECT_ORANGE, POINT_NONE, 0,AFF_ORANGE, INFINITE_AFFECT_DURATION, 0, false);
- }
- break;
- case 'e'://pembe efekt
- if (!ch->IsAffectFlag(AFFECT_PINK)){
- ch->AddAffect(AFFECT_PINK, POINT_NONE, 0,AFF_PINK, INFINITE_AFFECT_DURATION, 0, false);
- }
- break;
- case 'f'://mor efekt
- if (!ch->IsAffectFlag(AFFECT_PURPLE)){
- ch->AddAffect(AFFECT_PURPLE, POINT_NONE, 0,AFF_PURPLE, INFINITE_AFFECT_DURATION, 0, false);
- }
- break;
- case 'g'://turkuaz efekt
- if (!ch->IsAffectFlag(AFFECT_TURQUOISE)){
- ch->AddAffect(AFFECT_TURQUOISE, POINT_NONE, 0,AFF_TURQUOISE, INFINITE_AFFECT_DURATION, 0, false);
- }
- break;
- case 'h'://mavi efekt
- if (!ch->IsAffectFlag(AFFECT_BLUE)){
- ch->AddAffect(AFFECT_BLUE, POINT_NONE, 0,AFF_BLUE, INFINITE_AFFECT_DURATION, 0, false);
- }
- break;
- case 'j'://kýrmýzý efekt
- if (!ch->IsAffectFlag(AFFECT_RED)){
- ch->AddAffect(AFFECT_RED, POINT_NONE, 0,AFF_RED, INFINITE_AFFECT_DURATION, 0, false);
- }
- break;
- }
- }
- }
- ACMD(do_efektlerisil)
- {
- if (ch->IsDead() || ch->GetHP() <= 0 || !ch->IsPC())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, "Nie możesz tego zrobić.");
- return;
- }
- if (ch->RemoveAffect(AFFECT_YELLOW));
- if (ch->RemoveAffect(AFFECT_BROWN));
- if (ch->RemoveAffect(AFFECT_GREY));
- if (ch->RemoveAffect(AFFECT_ORANGE));
- if (ch->RemoveAffect(AFFECT_PINK));
- if (ch->RemoveAffect(AFFECT_PURPLE));
- if (ch->RemoveAffect(AFFECT_TURQUOISE));
- if (ch->RemoveAffect(AFFECT_BLUE));
- if (ch->RemoveAffect(AFFECT_RED));
- ch->ChatPacket(CHAT_TYPE_INFO, "Efekt Usunięty.");
- }
- ACMD(do_stat_val)
- {
- char arg1[256], arg2[256];
- two_arguments(argument, arg1, sizeof(arg1), arg2, sizeof(arg2));
- int val = 0;
- str_to_number(val, arg2);
- if (!*arg1 || val <= 0)
- return;
- if (ch->IsPolymorphed())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("Nie możesz tego zrobić."));
- return;
- }
- if (ch->GetPoint(POINT_STAT) <= 0)
- return;
- BYTE idx = 0;
- if (!strcmp(arg1, "st"))
- idx = POINT_ST;
- else if (!strcmp(arg1, "dx"))
- idx = POINT_DX;
- else if (!strcmp(arg1, "ht"))
- idx = POINT_HT;
- else if (!strcmp(arg1, "iq"))
- idx = POINT_IQ;
- else
- return;
- if (ch->GetRealPoint(idx) >= MAX_STAT)
- return;
- if (val > ch->GetPoint(POINT_STAT))
- {
- val = ch->GetPoint(POINT_STAT);
- }
- if (ch->GetRealPoint(idx) + val > MAX_STAT)
- {
- val = MAX_STAT - ch->GetRealPoint(idx);
- }
- ch->SetRealPoint(idx, ch->GetRealPoint(idx) + val);
- ch->SetPoint(idx, ch->GetPoint(idx) + val);
- ch->ComputePoints();
- ch->PointChange(idx, 0);
- if (idx == POINT_IQ)
- {
- ch->PointChange(POINT_MAX_HP, 0);
- }
- else if (idx == POINT_HT)
- {
- ch->PointChange(POINT_MAX_SP, 0);
- }
- ch->PointChange(POINT_STAT, -val);
- ch->ComputePoints();
- }
- const struct change_visual_eq_struct
- {
- const BYTE partNum;
- const std::string flagName;
- } change_visual_eq_fields[] = {
- { PART_MAIN, "visual_eq.main" },
- { PART_WEAPON, "visual_eq.weapon" },
- { PART_HAIR, "visual_eq.hair" },
- { PART_SASH, "visual_eq.sash" },
- };
- ACMD(do_change_visual_eq)
- {
- if (!ch)
- return;
- if (ch->IsPolymorphed())
- {
- ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("Nie mozesz tego wykonac. Jestes przemieniony w potwora."));
- return;
- }
- char arg1[256];
- one_argument(argument, arg1, sizeof(arg1));
- if (!*arg1)
- return;
- BYTE partNum = PART_MAX_NUM;
- str_to_number(partNum, arg1);
- switch (partNum)
- {
- case PART_MAIN:
- case PART_WEAPON:
- case PART_HAIR:
- case PART_SASH:
- {
- std::string flagName = change_visual_eq_fields[partNum].flagName;
- ch->SetQuestFlag(flagName, !ch->GetQuestFlag(flagName));
- break;
- }
- default:
- break;
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement