public void process(StringTokenizer command, String Username) { if (accessLevel != 0) { int userLevel = CampaignMain.cm.getServer().getUserLevel(Username); if (userLevel < getExecutionLevel()) { CampaignMain.cm.toUser( "AM:Insufficient access level for command. Level: " + userLevel + ". Required: " + accessLevel + ".", Username, true); return; } } /* * A command which builds a new mech for a player if: 1)he has enough * money and influence, and the room in which to place a new unit 2)the * given factory is open to make that weight unit, and the PP to do so * * Note that players may define the planet they want to produce with, if * not, the planet is selected at random from the avaliable pool of * producing planets. This is in order to allow players to select world * with specific tech biases, or specific faction tables, if they so * desire (ie - a Marik really wants a unit from that captured Steiner * assault world). * * USAGE: /c request#Weighclass#Unit Type#Planet#Factory Name - Planet & * Factory are optional, but fac must be given if a planet is given */ // get the player SPlayer p = CampaignMain.cm.getPlayer(Username); // set some defaults ... SPlanet planet = null; SUnitFactory factory = null; boolean needsMoreTechs = false; // used to make clickthrough String result = ""; // get the requested weightclass String weightstring = command.nextToken(); // check to see if the player is in SOL and trying to get new units if (p.getMyHouse().isNewbieHouse()) { if (weightstring.equals("resetunits")) { NewbieHouse nh = (NewbieHouse) p.getMyHouse(); CampaignMain.cm.toUser(nh.requestNewMech(p, false, null), Username, true); return; } // else result = CampaignMain.cm.getConfig("NewbieHouseName") + " players may not purchase new units; however, they may reset their units."; result += "<br><a href=\"MEKWARS/c request#resetunits\">Click here to request a reset of your units.</a>"; CampaignMain.cm.toUser(result, Username, true); return; } // boot the player's request if he has unmaintained units if (p.hasUnmaintainedUnit()) { CampaignMain.cm.toUser( "AM:Your faction refuses to assign new units to you force while units in your hangar are unmaintained!", Username, true); return; } // if the player qualifies for welfare, give him a unit. if (p.mayAcquireWelfareUnits()) { SHouse house = p.getMyHouse(); SUnit unit = buildWelfareMek(house.getName()); SPilot pilot = house.getNewPilot(unit.getType()); unit.setPilot(pilot); p.addUnit(unit, true); CampaignMain.cm.toUser( "AM:High Command has given you a new unit from its welfare rolls to help you get back on your feet!", Username, true); if (CampaignMain.cm.isKeepingUnitHistory()) { CampaignMain.cm.MySQL.addHistoryEntry( HistoryHandler.HISTORY_TYPE_UNIT, unit.getDBId(), HistoryHandler.UNIT_CREATED, unit.getProducer()); CampaignMain.cm.MySQL.addHistoryEntry( HistoryHandler.HISTORY_TYPE_UNIT, unit.getDBId(), HistoryHandler.UNIT_PRODUCED_BY_WELFARE, "Activated from garrison duty and assigned to combat duty."); CampaignMain.cm.MySQL.addHistoryEntry( HistoryHandler.HISTORY_TYPE_PILOT, pilot.getDBId(), HistoryHandler.PILOT_ASSIGNED, "Assigned to " + unit.getModelName()); CampaignMain.cm.MySQL.addHistoryEntry( HistoryHandler.HISTORY_TYPE_UNIT, unit.getDBId(), HistoryHandler.PILOT_ASSIGNED, pilot.getName() + " assigned to unit"); } return; } int weightclass; try { // try as an int (eg - 4 for assault) weightclass = Integer.parseInt(weightstring); } catch (Exception ex) { // formatting error. look for a string. weightclass = Unit.getWeightIDForName(weightstring.toUpperCase()); } // get the requested unit type int type_id = Unit.MEK; // default to Mek String typestring = command.nextToken(); try { // try as int type_id = Integer.parseInt(typestring); } catch (Exception ex) { // ex, so retry as string type_id = Unit.getTypeIDForName(typestring); } // break out if player lacks experience to buy weightclass if (!p.mayUse(weightclass)) { CampaignMain.cm.toUser( "AM:You are not experienced enough to use " + Unit.getWeightClassDesc(weightclass) + " units.", Username, true); return; } if (!Boolean.parseBoolean( p.getSubFaction() .getConfig( "CanBuyNew" + Unit.getWeightClassDesc(weightclass) + Unit.getTypeClassDesc(type_id)))) { CampaignMain.cm.toUser( "AM:Sorry as a member of " + p.getSubFactionName() + " you are unable to purchase this unit.", Username); return; } if (!p.hasRoomForUnit(type_id, weightclass)) { CampaignMain.cm.toUser( "AM:Sorry, you already have the maximum number of " + Unit.getWeightClassDesc(weightclass) + " " + Unit.getTypeClassDesc(type_id) + "s", Username); return; } /* * Check to see if a planet and factory names are specified. If they * are, fetch the planet and factory and make sure the user entered a * legal combo. */ String planetName = ""; String factoryName = ""; if (command.hasMoreElements()) { planetName = command.nextToken(); planet = (SPlanet) CampaignMain.cm.getData().getPlanetByName(planetName); if (planet == null) { CampaignMain.cm.toUser("AM:Could not find planet: " + planetName + ".", Username, true); return; } // make sure the player's faction owns the world if (!planet.getOwner().equals(p.getMyHouse())) { CampaignMain.cm.toUser( "AM:Your faction does not control " + planetName + ".", Username, true); return; } // make sure the planet makes units of the desired weightclass if (planet.getFactoriesOfWeighclass(weightclass).size() == 0) { CampaignMain.cm.toUser( planetName + " does not produce units of the weight class specified.", Username, true); return; } // check for a factory name token try { factoryName = command.nextToken(); } catch (NoSuchElementException e) { CampaignMain.cm.toUser( "AM:You requested a unit from " + planetName + ", but did not specifiy which factory to use.", Username, true); return; } // make sure the named factory exists Vector<SUnitFactory> namedFactories = planet.getFactoriesByName(factoryName); if (namedFactories.size() == 0) { CampaignMain.cm.toUser( "AM:There is no " + factoryName + " on " + planetName + ".", Username, true); return; } /* * make sure one of the named factories produces units of the right * size NOTE: Because of how this is being done, the same name can * be used for more than one factory on a planet, but only if * they're produce unique weightclasses. Any name duping in a * weightclass will cause odd behaviour. */ for (SUnitFactory currFac : namedFactories) { if (currFac.getWeightclass() == weightclass) { factory = currFac; break; } } if (factory == null) { CampaignMain.cm.toUser( factoryName + " on " + planetName + " does not produce units of the requested weightclass.", Username, true); return; } if (factory.getAccessLevel() > p.getSubFactionAccess()) { CampaignMain.cm.toUser( "You do not have sufficient rank to purchase a unit from " + factoryName + " on " + planetName + ".", Username); return; } // make sure the named factory can produce the requested type if (!factory.canProduce(type_id)) { CampaignMain.cm.toUser( factoryName + " on " + planetName + " does not produce units of the requested type.", Username, true); return; } // return if the factory is refreshing if (factory.getTicksUntilRefresh() > 0) { CampaignMain.cm.toUser( factoryName + " is currently refreshing. " + factory.getTicksUntilRefresh() + " miniticks remaining.", Username, true); return; } } /* * No more tokens were given. Pick a random factory from those which * originally belonged to the the faction. If we cannot find a factory, * we should return a failure. */ else { factory = p.getMyHouse().getNativeFactoryForProduction(type_id, weightclass, true); if (factory != null) { planet = factory.getPlanet(); } } if (planet == null || factory == null) { CampaignMain.cm.toUser( "AM:No " + p.getMyHouse().getName() + " factory is available to fill your order at this time (Click on icon in House Status to use captured factories).", Username, true); return; } // get prices for the unit int mechCbills = factory.getPriceForUnit(weightclass, type_id); int mechInfluence = factory.getInfluenceForUnit(weightclass, type_id); int mechPP = factory.getPPCost(weightclass, type_id); // adjust by multipliers if this is a non-original owner. SHouse playerHouse = p.getMyHouse(); if (!factory.getFounder().equalsIgnoreCase(playerHouse.getName())) { mechCbills = Math.round(mechCbills * CampaignMain.cm.getFloatConfig("NonOriginalCBillMultiplier")); mechInfluence = Math.round( mechInfluence * CampaignMain.cm.getFloatConfig("NonOriginalInfluenceMultiplier")); mechPP = Math.round(mechPP * CampaignMain.cm.getFloatConfig("NonOriginalComponentMultiplier")); } // Add penalty if the player is over a sliding limit if (p.willHaveHangarPenalty(type_id, weightclass)) { int costPenalty = p.calculateHangarPenaltyForNextPurchase(type_id, weightclass); mechCbills += costPenalty; } // reduce flu cost to ceiling if over if (mechInfluence > CampaignMain.cm.getIntegerConfig("InfluenceCeiling")) { mechInfluence = CampaignMain.cm.getIntegerConfig("InfluenceCeiling"); } // check to see if the player & house can afford the unit boolean hasEnoughMoney = false; boolean hasEnoughInfluence = false; boolean factionHasEnoughPP = false; if (p.getMoney() >= mechCbills) { hasEnoughMoney = true; } if (p.getInfluence() >= mechInfluence) { hasEnoughInfluence = true; } if (playerHouse.getPP(weightclass, type_id) >= mechPP) { factionHasEnoughPP = true; } if (hasEnoughMoney && hasEnoughInfluence && factionHasEnoughPP) { // check to make sure the player has enough support for the unit // requested int spaceTaken = SUnit.getHangarSpaceRequired(type_id, weightclass, 0, "null", p.getMyHouse()); if (spaceTaken > p.getFreeBays()) { needsMoreTechs = true; } // find out if your are using advanced repair if so buy bays instead // of hiring techs. boolean useBays = CampaignMain.cm.isUsingAdvanceRepair(); // if the player needs more techs/bays, make a compound link and // return if (needsMoreTechs) { int techCost = p.getTechHiringFee(); if (useBays) { techCost = CampaignMain.cm.getIntegerConfig("CostToBuyNewBay"); } int numTechs = spaceTaken - p.getFreeBays(); techCost = techCost * numTechs; int totalCost = techCost + mechCbills; StringBuilder toSend = new StringBuilder(); // if the player can't afford to pay for more support, tell him // so and return w/o a link. if (totalCost > p.getMoney()) { toSend.append( "AM:Command will not release a new unit to you unless support is in place; however, you cannot afford to buy the unit *and* "); if (useBays) { toSend.append(" purchase the necessary bayspace"); } else { toSend.append(" hire technicians"); } toSend.append( ". The total cost would be " + CampaignMain.cm.moneyOrFluMessage(true, true, totalCost) + ", but you only have " + CampaignMain.cm.moneyOrFluMessage(true, true, p.getMoney()) + "."); CampaignMain.cm.toUser(toSend.toString(), Username, true); return; } toSend.append( "AM:Quartermaster command will not send a new unit to your force until support resources are in place. You will need to "); if (useBays) { toSend.append("purchase " + numTechs + " more bays"); } else { toSend.append("hire " + numTechs + " more technicians"); } toSend.append( " at a cost of " + CampaignMain.cm.moneyOrFluMessage(true, true, techCost) + ". Combined cost of the new unit and necessary "); if (useBays) { toSend.append("bays"); } else { toSend.append("techs"); } toSend.append( " is " + CampaignMain.cm.moneyOrFluMessage(true, true, (mechCbills + techCost)) + " and " + CampaignMain.cm.moneyOrFluMessage(false, true, mechInfluence) + "."); toSend.append( "<br><a href=\"MEKWARS/c hireandrequestnew#" + numTechs + "#" + Unit.getWeightClassDesc(weightclass) + "#" + type_id + "#" + planet.getName() + "#" + factory.getName() + "\">Click here to purchase both the unit and the needed support.</a>"); CampaignMain.cm.toUser(toSend.toString(), Username, true); return; } SPilot pilot = playerHouse.getNewPilot(type_id); CampaignData.mwlog.dbLog( "Pulled pilot: " + pilot.toFileFormat("$", false) + " (DBId: " + pilot.getDBId() + ")"); if (CampaignMain.cm.isUsingMySQL()) { pilot.toDB(type_id, -1); } CampaignData.mwlog.dbLog( "Pilot saved: " + pilot.toFileFormat("$", false) + " (DBId: " + pilot.getDBId() + ")"); Vector<SUnit> mechs = factory.getMechProduced(type_id, pilot); StringBuffer results = new StringBuffer(); if (playerHouse.getBooleanConfig("UseCalculatedCosts")) { mechCbills = 0; } for (SUnit mech : mechs) { if (playerHouse.getBooleanConfig("UseCalculatedCosts")) { double unitCost = mech.getEntity().getCost(false); if (unitCost < 1) { unitCost = playerHouse.getPriceForUnit(mech.getWeightclass(), mech.getType()); } double costMod = playerHouse.getDoubleConfig("CostModifier"); mechCbills += (int) Math.round(unitCost * costMod); if (mechCbills > p.getMoney()) { CampaignMain.cm.toUser( "You could not afford the selected unit. Please try again", Username); return; } } if (CampaignMain.cm.getBooleanConfig("AllowPersonalPilotQueues") && mech.isSinglePilotUnit()) { SPilot pilot1 = (SPilot) mech.getPilot(); SPilot pilot2 = new SPilot("Vacant", 99, 99); mech.setPilot(pilot2); if (!pilot1.getName().equalsIgnoreCase("Vacant")) { playerHouse.getPilotQueues().addPilot(mech.getType(), pilot1, true); } } p.addUnit(mech, true); // give the actual unit... results.append(mech.getModelName()); results.append(", "); // Add unit history, if it's being kept if (CampaignMain.cm.isKeepingUnitHistory()) { CampaignMain.cm.MySQL.addHistoryEntry( HistoryHandler.HISTORY_TYPE_UNIT, mech.getDBId(), HistoryHandler.UNIT_CREATED, mech.getProducer()); CampaignMain.cm.MySQL.addHistoryEntry( HistoryHandler.HISTORY_TYPE_UNIT, mech.getDBId(), HistoryHandler.UNIT_BOUGHT_FROM_FACTORY, "Purchased from " + factory.getName() + " on " + factory.getPlanet().getName()); } } results.delete(results.length() - 2, results.length()); p.addMoney(-mechCbills); // then take away money p.addInfluence(-mechInfluence); // and take away influence // we're going to build the unit. set up a houseupdate string. StringBuilder hsUpdates = new StringBuilder(); // set the refresh miniticks hsUpdates.append( factory.addRefresh( (CampaignMain.cm.getIntegerConfig( Unit.getWeightClassDesc(factory.getWeightclass()) + "Refresh") * 100) / factory.getRefreshSpeed(), false)); hsUpdates.append(playerHouse.addPP(weightclass, type_id, -mechPP, false)); // remove // PP // from // the // faction result = "AM:You've been granted the following " + results.toString() + ". (-"; result += CampaignMain.cm.moneyOrFluMessage(true, false, mechCbills) + " / -" + CampaignMain.cm.moneyOrFluMessage(false, true, mechInfluence) + ")"; CampaignData.mwlog.mainLog( p.getName() + " bought the following " + results.toString() + " from " + factory.getName() + " on " + planet.getName()); CampaignMain.cm.toUser(result, Username, true); CampaignMain.cm.doSendHouseMail( playerHouse, "NOTE", p.getName() + " bought the following " + results.toString() + " from " + factory.getName() + " on " + planet.getName() + "!"); // send update to all players CampaignMain.cm.doSendToAllOnlinePlayers(playerHouse, "HS|" + hsUpdates.toString(), false); return; } // end if(enough money/influence/pp) else if (!hasEnoughMoney || !hasEnoughInfluence) { // tell the player // what he needs to // buy the unit result = "AM:You need at least " + CampaignMain.cm.moneyOrFluMessage(true, false, mechCbills) + " and " + CampaignMain.cm.moneyOrFluMessage(false, true, mechInfluence) + " to request a " + Unit.getTypeClassDesc(type_id) + " of this weight class from a factory."; CampaignMain.cm.toUser(result, Username, true); return; // break out ... } // end else(player has too few money or too little Influence) else if (!factionHasEnoughPP) { // tell the player that the faction needs // more PP result = "AM:Your faction does not have the components needed to produce such a unit at this time. Wait for your faction to gather more resources."; CampaignMain.cm.toUser(result, Username, true); return; // break out ... } // end else (not enough PP in faction) } // end process()
public void process(StringTokenizer command, String Username) { /* * Never check access level for register, but DO check * to ensure that a player is enrolled in the campaign. */ if (CampaignMain.cm.getPlayer(Username) == null) { CampaignMain.cm.toUser( "<font color=\"navy\"><br>---<br>You must have a campaign account in order to register a nickname. [<a href=\"MEKWARS/c enroll\">Click to get started</a>]<br>---<br></font>", Username, true); return; } try { StringTokenizer str = new StringTokenizer(command.nextToken(), ","); String regname = ""; String pw = ""; String email = ""; SPlayer player = null; try { regname = str.nextToken().trim().toLowerCase(); if (CampaignMain.cm.requireEmailForRegistration()) email = str.nextToken(); pw = str.nextToken(); } catch (Exception ex) { CampaignData.mwlog.errLog("Failure to register: " + regname); return; } // Check to see if the Username is already registered boolean regged = false; try { // MWPasswd.getRecord(regname, null); player = CampaignMain.cm.getPlayer(regname); if (player.getPassword() != null && player.getPassword().access >= 2) regged = true; } catch (Exception ex) { // Username already registered, ignore error. // CampaignData.mwlog.errLog(ex); regged = true; } if (regged && !CampaignMain.cm.getServer().isAdmin(Username)) { CampaignMain.cm.toUser("AM:Nickname \"" + regname + "\" is already registered!", Username); // CampaignData.mwlog.modLog(Username + " tried to register the nickname \"" + regname + // "\", which was already registered."); CampaignMain.cm.doSendModMail( "NOTE", Username + " tried to register the nickname \"" + regname + "\", which was already registered."); return; } // check passwd length if (pw.length() < 3 && pw.length() > 11) { CampaignMain.cm.toUser("AM:Passwords must be between 4 and 10 characters!", Username); return; } // Check for phpBB integration - there are a lot of possible outcomes here. if (CampaignMain.cm.isSynchingBB()) if (!CampaignMain.cm.MySQL.addUserToForum(Username, pw, email)) { CampaignMain.cm.doSendModMail( "NOTE", "Server was unable to send registration email to " + Username + ". Staff will need to give him his activation key."); CampaignMain.cm.toUser( "AM: The server was unable to send your registration email. Please ask staff for assistance.", Username, true); } // change userlevel int level = -1; if (CampaignMain.cm.getServer().isAdmin(Username)) { MWPasswd.writeRecord(regname, IAuthenticator.ADMIN, pw); level = IAuthenticator.ADMIN; } else { MWPasswd.writeRecord(regname, IAuthenticator.REGISTERED, pw); level = IAuthenticator.REGISTERED; } // send the userlevel change to all players CampaignMain.cm.getServer().getClient(regname).setAccessLevel(level); CampaignMain.cm.getServer().getUser(regname).setLevel(level); CampaignMain.cm.getServer().sendRemoveUserToAll(regname, false); CampaignMain.cm.getServer().sendNewUserToAll(regname, false); if (player != null) { CampaignMain.cm.doSendToAllOnlinePlayers( "PI|DA|" + CampaignMain.cm.getPlayerUpdateString(player), false); } if (CampaignMain.cm.isUsingMySQL() && player != null) { CampaignMain.cm.MySQL.setPlayerPassword( CampaignMain.cm.MySQL.getPlayerIDByName(Username), pw); CampaignMain.cm.MySQL.setPlayerAccess( CampaignMain.cm.MySQL.getPlayerIDByName(Username), level); if (CampaignMain.cm.isSynchingBB()) { // CampaignMain.cm.MySQL.addUserToForum(Username, pw, email); player.setForumID(CampaignMain.cm.MySQL.getUserForumID(Username, email)); CampaignMain.cm.MySQL.addUserToHouseForum( player.getForumID(), player.getMyHouse().getForumID()); } } // acknowledge registration CampaignMain.cm.toUser("AM:\"" + regname + "\" successfully registered.", Username); CampaignData.mwlog.modLog("New nickname registered: " + regname); CampaignMain.cm.doSendModMail( "NOTE", "New nickname registered: " + regname + " by: " + Username); } catch (Exception e) { CampaignData.mwlog.errLog(e); CampaignData.mwlog.errLog("^ Not supposed to happen! ^"); CampaignData.mwlog.errLog(e); CampaignData.mwlog.errLog("Not supposed to happen"); } }