-
Notifications
You must be signed in to change notification settings - Fork 170
Server Scripting
The script will execute in a global environment, and the return value of the initial execution is the scirpt
object.
The following global properties exist:
sys
Has all the various properties that call script functions.
Qt
I don't know why we have this, but it's functions should also be present on sys (unchecked.)
SESSION
Some thingermagiger to do other things
sys.clearChat()
Clears server's message window.
sys.changeAnnouncement(html)
Changes announcement in the config and updates it for all players.
sys.getAnnouncement()
Gets the announcement in the config.
print(variable1, variable2, ...)
Displays the content of the variables in the server's mainchat.
sys.sendAll(message, channelId)
sends a message to the mainchat. If optional channelId is not present, will send a message to all channels.
sys.sendHtmlAll(message, channelId)
sends a message to the mainchat. It will be displayed in html. If optional channelId is not present, will send a message to all channels. See Sending HTML for details.
sys.sendHtmlMessage(playerId, message, channelId)
sends a message only to the mainchat of that player. It will be displayed in html. If optional channelId is not present, will send a message to the user on all his channels. See Sending HTML for details.
sys.sendMessage(playerId, message, channelId)
sends a message only to the mainchat of that player. If optional channelId is not present, will send a message to the user on all his channels.
sys.setAnnouncement(html, playerId)
changes announcement. If optional playerId is not specified all players will see updated announcement.
sys.avatar(player_id)
returns player's avatar id. Will return null if player is not logged it.
sys.auth(player_id)
returns the authority level of that player.
sys.away(player_id)
is player away? Will return undefined if player is not logged in.
sys.ban(player_name)
bans someone in DB. Use kick() manually if needed.
sys.battling(player_id)
returns true or false depending on if the player is battling.
sys.changeAvatar(playerId, avatarId)
will set player's avatar to avatarId.
sys.changeAuth(player_id, new_auth)
changes the auth of the player to the new auth. Player must be online.
sys.changeAway(player_id, away)
changes the "business" of that player.
sys.changeDbAuth(player_name, new_auth)
changes the auth of the player in the DB to the new auth. If a player is online effective auth will not change until s/he logs off or changeAuth() called.
sys.changeInfo(player_id, new_info)
temporary changes player's challenge window info to new_info (HTML).
sys.changeName(player_id, new_name)
Temporarily changes player's name to new_name. New player is not created. No uniqueness check is performed. Server window will not be updated. Use at your own risk.
sys.changeRating(name, tier, new_rating)
Changes the rating of a player in that tier.
sys.changeTier(player_id, team, tier)
Changes a user's tier.
sys.clearPass(name)
Removes the password associated to that name.
sys.hasLegalTeamForTier(player_id, team, tier)
returns true or false depending on if the player has a team valid for this tier.
sys.id(player_name)
returns the id of the player with that name.
sys.ip(player_id)
returns the IP of that player
sys.hostName(player_ip, name)
Works like webCall. This functions returns the hostName of the player.
sys.kick(player_id)
kicks that player.
sys.ladderEnabled(player_id)
returns true or false depending on if that player has ladder enabled.
sys.ladderRating(player_id, tier)
returns the ladder rating of that player. If tier is not specified current one will be used.
sys.loggedIn(player_id)
returns true or false depending on if the player is logged in or not.
sys.name(player_id)
returns the name of the player with that id.
sys.ranking(player_id)
returns the ranking of that player in his tier.
sys.ranking(name, tier)
returns the ranking of that player for that tier.
sys.ratedBattles(player_id)
number of rated battles player did.
sys.ratedBattles(name, tier)
number of rated battles player did in a given tier.
sys.resetLadder(tier)
reset all players rankings in the selected tier and update them on the server.
sys.synchronizeTierWithSQL(tier)
reloads all the ratings of the tier from the SQL database and updates all the ratings of the people of the tier on the server.
sys.tier(player_id, team)
returns the tier of that player.
sys.unban(player_name)
unbans a name.
sys.updatePlayer(player_id)
updated changed player data for all player in server (after changing Pokémon with script for example, so the correct team is shown in the challenge window). This is not needed for changeInfo as is does that automatically.
sys.getVal(key)
returns the variable stored in the registry with that key.
sys.getVal(file, key)
returns the variable stored in the file with that key.
sys.getValKeys(file)
returns an array of keys stored (without values). "file" parameter is optional.
sys.removeVal(key)
deletes the variable in the registry.
sys.removeVal(key, file)
deletes the variable in the file.
sys.saveVal(key, value)
saves a variable in the registry so it'll still be there after a server restart.
sys.saveVal(file, key, value)
saves a variable to a file so it'll still be there after a server restart.
sys.callLater(script, seconds)
runs the script given in parameter seconds later.
sys.callQuickly(script, milliseconds)
works like callLater() but accepts milliseconds as parameter instead of seconds. Don't overdo it.
sys.changeScript(newScript, triggerStartUp)
changes the script with the content. Can be used with webCall or getFileContent to do cool stuff. If optional triggerStartUp is true serverStartUp event will be triggered after loading a new script.
sys.delayedCall(function, seconds)
works like callLater() but accepts a function without arguments as a first parameter instead of a string. See Passing a function to a delayedCall for details.
sys.eval(script)
runs the script given in parameter. Returns the result.
sys.stopEvent()
if called before an event occurs, if possible, stop the events from happening. If called in an event that starts by "before", stops the event from happenning. For example, if called in beforeChatMessage, the message of the player won't display. If called in beforeLogIn, the player won't be allowed to log in. If called in beforeChallengeIssued, the challenge won't be issued.
sys.system(command)
tell the underlying OS to run the command line.
sys.appendToFile(filename, content)
append content to the content of the file.
sys.deleteFile(filename)
sys.getFileContent(filename)
returns the content of the file.
sys.writeToFile(filename, content)
clear the content of the file and write that.
sys.synchronousWebCall(url)
calls the web url given, waits for the reply, and returns the reply.
sys.synchronousWebCall(url, args)
calls the web url given with the args as POST arguments, waits for the reply, and returns the reply.
sys.webCall(url, script)
calls the web url given, and when the reply is received runs the script given in parameter. At that moment the variable "resp" will contain the response of the web server.
sys.webCall(url, script, args)
calls the web url given with the args as POST arguments, and otherwise behaves the same way as the previous function.
sys.ability(num)
returns ability name by its id.
sys.abilityNum(abilityName)
returns ability id by its name.
sys.aliases(ip)
returns an array of users for that IP.
sys.banList()
returns an array of banned user names.
sys.dbAuth(name)
returns the authority from the member in the database with that name.
sys.dbAuths()
returns an array of names of people whose auth is superior to 0.
sys.dbIp(name)
returns the ip from the member in the database with that name.
sys.dbLastOn(name)
returns the last date of appearance of that person as shown in the Control Panel.
sys.dbExpire(name)
Returns the amount of days left for the account with the specified name to expire.
sys.dbRegistered(name)
returns if the name is registered with a password or not.
sys.dbExpire(name)
Returns the amount of days until a player expires in the database.
sys.dbExpiration()
Returns the amount of days that the account will stay if it's inactive.
sys.gen(pokenum)
gives the Pokémon's generation.
sys.getColor(id)
gets a user's hex code for color.
sys.getTierList()
returns an array of tiers.
sys.hiddenPowerType(gen, hpdv, attdv, defdv, spddv, sattdv, sdefdv)
returns type id for given DVs.
sys.item(num)
returns the name of the item.
sys.itemNum(name)
returns the number of the item.
sys.maxAuth(ip)
returns the maximum authority associated to that IP.
sys.move(num)
returns the name of the move.
sys.moveNum(name)
returns the num of the move.
sys.nature(num)
returns the corresponding nature.
sys.natureNum(name)
returns the number corresponding to that nature.
sys.numPlayers()
returns the number of players online.
sys.playerIds()
return an array containing the ids of all the players online. You can use this function in your sendall scripts, masskick, etc.
sys.pokeAbility(poke_id, slot, gen)
returns id of an ability that Pokémon can have. slot is either 0, 1, or 2 (which ability to return). gen is optional and last gen is used when omitted. Will return undefined if Pokémon is unknown or slot is out of range.
sys.pokemon(num)
returns the name of the Pokémon.
sys.pokeNum(name)
returns the number of the Pokémon.
sys.pokeType1(pokeId, gen)
returns Pokémon's primary type id. If optional gen is not specified last supported Generation will be used.
sys.pokeType2(pokeId, gen)
returns Pokémon's secondary type id. If optional gen is not specified last supported Generation will be used. Returns 17 (i.e. type() from it would be "???") if there is none.
sys.totalPlayersByTier(tier)
returns the total number of players that are ranked in that tier.
sys.type(id)
returns Pokémon type's display name by id.
sys.typeNum(typeName)
returns Pokémon type's id by name.
sys.weather(weatherId)
returns weather name by id.
sys.weatherNum(weatherName)
returns weather id by name. weatherName can be "hailstorm", "rain", "sandstorm", "sunny", and "normal".
sys.changePokeAbility(player_id, team, slot, ability_num)
Changes ability of a Pokémon in selected slot.
sys.changePokeGender(player_id, team, slot, gender)
Changes gender of a Pokémon in selected slot. gender must be either 0 (neutral), 1 (male), or 2 (female).
sys.changePokeHappiness(player_id, team, slot, new_value)
new_value must be in [0..255] range.
sys.changePokeItem(player_id, team, pokeSlot, itemnum)
Changes the item of the Pokémon in that slot.
sys.changePokeLevel(player_id, team, pokeSlot, pokeLevel)
Changes the level of the Pokémon in that slot.
sys.changePokeMove(player_id, team, pokeSlot, moveSlot, movenum)
Changes the move of that Pokémon in that moveslot (move slots range from 0 to 3).
sys.changePokeName(player_id, team, slot, name)
Changes name of a Pokémon in selected slot.
sys.changePokeNature(player_id, team, slot, nature)
Changes the nature of a Pokémon in selected slot.
sys.changePokeNum(player_id, team, pokeSlot, pokeNum)
Changes the Pokémon in that slot (eg 150 = Mewtwo), slots range from 0 to 5.
sys.changePokeShine(player_id, team, slot, new_value)
new_value is either true or false.
sys.compatibleAsDreamWorldEvent(player_id, team, slot)
Checks if the Pokémon is a valid male DW Pokémon (no breeding moves).
sys.hasDreamWorldAbility(player_id, team, index)
Returns true if a Pokémon in the team is using a DW ability. Returns false otherwise.
sys.hasTeamItem(player_id, team, itemnum)
Returns true or false depending if one Pokémon in the team has that item.
sys.hasTeamMove(player_id, team, movenum)
Returns true if the team has a Pokémon with that move or false otherwise.
sys.hasTeamPoke(player_id, team, pokenum)
Returns true or false depending if that player has that Pokémon in his team.
sys.hasTeamPokeMove(player_id, team, pokeslot, movenum)
Returns true or false depending if that Pokémon has the move or not.
sys.indexOfTeamPoke(player_id, team, pokenum)
Returns the slot of the Pokémon in the team or undefined if the Pokémon is not found.
sys.indexOfTeamPokeMove(player_id, team, pokeslot, movenum)
Returns the slot of the move in the moveset of that Pokémon in the team or undefined if the move is not found.
sys.changeTeamPokeDV(player_id, team, slot, stat, newValue)
stat's DV for the selected Pokémon will be set to newValue.
sys.changeTeamPokeEV(player_id, team, slot, stat, newValue)
stat's EV for the selected Pokémon will be set to newValue.
sys.teamPoke(player_id, team, slot)
Returns Pokémon in the team of that player at that slot (slots start from 0).
sys.teamPokeAbility(player_id, team, slot)
Returns Pokémon's ability id in a specified team slot.
sys.teamPokeDV(player_id, slot, team, stat)
Returns DV (IV) of Pokémon in a specified slot for specified stat.
sys.teamPokeGender(player_id, team, slot)
Returns gender of a Pokémon in a specified slot.
sys.teamPokeEV(player_id, team, slot, stat)
Returns EV of Pokémon in a specified slot for specified stat.
sys.teamPokeItem(player_id, team, pokeslot)
Returns the item of that Pokémon (slots start from 0).
sys.teamPokeLevel(player_id, team, pokeslot)
Returns the level of the Pokémon in that slot.
sys.teamPokeMove(player_id, team, pokeslot, moveslot)
Returns the move of the Pokémon of the team of that player (slots start from 0).
sys.teamPokeNature(player_id, team, pokeslot)
Returns the nature of the Pokémon in that slot.
sys.teamPokeNick(player_id, team, pokeslot)
Returns Pokémon's nickname.
These functions affect server globally.
sys.exportMemberDatabase()
saves all the members database to a file called members.txt, which would be imported on next restart if the SQL database were empty of players.
sys.exportTierDatabase()
saves all the tiers database (ratings) to files called tier_NameOfTier.txt, which would be imported on next restart if the SQL database were empty for those tiers
sys.makeServerPublic(flag)
makes server public if flag parameter is true. Private if false.
sys.memoryDump()
prints a state of the memory, was used to evaluate the memory consumption.
sys.modifyBaseStat(poke_id, stat, value)
will change Pokémon's base stat to specified value (0-255).
sys.modifyMovePower(moveNum, power, generation)
will change move's power to given 'power' value (0-255). 1 will cause zero damage but still counts as attacking move (unlike 0). If optional 'generation' is not specified last supported Generation will be used.
sys.modifyMoveAccuracy(moveNum, accuracy, generation)
will change move's accuracy to given 'accuracy' value. If optional 'generation' is not specified last supported Generation will be used.
sys.modifyMovePP(moveNum, pp, generation)
will change move's PP to given 'pp' value. If optional 'generation' is not specified last supported Generation will be used.
sys.modifyMovePriority(moveNum, priority, generation)
will change move's priority to given 'priority' value (from -128 to 127). If optional 'generation' is not specified last supported Generation will be used.
sys.modifyPokeAbility(poke_id, ability_slot, ability_id, gen)
will change given Pokémon's ability globally. ability_slot is either 0, 1, or 2. gen is optional and equals to last supported gen by default. Team Builder info will not be changed however.
sys.modifyTypeChart(attacker_type_id, defender_type_id, modifier)
will modify type chart for server. modifier must be one of the following strings"none", "ineffective", "normal", "effective".
sys.reloadTiers()
sys.shutDown()
shuts down the server (after calling the serverShutDown() event).
sys.updateRatings()
updates all ratings (has something to do with rating decay).
sys.rand(min, max)
returns a random number between min inclusive and max exclusive (like rand(0, 4) will return 0, 1, 2 or 3).
sys.time()
returns the number of seconds elapsed since 1 Jan 1970.
It is advised to allow the user to have at least one channel open at all times. Naturally, the server won't allow a user to leave a channel if it's the last channel open, but it's possible with scripts. If a user has no channel open, he has a blank screen replacing main chat, players list, and battles list, and it's not very nice.
sys.channel(channelId)
returns the name of that channel.
sys.channelId(channelName)
return channel's id by name.
sys.channelIds()
returns an array of channel ids.
sys.channelsOfPlayer(playerId)
an array of channel ids a player is on.
sys.createChannel(channelName)
creates an channel with that name. The channel won't be destroyed until one player logs on that channel and off when he's the only player online. Returns the id of the create channel.
sys.existChannel(channelName)
returns true if a channel with that name exists.
sys.isInChannel(playerId, channelId)
sys.isInSameChannel(player1, player2)
sys.kick(playerId, channelId)
sys.playersOfChannel(channelId)
an array of players for a channel.
sys.putInChannel(playerId, channelId)
forces a player to join a channel. Will bypass the 7 channels limit.
Use these functions ONLY in battleSetup event and only with battle_id it'll pass to you. Otherwise things will break.
sys.inflictStatus(battle_id, to_first_player, slot, status_id)
will apply status condition to first player if to_first_player is true. To second one otherwise. Available statusesparalyze (1), sleep (2), poison (5), freeze (3), burn (4), fine (0) and KO (31).
sys.prepareWeather(battle_id, weather_id)
makes it so a specified weather is already in place when battle starts. This weather will not end by itself but still can be changed with weather changing moves.
sys.forceBattle(player_id_1, player_id_2, clauses, mode, is_rated)
will force battle between 2 players.