WarpPortals
Create portals of any shape/size/block! Functional, robust, customizable, and API extensible... this is WarpPortals!
Features
- Portals of any shape, size, or block type!
-
Now has an API!
- Documentation can be found at WarpPortals/API
- An example implementation can be found at example/WarpPortalsEventListener.java.
- Create portals with any block type!
- Portals without frames or with frames of any material
- Portals that work between worlds
- Easy to create Portals
- Easy to set destinations
- Precise teleportations
- Global Enable or Disable normal portals functionality
- Per-portal permissions. Setup donor portals!
Commands
Check out the Table of Commands
FAQ
How do you create a Portal?
- First choose the Portal destination and set it using "/wpdc [name]". This command will set the destination to your current location, world AND angle of view.
- Second, build a portal of any shape out of Gold Blocks. These will make up the Portal's body.
- Third, hold a non-block item and run the command "/wppc [portalName] [destName] [portalBlockMaterial]". This will make it so the next Gold Block you click will turn them into a Portal made of the specified portalBlockMaterial, eg WATER.
- Fourth, right-click any one of the Gold Blocks you built. The plugin will find all adjacent Gold Blocks and turn them all into a Portal!
- Fifth, profit.
Who can use a WarpPortal?
Any one can use a WarpPortal by default. You can revoke someone's WarpPortal rights by setting their permission "warpportal.enter" to false. New: The WarpPortals' Event API allows for this to be overridden!
How do you use WarpPortals?
WarpPortals are always active and simply walking though one will teleport you to its destination.
Who can create/admin a WarpPortal?
Only players who are ops or have the "warpportal.admin" permission.
What settings are there?
- You can change whether normal Nether/End portals function. For example, setting this to false would mean that when a player walked through a Nether portal that they activated with flint, nothing would happen.
- You can change the general Text Color used by the plugin. By default Yellow.
- You can adjust the max portal size. This limit exists so that a Portal so large that it would eternally crash the server can't be created. By default 1000.
- You can change the teleportation message. By default it is "Wooooooooosh!"
- You can change the teleportation message Text Color. By default Purple.
Is there Economy support?
No. Portals are always active and currently don't support any form of Economy plugins. New: The WarpPortals' Event API provides the means for an external plugin to be written to handle this.
What bugs are there?
<s>Ghost Portals: Currently, anyone can break the Portal Blocks that make up the Portal and that will cause the PORTALENTERED event to never fire. This means that to the plugin the Portal still exists but realistically it isn't there anymore. To keep this from happening something like WorldGuard should be used to protect the Portals (though this protection may be a built-in feature in the future). To deal with the possibility of all the Portal blocks getting broken in a Portal, you can use the "/pdelete [portalName]" command to return the Portal to its original Gold Block form. If only a few blocks get broken, simply replacing them with new Portal Blocks should work._</s> Fixed in version 4.1.3
<s>Bad Text Colors: Also, the Text Color settings don't appear to be cross OS Compatible. By default they are setup for Windows but if they don't work for you (if you get white text from the plugin) all Text Color Codes are editable in the Plugin's settings file.</s> Fixed in version 2.0.1
<s>Single Width Portals: Single width portals can only face East or West. This is a very weird bug but it is an unfortunately un-fixable problem. Portal block orientation is decided off of the adjacent portal blocks. Therefore, if two portal blocks are side-by-side, they will connect and face the right way. (Side Note: Even this was a hack and required overriding portal block physics). Sadly, a single portal block doesn't have anything to base it's orientation upon and will then default to East/West. This forum thread details the problem <https://forums.bukkit.org/threads/rotating-portal- blocks.12598/forums.bukkit.org/threads/rotating-portal-blocks.12598/></s> Only applies to WarpPortals made of Nether Blocks as of version 4.1.3
Install
- Download the latest version right here!
- Drop it into the Plugins folder in your CraftBukkit install.
- Go create some spiffy, funky, wild, seriously fun Portals!
Source Code and Downloads
The latest Bukkit approved version to can be found attached to this page! Though you can always find the absolute latest version at [Latest Version](https://github.com/McCraftaholics/Bukkit- WarpPortals/raw/master/WarpPortals_latest.jar)
Source code can be found at github.com/McCraftaholics/Bukkit- WarpPortals
- Please feel free to make changes!
- Pull requests are awesome. Issues can be posted at github.com/McCraftaholics/Bukkit-WarpPortals/issues
API
WarpPortals now has an Event API. Bukkit explains Events at Event API Reference. WarpPortals triggers custom events allowing other plugins to tie into these events. The events provide player & portal information and allow other plugins to cancel the portal teleportation.
Further documentation can be found at WarpPortals/API
Open an Issue on the GitHub page if you have any questions!
Changelog
5.6.5
- Replace usage of player name's with new player UUID standard
- Rename portal.yml backups to "*.yml.bac" in order to signify the data type
5.6.4
-
Merge PR #28 from xxyy
- Fix Nether portals not disappearing when frame destroyed
- Thank you xxyy!
- Devs, this plugin is now built using maven
5.6.3
-
Restore original permission system - Fixes 'OP only' errors!
- Portals are mass turned on/off for players
-
New per-portal permission system can be enabled
- Set 'portals>permission>checkIndividualPortalPermissions' to 'true' in the config file
- This setting requires wildcard permission support for normal operation
5.5.2
-
Teleportation messages can now be disabled, properly.
- Set portals>teleport>message to "&none", without the quotes, in the config.yml file # for real this time
-
WarpPortals now handles World unloads and deletions
- This should fix all known issues causing data to be deleted
- The portal ID tool is multi-use, it won't dequip after each ID.
-
Per-portal permissions can now be set (eg, donor rank portals)
- WarpPortals now check for if a player has "warpportals.enter.{PortalName}" permission before teleporting
- By default ever player has "warpportals.enter.*", this can be changed and allows for donor rank portals and such
- You can set whether players are told that they don't have permission, or make the portal "silent"
- Faster onPlayerMove algorithm that is over 100% more efficient in some situations!
-
Users are alerted when they run commands without proper permission
- Should help permission debugging
- CommandHandler polished for more efficiency as well
4.2.1
-
Teleportation messages can now be disabled.
- Set portals>teleport>message to "&none", without the quotes, in the config.yml file
-
WarpPortals now auto backups the data file after every portal creation
- This should allow for easy recovery in the event of data loss
- As of now, there is no limit on the number of backup files that can be created. Manual cleanup may be necessary.
-
New API event added: WarpPortalsCreateEvent
- Triggered when a user creates a WarpPortal
- Allows access to the new portals name, destination, blocks
- Allows these elements to be modified by other plugins
4.1.4 Critical Fix
-
WarpPortals now handles permissions properly
- Non-ops can use WarpPortals
- Follows Bukkit Permissions structure
- Thank you WeaselSqueezer
4.1.3
-
New portal interaction engine on the backend
- WarpPortals can be made of any block type!
- WarpPortals activate faster for players in survival mode
- Protect WarpPortals from getting destroyed
- Keeps liquids from flowing inside portals so that portals can be made of water/lave
-
Renamed all WarpPortal commands in a more logical manner
- Separated commands into wp-portal-* and wp-destination-*
- Abbreviations added for ease-of-typing, checkout Aliases
3.0.0 (2.1.1 merged in)
- Added soft-depends to hopefully fix all the lost portals errors!
-
Added WarpPortals Event API
- Plugins can be written that tie into WarpPortals
- Example: An economy plugin can be created that charges people for portal use
- Allows 3rd parties to add missing features
2.01
-
ENDER PORTALS!!!!
- Horizontal portals can now be made out of Ender Portal!
- Instead of using Gold Block to create the portal, use Quartz Block.
- Unlike Normal Portals which are vertical, Ender Portals are horizontal beasts.
- BugFix: Chat Colors are now used for portal creation.
- BugFix: Portal Creation Tools stay active for retries when a portal fails to create due to MaxRecursionLimit or similar.
- Minor: Portal Delete Tools now alert when they are equipped.
1.93
-
Chat Colors are now handled properly, the Bukkit way.
- Setting a Chat Color doesn't require any special characters in the config file anymore! Just the color code. (eg. '3' instead of '&3')
- In addition to convenience, this should fix all of the config problems! @R4m8o, @DarkenInsanity, @SpookyPirate
- Portals now also save their state to disk on creation. This should fix any lost portal errors. @getnjr, @iDazzah
1.81
- Error reporting for Config File Loading and Portal Saving has been improved. Instead of receiving an obscure message, the actual error is now reported.
1.70
- Compiled and coded against Java SE 6. Supports Java 6 finally! Use it on both Java 6 and 7 :)
1.64
- Added MCStats support (http:mcstats.org) for my own personal enjoyment and motivation! Don't worry, you can opt-out of course. Everything about it is explained at this forum thread MCStats / Plugin Metrics (R7) - Easy & advanced Plugin Statistics.
1.63
- WarpPortals requests highest priority on Portal Enter events. This should fix normal portals acting weird (@SpookyPirate) and Warp Portals taking a while to teleport (@mrchasez)
1.61
- The functionality (as in: the ability to teleport like normal) of traditional Nether/End portals is now toggleable via settings. @sgtcaze
1.50
- Non-WarpPortals now function like normal! @SpookyPirate
1.43
- Hopefully fixed any File Reading / Scanner errors. Thanks Zylithi!
- Fixed command conflict with WorldGuard concerning teleporting to Portals/Destinations.
1.31
- First offical release!
Enjoy :)
how can i make it so players who are not opped can use the watpportals because currently on ops can use them and i dont know ehy
I have the same error and upon restart, i get this (BluFroYo is the world's Name):
[20:06:17] [Server thread/INFO]: [WarpPortals] Error in Portal's data file with String "tpCoords: (BluFroYo,269.5,77.0,452.5,-2.0092726E-5,-358.69165)".
[20:06:17] [Server thread/INFO]: [WarpPortals] Error in Portal's data file with String "tpCoords: (BluFroYo,269.5,77.0,452.5,-2.0092726E-5,-358.69165)".
[20:06:17] [Server thread/WARN]: [WarpPortals] WarpPortal data loaded using the old data-structure. The next save will migrate it to the latest portals.yml version.
@NiCk1312
Doesn't work for me, just resets to default.
@Epicballzy
What i did to get rid of it, I just opened up the config, and just leave it blank next to the message, besides the # and the stuff after the # (You can leave it or get rid of the stuff after the # it wont affect anything)
I really love this plugin and great tutorial!
I can't seem to get the "Woooooooosh" message to go away.. I put "&none" to disable itbut it still says wooooooooosh. I also tried stopping the server, changing it the staring the server but it didn't work. Any reasons why?
@awendland
@awendland
I'm currently re-doing all of the portals which i've made before. I've created one and restarted without a problem. Will report back when done with all portals or when portals stop working. Ps. Thank you for being so active on your plugin.
@fefect
Post a screenshot of the error printout exactly and then what occurs when the portals.yml file is deleted and the server restarted. Is the error always reproduced?
@awendland
I've tried that with no succes following up. This is the second portal plugin i'm currently trying and they all seem to have their problems (Multiverse-portals which din't work for new-players) and now this plugin..
@fefect
As I am aware, this is entirely an OS issue. WarpPortals uses standard Java conventions of accessing files on the file system. This error is only thrown when the file write call throws an access exception.
WarpPortals is opensource so if someone with greater Java know-how would like to take a look and improve upon its IO handling, please, be my guest!
What you can try is copying the contents of portals.yml, deleting the file, restarting the server, shutting the server down, and then pasting the contents into the newly created version of the file.
@ProbablyRaging
This, i've got the same now. And i do not want to reset all of my portals and do it all over again everytime i restart.
The 'OP only error' is now fixed as of v0563
Sorry about the difficulty! Enjoy :)
When ever I make a portal, if your not an OP it says, You do not have permission to use this Warp Portal
This is very good!
EDIT: I solved the problem, all I had to do was delete the existing portals.yml file, restart the server and it created a new portals.yml file with the correct permissions.
Hi mate, awesome plugin you have here.
I just have one little problem that is stopping me from using your plugin at the moment.
After creating a portal, testing the portal to make sure it is working correctly and then restarting my server, all my portals get deleted and return back to gold blocks. I receive an error in console which I will paste below.
07.03 20:45:51 [Server] ERROR Can't save WarpPortals data! WarpPortals does not have write access to the save location "/plugins/WarpPortals/portals.yml". 07.03 20:45:51 [Server] INFO Disabling WarpPortals v5.5.2 07.03 20:45:51 [Server] INFO Disabling WGCustomFlags v1.6 07.03 20:45:51 [Server] INFO Stopping server 07.03 20:45:51 [Server] INFO CONSOLE: Stopping the server..
I have tried to change permissions for portals.yml but for some reason that does not seem to work either.
Hope to get this fixed ASAP as I really enjoy this plugin!
-PR
@Atkcon
warpportals.enter.[nameofportal] (replace [nameofportal] with the name of your portal without the brackets. Using this permission you can assign a specific group you create with the ability to use that specific portal. i.e. a group called portalusers have the permissions warpportals.enter.[nameofportal1], warpportals.enter.[nameofportal2], etc. Once the person donates, assign them that group. They will then have the permissions needed to enter [nameofportal1] and [nameofportal2] This is a good way to go about it because other portals you may have created that are public can still be accessed by anyone. i.e. defaultgroup having permission warpportals.enter.[nameofpublicportal]
For everyone that is having trouble getting the permissions working for Warp Portals; I set the permission warpportals.enter.[nameofportal] for my groups to get it working. warpportals.enter.* wasn't cutting it (I use zPermissions and it never has liked stars...) as well as warpportals.enter and warpportal.enter So as of now I must set the permission per portal I use to make it work. This isn't a hassle for me because I won't be allowing players to create their own portals and therefore will not be worrying about setting the permission for every portal being created by others. I can easily regulate my own portals. Hope this helps, cheers!
Latest version still unable to working with group manager. Even with permission, it will shown permission denied.
I know that this is probably an obvious question but how do you make a donor portal? do you give them permission in pex? if so, what is the permission?
Thanks! been looking for this all day
@iaXedu You can fix this by opening the server file goto plugins folder open up groupmanger folder open up worlds folder choose world open groups in an text editor (Notepad recommended) find the groups you choose and add warpportals.admin.listcommands
Hope This Helped Cubic