Inactive [INFO/ADMIN] LogBlock v1.54 - Enderdragon Logging! Tree Grow Logging! [1.4.5]

Discussion in 'Inactive/Unsupported Plugins' started by DiddiZ, Feb 15, 2011.

  1. Offline

    DiddiZ

    Version: 1.50​
    [​IMG]
    [​IMG]
    Find and Backroll those Damn Griefers
    LogBlock release are on DevBukkit:
    http://dev.bukkit.org/server-mods/logblock/

    LogBlock dev builds:
    http://ci.kitteh.org/job/LogBlock/

    Please read the installation guide

    I won't port LogBlock myself to mcAPI. Source code is available, so it shouldn't be to difficult for someone else to do it, also I'm still here. so I can answer questions. If there is more than one willing, that's up to you to handle that.




    The reasons I take this step, are the usual: I quit playing Minecraft about 5 months ago and lastly I was struggling to keep up with updates. The developement of Guardian made slow progress, so I fear it won't be ready to fully replace LB in time.


    Download latest dev build: Jenkins
    View the source code: GitHub
    Table of contents:
    1. Description
    2. Features
    3. Why to use LogBlock
    4. Example command
    5. Older versions
    6. Change log
    7. Todo list / feature requests
    8. Permission nodes
    9. Plugins supporting this
    10. Support the dev
    11. How to post error messages
    12. Advertizing
    Description:

    LogBlock logs block changes into a MySQL database. Block changes can be placed or destroyed block, explosions, burned blocks, sign text changes, chest access, leaves decay etc.
    It can be used as griefer identification tool, to find out who build a particular building, or even roll back changes by certain players. Other purposes can be e.g: Undoing of forest fires
    All additional features are optional, to keep the database as short as possible. All database actions run in their own threads to avoid server lags.
    The use of permissions plugin (or any clone) is possible, but not necessary.
    Uses Spout for chest logging (but it's fully optional, and there is no need for the client mod at all).

    Features:
    • Logging for block placing, block braking, fire, explosions, leaves decay, signtexts, lava flow and chest content
    • Very mighty commands system, not only allowing to rollback and redo, but also to tp to blockchanges, delete log ingame etc. Full list of commands.
    • Many parameters for lookup/rollback/redo/tp/clearlog commands: Block changes of one ore more player, in a specific area, in a world edit selection, specific block types only, block changes older or newer that a specific date, destroyed/created block only, in a different world and combinations of all these parameters. Full list of parameters.
    • Rebuilding map after importing a backup (/lb redo)
    • Last parameter to use the parameters of the last command
    • Quick ingame lookup of block history a wood pickaxe or a bedrock block.
    • All commands accessible from console (exept tools :D)
    • Custom queries for tools.
    • Different tool modes (lookup, rollback, redo, writelogfile and clearlog)
    • Saves block data like wool color, log type, torch adjustment, etc
    • Multiworld and multiserver support (some servers sharing the same database)
    • BigBrother log import
    • Loggable super pickaxe plugin (not to confuse with WorldEdit's super pickaxe)
    • API
    • Webstats
    Why to use LogBlock:

    Example commands: (thanks to tha d0ctor, read more about commands here)

    /lb rollback player fire since 1d3h – rolls back fire 1 day 3 hours
    /lb rollback player fire since 1d3h area 15 – rolls back fire 1 day 3 hours within a radius of 15 blocks

    /lb rollback player thad0ctor since 1h - rolls back thad0ctor 1 hour
    /lb rollback player thad0ctor since 1d area 5 – rolls back thad0ctor actions for the last day within 5 blocks
    /lb rollback area 10 since 1h30m - rolls back all modifications within 10 blocks since the list 1 hours and 30 mins
    /lb rollback area 10 before 06.11.2011 - roll back all changes in an area of 1o before June 11th, 2011
    /lb rollback player thad0ctor since 05:36:00 - roll back all changes of thad0ctor since 05:36 (server time)


    Download, Command, Configuration and Details:
    [​IMG]http://diddiz.insane-architects.net/logblock.php

    Changelog:
    -> Full changelog
    • LogBlock v1.50 # 81 (Dez. 13, 2011)
      Works with CraftBukkit 1.0.1-R1
      • Feature: /lb me shows the total block count
      • Feature: Chest logging without spout
      • Feature: Enderdragon logging
      • Feature: Logging for tree and mushroom grow (thanks to MD5 for the api)
      • Fix: Area param works again with default radius
      • Fix: Rollbacks got slowed down a bit to avoid rare server crashes
      • Fix: If mysql username, password or database only consist of unquoted numbers, LB will read them now
      • Config: World configs changed totally, some names changed and all logging options are now in an own section
    • LogBlock v1.41 #63 (Nov. 15, 2011)
      Works with CraftBukkit recommended build #1337
      • Fix: Players with spawnTools permission are no longer allowed to spawn all tools.
      • Fix: Added a check to avoid "The permission xy is already defined!" errors
    • LogBlock v1.40 #60 (Nov. 09, 2011)
      Works with CraftBukkit recommended build #1337
      • Feature: Custom auto ClearLog
      • Feature: Reduced error spam. Instead of like 40 line of error code, there is now just a warning stating the MySQL con
      • Feature: The queue will now be dumped after 10 tries even when the MySQL server is connected
      • Feature: Custom material names, allows naming custom blocks
      • Feature: LogBlock will now respond to messages when started without MySQL connection
      • Fix: Log import runs now async
      • Fix: Log import errors won't crash the server
      • Fix: Console commands work again
      • Fix: You can now use upper case letter in tool names (I don't know why you even should, but ...)
      • Config: Added clearlog.auto, clearlog.enableAutoClearlog in main config. Added materials.yml. Removed clearlog.keepLogDays
      • Permissions: Added 'logblock.spawnTools'
    • LogBlock v1.32 (Oct. 04, 2011)
      Works with CraftBukkit recommended build #1240
      • Feature: Player info logging: firstLogin, lastLogin, onlinetime, ip. No ingame lookup yet.
      • Feature: /lb queuesize to see the current queue size
      • Fix: Door logging logs now also fence gates
      • Fix: Bukkit api break in CB #1191
      • Fix: time restriction works now as intended. Thanks to xrobau
      • Fix: Players with insufficient permissions can't smuggle bedrock from one world to another
      • Config: Added logPlayerInfo
    • LogBlock v1.30 (Sep. 22, 2011)
      Works with CraftBukkit recommended build #1185
      • Feature: Chat lookup /lb chat player diddiz search +admin +sucks +dicks (more info)
      • Feature: Door logging
      • Feature: Dynamic tools, define your own tools
      • Feature: Use since and before to define a timespan
      • Feature: Enderman logging
      • Feature: cake logging (who ate it)
      • Config: Added logEndermen, logCakes and logDoors to world config and moved the tool section in main config.
      • Permissions: logblock.tool changed to logblock.tools.tool and
        logblock.toolblock to logblock.tools.toolblock.
    Todo List:

    https://github.com/LogBlock/LogBlock/issues

    Permission Nodes:
    https://github.com/LogBlock/LogBlock/wiki/Permissions

    Plugins supporting Logblock:
    List (open)

    When you want to appear your plugin here, tell me about



    Support the developer (that's me :D):
    If you want to support me writing plugins or want to thank me for the plugin/support, you can: Suggest features I missed, report bugs (best with fix :D), donate via PayPal, flattr my plugins, gift me The Witcher 2 (thanks to newyoukdaily), 2x 1GB DDR1 modules (thanks to HonestFlames), or send me the inner life of a laptop or netbook with a broken display (need it to build a model aircraft, so there is no need for parts like display and keyboard).

    [​IMG]


    How to post error messages:


    I won't aswer questions to general MySQL setup/installation/what is MySQL (there are lots of good tutorials out there, use google)
    Please read the installation guide before asking a question about installation problems.
    Please read the FAQ before posting a error report. It may be solved there.
    In case of rollback or lookup problems: Type /lb savequeue and try again (when it's fixed then, it was a consumer problem, see FAQ)
    When you post error messages, it's important to paste the whole stack trace!

    Advertizing:
    Newyorkdailys Plugin Support Buisness (open)
    Still can't get LogBlock working, or any other plugin? Are you getting errors in your console and cant figure out why? Newyorkdaily offers Basic/Advanced Plugin support.
    • General/Advanced troubleshooting: FREE!
    • Plugin Installations: 1-2 Plugins - FREE!
    • 3 or More Plugins - $2
    Click on the link below to connect to him now!
    http://wbe001.mibbit.com/?settings=7cb4fd3cdd72754df475fb92a0b65f6c&server=irc.Mibbit.Net&channel=#CBPluginSupport


    There is a LogBlock irc channel: #logblock at irc.esper.net.
    You can ask me on skype. My name is 'hawky.diddiz'.
     
  2. Offline

    sfxworks

    Hi!
    Is logblock suppose to go this slow?? I mean, im using a paid mysql server. I even had to restart the server because the que was getting to huge. When I hosted it remotely, it worked fast, but that was back in 1.6.

    [​IMG]
     
  3. Offline

    DiddiZ

    Wow, really slow. Try the dev build, could speed this up a bit.
     
  4. Offline

    Ratchet

    anyone doing large rollbacks over like a few days, does it work fine? i'm using BB now and if I do a large rollback it crashes my server halfway through, does LB handle this okay?
     
  5. Offline

    palz2015

    Why the hell doesnt it log other worlds?
    Only the main world is logged... wtf?
    I'm using multiverse.
     
  6. Offline

    DiddiZ

    Yup, at least i heard nothing contrary since v0.4 :D
    You've to add worlds manually to loggedWorlds (and enter a corresponding table under tables)
     
    palz2015 likes this.
  7. Offline

    Ratchet

    alright thanks. my server is currently having an issue where players chests are being erased of their contents at random, it seems to be a bug with bukkit / minecraft since 1.7. BB doesn't have chest rollback features so I am thinking of switching to logblock to fix it when it happens to players. do you know if it will work if a players chest contents is just randomly erased? will rolling it back restore everything they have at the time I tell it to restore from?

    at any rate, could you tell me how to roll back chest contents anyway? i'm trying it out now.

    thanks
     
  8. Offline

    DiddiZ

    You can restore a chest, that got placed after LB was installed, so the full content is logged.
    Then you can delete/clear the chest (in hidden mode /lb hide) and redo all chest accesses.
    But as this only works when ALL accesses to that chest are logged, you better use the WorldEdit //restore fuction. Therefore you need backups (guess you've some :D). Make a selection containing the chest and enter //restore, and the chest content is back :D
    Chest rollback works with normal rollback, but when you want to do it explicitely: /lb rb chestaccess area 5
     
  9. Offline

    Ratchet

    so the steps are type /lb hide
    remove the chests
    then /lb rb chestaccess area 5 ?
     
  10. Offline

    deshadowc

    Sorry if I missed this somewhere, but is there any way to disable the toolblockid setting? If I comment it out, remove it, leave it blank, or set it to an impossible number it resets back to 7.
     
  11. Offline

    DiddiZ

    Um, what do you want? Totally disable the toolblock?
    There are some ways, but the most accurate would be:
    /lb hide
    remove the chest
    /lb toolblock mode redo
    /lb toolblock (if you don't have one yet)
    and placing the bedrock instead of the chest.
     
  12. Offline

    deshadowc

    Yes since I just use the normal tool, and from time to time I use bedrock when building.
     
  13. Offline

    DiddiZ

    You could set it to 95.
     
  14. Offline

    Ratchet

    doesn't seem to be working for me.. placing the bedrock has no effect
     
  15. Offline

    DiddiZ

    Does it say: No result found, aborted, or does nothing happen and you just placed a bedrock block?
    So does LB anser at all? When not, it disabled itself at load, look there for an error message.
     
  16. Offline

    Narmotur

    Question: I don't think logblock currently logs chat. Maybe I just missed it, but if not, are there ever any plans to log chat/commands?
     
  17. Offline

    deshadowc

    Getting this a lot in my log in the 1.20 version, seems to happen randomly sometimes when blocks are broken too.
    Code:
    LogBlock: Bukkit provided no block type for the block placed by dragonshardz at world:671:83-656. Please check the conditions this happened under, and report it to Diddiz or Bukkit.
    Happens whenever someone places a half step on another turning it into a double half step.

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

    DiddiZ

    It's on the todo list. Most likely the first feature for v1.30 to add :D
    Lesser. Definitely.
    Will check that. Thanks.

    EDIT: You're right. They messed up doublesteps again ... Will file a bug report.
     
  19. Offline

    OrtwinS

    Hi @DiddiZ

    First of all: I'd like to confess my undieing love for Logblock. It makes the entire 'Grief management' chapter of server management so incredible stress-less.

    Secondly: Does 1.10 work with newer versions of BukkitContrib?
    I want to update to higher CraftBukkit versions and becasue of BukkitContribs tight corrolation with specific CB builds I must update Contrib as well. Version 0.1.2 to be specific.
     
  20. Offline

    DiddiZ

    1. You're welcome :)
    2. It works, have it on my test and public servers.
     
  21. Offline

    OrtwinS

    Might want to put that in the first post, prevents confusion/more questions. :D
     
  22. Offline

    gothroach

    Just updated to 953 on my server, and started getting the following error periodically in console:
    Code:
    07:59:45 [SEVERE] [LogBlock Consumer] SQL exception
    com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: Column 'victim' cannot be null
            at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
            at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39)
            at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)
            at java.lang.reflect.Constructor.newInstance(Constructor.java:513)
            at com.mysql.jdbc.Util.handleNewInstance(Util.java:407)
            at com.mysql.jdbc.Util.getInstance(Util.java:382)
            at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1039)
            at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3593)
            at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3525)
            at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1986)
            at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2140)
            at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2620)
            at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2570)
            at com.mysql.jdbc.StatementImpl.execute(StatementImpl.java:779)
            at com.mysql.jdbc.StatementImpl.execute(StatementImpl.java:622)
            at de.diddiz.LogBlock.Consumer.run(Consumer.java:286)
            at java.util.TimerThread.mainLoop(Timer.java:512)
            at java.util.TimerThread.run(Timer.java:462)
    I believe my schema to be correct, and I'm running the same LB version (1.10) as before- any suggestions?
     
  23. Offline

    DiddiZ

    Disable kill logging, or ignore it, or try the dev build.
     
  24. Offline

    DiddiZ

    Final dev build for v1.20 (v3)
    • The consumer runs up to 5 times faster (under test circumstances)
    • Added pages for lookups and /lb page, /lb next, /lb prev commands
    • Button and lever logging
    • /lb tp works with unloaded chunks
    • Tool lookup shows log of both chest halfes
    • Config to exclude some block types from logging
    • Added maxRadius/Time config and ignoreRestrictions permission
    • Piston rollback support (the piston blocks itself, not the moved blocks, although bukkit needs a fix until it works)
    • Fixed keepLogDays only working for one world
    • Added /lb tool default to reset costum parameters
    • Added area 0 and all as default parameters for tools, so you skip it
    • Fixed two three server freezes
    • Fixed leaves decaying after rollback
    • Added support for ItemCraft (only logging, but seemingly not rollback)
    • Fixed spacing for summed lookups in console and logfiles
    • Added exclude player parameter: /lb player !DiddiZ
    • Improved some messages, especially when setting tool parameters.
    Brought sum parameter to work again, asynced connections where possible, increased time before connection times out.

    So, should be really final this time (it passed 3/4 beta testers before). LB v1.20 is aimed for tomorrow.
     

    Attached Files:

  25. Offline

    newyorkdaily

    Its not logblock's fault, and it doesn't matter how much you pay for your mysql, its the fact that your MySQL server and your Minecraft server are not on the same Lan. I know because it happens to me also. Do not worry about it, it should not cause you lag and if you have to stop or restart your server use the /lb savequeue command and let it save the queue first. Using this command before stopping or restarting the server and letting it finish saving will allow your users to stay connected while it saves the queue and will be lag free while it saves the queue.

    Rofl, would that one stubborn beta tester happen to be named newyorkdaily?

    Also look at ur skype, have some.....unfortunate news :(

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

    DiddiZ

    Of course.
    But the more bugs you find the better tester you are :D
     
  27. Offline

    newyorkdaily

    HOOAH!!! :D lol
     
  28. Offline

    Ratchet

    Code:
    LogBlock: Bukkit provided no block type for the block placed by Fit29 at Ragnarok:845:79705. Please check the conditions this happened under, and report it to Diddiz or Bukkit.
    player went offline so I couldn't ask what block it was o.o
     
  29. Offline

    newyorkdaily

    After doing some debugging myself, im pretty sure i narrowed it down to, this pops up when a player opens or closes a piston.
     
  30. Offline

    palz2015

    oh sorry, I figured it out just after I posted -.-

    Em, when I use my tool/toolblock, it says "null", even if someone built it... what's going on? Yes, I have mysql set up. Yes, It worked before.
    Code:
    2011-07-08 18:45:00 [SEVERE] [LogBlock] Error while fetching connection
    com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure
    
    The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server.
        at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
        at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
        at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
        at java.lang.reflect.Constructor.newInstance(Unknown Source)
        at com.mysql.jdbc.Util.handleNewInstance(Util.java:407)
        at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:1116)
        at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:343)
        at com.mysql.jdbc.ConnectionImpl.coreConnect(ConnectionImpl.java:2334)
        at com.mysql.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:2371)
        at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2163)
        at com.mysql.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:794)
        at com.mysql.jdbc.JDBC4Connection.<init>(JDBC4Connection.java:47)
        at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
        at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
        at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
        at java.lang.reflect.Constructor.newInstance(Unknown Source)
        at com.mysql.jdbc.Util.handleNewInstance(Util.java:407)
        at com.mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:378)
        at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:305)
        at java.sql.DriverManager.getConnection(Unknown Source)
        at java.sql.DriverManager.getConnection(Unknown Source)
        at de.diddiz.util.MySQLConnectionPool.getConnection(MySQLConnectionPool.java:64)
        at de.diddiz.LogBlock.LogBlock.getConnection(LogBlock.java:180)
        at de.diddiz.LogBlock.LogBlock.onLoad(LogBlock.java:68)
        at org.bukkit.craftbukkit.CraftServer.loadPlugins(CraftServer.java:121)
        at org.bukkit.craftbukkit.CraftServer.<init>(CraftServer.java:89)
        at net.minecraft.server.ServerConfigurationManager.<init>(ServerConfigurationManager.java:51)
        at net.minecraft.server.MinecraftServer.init(MinecraftServer.java:132)
        at net.minecraft.server.MinecraftServer.run(MinecraftServer.java:335)
        at net.minecraft.server.ThreadServerApplication.run(SourceFile:422)
    Caused by: java.net.ConnectException: Connection refused: connect
        at java.net.PlainSocketImpl.socketConnect(Native Method)
        at java.net.PlainSocketImpl.doConnect(Unknown Source)
        at java.net.PlainSocketImpl.connectToAddress(Unknown Source)
        at java.net.PlainSocketImpl.connect(Unknown Source)
        at java.net.SocksSocketImpl.connect(Unknown Source)
        at java.net.Socket.connect(Unknown Source)
        at java.net.Socket.connect(Unknown Source)
        at java.net.Socket.<init>(Unknown Source)
        at java.net.Socket.<init>(Unknown Source)
        at com.mysql.jdbc.StandardSocketFactory.connect(StandardSocketFactory.java:254)
        at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:292)
        ... 23 more
    2011-07-08 18:45:00 [SEVERE] [LogBlock] Error while loading:
    java.lang.NullPointerException
        at de.diddiz.LogBlock.LogBlock.onLoad(LogBlock.java:68)
        at org.bukkit.craftbukkit.CraftServer.loadPlugins(CraftServer.java:121)
        at org.bukkit.craftbukkit.CraftServer.<init>(CraftServer.java:89)
        at net.minecraft.server.ServerConfigurationManager.<init>(ServerConfigurationManager.java:51)
        at net.minecraft.server.MinecraftServer.init(MinecraftServer.java:132)
        at net.minecraft.server.MinecraftServer.run(MinecraftServer.java:335)
        at net.minecraft.server.ThreadServerApplication.run(SourceFile:422)
    That happens on startup and it disables itself.

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

    DiddiZ

    I could figure out at least double steps and flint and steel causing it, but there are probably more causes. I'm sorry to use LB as debug tool for the BlockÜlace event, but there is apparently no ohter way.
    Will check that.
    Hm, the MySQL server could be down/not startet. Or when you use a remote one, the ip could have changed.
     

Share This Page