Factions/src/com/massivecraft/factions/Factions.java

215 lines
8.5 KiB
Java
Raw Normal View History

package com.massivecraft.factions;
2013-04-22 09:37:53 +02:00
import com.massivecraft.factions.adapter.BoardAdapter;
import com.massivecraft.factions.adapter.BoardMapAdapter;
import com.massivecraft.factions.adapter.RelAdapter;
import com.massivecraft.factions.adapter.TerritoryAccessAdapter;
import com.massivecraft.factions.chat.modifier.ChatModifierLc;
import com.massivecraft.factions.chat.modifier.ChatModifierLp;
import com.massivecraft.factions.chat.modifier.ChatModifierParse;
import com.massivecraft.factions.chat.modifier.ChatModifierRp;
import com.massivecraft.factions.chat.modifier.ChatModifierUc;
import com.massivecraft.factions.chat.modifier.ChatModifierUcf;
2017-01-03 11:47:51 +01:00
import com.massivecraft.factions.chat.tag.ChatTagName;
import com.massivecraft.factions.chat.tag.ChatTagNameforce;
import com.massivecraft.factions.chat.tag.ChatTagRelcolor;
import com.massivecraft.factions.chat.tag.ChatTagRole;
import com.massivecraft.factions.chat.tag.ChatTagRoleprefix;
import com.massivecraft.factions.chat.tag.ChatTagRoleprefixforce;
import com.massivecraft.factions.chat.tag.ChatTagTitle;
2017-01-03 11:47:51 +01:00
import com.massivecraft.factions.cmd.CmdFactions;
2017-02-10 18:34:42 +01:00
import com.massivecraft.factions.cmd.type.TypeFactionChunkChangeType;
import com.massivecraft.factions.cmd.type.TypeRel;
2017-01-03 11:47:51 +01:00
import com.massivecraft.factions.engine.EngineCanCombatHappen;
import com.massivecraft.factions.engine.EngineChat;
2017-01-03 11:47:51 +01:00
import com.massivecraft.factions.engine.EngineChunkChange;
import com.massivecraft.factions.engine.EngineDenyCommands;
import com.massivecraft.factions.engine.EngineEcon;
import com.massivecraft.factions.engine.EngineExploit;
2017-01-03 11:47:51 +01:00
import com.massivecraft.factions.engine.EngineFlagEndergrief;
import com.massivecraft.factions.engine.EngineFlagExplosion;
import com.massivecraft.factions.engine.EngineFlagFireSpread;
import com.massivecraft.factions.engine.EngineFlagSpawn;
import com.massivecraft.factions.engine.EngineFlagZombiegrief;
import com.massivecraft.factions.engine.EngineLastActivity;
import com.massivecraft.factions.engine.EngineMotd;
import com.massivecraft.factions.engine.EngineMoveChunk;
import com.massivecraft.factions.engine.EnginePermBuild;
import com.massivecraft.factions.engine.EnginePlayerData;
import com.massivecraft.factions.engine.EnginePower;
import com.massivecraft.factions.engine.EngineSeeChunk;
2017-01-03 11:47:51 +01:00
import com.massivecraft.factions.engine.EngineShow;
import com.massivecraft.factions.engine.EngineTeleportHomeOnDeath;
import com.massivecraft.factions.engine.EngineTerritoryShield;
import com.massivecraft.factions.engine.EngineVisualizations;
2013-04-22 09:37:53 +02:00
import com.massivecraft.factions.entity.Board;
import com.massivecraft.factions.entity.BoardColl;
import com.massivecraft.factions.entity.FactionColl;
2017-01-03 11:47:51 +01:00
import com.massivecraft.factions.entity.MConfColl;
import com.massivecraft.factions.entity.MFlagColl;
import com.massivecraft.factions.entity.MPermColl;
2013-04-26 08:02:32 +02:00
import com.massivecraft.factions.entity.MPlayerColl;
import com.massivecraft.factions.entity.migrator.MigratorMConf001EnumerationUtil;
2017-02-10 18:34:42 +01:00
import com.massivecraft.factions.event.EventFactionsChunkChangeType;
2016-11-05 15:42:16 +01:00
import com.massivecraft.factions.integration.V19.IntegrationV19;
2014-06-04 14:02:23 +02:00
import com.massivecraft.factions.integration.herochat.IntegrationHerochat;
import com.massivecraft.factions.integration.lwc.IntegrationLwc;
2016-02-25 22:28:09 +01:00
import com.massivecraft.factions.integration.spigot.IntegrationSpigot;
2015-09-05 12:58:15 +02:00
import com.massivecraft.factions.integration.worldguard.IntegrationWorldGuard;
import com.massivecraft.factions.mixin.PowerMixin;
2017-01-03 11:47:51 +01:00
import com.massivecraft.factions.task.TaskEconLandReward;
import com.massivecraft.factions.task.TaskFlagPermCreate;
import com.massivecraft.factions.task.TaskPlayerDataRemove;
import com.massivecraft.factions.task.TaskPlayerPowerUpdate;
2014-06-04 14:02:23 +02:00
import com.massivecraft.massivecore.MassivePlugin;
2017-02-10 18:34:42 +01:00
import com.massivecraft.massivecore.command.type.RegistryType;
2014-06-04 14:02:23 +02:00
import com.massivecraft.massivecore.util.MUtil;
2014-09-13 10:24:49 +02:00
import com.massivecraft.massivecore.xlib.gson.GsonBuilder;
2017-03-24 13:05:58 +01:00
import org.bukkit.ChatColor;
2014-06-04 14:02:23 +02:00
public class Factions extends MassivePlugin
{
// -------------------------------------------- //
// CONSTANTS
// -------------------------------------------- //
public final static String FACTION_MONEY_ACCOUNT_ID_PREFIX = "faction-";
public final static String ID_NONE = "none";
public final static String ID_SAFEZONE = "safezone";
public final static String ID_WARZONE = "warzone";
public final static String NAME_NONE_DEFAULT = ChatColor.DARK_GREEN.toString() + "Wilderness";
public final static String NAME_SAFEZONE_DEFAULT = "SafeZone";
public final static String NAME_WARZONE_DEFAULT = "WarZone";
// -------------------------------------------- //
// INSTANCE & CONSTRUCT
// -------------------------------------------- //
private static Factions i;
public static Factions get() { return i; }
2017-03-24 11:51:25 +01:00
public Factions() { Factions.i = this; }
// -------------------------------------------- //
// FIELDS
// -------------------------------------------- //
2013-04-22 15:05:00 +02:00
// Database Initialized
private boolean databaseInitialized;
public boolean isDatabaseInitialized() { return this.databaseInitialized; }
// Mixins
2017-02-10 18:34:42 +01:00
@Deprecated public PowerMixin getPowerMixin() { return PowerMixin.get(); }
@Deprecated public void setPowerMixin(PowerMixin powerMixin) { PowerMixin.get().setInstance(powerMixin); }
// -------------------------------------------- //
// OVERRIDE
// -------------------------------------------- //
@Override
2016-02-25 22:28:09 +01:00
public void onEnableInner()
{
2017-02-22 08:22:08 +01:00
// Register types
RegistryType.register(Rel.class, TypeRel.get());
RegistryType.register(EventFactionsChunkChangeType.class, TypeFactionChunkChangeType.get());
2013-04-19 18:34:21 +02:00
// Register Faction accountId Extractor
// TODO: Perhaps this should be placed in the econ integration somewhere?
MUtil.registerExtractor(String.class, "accountId", ExtractorFactionAccountId.get());
2013-04-24 14:31:10 +02:00
// Initialize Database
// MConf should always be activated first for all plugins. It's simply a standard. The config should have no dependencies.
// MFlag and MPerm are both dependency free.
// Next we activate Faction, MPlayer and Board. The order is carefully chosen based on foreign keys and indexing direction.
// MPlayer --> Faction
// We actually only have an index that we maintain for the MPlayer --> Faction one.
// The Board could currently be activated in any order but the current placement is an educated guess.
// In the future we might want to find all chunks from the faction or something similar.
// We also have the /f access system where the player can be granted specific access, possibly supporting the idea of such a reverse index.
2013-04-22 15:05:00 +02:00
this.databaseInitialized = false;
MigratorMConf001EnumerationUtil.get().setActive(true);
MConfColl.get().setActive(true);
2016-02-25 22:28:09 +01:00
MFlagColl.get().setActive(true);
MPermColl.get().setActive(true);
FactionColl.get().setActive(true);
MPlayerColl.get().setActive(true);
2016-02-25 22:28:09 +01:00
BoardColl.get().setActive(true);
2013-04-22 15:05:00 +02:00
this.databaseInitialized = true;
2016-02-25 22:28:09 +01:00
// Activate
this.activate(
// Command
CmdFactions.class,
2016-02-25 22:28:09 +01:00
// Engines
2017-01-03 11:47:51 +01:00
EngineCanCombatHappen.class,
EngineChat.class,
2017-01-03 11:47:51 +01:00
EngineChunkChange.class,
EngineDenyCommands.class,
EngineExploit.class,
2017-01-03 11:47:51 +01:00
EngineFlagEndergrief.class,
EngineFlagExplosion.class,
EngineFlagFireSpread.class,
EngineFlagSpawn.class,
EngineFlagZombiegrief.class,
EngineLastActivity.class,
EngineMotd.class,
EngineMoveChunk.class,
EnginePermBuild.class,
EnginePlayerData.class,
EnginePower.class,
EngineSeeChunk.class,
2017-01-03 11:47:51 +01:00
EngineShow.class,
EngineTeleportHomeOnDeath.class,
EngineTerritoryShield.class,
EngineVisualizations.class,
EngineEcon.class, // TODO: Take an extra look and make sure all economy stuff is handled using events.
2016-02-25 22:28:09 +01:00
// Integrate
IntegrationHerochat.class,
IntegrationLwc.class,
IntegrationWorldGuard.class,
2016-11-05 15:42:16 +01:00
IntegrationV19.class,
2016-02-25 22:28:09 +01:00
// Spigot
IntegrationSpigot.class,
2016-02-25 22:28:09 +01:00
// Modulo Repeat Tasks
TaskPlayerPowerUpdate.class,
TaskPlayerDataRemove.class,
TaskEconLandReward.class,
TaskFlagPermCreate.class,
// ChatModifiers
ChatModifierLc.class,
ChatModifierLp.class,
ChatModifierParse.class,
ChatModifierRp.class,
ChatModifierUc.class,
ChatModifierUcf.class,
// ChatTags,
ChatTagRelcolor.class,
ChatTagRole.class,
ChatTagRoleprefix.class,
ChatTagRoleprefixforce.class,
ChatTagName.class,
ChatTagNameforce.class,
ChatTagTitle.class
);
}
2017-03-24 14:19:26 +01:00
@Override
public GsonBuilder getGsonBuilder()
{
2013-04-16 11:27:03 +02:00
return super.getGsonBuilder()
.registerTypeAdapter(TerritoryAccess.class, TerritoryAccessAdapter.get())
.registerTypeAdapter(Board.class, BoardAdapter.get())
.registerTypeAdapter(Board.MAP_TYPE, BoardMapAdapter.get())
.registerTypeAdapter(Rel.class, RelAdapter.get())
2013-04-16 11:27:03 +02:00
;
}
}