--- a/net/minecraft/server/ExpirableListEntry.java
+++ b/net/minecraft/server/ExpirableListEntry.java
@@ -22,7 +22,7 @@
     }
 
     protected ExpirableListEntry(T t0, JsonObject jsonobject) {
-        super(t0, jsonobject);
+        super(checkExpiry(t0, jsonobject), jsonobject);
 
         Date date;
 
@@ -65,4 +65,30 @@
         jsonobject.addProperty("expires", this.d == null ? "forever" : ExpirableListEntry.a.format(this.d));
         jsonobject.addProperty("reason", this.e);
     }
+
+    // CraftBukkit start
+    public String getSource() {
+        return this.c;
+    }
+
+    public Date getCreated() {
+        return this.b;
+    }
+
+    private static <T> T checkExpiry(T object, JsonObject jsonobject) {
+        Date expires = null;
+
+        try {
+            expires = jsonobject.has("expires") ? a.parse(jsonobject.get("expires").getAsString()) : null;
+        } catch (ParseException ex) {
+            // Guess we don't have a date
+        }
+
+        if (expires == null || expires.after(new Date())) {
+            return object;
+        } else {
+            return null;
+        }
+    }
+    // CraftBukkit end
 }