World Resourcepacks icon

World Resourcepacks -----

Easily set server resource packs per world or your whole server!



[​IMG] Made in Germany with love (and beer)

[​IMG]
Did you ever want to set a different server resource pack for your each of your worlds? Or switch your current resource pack with just one command? Then you came to the right place!

This plugin lets you set one Server Resource Pack for each of your worlds or event your whole server! It also allows you to specify packs that should be usable on multiple worlds!

It is also compatible with my Bungee Resourcepacks plugin for the BungeeCord proxy and will not make the player redownload a resource pack after server switching if it got already applied by Bungee Resourcepacks on another server!


Please note that the Vanilla Minecraft client only applies server resource packs that are smaller than 200MiB! (50MiB before 1.15, 100MiB before 1.18)

Also certain new SSL certificates for URLs (like Let's Encrypt) do not work with the old Java version shipped with Minecraft before version 1.17 (Java 1.8.0_51, a bug report regarding that has been filed with Mojang) so you'll have to either use a different certificate or a non encrypted download (not recommended!)


For an enhanced version of this plugin that can run actions like kicking players take a look at the paid version Force Resourcepacks!
It also lets you react with lots of different actions (commands, teleportation, messages titles and of course kicking) when the player accepts and downloads the pack!
It also adds PlaceholderAPI and WorldGuard support!


Note: This plugin does not work with older Minecraft versions that do not support server resourcepacks!

Features
  • Set different server resourcepacks per world or whole server
  • Multiple pack support (on 1.20.3+)
  • Match world names with regex!
  • Commands to configure the plugin ingame
  • Language system with messages depending on the locale of the client
  • Simplified compoment/json message formatting syntax (MineDown)
  • Configurable delay before sending the pack to a player
  • Remembers which pack a user has currently applied and doesn't resend on world switch
  • Let the user set the pack himself. The pack can be re-applied on each login and will be used for resets in worlds that don't have the pack
  • Inform the user which pack the server send them if it was done automatically
  • ResourcePackSendEvent and ResourcePackSelectEvent for developers to react on the sending or selecting of a pack in their own plugins
  • Send the correct pack depending on the client's version (requires ViaVersion or ProtocolSupport) This is done by defining multiple pack variants with different minecraft version or pack format settings.
  • Automatically generates the sha1 hashes!
  • Compatible with AuthMe Reloaded, OpenLogin, NLogin, LibrePremium, JPremium.
    Do you need it to be compatible with more plugins?
    Contact me!
  • Need more features like WorldGuard support and kicking when the player rejects the pack? Take a look at Force Resourcepacks!
Statistics
Donations
Programming is time intensive and I would really appreciate your support!
So if you can afford it or make commercially use of this plugin feel free to buy me a beer.
Patreon with rewards: [​IMG]
Paypal: https://s.moep.tv/donate
Ðoge: D7G4Svo7GTNHpuhjwUBj2k7qANnZHwYD4p
BTC: 1EXMFRknc7kLwCmM1zf5LXNnPD4ihVCEhQ

Commands

To execute every /wrp command you need the worldresourcepacks.command permission!
/wrp reload [resend] - worldresourcepacks.command.reload
- Reloads the config file; resends the packs to every online player if the 2nd argument is "resend"

/wrp version - worldresourcepacks.command.version
- Shows the version of this plugin
/wrp generatehashes - worldresourcepacks.command.generatehashes
- Manually generate the resource pack hashes
/wrp addpack <name> <url> - worldresourcepacks.command.
addpack
- Add a new pack
/wrp pack <pack> -
worldresourcepacks.command.pack
- View and edit an existing pack
/wrp listassignments - worldresourcepacks.command.listassignments
- View all server assignments
/wrp deleteassignment <assignment> - worldresourcepacks.command.deleteassignment
- Delete a world assignment
/wrp deleteassignment <assignment> - worldresourcepacks.command.deleteassignment
- Delete a world assignment
/wrp assignment <assignment> - worldresourcepacks.command.assignment
- View and edit a world assignment

/wrp globalassignment - worldresourcepacks.command.globalassignment
- View and edit the global assignment

/resetpack [<playername>] [<temp>] - bungeeresourcepacks.command.resetpack
- Reset the pack (of a player) to the empty one or the stored pack. (Like what would happen if you joined a server without any pack) If <temp> is set to false the stored pack of the player is reset too.


To execute every /usepack command you need the worldresourcepacks.command.usepack permission!
To execute it for other players you need worldresourcepacks.command.usepack.others!
To have access to a specific pack a player needs the worldresourcepacks.pack.<packname> permission or the one defined for the pack in it's config section!
/usepack - List all packs available to you
/usepack <packname> [<playername>] - Send a specific pack to yourself or another player
Config
Code (YAML):
debug : true
# Default language
default-language
: en
# Disable all metrics included in this plugin.
disable-metrics
: false
# Whether or not resourcepack file hashes should be generated on startup:
autogeneratehashes
: true
# Whether /usepack should apply packs temporary or permanent when run without any argument:
usepack-is-temporary
: true
# Whether packs that a player has stored will override a matched assignments
stored-packs-override-assignments
: false
# When manually setting a permanent pack then it will be reset if the user disconnects in under x amount of seconds.
# 0 or anything below will disable this functionality
permanent-pack-remove-time
: 30
packs
:
  lobbypack
:
    # The url the client should download the resourcepack from.
    # Has to be a direct download link! No mediafire/mega/other oneclick-hoster!
    url
: http://example.com/lobbyresourcepack.zip
    # The sha1 hash of the resourcepack's zip file,
    # Not supported by bukkit so it currently does not matter what you write here!
    hash
: abcdef012345678abcdef012345678abcdef0123
    # The format version of this resourcepack
    format
: 1
    # Directly define the Minecraft version instead of the format
    # Supports string representation of the versions and protocol numbers
    # You don't need to define both the version and the format (if so then the highest one will take effect)
    version
: "1.8"
    # Whether or not this pack will only be send to players with a certain permission
    # permission: worldresourcepacks.pack.<packname>
    restricted
: false
    # If you want you can define a specific permission for this pack if you don't want
    # the default worldresourcepacks.pack.<packname> permission!
    permission
: worldresourcepacks.pack.lobbypack
  gamepack
:
    # Set different variants e.g. for different versions or permissions
    # This list supports all normal pack settings and is checked top to bottom.
    # The first one that matches the player will be used.
    variants
:
    - url
: http://example.com/minigameresourcepack_1_15.zip
      hash
: 012345678abcdef012345678abcdef012345678a
      version
: '1.15'
    - url
: http://example.com/minigameresourcepack_1_12.zip
      hash
: 012345678abcdef01234567dddcdef012345678a
      version
: '1.12'
# Empty pack to reset the pack to the default one
empty
:
  url
: http://cdn.moep.tv/files/Empty.zip
  hash
: 01517226212d27586ea0c5d6aff1aa5492dd2484
global
:
  pack
: lobbypack
  # List of packs to not replace if the user already has them
  # If no main pack is set the first one also gets used to reset
  # the pack if the user has a non secondary one
  # Also this list will be used to select a pack if a user does not have the permission
  # or the right version to use that pack. (From top to bottom)
  #secondary:
  #- lobbypack
  # Delay in ticks before sending the pack to a player after he logs in/switches to the world
  send-delay
: 10
worlds
:
  lobby
:
    pack
: lobbypack
    #secondary:
    #- gamepack
  minigame
:
    pack
: gamepack
    # Use a regex to target all worlds with a certain name
    regex
: 'minigame_.*'
Warning: This config might not always be up to date, please make sure to reference the one from the GitHub repo, especially when using development builds!
About the client freeze
This should no longer be an issue with 1.20.3!

When a server resource pack is send to a client it will shortly freeze after the download is complete. (Same as manually applying a local pack) This happens because the client has to reload all resources, check which resources overlap and do some other calculation and manipulation with them. (Like stitching all the textures together to a single image like they were in the first texture pack format) It's not a download issue as the client will locally cache the pack files and not re-download them if their hash didn't change.​

How long this takes generally depends on the PC's performance and the size of the textures (HD packs take longer) that are used in all resource packs that the player has applied. (So even if the server resource pack doesn't contain any HD textures or textures at all the client will still completely reload all locally applied resource packs) This is something that has to be fixed in the client by Mojang for example by only reloading resources that changed.​

1.14,1.15 and 1.16 as well as 1.20.3 again have some major improvements there so suggest players to use these if they have issues with your server resourcepack!
Dev-Resources
The source is available on GitHub and licensed under the GPLv3.
Dev builds can be found on the Minebench.de Jenkins.
There are also some Javadocs if you intend to develop plugins based on mine.
Support
You can receive support in the resource discussion thread, the GitHub issue tracker, my IRC channel, or my Discord.
Metrics
This resource includes bstats.org metrics. If you don't want bstats to collect info on your server then you can disable it in the bStats/config.yml file. The license the used bStats-lite class is under can be found here.​

Other Resources

[​IMG]
This resource is distributed without any warranty or liability by the author.
Resource Information
Author:
----------
Total Downloads: 28,418
First Release: Feb 23, 2016
Last Update: Jul 22, 2025
Category: ---------------
All-Time Rating:
42 ratings
Version -----
Released: --------------------
Downloads: ------
Version Rating:
----------------------
-- ratings