[INACTIVE][FUN/ADMN] Spyer 1.5_1 - invisibility for moderating and pvp!(alternative to Vanish) SPOUT

Discussion in 'Inactive/Unsupported Plugins' started by nickguletskii, Feb 27, 2011.

  1. Offline



    Hotfixed SpyerFun on 16th of August. Version number of the jar didn't change. Fixed a bunch of bugs.
    SpyerFun - a plugin that allows playersto become invisible for some time. Each second the player "eats" one item out of the stack he is holding (hider item, sugar by default). While invisible, mob can and will still attack the player, although other players (exceptions are implemented) can not. The player will reappear when he either runs out of the hider item or switches to another item in his action bar, e.g. a sword.
    SpyerAdmin - a plugin that allows moderators to hide themselves for an unlimited amount of time, as well as simulating them leaving. This is a constantly updated alternative to Vanish, with much more features and configurations!
    Thanks to brafenschlug for this hilarious video of moderators playing pranks on players!

    • Now uses Spout! This plugin is no longer CPU heavy!
    • Allows players to become invisible for a set amount of time!
    • Adds more fun to PVP.
    • Allows administrators to hide themselves and simulate them quitting! Overrides msg,r and list.
    • Stops players from picking things up while using SpyerAdmin (see the configuration section)
    • Knocks players out from invisibility (SpyerFun) when they get damaged (see the configuration section)
    • Knocks players out from invisibility (SpyerFun) when they left-click a block (see the configuration section)
    • Now reload friendly!
    How to use (SpyerAdmin):
    • Use /spy to become and stop being invisible (toggled).
    • Use /quit to simulate you quitting/joining (toggled).
    • Place 1 piece of the indicator item into your quickbar. It will indicate if you are hidden or not. By default it is glowstone that turns into sulphur. You can configure that in plugins/Spyer/SpyerAdmin.conf.
    How to use (SpyerFun):
    • Right click with the "hider" item, every second it will eat up one item from the stack.
    • To add/change "hider" items, go to plugins/Spyer/items.yml. You'll see something like this:
      {352: 3000, 353: 1000}
      Items are separated by commas. The ID is the right value, and the time of usage (per block) in milliseconds(HAS to be dividable by 50!). So if I want to add clay to work for 10 seconds per piece, I will do something like
      {352: 3000, 353: 1000, 337: 10000}
      Note: by default, bones and sugar are used.
    Installation instructions, downloads:

    Install server-side Spout. No Spout client required.
    Extract the contents of the bundle(Spyer.zip) into the plugins folder.
    Bundle downloads:
    Download command line installer
    jars (open)

    Instructions for different setups:
    • Essentials: Download SpyerInstaller, put it in the server directory and run it from terminal(console). Go to configuration->4.
    • Vanilla Bukkit: go to (server directory)/plugins/Spyer. Open repo.conf, replace everything with
    • CommandBook: Special version for you! semi-direct Replace SpyerAdminConmmands.jar with this version!

    List of permissions:
    1. spyer.spy (Players who have this have access to the /spy and /quit commands, without permissions checks for op powers)
    2. spyer.seeAll (Players who have this can see people who are hidden, without permissions checks for op powers)
    3. spyer.fun (Players who have this can use SpyerFun, without permissions defaults to true)
    4. spyer.stopmobs.admin (Stops moderators from being attacked by mobs while hidden)
    5. spyer.stopmobs.fun (Stops players from being attacked by mobs while hidden)
    • spyer.yml - responsible for holding timing data. If syncWithScheduler is true, the plugin will use the bukkit's scheduler (recommended). If false, use Java timers. refreshRate defines the time in ticks (in milliseconds if syncWithScheduler = false). Add the optional field coolDown and set its value to your cooldown time in milliseconds (for SpyerFun, time in between invisibility uses). Add pickUp: true to allow picking up items while hidden in SpyerAdmin. To knock out people from SpyerFun when they damage an entity, add "onDamage: true". To knock out people from SpyerFun when they left click a block, add "onBlock: true". To stop invisible players (SpyerFun) from damaging other living entities, add "noDamage: true". Boolean "wait" allows/disallows the plugin to delay reloading to give them time to hide.
    • repo.conf - holds the url of the repository from which SpyerAdmin will update the script.
    • script.js - compatibility layer between plugins. e.g. Essentials script will simulate Essentials commands, Vanilla script will simulate the normal minecraft commands.
    • items.yml - holds the list of items used in SpyerFun
    • SpyerAdmin.conf - holds indicator item ids for SpyerAdmin
    Modifying scripts:
    1. Comment out all the lines in repo.conf.
    2. Modify the script.
    3. If you want to update the script, you can get it from [repopath]/script.js
    Version: v1.5_1

    Known issues
    • If you get a NullPointer when enabled (that contains something like "at nickguletskii200.SpyerAdmin.CustomHandling.<init>(Unknown Source)", then download this and put it into your jre's lib directory. You might also need to install Rhino. Disclaimer: this file is a part of the OpenJDK package.
    Changelog (open)

    Version 1.5
    • Migrated to Spout packet filtering. Timers are now only used for indicators(admin) and item deduction(fun). You can decrease the tick rate now if you want.
    • 1.5_1 Fixed the whole bundle. Nasty bug didn't appear in testing!
    Version 1.4
    • Separated SpyerAdmin into two modules.
    • July 17th - now using bukkit permissions API. Blind update. If you got this plugin before build 1000, then you have the old version. If you got it after build 1000, new version.
    Version 1.3
    • Made plugins reload friendly.
    • _1 Essentials 2.3 compatibility added through autoupdate.
    • _2 Fixed default item pickup. Now doesn't pick up items by default.
    • _3 Added noDamage property for SpyerFun.
    Version 1.2
    • Improved performance.
    • Added position checks.
    Version 1.1
    • Some little customisation upgrades.
    • Some hotfixes.
    • Improved SpyerFun's invisibility system.
    Version 1.0
    • Added mob targeting control.
    • Hotfix: fixed(hopefully) the log spam!
    • Small feature added (13/05/11): cooldown times for SpyerFun.
    Version 0.9
    • Permissions support!
    • Cleaned up code.
    Version 0.8
    • Added indicators.
    • You can now do /spy [on|off] to force.
    • Invisibility persists when you reconnect.
    • Fixed updater to work with Windows.
    • 0.8_1 fixed some problems with commands.
    • 0.8_2 major fixes.
    Version 0.7 (SpyerAdmin only for now)
    • Automatic script updating.
    • Better logging (will help me get rid of bugs) (coming soon)
    Version 0.6
    • Scripting support! That means no more compile-time library linking and more compatibility!
    • Multiple item support for SpyerFun added!
    Version 0.5
    • Added refreshrate and sync method variables. See the usage instructions to learn how to cofnigure them.
    Version 0.4

    • Extended functionality of /quit. Overrides msg and list commands of essentials.
    Version 0.3
    • A rewrite, separated packages. Hopefully removed all known bugs.
    • 0.3_1 Separated in-game configurations into another package.
    • 0.3_2 Fixed some bugs.
    • 0.3_21 Fixed some exceptions, small fix.
    Version 0.2
    • Shadow moderation ("addspy <player>" - allows player to hide with "spy" and "quit", "removespy <player>" - opposite. "addseeall <player>" - allows player to see hidden players, "removeseeall <player>" - oppiste. "spy" - hides you until called again. "quit" - hides and removes you from the list of players.
    • Click in the air now works
    • Migrated to SnakeYaml, no more jars!
    • 0.2_1 upgraded to remove double invisibility, quit now fully simulates player leaving.
    • 0.2_2 fixed player reappearing after "spying".
    • 0.2_3 huuuuuuuge bugfixes!
    • 0.2_4 fixed some bugs, one known: you have to say "/spy" twice to hide after using sugar/other hider item.
    Version 0.1
    • Release

    • Some technical cleanups
    • Suggest more!
    Credits (no particular order)
    These people helped me by posting a lot of descriptive bug reports, removing bugs from scripts, making videos, cooperating with debugging and helping other users understand my horrible documentation ;)
    • The PC Tech Guy
    • Sparx
    • Tim Yong
    • Greylocke
    • KevinHouse
    • aidan matzko
    • brafenschlug
    • Nelien
  2. Offline


    Could you hide us also from the number of connected ?

    For example, we're two on the server.

    I type /spy then /list :

    "There are 2 out of a maximum of 12 players online."
    No names under that line, by the way. (is it normal ??)

    ... It should be 1, not 2. So we still know that I'm connected to the server.


    Where are the permissions for list/msg/r ??
  3. Offline


    so does this work with permissions 3.x
  4. Offline


    I cant use the comand /list
    it doesent list the players anymore but rather lists how many players are conected

    it also give me a big nasty sever eror
  5. Offline


    There's a problem with Spyer after Spout update:
    2011-08-03 13:43:01 [SEVERE] java.net.ConnectException: Connection timed out: connect
    2011-08-03 13:43:01 [SEVERE]  at java.net.DualStackPlainSocketImpl.connect0(Native Method)
    2011-08-03 13:43:01 [SEVERE]  at java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:69)
    2011-08-03 13:43:01 [SEVERE]  at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:337)
    2011-08-03 13:43:01 [SEVERE]  at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:198)
    2011-08-03 13:43:01 [SEVERE]  at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:180)
    2011-08-03 13:43:01 [SEVERE]  at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:157)
    2011-08-03 13:43:01 [SEVERE]  at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:391)
    2011-08-03 13:43:01 [SEVERE]  at java.net.Socket.connect(Socket.java:579)
    2011-08-03 13:43:01 [SEVERE]  at java.net.Socket.connect(Socket.java:528)
    2011-08-03 13:43:01 [SEVERE]  at sun.net.NetworkClient.doConnect(NetworkClient.java:180)
    2011-08-03 13:43:01 [SEVERE]  at sun.net.www.http.HttpClient.openServer(HttpClient.java:388)
    2011-08-03 13:43:01 [SEVERE]  at sun.net.www.http.HttpClient.openServer(HttpClient.java:483)
    2011-08-03 13:43:01 [SEVERE]  at sun.net.www.http.HttpClient.<init>(HttpClient.java:213)
    2011-08-03 13:43:01 [SEVERE]  at sun.net.www.http.HttpClient.New(HttpClient.java:300)
    2011-08-03 13:43:01 [SEVERE]  at sun.net.www.http.HttpClient.New(HttpClient.java:316)
    2011-08-03 13:43:01 [SEVERE]  at sun.net.www.protocol.http.HttpURLConnection.getNewHttpClient(HttpURLConnection.java:992)
    2011-08-03 13:43:01 [SEVERE]  at sun.net.www.protocol.http.HttpURLConnection.plainConnect(HttpURLConnection.java:928)
    2011-08-03 13:43:01 [SEVERE]  at sun.net.www.protocol.http.HttpURLConnection.connect(HttpURLConnection.java:846)
    2011-08-03 13:43:01 [SEVERE]  at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1296)
    2011-08-03 13:43:01 [SEVERE]  at nickguletskii200.SpyerAdmin.Updater.download(Unknown Source)
    2011-08-03 13:43:01 [SEVERE]  at nickguletskii200.SpyerAdmin.SpyerAdminCommands.onEnable(Unknown Source)
    2011-08-03 13:43:01 [SEVERE]  at org.bukkit.plugin.java.JavaPlugin.setEnabled(JavaPlugin.java:126)
    2011-08-03 13:43:01 [SEVERE]  at org.bukkit.plugin.java.JavaPluginLoader.enablePlugin(JavaPluginLoader.java:878)
    2011-08-03 13:43:01 [SEVERE]  at org.bukkit.plugin.SimplePluginManager.enablePlugin(SimplePluginManager.java:272)
    2011-08-03 13:43:01 [SEVERE]  at org.bukkit.craftbukkit.CraftServer.loadPlugin(CraftServer.java:162)
    2011-08-03 13:43:01 [SEVERE]  at org.bukkit.craftbukkit.CraftServer.enablePlugins(CraftServer.java:146)
    2011-08-03 13:43:01 [SEVERE]  at net.minecraft.server.MinecraftServer.e(MinecraftServer.java:284)
    2011-08-03 13:43:01 [SEVERE]  at net.minecraft.server.MinecraftServer.a(MinecraftServer.java:271)
    2011-08-03 13:43:01 [SEVERE]  at net.minecraft.server.MinecraftServer.init(MinecraftServer.java:148)
    2011-08-03 13:43:01 [SEVERE]  at net.minecraft.server.MinecraftServer.run(MinecraftServer.java:335)
    2011-08-03 13:43:01 [SEVERE]  at net.minecraft.server.ThreadServerApplication.run(SourceFile:422)
  6. Offline

    Grammar Troll

    RGadelha likes this.
  7. Offline


  8. Offline


    When I do /list

    18:20:37 [SEVERE] javax.script.ScriptException: sun.org.mozilla.javascript.internal.EcmaError: TypeError: Cannot call method "getSettings" of null (<Unknown source>#28) in <Unknown source> at line number 28
    18:20:37 [SEVERE]       at com.sun.script.javascript.RhinoScriptEngine.invoke(RhinoScriptEngine.java:184)
    18:20:37 [SEVERE]       at com.sun.script.javascript.RhinoScriptEngine.invokeFunction(RhinoScriptEngine.java:142)
    18:20:37 [SEVERE]       at nickguletskii200.SpyerAdmin.CustomHandling.who(Unknown Source)
    18:20:37 [SEVERE]       at nickguletskii200.SpyerAdmin.SpyerAdminCommands.onCommand(Unknown Source)
    18:20:37 [SEVERE]       at org.bukkit.command.PluginCommand.execute(PluginCommand.java:35)
    18:20:37 [SEVERE]       at org.bukkit.command.SimpleCommandMap.dispatch(SimpleCommandMap.java:129)
    18:20:37 [SEVERE]       at org.bukkit.craftbukkit.CraftServer.dispatchCommand(CraftServer.java:320)
    18:20:37 [SEVERE]       at net.minecraft.server.NetServerHandler.handleCommand(NetServerHandler.java:713)
    18:20:37 [SEVERE]       at net.minecraft.server.NetServerHandler.chat(NetServerHandler.java:677)
    18:20:37 [SEVERE]       at net.minecraft.server.NetServerHandler.a(NetServerHandler.java:670)
    18:20:37 [SEVERE]       at net.minecraft.server.Packet3Chat.a(Packet3Chat.java:33)
    18:20:37 [SEVERE]       at net.minecraft.server.NetworkManager.b(NetworkManager.java:226)
    18:20:37 [SEVERE]       at net.minecraft.server.NetServerHandler.a(NetServerHandler.java:85)
    18:20:37 [SEVERE]       at net.minecraft.server.NetworkListenThread.a(SourceFile:105)
    18:20:37 [SEVERE]       at net.minecraft.server.MinecraftServer.h(MinecraftServer.java:451)
    18:20:37 [SEVERE]       at net.minecraft.server.MinecraftServer.run(MinecraftServer.java:361)
    18:20:37 [SEVERE]       at net.minecraft.server.ThreadServerApplication.run(SourceFile:422)
  9. Offline


    See "known problems". Cause: running JDK/JRE without javascript engine.

    You are using an old version of bukkit.

    Configure properly please.

    Source (although not the latest) is available on github.
    Because you don't have a bukkit permissions API compliant permissions plugin.
    What is the actual error?
    Doesn't that already work? list, msg and r commands use the same permissions as the plugin they were extended from.

    Works with any bukkit permissions API compliant plugin.
    "big nasty sever eror" please.
    That means that it couldn't connect to dropox on time.
    See the indicator item.
    That plugin uses wrong priorities for its events. Please ask the plugin author to change them so that they are executed first, not last.
    You didn't set it up correctly.

    EDIT by Moderator: merged posts, please use the edit button instead of double posting.
    Last edited by a moderator: May 10, 2016
  10. Offline


    Where i can find it how to do this?
    Because i already have permissions 3.1.16 ...
  11. Offline


  12. Offline


    CB 1000 and Spyer for CB 1000

    :54:34 [SEVERE] java.io.FileNotFoundException: spyeradmin.log (Too many open files)
    19:54:34 [SEVERE] at java.io.FileOutputStream.openAppend(Native Method)
    19:54:34 [SEVERE] at java.io.FileOutputStream.<init>(FileOutputStream.java:177)
    19:54:34 [SEVERE] at java.io.FileWriter.<init>(FileWriter.java:90)
    19:54:34 [SEVERE] at nickguletskii200.SpyerAdmin.Debugging.appendFile(Unknown Source)
    19:54:34 [SEVERE] at nickguletskii200.SpyerAdmin.Debugging.access$000(Unknown Source)
    19:54:34 [SEVERE] at nickguletskii200.SpyerAdmin.Debugging$1.doInBackground(Unknown Source)
    19:54:34 [SEVERE] at javax.swing.SwingWorker$1.call(SwingWorker.java:277)
    19:54:34 [SEVERE] at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)
    19:54:34 [SEVERE] at java.util.concurrent.FutureTask.run(FutureTask.java:138)
    19:54:34 [SEVERE] at javax.swing.SwingWorker.run(SwingWorker.java:316)
    19:54:34 [SEVERE] at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
    19:54:34 [SEVERE] at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
    19:54:34 [SEVERE] at java.lang.Thread.run(Thread.java:662)
  13. Offline


    Something is spamming open files. Don't think it is to do with my plugin.
  14. Offline


    Any chance of adding support for mChatEssentials /list /who commands?
  15. Offline


    No, because it isn't populaar enough. You or the author can write a script though.
  16. Offline


    Thanks for the reply, I've just edited the commandbook version of SpyerAdmin to work with mChatEssentials on my server :D
  17. Offline


    Okay :)
  18. Offline


    Love this Plugin Well Done!
  19. Code:
    2011-08-13 22:28:12 [SEVERE] java.lang.NoSuchMethodException: no such method: playerMsg
    2011-08-13 22:28:12 [SEVERE]     at com.sun.script.javascript.RhinoScriptEngine.invoke(Unknown Source)
    2011-08-13 22:28:12 [SEVERE]     at com.sun.script.javascript.RhinoScriptEngine.invokeFunction(Unknown Source)
    2011-08-13 22:28:12 [SEVERE]     at nickguletskii200.SpyerAdmin.CustomHandling.playerMsg(Unknown Source)
    2011-08-13 22:28:12 [SEVERE]     at nickguletskii200.SpyerAdmin.SpyerAdminCommands.onCommand(Unknown Source)
    2011-08-13 22:28:12 [SEVERE]     at org.bukkit.command.PluginCommand.execute(PluginCommand.java:35)
    2011-08-13 22:28:12 [SEVERE]     at org.bukkit.command.SimpleCommandMap.dispatch(SimpleCommandMap.java:129)
    2011-08-13 22:28:12 [SEVERE]     at org.bukkit.craftbukkit.CraftServer.dispatchCommand(CraftServer.java:320)
    2011-08-13 22:28:12 [SEVERE]     at net.minecraft.server.NetServerHandler.handleCommand(NetServerHandler.java:713)
    2011-08-13 22:28:12 [SEVERE]     at net.minecraft.server.NetServerHandler.chat(NetServerHandler.java:677)
    2011-08-13 22:28:12 [SEVERE]     at net.minecraft.server.NetServerHandler.a(NetServerHandler.java:670)
    2011-08-13 22:28:12 [SEVERE]     at net.minecraft.server.Packet3Chat.a(Packet3Chat.java:33)
    2011-08-13 22:28:12 [SEVERE]     at net.minecraft.server.NetworkManager.b(NetworkManager.java:226)
    2011-08-13 22:28:12 [SEVERE]     at net.minecraft.server.NetServerHandler.a(NetServerHandler.java:85)
    2011-08-13 22:28:12 [SEVERE]     at net.minecraft.server.NetworkListenThread.a(SourceFile:105)
    2011-08-13 22:28:12 [SEVERE]     at net.minecraft.server.MinecraftServer.h(MinecraftServer.java:451)
    2011-08-13 22:28:12 [SEVERE]     at net.minecraft.server.MinecraftServer.run(MinecraftServer.java:361)
    2011-08-13 22:28:12 [SEVERE]     at net.minecraft.server.ThreadServerApplication.run(SourceFile:422)
    After installing your plugin nobody can send private mesages via CommandBook. You see the error. But minecraft's command /tell still work. Know what's the problem?
  20. There is a problem, I right click with a diamond (Which should give me 10 seconds of invisibility, which it does) but if it does not eat the diamond unless I keep my hotbar selection on the diamond until I become visible again. If I scroll away from the diamond, it does not eat it.
  21. Offline


    You didn't set the plugin up correctly.
    It should eat it when you switch to something else. Are you sure it doesn't eat the diamond?
  22. I'm sure. Although only I (The OP) tried
  23. Offline


    How many diamonds did you have?
  24. Just one (Used /i diamond)
  25. Offline


    Hmm, weird. I'll check later.
  26. Offline


    Is it me or when you start the server whislt running this, it seems to hang during loading for ages? then give out some HTTP error related messages? more imoprtantly, can I disable this part of it? why does it need HTTP ?:S
  27. Offline


  28. Offline


    Oh right. I thnk I disabled them now. It loads fine.
  29. Offline


    Sorry it took so long to fix. Fixed a bunch of bugs. Too lazy to change version.
  30. Offline


    Sorry but i have alerter plugin and when i install spyer all alerter areas disappears!(Getting errors to alerter to) Pleasse help me with this i wanna fix this!
  31. No problem, thanks ;D

Share This Page