Skip to content

Filters

Added in version 1.18.2-0.7.24r and 1.19.3-0.7.23b

The tables which are added to one of our item/fluid transferring functions are called Item/Fluid Filters. The functions use these to find the item you're looking for. These can set the item, count, slots, tags, nbt or fingerprint values.

Syntax

Item/Fluid Name and Tag

The item's/fluid's filter name or tag can be specified with the name field. If this field is not set, the filter will try to search for items with the right nbt values specified in the nbt field or fingerprints.

This can be a tag or a name. To filter for tags, place a # in front of the name.

{
    name = "minecraft:enchanted_book" -- Will just search for an enchanted book, nbt values are ginored
}
{
    name = "#forge:ores/gold" -- Will search for the gold ore tag, nbt values are ignored
}

Count

The item's/fluid's filter amout can be specified with the count field. Standard values are 64 or 1000 for fluids.

{
    name = "minecraft:cobblestone",
    count = 128000 -- Will try to export 128000 cobblestone to the target inventory. It will transfer less if there is not enough space in the target inventory or if there aren't enough items in the source inventory
}

NBT Values

Only for MC versions 1.20.4 and older!

NBT Values are specified with the nbt field. The field needs to be a string which contains a json which can be parsed to a nbt tag.

{
    name = "minecraft:enchanted_book" 
    nbt="{StoredEnchantments: [{lvl: 2s, id: \"minecraft:blast_protection\"}]}"} -- Will search for an enchanted book with the blast protection enchantment level 2
}

Any strings inside the nbt value needs to be prefixed with a \

Data Components

Only for MC versions 1.20.5 and newer!

Since 1.20.5, mojang moved to a new data component system to store data for items and other things instead of using NBT. To use that new filter, you need to provide a components key instead of the old nbt key.

{
    name = "minecraft:enchanted_book" 
    components= {
        ["minecraft:stored_enchantments"] = {
            levels = {
                ["minecraft:aqua_affinity"] = 1
            }
        }
    } -- Will search for an enchanted book with the aqua affinity enchantment level 1
}

Other AP features also return a components key for items which you can directly use as a filter.

Slots

Only available for item filters

Slots can be specified with the toSlot or fromSlot field. The inventory manager uses 103-100 for the armor slots helmet to boots and 36 for the offhand.

Storage systems like the rs or me bridge will ignore these fields if they are used to specify the slot of the system. Like toSlot if you use it for importItem

If the slot can't be found or if the slot can't accept this item, the item will not be transferred.

{
    toSlot = 6, -- Tries to move the item to this slot of the target inventory
    fromSlot = 36, -- Tries to remove the item from the offhand
}

Fingerprints

The fingerprint is a MD5 hash calculated of the nbt tag, the registry name and the display name.

This can be useful if you want to only filter for one very specific item. Also helpful if you don't want to copy the nbt tag for an item into the filter.

A fingerprint can be generated with the /advancedperipherals getHashItem command while holding the item in your main hand.

If the fingerprint field is specified, the nbt and name field will be ignored.

{
    fingerprint = "227FCCBE693942047DD04AA96F735F2E" -- The hash for a protection 4 enchanted book
    count = 5 -- Try to move 5 protection 4 books to the target inventory
}

Comments