Achievements - made by Lolmewn
What does this plugin do?
This plugin allows you to add additional achievements to the game. This plugin requries my other plugin, Stats, to work.
Using this plugin, you can add achievements to the game, and add rewards to them. Whenever a player gets an achievement, you can let commands run, give them money and/or items, and much more using the API this plugin will have.
How do I install this?
Download the latest file from the files page and put it in your plugins folder.
Configuring the plugin
There's nothing much to configure here yet. You can toggle whether or not it auto-updates, but that's about it.
This is where you will store all your achievements. An achievement must have the following layout:
<id> name: YourAchievementName goals: - Stat <amount> <TOTAL or the variables belonging to this Stat> - another one?
The rest of the things is pretty self-explanatory. Once I have time, I will write down a good how-to-write achievements page.
These are the available Stats:
|Block_break||All broken blocks with their Datavalues||itemId itemData breaking|
|Block_place||All placed blocks with their Datavalues||itemId itemData breaking|
|Death||All deaths with their causes||cause entity(boolean, true is safest)|
|Kill||All kills with their causes||type|
|Move||Walking, sailing, riding a train, on the back of a pig or by horse.||type (0=walk, 1=boat, 2=train, 3=pig, 4=pig in train, 5=horse)|
|Playtime||Time played in seconds|
|Xp_gained||Total XP gained|
|Joins||Total times joined|
|Fish_catched||Total fish Caught|
|Damage_taken||Total damage taken|
|Times_kicked||Total times kicked|
|Tools_broken||Total Tools broken|
|Eggs_thrown||Total eggs thrown|
|Items_crafted||Total items crafted|
|Omnomnom||Total times had a snack|
|On_fire||Total times being on fire|
|Words_said||Total words said|
|Commandsdone||Total commands done|
|Votes||Total times voted for the server (uses Votifier)|
|Worldchange||Total times worlds changed|
|Bucketfill||Total buckets filled|
|Bucketempty||Total buckets emptied|
|Bedenter||Total times bed entered|
|Itemdrops||Total times items dropped|
|Itempickups||Total times items picked up|
|Teleports||Total times teleported|
|Shear||Total times sheared|
|Lastjoin||The time the player joined the server last|
|Lastleave||The time the player left the server last|
Want to use a Stat that uses variables? You have to specify either the variables or use 'TOTAL'.
Variables with StatTypes
Some Stats have variables. A good example is Block_break, it has the variables <blockId> <blockData> and <breaking>.
If you want to have a goal where a player must break 5 blue wool blocks, the goal would be
- Block_break 5 35 3 true
If the block has no special blockData (e.g. there's only one type of it), use 0 as blockData. Example:
- Block_break 20 1 0 true
This means break 20 stone blocks.
Examples for the other special Stats:
- Block_place 5 TOTAL - Move 1000 1 #move 1000 blocks with transport type 1 (boat) - Kill 10 Zombie - Death 3 Creeper
The format always is - Stat Amount Total|Variables|<empty>
The way Item Rewards are written down is somewhat difficult. Basically, you should write it down as
items: <itemId>.<itemData>,<amount>;<itemId>.<itemData>,amount;... etc. items: 35.3,10;1,10 items: 1,20
Note that the itemData doesn't have to be specified
The itemID obvioulsy is the ID the item has (which you can find a full list of here), the itemData is also on that list, and the amount.. well, duhh.
The first example gives you 10 colored wool, and 10 stone. The second example gives you 20 stone.
You can find an example right here. When writing new achievements, I suggest you grab this page and see what all the options do.
Commands and permissions
|/ach||achievements.view.self||Check out your progress|
|/ach player <player>||achievements.view.others||Check out someone elses progress|
|/ach reload||achievements.reload||Saves all players and reloads all achievements|
|/ach page <page>||achievements.view.self||Check out page <page> of your progress|
|/ach <achievement>||Check out what the achievement is all about|
Development builds of this project can be acquired at the provided continuous integration server.
These builds have not been approved by the BukkitDev staff. Use them at your own risk, they may or may not work at all.
Development builds for Stats can be found at my CI, over at http://ci.lolmewn.nl/job/Achievements/.
Want to help develop, or simply view what makes this plugin run?
Visit my bitbucket!
This plugin utilises Hidendra's plugin metrics system, which means that the following information is collected and sent to mcstats.org:
- A unique identifier
- The server's version of Java
- Whether the server is in offline or online mode
- The plugin's version
- The server's version
- The OS version/name and architecture
- The core count for the CPU
- The number of players online
- The Metrics version
If you wish to disable this feature (/me cries), you can do so by opt-ing out, which you can do in the config file under /plugins/PluginMetrics/
This plugin has a built-in auto-updater, which connects to BukkitDev to check for updates. If you, for some reason, wish to disable this process, you can do so by setting 'update' to false in the plugins' settings file.
You can find me (and possibly, when I'm around, support) in my IRC channel #Lolmewn on irc.esper.net - See you there!