diff --git a/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftInventoryFurnace.java b/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftInventoryFurnace.java
index 29a8cd7667..33c970b467 100644
--- a/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftInventoryFurnace.java
+++ b/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftInventoryFurnace.java
@@ -40,6 +40,21 @@ public class CraftInventoryFurnace extends CraftInventory implements FurnaceInve
         this.setItem(0, stack);
     }
 
+    // Paper start
+    @Override
+    public boolean isFuel(ItemStack stack) {
+        net.minecraft.server.level.ServerLevel world = ((org.bukkit.craftbukkit.CraftWorld) org.bukkit.Bukkit.getWorlds().get(0)).getHandle();
+        return stack != null && !stack.getType().isEmpty() && world.fuelValues().isFuel(CraftItemStack.asNMSCopy(stack));
+    }
+
+    @Override
+    public boolean canSmelt(ItemStack stack) {
+        // data packs are always loaded in the main world
+        net.minecraft.server.level.ServerLevel world = ((org.bukkit.craftbukkit.CraftWorld) org.bukkit.Bukkit.getWorlds().get(0)).getHandle();
+        return stack != null && !stack.getType().isEmpty() && world.recipeAccess().getRecipeFor(((AbstractFurnaceBlockEntity) this.inventory).recipeType, new net.minecraft.world.item.crafting.SingleRecipeInput(CraftItemStack.asNMSCopy(stack)), world).isPresent();
+    }
+    // Paper end
+
     @Override
     public Furnace getHolder() {
         return (Furnace) this.inventory.getOwner();