diff --git a/astron/dclass/toon.dc b/astron/dclass/toon.dc index 909a87eb..7a225891 100644 --- a/astron/dclass/toon.dc +++ b/astron/dclass/toon.dc @@ -72,6 +72,7 @@ from toontown.estate import DistributedGarden/AI from toontown.shtiker import DeleteManager/AI from toontown.ai import NewsManager/AI from toontown.shtiker import PurchaseManager/AI +from toontown.shtiker import GroupManager/AI from toontown.shtiker import NewbiePurchaseManager/AI from toontown.safezone import SafeZoneManager/AI from toontown.tutorial import TutorialManager/AI @@ -1488,6 +1489,16 @@ dclass PurchaseManager : DistributedObject { setPurchaseExit() broadcast; }; +dclass GroupManager : DistributedObject { + createGroup(uint32, uint32, string) clsend airecv; + closeGroup(uint32, uint32) clsend airecv; + addPlayerId(uint32, uint32, uint32) clsend airecv; + removePlayerId(uint32, uint32, uint32) clsend airecv; + getInfo(uint32) clsend airecv; + setInfo(string) clsend airecv; + info(string); +}; + dclass NewbiePurchaseManager : PurchaseManager { setOwnedNewbieId(uint32) required broadcast ram; }; diff --git a/otp/distributed/DCClassImports.py b/otp/distributed/DCClassImports.py index 3f9638d0..387213a6 100644 --- a/otp/distributed/DCClassImports.py +++ b/otp/distributed/DCClassImports.py @@ -1,58 +1,58 @@ -# This file was generated by the parse_dclass.py utility. -from pandac.PandaModules import * - - -hashVal = 3181838135L - - -from toontown.coghq import DistributedCashbotBossSafe, DistributedCashbotBossCrane, DistributedBattleFactory, DistributedCashbotBossTreasure, DistributedCogHQDoor, DistributedSellbotHQDoor, DistributedFactoryElevatorExt, DistributedMintElevatorExt, DistributedLawOfficeElevatorExt, DistributedLawOfficeElevatorInt, LobbyManager, DistributedMegaCorp, DistributedFactory, DistributedLawOffice, DistributedLawOfficeFloor, DistributedLift, DistributedDoorEntity, DistributedSwitch, DistributedButton, DistributedTrigger, DistributedCrushableEntity, DistributedCrusherEntity, DistributedStomper, DistributedStomperPair, DistributedLaserField, DistributedGolfGreenGame, DistributedSecurityCamera, DistributedMover, DistributedElevatorMarker, DistributedBarrelBase, DistributedGagBarrel, DistributedBeanBarrel, DistributedHealBarrel, DistributedGrid, ActiveCell, DirectionalCell, CrusherCell, DistributedCrate, DistributedSinkingPlatform, BattleBlocker, DistributedMint, DistributedMintRoom, DistributedMintBattle, DistributedStage, DistributedStageRoom, DistributedStageBattle, DistributedLawbotBossGavel, DistributedLawbotCannon, DistributedLawbotChair, DistributedCogKart, DistributedCountryClub, DistributedCountryClubRoom, DistributedMoleField, DistributedCountryClubBattle, DistributedMaze, DistributedFoodBelt, DistributedBanquetTable, DistributedGolfSpot -from toontown.golf import DistributedPhysicsWorld, DistributedGolfHole, DistributedGolfCourse -from toontown.building import DistributedAnimatedProp, DistributedTrophyMgr, DistributedBuilding, DistributedAnimBuilding, DistributedBuildingQueryMgr, DistributedToonInterior, DistributedToonHallInterior, DistributedSuitInterior, DistributedHQInterior, DistributedGagshopInterior, DistributedPetshopInterior, DistributedKartShopInterior, DistributedBankInterior, DistributedBankCollectable, DistributedLibraryInterior, DistributedDoor, DistributedAnimDoor, DistributedKnockKnockDoor, DistributedElevator, DistributedElevatorFSM, DistributedElevatorExt, DistributedElevatorInt, DistributedElevatorFloor, DistributedBossElevator, DistributedVPElevator, DistributedCFOElevator, DistributedCJElevator, DistributedBBElevator, DistributedBoardingParty, DistributedTutorialInterior, DistributedClubElevator -from toontown.uberdog.DistributedPartyManager import DistributedPartyManager -from otp.friends import FriendManager, AvatarFriendsManager, PlayerFriendsManager, GuildManager, FriendInfo, AvatarFriendInfo -from otp.level import DistributedLevel, DistributedEntity, DistributedInteractiveEntity -from toontown.shtiker import DeleteManager, PurchaseManager, NewbiePurchaseManager -from toontown.pets import DistributedPetProxy -from toontown.uberdog.ClientServicesManager import ClientServicesManager -from toontown.ai import WelcomeValleyManager, NewsManager, DistributedAprilToonsMgr, DistributedBlackCatMgr, DistributedPolarBearMgr, DistributedPolarPlaceEffectMgr, DistributedGreenToonEffectMgr, DistributedResistanceEmoteMgr, DistributedScavengerHuntTarget, DistributedTrickOrTreatTarget, DistributedWinterCarolingTarget, DistributedSillyMeterMgr -from toontown.ai.DistributedTrashcanZeroMgr import DistributedTrashcanZeroMgr -from toontown.uberdog.DistributedMailManager import DistributedMailManager -from otp.chat import ChatAgent -from toontown.classicchars import DistributedCCharBase, DistributedMickey, DistributedVampireMickey, DistributedMinnie, DistributedWitchMinnie, DistributedGoofy, DistributedSuperGoofy, DistributedDaisy, DistributedSockHopDaisy, DistributedChip, DistributedPoliceChip, DistributedDale, DistributedJailbirdDale, DistributedGoofySpeedway, DistributedDonald, DistributedFrankenDonald, DistributedDonaldDock, DistributedPluto, DistributedWesternPluto -from toontown.uberdog.DistributedCpuInfoMgr import DistributedCpuInfoMgr -from toontown.parties.GlobalPartyManager import GlobalPartyManager -from toontown.racing.DistributedStartingBlock import DistributedViewingBlock -from toontown.ai.DistributedPhaseEventMgr import DistributedPhaseEventMgr -from toontown.pets.PetDCImports import * -from toontown.suit import DistributedSuitPlanner, DistributedSuitBase, DistributedSuit, DistributedTutorialSuit, DistributedFactorySuit, DistributedMintSuit, DistributedStageSuit, DistributedSellbotBoss, DistributedCashbotBoss, DistributedCashbotBossGoon, DistributedGoon, DistributedGridGoon, DistributedLawbotBoss, DistributedLawbotBossSuit, DistributedBossbotBoss -from toontown.distributed import ToontownDistrict, ToontownDistrictStats, DistributedTimer -from toontown.effects import DistributedFireworkShow -from toontown.uberdog.DistributedDataStoreManager import DistributedDataStoreManager -from toontown.safezone import DistributedTrolley, DistributedPartyGate, DistributedBoat, DistributedButterfly, DistributedMMPiano, DistributedDGFlower, DistributedFishingSpot, SafeZoneManager, DistributedTreasure, DistributedGolfKart, DistributedPicnicBasket, DistributedGameTable, DistributedChineseCheckers, DistributedCheckers, DistributedFindFour -from toontown.fishing import DistributedFishingPond, DistributedFishingTarget, DistributedPondBingoManager -from toontown.minigame import DistributedMinigame, DistributedMinigameTemplate, DistributedRaceGame, DistributedCannonGame, DistributedPhotoGame, DistributedPatternGame, DistributedRingGame, DistributedTagGame, DistributedMazeGame, DistributedTugOfWarGame, DistributedCatchGame, DistributedDivingGame, DistributedTargetGame, DistributedTravelGame, DistributedPairingGame, DistributedVineGame, DistributedIceGame, DistributedCogThiefGame, DistributedTwoDGame -from toontown.racing import DistributedVehicle, DistributedStartingBlock, DistributedRace, DistributedKartPad, DistributedRacePad, DistributedViewPad, DistributedStartingBlock, DistributedLeaderBoard, DistributedGag, DistributedProjectile -from toontown.distributed.NonRepeatableRandomSourceUD import NonRepeatableRandomSourceUD -from toontown.catalog import CatalogManager -from toontown.ai.DistributedHydrantZeroMgr import DistributedHydrantZeroMgr -from toontown.rpc.AwardManager import AwardManager -from toontown.parties import DistributedParty, DistributedPartyActivity, DistributedPartyTeamActivity, DistributedPartyCannon, DistributedPartyCannonActivity, DistributedPartyCatchActivity, DistributedPartyWinterCatchActivity, DistributedPartyCogActivity, DistributedPartyWinterCogActivity, DistributedPartyFireworksActivity, DistributedPartyDanceActivityBase, DistributedPartyDanceActivity, DistributedPartyDance20Activity, DistributedPartyValentineDanceActivity, DistributedPartyValentineDance20Activity, DistributedPartyTrampolineActivity, DistributedPartyValentineTrampolineActivity, DistributedPartyVictoryTrampolineActivity, DistributedPartyWinterTrampolineActivity, DistributedPartyTugOfWarActivity, DistributedPartyJukeboxActivityBase, DistributedPartyJukeboxActivity, DistributedPartyJukebox40Activity, DistributedPartyValentineJukeboxActivity, DistributedPartyValentineJukebox40Activity -from toontown.uberdog.DistributedInGameNewsMgr import DistributedInGameNewsMgr -from toontown.coghq.InGameEditorDCImports import * -from toontown.friends import TTPlayerFriendsManager, TTUFriendsManager -from toontown.cogdominium import DistributedCogdoInterior, DistributedCogdoBattleBldg, DistributedCogdoElevatorExt, DistributedCogdoElevatorInt, DistributedCogdoBarrel, DistCogdoGame, DistCogdoLevelGame, DistCogdoBoardroomGame, DistCogdoCraneGame, DistCogdoMazeGame, DistCogdoFlyingGame, DistCogdoCrane, DistCogdoCraneMoneyBag, DistCogdoCraneCog -from otp.distributed import Account, ObjectServer, DistributedDistrict, DistributedDirectory, DistributedTestObject, CentralLogger -from toontown.estate import DistributedCannon, DistributedTarget, EstateManager, DistributedEstate, DistributedHouse, DistributedHouseInterior, DistributedGarden, DistributedHouseDoor, DistributedBankMgr, DistributedMailbox, DistributedFurnitureManager, DistributedFurnitureItem, DistributedBank, DistributedCloset, DistributedTrunk, DistributedPhone, DistributedFireworksCannon, DistributedLawnDecor, DistributedGardenPlot, DistributedGardenBox, DistributedFlower, DistributedGagTree, DistributedStatuary, DistributedToonStatuary, DistributedChangingStatuary, DistributedAnimatedStatuary, DistributedPlantBase, DistributedLawnDecor -from toontown.toon import DistributedToon, DistributedNPCToonBase, DistributedNPCToon, DistributedSmartNPC, DistributedSmartNPC, DistributedNPCSpecialQuestGiver, DistributedNPCFlippyInToonHall, DistributedNPCScientist, DistributedNPCClerk, DistributedNPCTailor, DistributedNPCBlocker, DistributedNPCFisherman, DistributedNPCPartyPerson, DistributedNPCPetclerk, DistributedNPCKartClerk, DistributedNPCYin, DistributedNPCYang, DistributedNPCBanker -from toontown.tutorial import DistributedBattleTutorial, TutorialManager -from toontown.coderedemption.TTCodeRedemptionMgr import TTCodeRedemptionMgr -from toontown.distributed.NonRepeatableRandomSourceAI import NonRepeatableRandomSourceAI -from toontown.ai.DistributedMailboxZeroMgr import DistributedMailboxZeroMgr -from toontown.uberdog.DistributedDeliveryManager import DistributedDeliveryManager -from direct.distributed import DistributedObject, DistributedNode, DistributedSmoothNode, DistributedCartesianGrid, DistributedCamera, DistributedObjectGlobal -from otp.ai import TimeManager, MagicWordManager -from otp.avatar import DistributedAvatar, DistributedPlayer, AvatarHandle -from toontown.battle import DistributedBattleBase, DistributedBattle, DistributedBattleBldg, DistributedBattleFinal, DistributedBattleWaiters, DistributedBattleDiners - - -dcImports = locals().copy() +# This file was generated by the parse_dclass.py utility. +from pandac.PandaModules import * + + +hashVal = 3179828763L + + +from toontown.coghq import DistributedCashbotBossSafe, DistributedCashbotBossCrane, DistributedBattleFactory, DistributedCashbotBossTreasure, DistributedCogHQDoor, DistributedSellbotHQDoor, DistributedFactoryElevatorExt, DistributedMintElevatorExt, DistributedLawOfficeElevatorExt, DistributedLawOfficeElevatorInt, LobbyManager, DistributedMegaCorp, DistributedFactory, DistributedLawOffice, DistributedLawOfficeFloor, DistributedLift, DistributedDoorEntity, DistributedSwitch, DistributedButton, DistributedTrigger, DistributedCrushableEntity, DistributedCrusherEntity, DistributedStomper, DistributedStomperPair, DistributedLaserField, DistributedGolfGreenGame, DistributedSecurityCamera, DistributedMover, DistributedElevatorMarker, DistributedBarrelBase, DistributedGagBarrel, DistributedBeanBarrel, DistributedHealBarrel, DistributedGrid, ActiveCell, DirectionalCell, CrusherCell, DistributedCrate, DistributedSinkingPlatform, BattleBlocker, DistributedMint, DistributedMintRoom, DistributedMintBattle, DistributedStage, DistributedStageRoom, DistributedStageBattle, DistributedLawbotBossGavel, DistributedLawbotCannon, DistributedLawbotChair, DistributedCogKart, DistributedCountryClub, DistributedCountryClubRoom, DistributedMoleField, DistributedCountryClubBattle, DistributedMaze, DistributedFoodBelt, DistributedBanquetTable, DistributedGolfSpot +from toontown.golf import DistributedPhysicsWorld, DistributedGolfHole, DistributedGolfCourse +from toontown.building import DistributedAnimatedProp, DistributedTrophyMgr, DistributedBuilding, DistributedAnimBuilding, DistributedBuildingQueryMgr, DistributedToonInterior, DistributedToonHallInterior, DistributedSuitInterior, DistributedHQInterior, DistributedGagshopInterior, DistributedPetshopInterior, DistributedKartShopInterior, DistributedBankInterior, DistributedBankCollectable, DistributedLibraryInterior, DistributedDoor, DistributedAnimDoor, DistributedKnockKnockDoor, DistributedElevator, DistributedElevatorFSM, DistributedElevatorExt, DistributedElevatorInt, DistributedElevatorFloor, DistributedBossElevator, DistributedVPElevator, DistributedCFOElevator, DistributedCJElevator, DistributedBBElevator, DistributedBoardingParty, DistributedTutorialInterior, DistributedClubElevator +from toontown.uberdog.DistributedPartyManager import DistributedPartyManager +from otp.friends import FriendManager, AvatarFriendsManager, PlayerFriendsManager, GuildManager, FriendInfo, AvatarFriendInfo +from otp.level import DistributedLevel, DistributedEntity, DistributedInteractiveEntity +from toontown.shtiker import DeleteManager, PurchaseManager, GroupManager, NewbiePurchaseManager +from toontown.pets import DistributedPetProxy +from toontown.uberdog.ClientServicesManager import ClientServicesManager +from toontown.ai import WelcomeValleyManager, NewsManager, DistributedAprilToonsMgr, DistributedBlackCatMgr, DistributedPolarBearMgr, DistributedPolarPlaceEffectMgr, DistributedGreenToonEffectMgr, DistributedResistanceEmoteMgr, DistributedScavengerHuntTarget, DistributedTrickOrTreatTarget, DistributedWinterCarolingTarget, DistributedSillyMeterMgr +from toontown.ai.DistributedTrashcanZeroMgr import DistributedTrashcanZeroMgr +from toontown.uberdog.DistributedMailManager import DistributedMailManager +from otp.chat import ChatAgent +from toontown.classicchars import DistributedCCharBase, DistributedMickey, DistributedVampireMickey, DistributedMinnie, DistributedWitchMinnie, DistributedGoofy, DistributedSuperGoofy, DistributedDaisy, DistributedSockHopDaisy, DistributedChip, DistributedPoliceChip, DistributedDale, DistributedJailbirdDale, DistributedGoofySpeedway, DistributedDonald, DistributedFrankenDonald, DistributedDonaldDock, DistributedPluto, DistributedWesternPluto +from toontown.uberdog.DistributedCpuInfoMgr import DistributedCpuInfoMgr +from toontown.parties.GlobalPartyManager import GlobalPartyManager +from toontown.racing.DistributedStartingBlock import DistributedViewingBlock +from toontown.ai.DistributedPhaseEventMgr import DistributedPhaseEventMgr +from toontown.pets.PetDCImports import * +from toontown.suit import DistributedSuitPlanner, DistributedSuitBase, DistributedSuit, DistributedTutorialSuit, DistributedFactorySuit, DistributedMintSuit, DistributedStageSuit, DistributedSellbotBoss, DistributedCashbotBoss, DistributedCashbotBossGoon, DistributedGoon, DistributedGridGoon, DistributedLawbotBoss, DistributedLawbotBossSuit, DistributedBossbotBoss +from toontown.distributed import ToontownDistrict, ToontownDistrictStats, DistributedTimer +from toontown.effects import DistributedFireworkShow +from toontown.uberdog.DistributedDataStoreManager import DistributedDataStoreManager +from toontown.safezone import DistributedTrolley, DistributedPartyGate, DistributedBoat, DistributedButterfly, DistributedMMPiano, DistributedDGFlower, DistributedFishingSpot, SafeZoneManager, DistributedTreasure, DistributedGolfKart, DistributedPicnicBasket, DistributedGameTable, DistributedChineseCheckers, DistributedCheckers, DistributedFindFour +from toontown.fishing import DistributedFishingPond, DistributedFishingTarget, DistributedPondBingoManager +from toontown.minigame import DistributedMinigame, DistributedMinigameTemplate, DistributedRaceGame, DistributedCannonGame, DistributedPhotoGame, DistributedPatternGame, DistributedRingGame, DistributedTagGame, DistributedMazeGame, DistributedTugOfWarGame, DistributedCatchGame, DistributedDivingGame, DistributedTargetGame, DistributedTravelGame, DistributedPairingGame, DistributedVineGame, DistributedIceGame, DistributedCogThiefGame, DistributedTwoDGame +from toontown.racing import DistributedVehicle, DistributedStartingBlock, DistributedRace, DistributedKartPad, DistributedRacePad, DistributedViewPad, DistributedStartingBlock, DistributedLeaderBoard, DistributedGag, DistributedProjectile +from toontown.distributed.NonRepeatableRandomSourceUD import NonRepeatableRandomSourceUD +from toontown.catalog import CatalogManager +from toontown.ai.DistributedHydrantZeroMgr import DistributedHydrantZeroMgr +from toontown.rpc.AwardManager import AwardManager +from toontown.parties import DistributedParty, DistributedPartyActivity, DistributedPartyTeamActivity, DistributedPartyCannon, DistributedPartyCannonActivity, DistributedPartyCatchActivity, DistributedPartyWinterCatchActivity, DistributedPartyCogActivity, DistributedPartyWinterCogActivity, DistributedPartyFireworksActivity, DistributedPartyDanceActivityBase, DistributedPartyDanceActivity, DistributedPartyDance20Activity, DistributedPartyValentineDanceActivity, DistributedPartyValentineDance20Activity, DistributedPartyTrampolineActivity, DistributedPartyValentineTrampolineActivity, DistributedPartyVictoryTrampolineActivity, DistributedPartyWinterTrampolineActivity, DistributedPartyTugOfWarActivity, DistributedPartyJukeboxActivityBase, DistributedPartyJukeboxActivity, DistributedPartyJukebox40Activity, DistributedPartyValentineJukeboxActivity, DistributedPartyValentineJukebox40Activity +from toontown.uberdog.DistributedInGameNewsMgr import DistributedInGameNewsMgr +from toontown.coghq.InGameEditorDCImports import * +from toontown.friends import TTPlayerFriendsManager, TTUFriendsManager +from toontown.cogdominium import DistributedCogdoInterior, DistributedCogdoBattleBldg, DistributedCogdoElevatorExt, DistributedCogdoElevatorInt, DistributedCogdoBarrel, DistCogdoGame, DistCogdoLevelGame, DistCogdoBoardroomGame, DistCogdoCraneGame, DistCogdoMazeGame, DistCogdoFlyingGame, DistCogdoCrane, DistCogdoCraneMoneyBag, DistCogdoCraneCog +from otp.distributed import Account, ObjectServer, DistributedDistrict, DistributedDirectory, DistributedTestObject, CentralLogger +from toontown.estate import DistributedCannon, DistributedTarget, EstateManager, DistributedEstate, DistributedHouse, DistributedHouseInterior, DistributedGarden, DistributedHouseDoor, DistributedBankMgr, DistributedMailbox, DistributedFurnitureManager, DistributedFurnitureItem, DistributedBank, DistributedCloset, DistributedTrunk, DistributedPhone, DistributedFireworksCannon, DistributedLawnDecor, DistributedGardenPlot, DistributedGardenBox, DistributedFlower, DistributedGagTree, DistributedStatuary, DistributedToonStatuary, DistributedChangingStatuary, DistributedAnimatedStatuary, DistributedPlantBase, DistributedLawnDecor +from toontown.toon import DistributedToon, DistributedNPCToonBase, DistributedNPCToon, DistributedSmartNPC, DistributedSmartNPC, DistributedNPCSpecialQuestGiver, DistributedNPCFlippyInToonHall, DistributedNPCScientist, DistributedNPCClerk, DistributedNPCTailor, DistributedNPCBlocker, DistributedNPCFisherman, DistributedNPCPartyPerson, DistributedNPCPetclerk, DistributedNPCKartClerk, DistributedNPCYin, DistributedNPCYang, DistributedNPCBanker +from toontown.tutorial import DistributedBattleTutorial, TutorialManager +from toontown.coderedemption.TTCodeRedemptionMgr import TTCodeRedemptionMgr +from toontown.distributed.NonRepeatableRandomSourceAI import NonRepeatableRandomSourceAI +from toontown.ai.DistributedMailboxZeroMgr import DistributedMailboxZeroMgr +from toontown.uberdog.DistributedDeliveryManager import DistributedDeliveryManager +from direct.distributed import DistributedObject, DistributedNode, DistributedSmoothNode, DistributedCartesianGrid, DistributedCamera, DistributedObjectGlobal +from otp.ai import TimeManager, MagicWordManager +from otp.avatar import DistributedAvatar, DistributedPlayer, AvatarHandle +from toontown.battle import DistributedBattleBase, DistributedBattle, DistributedBattleBldg, DistributedBattleFinal, DistributedBattleWaiters, DistributedBattleDiners + + +dcImports = locals().copy() diff --git a/otp/distributed/DistributedDistrictAI.py b/otp/distributed/DistributedDistrictAI.py index 54a1dd01..b9870151 100644 --- a/otp/distributed/DistributedDistrictAI.py +++ b/otp/distributed/DistributedDistrictAI.py @@ -1,6 +1,6 @@ from direct.directnotify.DirectNotifyGlobal import directNotify from direct.distributed.DistributedObjectAI import DistributedObjectAI - +from toontown.toonbase import ToontownGlobals class DistributedDistrictAI(DistributedObjectAI): notify = directNotify.newCategory('DistributedDistrictAI') @@ -8,6 +8,16 @@ class DistributedDistrictAI(DistributedObjectAI): name = 'District' available = 0 + def announceGenerate(self): + DistributedObjectAI.announceGenerate(self) + doId = self.doId - (self.doId % 100000000 % 1000000) + self.air.groupManager.shardGroups[doId] = { + ToontownGlobals.SellbotHQ: ['VP Group', []], + ToontownGlobals.CashbotHQ: ['CFO Group', []], + ToontownGlobals.LawbotHQ: ['CJ Group', []], + ToontownGlobals.BossbotHQ: ['CEO Group', []], + } + def setName(self, name): self.name = name diff --git a/toontown/ai/ServiceStart.py b/toontown/ai/ServiceStart.py index 02df1a35..4850f968 100644 --- a/toontown/ai/ServiceStart.py +++ b/toontown/ai/ServiceStart.py @@ -35,7 +35,6 @@ if args.astron_ip: localconfig += 'air-connect %s\n' % args.astron_ip if args.eventlogger_ip: localconfig += 'eventlog-host %s\n' % args.eventlogger_ip loadPrcFileData('Command-line', localconfig) - from otp.ai.AIBaseGlobal import * from toontown.ai.ToontownAIRepository import ToontownAIRepository diff --git a/toontown/ai/ToontownAIRepository.py b/toontown/ai/ToontownAIRepository.py index f1dcad48..175ff476 100644 --- a/toontown/ai/ToontownAIRepository.py +++ b/toontown/ai/ToontownAIRepository.py @@ -46,6 +46,7 @@ from toontown.hood import ZoneUtil from toontown.pets.PetManagerAI import PetManagerAI from toontown.safezone.SafeZoneManagerAI import SafeZoneManagerAI from toontown.suit.SuitInvasionManagerAI import SuitInvasionManagerAI +from toontown.shtiker.GroupManagerAI import GroupManagerAI from toontown.toon import NPCToons from toontown.toonbase import ToontownGlobals from toontown.tutorial.TutorialManagerAI import TutorialManagerAI @@ -70,6 +71,7 @@ class ToontownAIRepository(ToontownInternalRepository): self.mintMgr = None self.lawOfficeMgr = None self.countryClubMgr = None + self.groupManager = GroupManagerAI(self) self.zoneAllocator = UniqueIdAllocator(ToontownGlobals.DynamicZonesBegin, ToontownGlobals.DynamicZonesEnd) @@ -117,6 +119,7 @@ class ToontownAIRepository(ToontownInternalRepository): self.holidayManager = HolidayManagerAI(self) self.buildingQueryMgr = DistributedBuildingQueryMgrAI(self) self.buildingQueryMgr.generateWithRequired(2) + self.groupManager.generateWithRequired(2) if self.wantFishing: self.fishManager = FishManagerAI(self) if self.wantHousing: diff --git a/toontown/distributed/ToontownClientRepository.py b/toontown/distributed/ToontownClientRepository.py index bd6d400f..14cf99f1 100644 --- a/toontown/distributed/ToontownClientRepository.py +++ b/toontown/distributed/ToontownClientRepository.py @@ -45,7 +45,6 @@ from toontown.distributed import ToontownDistrictStats from toontown.makeatoon import TTPickANamePattern from toontown.parties import ToontownTimeManager from toontown.toon import Toon, DistributedToon -from toontown.building import DistributedBuildingQueryMgr from ToontownMsgTypes import * import HoodMgr import PlayGame diff --git a/toontown/distributed/ToontownDistrictStatsAI.py b/toontown/distributed/ToontownDistrictStatsAI.py index 76ebabec..843a4971 100644 --- a/toontown/distributed/ToontownDistrictStatsAI.py +++ b/toontown/distributed/ToontownDistrictStatsAI.py @@ -1,7 +1,6 @@ from direct.directnotify.DirectNotifyGlobal import directNotify from direct.distributed.DistributedObjectAI import DistributedObjectAI - class ToontownDistrictStatsAI(DistributedObjectAI): notify = directNotify.newCategory('ToontownDistrictStatsAI') diff --git a/toontown/shtiker/GroupManager.py b/toontown/shtiker/GroupManager.py new file mode 100644 index 00000000..a0f962e8 --- /dev/null +++ b/toontown/shtiker/GroupManager.py @@ -0,0 +1,43 @@ +from pandac.PandaModules import * +from direct.distributed import DistributedObject +from direct.directnotify import DirectNotifyGlobal +from toontown.toonbase import ToontownGlobals + +class GroupManager(DistributedObject.DistributedObject): + notify = DirectNotifyGlobal.directNotify.newCategory('GroupManager') + neverDisable = 1 + + def __init__(self, cr): + DistributedObject.DistributedObject.__init__(self, cr) + self.cr = cr + self.groupStatus = {} + + def announceGenerate(self): + DistributedObject.DistributedObject.announceGenerate(self) + self.cr.groupManager = self + self.d_getInfo(0) + + def delete(self): + DistributedObject.DistributedObject.delete(self) + self.cr.groupManager = None + + def d_createGroup(self, shardId, playerId, groupType): + self.sendUpdate('createGroup', [shardId, playerId, groupType]) + + def d_closeGroup(self, shardId, groupId): + self.sendUpdate('closeGroup', [shardId, groupId]) + + def d_addPlayerId(self, shardId, groupId, playerId): + self.sendUpdate('addPlayerId', [shardId, groupId, playerId]) + + def d_removePlayerId(self, shardId, groupId, playerId): + self.sendUpdate('removePlayerId', [shardId, groupId, playerId]) + + def d_getInfo(self, shardId): + self.sendUpdate('getInfo', [shardId]) + + def d_setInfo(self, shardInfo): + self.sendUpdate('setInfo', [shardInfo]) + + def info(self, groups): + self.groupStatus = eval(groups) diff --git a/toontown/shtiker/GroupManagerAI.py b/toontown/shtiker/GroupManagerAI.py new file mode 100644 index 00000000..6a5d2afa --- /dev/null +++ b/toontown/shtiker/GroupManagerAI.py @@ -0,0 +1,61 @@ +from pandac.PandaModules import * +from direct.distributed import DistributedObjectAI +from direct.directnotify import DirectNotifyGlobal +from toontown.toonbase import ToontownGlobals + +class GroupManagerAI(DistributedObjectAI.DistributedObjectAI): + notify = DirectNotifyGlobal.directNotify.newCategory('GroupManagerAI') + + def __init__(self, air): + DistributedObjectAI.DistributedObjectAI.__init__(self, air) + self.air = air + self.shardGroups = {} + + def announceGenerate(self): + DistributedObjectAI.DistributedObjectAI.announceGenerate(self) + self.air.groupManager = self + + def delete(self): + DistributedObjectAI.DistributedObjectAI.delete(self) + self.air.groupManager = None + + def createGroup(self, shardId, playerId, groupType): + if len(self.shardGroups[shardId]) is 0: + groupId = 1 + else: + groupId = sorted(self.shardGroups[shardId])[-1]+1 + if groupId in self.shardGroups[shardId]: + return + self.shardGroups[shardId][groupId] = [groupType, [playerId]] + avId = self.air.getAvatarIdFromSender() + groups = str(self.shardGroups) + self.sendUpdateToAvatarId(avId, 'info', [groups]) + + def closeGroup(self, shardId, groupId): + if self.shardGroups[shardId].get(groupId): + del self.shardGroups[shardId][groupId] + avId = self.air.getAvatarIdFromSender() + groups = str(self.shardGroups) + self.sendUpdateToAvatarId(avId, 'info', [groups]) + + def addPlayerId(self, shardId, groupId, playerId): + if self.shardGroups[shardId].get(groupId) and playerId not in self.shardGroups[shardId].get(groupId): + self.shardGroups[shardId][groupId][1].append(playerId) + avId = self.air.getAvatarIdFromSender() + groups = str(self.shardGroups) + self.sendUpdateToAvatarId(avId, 'info', [groups]) + + def removePlayerId(self, shardId, groupId, playerId): + if self.shardGroups[shardId].get(groupId): + self.shardGroups[shardId][groupId][1].remove(playerId) + avId = self.air.getAvatarIdFromSender() + groups = str(self.shardGroups) + self.sendUpdateToAvatarId(avId, 'info', [groups]) + + def getInfo(self, shardId): + avId = self.air.getAvatarIdFromSender() + groups = str(self.shardGroups) + self.sendUpdateToAvatarId(avId, 'info', [groups]) + + def setInfo(self, shardInfo): + self.shardGroups = eval(shardInfo) diff --git a/toontown/shtiker/ShardPage.py b/toontown/shtiker/ShardPage.py index 00bd8ddb..91627a17 100644 --- a/toontown/shtiker/ShardPage.py +++ b/toontown/shtiker/ShardPage.py @@ -5,6 +5,7 @@ from pandac.PandaModules import * from toontown.distributed import ToontownDistrictStats from toontown.hood import ZoneUtil from toontown.shtiker import ShtikerPage +from toontown.coghq import CogDisguiseGlobals from toontown.suit import SuitDNA from toontown.suit import Suit from toontown.toonbase import TTLocalizer @@ -83,6 +84,9 @@ class ShardPage(ShtikerPage.ShtikerPage): self.showPop = config.GetBool('show-population', 0) self.showTotalPop = config.GetBool('show-total-population', 0) self.noTeleport = config.GetBool('shard-page-disable', 0) + self.groupTypes = ['VP Group', 'CFO Group', 'CJ Group', 'CEO Group'] + self.shardGroups = None + self.currentGroupJoined = None def load(self): main_text_scale = 0.06 @@ -91,7 +95,7 @@ class ShardPage(ShtikerPage.ShtikerPage): helpText_ycoord = 0.403 self.helpText = DirectLabel(parent=self, relief=None, text='', text_scale=main_text_scale, text_wordwrap=12, text_align=TextNode.ALeft, textMayChange=1, pos=(0.058, 0, helpText_ycoord)) shardPop_ycoord = helpText_ycoord - 0.523 - totalPop_ycoord = shardPop_ycoord - 0.35 + totalPop_ycoord = shardPop_ycoord - 0.44 self.districtInfo = NodePath('Selected-Shard-Info') self.districtInfo.reparentTo(self) self.totalPopulationText = DirectLabel(parent=self.districtInfo, relief=None, text=TTLocalizer.ShardPagePopulationTotal % 1, text_scale=main_text_scale, text_wordwrap=8, textMayChange=1, text_align=TextNode.ACenter, pos=(0.4247, 0, totalPop_ycoord)) @@ -115,6 +119,7 @@ class ShardPage(ShtikerPage.ShtikerPage): curShardTuples = base.cr.listActiveShards() curShardTuples.sort(compareShardTuples) actualShardId = base.localAvatar.defaultShard + base.cr.groupManager.d_getInfo(1) for i in xrange(len(curShardTuples)): shardId, name, pop, WVPop, invasionStatus = curShardTuples[i] if shardId == actualShardId: @@ -192,12 +197,57 @@ class ShardPage(ShtikerPage.ShtikerPage): return buttonTuple + def makeGroupButton(self, shardId, groupType, groupPop, groupId): + if not groupType in self.groupTypes: + return + groupButtonParent = DirectFrame() + groupButtonL = DirectButton(parent=groupButtonParent, relief=None, text=groupType, text_pos=(0.0, -0.0225), text_scale=0.06, text_align=TextNode.ALeft, text_fg=Vec4(0, 0, 0, 1), text3_fg=self.textDisabledColor, text1_bg=self.textDownColor, text2_bg=self.textRolloverColor, textMayChange=0, command=self.joinGroup) + popText = str(groupPop) + if popText is None: + return + model = loader.loadModel('phase_3.5/models/gui/matching_game_gui') + button = model.find('**/minnieCircle') + + groupButtonR = DirectButton(parent=groupButtonParent, relief=None, + image=button, + image_scale=(0.3, 1, 0.3), + image2_scale=(0.35, 1, 0.35), + image_color=Vec4(0, 0.8, 0, 1), + pos=(0.58, 0, -0.0125), + text=popText, + text_scale=0.055, + text_align=TextNode.ACenter, + text_pos=(-0.00575, -0.0125), text_fg=Vec4(0, 0, 0, 1), text3_fg=Vec4(0, 0, 0, 1), text1_bg=self.textRolloverColor, text2_bg=self.textRolloverColor, textMayChange=1) + + leaveButton = DirectButton(parent=groupButtonParent, relief=None, + image=button, + image_scale=(0.3, 1, 0.3), + image2_scale=(0.35, 1, 0.35), + image_color=Vec4(0, 0.8, 0, 1), + pos=(0.50, 0, -0.0125), + text='Leave', + text_scale=0.055, + text_align=TextNode.ACenter, + text_pos=(-0.00575, -0.0125), + text_fg=Vec4(0, 0, 0, 0), + text2_fg=Vec4(0, 0, 0, 1), + command=self.leaveGroup) + + leaveButton.hide() + model.removeNode() + button.removeNode() + + buttonTuple = (groupButtonParent, groupButtonR, groupButtonL, leaveButton) + groupButtonL['extraArgs'] = [shardId, groupId, buttonTuple] + leaveButton['extraArgs'] = [shardId, groupId, buttonTuple] + return buttonTuple + def removeRightBrain(self): self.districtInfo.find('**/*district-info').removeNode() def reloadRightBrain(self, shardPop, shardName, shardId, buttonTuple): - if not self.districtInfo: - return + base.cr.groupManager.d_getInfo(1) + self.currentRightBrain = (shardPop, shardName, shardId, buttonTuple) if self.districtInfo.find('**/*district-info'): self.removeRightBrain() if self.currentBTL: @@ -206,13 +256,13 @@ class ShardPage(ShtikerPage.ShtikerPage): self.currentBTR['state'] = DGG.NORMAL popText = self.getPopText(shardPop) districtInfoNode = self.districtInfo.attachNewNode('district-info') - self.districtStatusLabel = DirectLabel(parent=districtInfoNode, relief=None, pos=(0.4247, 0, 0.40), text=popText, text_scale=0.09, text_fg=Vec4(0, 0, 0, 1), textMayChange=1) + self.districtStatusLabel = DirectLabel(parent=districtInfoNode, relief=None, pos=(0.4247, 0, 0.45), text=popText, text_scale=0.09, text_fg=Vec4(0, 0, 0, 1), textMayChange=1) pText = '%s Population: %s' % (shardName, str(shardPop)) - self.populationStatusLabel = DirectLabel(parent=districtInfoNode, relief=None, pos=(0.4247, 0, 0.33), text=pText, text_scale=0.04, text_fg=Vec4(0, 0, 0, 1), textMayChange=1) + self.populationStatusLabel = DirectLabel(parent=districtInfoNode, relief=None, pos=(0.4247, 0, 0.38), text=pText, text_scale=0.04, text_fg=Vec4(0, 0, 0, 1), textMayChange=1) tText = 'Teleport to\n%s' % shardName tImage = loader.loadModel('phase_4/models/gui/purchase_gui') tImage.setSz(1.35) - self.shardTeleportButton = DirectButton(parent=districtInfoNode, relief=None, pos=(0.4247, 0, 0.2), image=(tImage.find('**/PurchScrn_BTN_UP'), tImage.find('**/PurchScrn_BTN_DN'), tImage.find('**/PurchScrn_BTN_RLVR')), text=tText, text_scale=0.065, text_pos=(0.0, 0.015), text_fg=Vec4(0, 0, 0, 1), textMayChange=1, command=self.choseShard, extraArgs=[shardId]) + self.shardTeleportButton = DirectButton(parent=districtInfoNode, relief=None, pos=(0.4247, 0, 0.25), image=(tImage.find('**/PurchScrn_BTN_UP'), tImage.find('**/PurchScrn_BTN_DN'), tImage.find('**/PurchScrn_BTN_RLVR')), text=tText, text_scale=0.065, text_pos=(0.0, 0.015), text_fg=Vec4(0, 0, 0, 1), textMayChange=1, command=self.choseShard, extraArgs=[shardId]) self.currentBTL = buttonTuple[1] self.currentBTR = buttonTuple[2] @@ -222,11 +272,165 @@ class ShardPage(ShtikerPage.ShtikerPage): if shardId == self.getCurrentShardId(): self.shardTeleportButton['state'] = DGG.DISABLED -## suitHead = NodePath('CogHead-%s' % shardName) -## head = self.createSuitHead() -## head.reparentTo(suitHead) -## suitHead.reparentTo(self.districtInfo) -## suitHead.setPos(0.4247, 0, 0.2) + if self.shardGroups is not None: + for button in self.shardGroups: + button.detachNode() + + self.shardGroups = [] + + base.cr.groupManager.d_getInfo(1) + shardId = base.localAvatar.defaultShard - (base.localAvatar.defaultShard % 100000000 % 1000000) + for gid, ginfo in base.cr.groupManager.groupStatus[shardId].items(): + btuple = self.makeGroupButton(shardId, ginfo[0], len(ginfo[1]), gid) + if base.localAvatar.doId in ginfo[1]: + btuple[1]['state'] = DGG.DISABLED + btuple[2]['state'] = DGG.DISABLED + btuple[3].show() + self.shardGroups.append(btuple[0]) + + self.districtGroups = DirectScrolledList(parent=districtInfoNode, relief=None, + pos=(0.38, 0, -0.34), + incButton_image=(self.gui.find('**/FndsLst_ScrollUp'), + self.gui.find('**/FndsLst_ScrollDN'), + self.gui.find('**/FndsLst_ScrollUp_Rllvr'), + self.gui.find('**/FndsLst_ScrollUp')), + incButton_relief=None, + incButton_scale=(self.arrowButtonScale, + self.arrowButtonScale, + -self.arrowButtonScale), + incButton_pos=(self.buttonXstart + 0.005, 0, -0.125), + incButton_image3_color=Vec4(1, 1, 1, 0.2), + decButton_image=(self.gui.find('**/FndsLst_ScrollUp'), + self.gui.find('**/FndsLst_ScrollDN'), + self.gui.find('**/FndsLst_ScrollUp_Rllvr'), + self.gui.find('**/FndsLst_ScrollUp')), + decButton_relief=None, + decButton_scale=(self.arrowButtonScale, + self.arrowButtonScale, + self.arrowButtonScale), + decButton_pos=(self.buttonXstart, 0.0025, 0.445), + decButton_image3_color=Vec4(1, 1, 1, 0.2), + itemFrame_pos=(self.itemFrameXorigin, 0, self.itemFrameZorigin), + itemFrame_scale=1.0, + itemFrame_relief=DGG.SUNKEN, + itemFrame_frameSize=(self.listXorigin, + (self.listXorigin + self.listFrameSizeX), + self.listZorigin/2.1, + (self.listZorigin + self.listFrameSizeZ)/2.1), + itemFrame_frameColor=(0.85, 0.95, 1, 1), + itemFrame_borderWidth=(0.01, 0.01), + numItemsVisible=15, + forceHeight=0.065, + items=self.shardGroups) + + def joinGroup(self, shardId, groupId, buttonTuple): + self.acceptOnce('confJoin', self.confirmJoinGroup, extraArgs=[shardId, groupId, buttonTuple]) + self.joinDialog = TTDialog.TTGlobalDialog(message='Would you like to join this group?', doneEvent='confJoin', style=4) + + def rejectGroup(self, reason, suitType=0): + self.acceptOnce('remRjD', self.doneReject) + if reason == 1: + self.rejectDialog = TTDialog.TTGlobalDialog(message='You need more suit parts!', doneEvent='remRjD', style=1) + elif reason == 2: + if suitType == 0: + meritType = 'Stock Options' + elif suitType == 1: + meritType = 'Merits' + elif suitType == 2: + meritType = 'Cogbucks' + elif suitType == 3: + meritType = 'Notices' + print(meritType, suitType, meritType[suitType]) + self.rejectDialog = TTDialog.TTGlobalDialog(message='You need more %s!'%meritType, doneEvent='remRjD', style=1) + elif reason == 3: + self.rejectDialog = TTDialog.TTGlobalDialog(message='That group is full!', doneEvent='remRjD', style=1) + elif reason == 4: + self.rejectDialog = TTDialog.TTGlobalDialog(message='You\'re already in a group!', doneEvent='remRjD', style=1) + elif reason == 5: + self.rejectDialog = TTDialog.TTGlobalDialog(message='You can\'t leave the district while you\'re in a group!', doneEvent='remRjD', style=1) + + def doneReject(self): + self.rejectDialog.cleanup() + del self.rejectDialog + + def confirmJoinGroup(self, shardId, groupId, buttonTuple): + doneStatus = self.joinDialog.doneStatus + self.joinDialog.cleanup() + del self.joinDialog + if doneStatus is not 'ok': + return + for gid in base.cr.groupManager.groupStatus[shardId].keys(): + if base.localAvatar.doId in base.cr.groupManager.groupStatus[shardId][gid][1]: + self.rejectGroup(4) + return + if len(base.cr.groupManager.groupStatus[shardId][groupId][1]) >= 8: + self.rejectGroup(3) + return + suitIdx = -1 + if groupId == 10000: + suitIdx = 0 + elif groupId == 11000: + suitIdx = 1 + elif groupId == 12000: + suitIdx = 2 + elif groupId == 13000: + suitIdx = 3 + merits = base.localAvatar.cogMerits[suitIdx] + if CogDisguiseGlobals.getTotalMerits(base.localAvatar, suitIdx) > merits: + self.rejectGroup(2, suitIdx) + return + parts = base.localAvatar.getCogParts() + if not CogDisguiseGlobals.isSuitComplete(parts, suitIdx): + self.rejectGroup(1) + return + base.cr.groupManager.d_addPlayerId(shardId, groupId, base.localAvatar.doId) + base.cr.groupManager.d_getInfo(1) + try: + place = base.cr.playGame.getPlace() + except: + try: + place = base.cr.playGame.hood.loader.place + except: + place = base.cr.playGame.hood.place + self.currentGroupJoined = [shardId, groupId] + if ZoneUtil.getCanonicalHoodId(self.getCurrentZoneId()) == groupId: + return + base.cr.groupManager.d_getInfo(1) + place.requestTeleport(groupId, groupId, shardId, -1) + + def leaveGroup(self, shardId, groupId, buttonTuple): + self.acceptOnce('confLeave', self.confirmLeaveGroup, extraArgs=[shardId, groupId, buttonTuple]) + self.joinDialog = TTDialog.TTGlobalDialog(message='Are you sure you want to leave this group?', doneEvent='confLeave', style=4) + + def confirmLeaveGroup(self, shardId, groupId, buttonTuple): + doneStatus = self.joinDialog.doneStatus + self.joinDialog.cleanup() + del self.joinDialog + if doneStatus is not 'ok': + return + self.currentGroupJoined = None + if not base.localAvatar.doId in base.cr.groupManager.groupStatus[shardId][groupId][1]: + return + base.cr.groupManager.d_removePlayerId(shardId, groupId, base.localAvatar.doId) + base.cr.groupManager.d_getInfo(1) + try: + place = base.cr.playGame.getPlace() + except: + try: + place = base.cr.playGame.hood.loader.place + except: + place = base.cr.playGame.hood.place + hoodId = -1 + if groupId == 10000: + hoodId = 1000 + elif groupId == 11000: + hoodId = 5000 + elif groupId == 12000: + hoodId = 9000 + elif groupId == 13000: + hoodId = 3000 + base.cr.groupManager.d_getInfo(1) + place.requestTeleport(hoodId, hoodId, shardId, -1) def getPopColor(self, pop): if pop <= self.lowPop: @@ -357,6 +561,7 @@ class ShardPage(ShtikerPage.ShtikerPage): helpText += TTLocalizer.ShardPageHelpMove def enter(self): + base.cr.groupManager.d_getInfo(1) self.askForShardInfoUpdate() self.updateScrollList() currentShardId = self.getCurrentShardId() @@ -372,10 +577,10 @@ class ShardPage(ShtikerPage.ShtikerPage): for shardId, buttonTuple in self.shardButtonMap.items(): buttonTuple[1]['state'] = DGG.NORMAL buttonTuple[2]['state'] = DGG.NORMAL + self.removeRightBrain() self.ignore('shardInfoUpdated') self.ignore('ShardPageConfirmDone') taskMgr.remove('ShardPageUpdateTask-doLater') - ShtikerPage.ShtikerPage.exit(self) def shardChoiceReject(self, shardId): @@ -393,6 +598,10 @@ class ShardPage(ShtikerPage.ShtikerPage): canonicalHoodId = ZoneUtil.getCanonicalHoodId(base.localAvatar.lastHood) currentShardId = self.getCurrentShardId() + if self.currentGroupJoined: + self.rejectGroup(5) + return + if shardId == currentShardId: return elif shardId == base.localAvatar.defaultShard: