JobBank.java 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. package me.km.jobsystem;
  2. import me.km.api.Module;
  3. import me.km.databank.SimpleDataBank;
  4. import java.util.ArrayList;
  5. import me.km.databank.DataBank;
  6. import net.minecraft.entity.player.EntityPlayer;
  7. public class JobBank extends SimpleDataBank
  8. {
  9. public JobBank(Module m, DataBank c)
  10. {
  11. super(m, c);
  12. }
  13. @Override
  14. protected void init()
  15. {
  16. // Speicher für den aktuellen Beruf
  17. if(!this.doesTableExist("currentjob"))
  18. {
  19. this.getModule().sendToConsole("Der Speicher für die aktuellen Beruf wurde nicht gefunden, erstelle ...");
  20. if(this.update("CREATE TABLE IF NOT EXISTS currentjob ("
  21. + "id INT NOT NULL AUTO_INCREMENT PRIMARY KEY, "
  22. + "player_id INT NOT NULL, "
  23. + "job TINYINT NOT NULL, "
  24. + "INDEX (player_id), "
  25. + "UNIQUE INDEX (player_id,job), "
  26. + "FOREIGN KEY (player_id) REFERENCES minecraft.players(id) ON DELETE RESTRICT);", false))
  27. {
  28. this.getModule().sendToConsole("Der Speicher für die aktuellen Beruf wurde erstellt.");
  29. }
  30. }
  31. else
  32. {
  33. this.getModule().sendToConsole("Der Speicher für die aktuellen Beruf wurde gefunden.");
  34. }
  35. // Jobdatenbank
  36. if(!this.doesTableExist("jobs"))
  37. {
  38. this.getModule().sendToConsole("Die Jobdatenbank wurde nicht gefunden, erstelle ...");
  39. if(this.update("CREATE TABLE IF NOT EXISTS jobs ("
  40. + "id INT NOT NULL AUTO_INCREMENT PRIMARY KEY, "
  41. + "player_id INT NOT NULL, "
  42. + "job TINYINT NOT NULL, "
  43. + "xp INT NOT NULL DEFAULT 0, "
  44. + "level TINYINT NOT NULL DEFAULT 1, "
  45. + "UNIQUE INDEX (player_id,job), "
  46. + "FOREIGN KEY (player_id) REFERENCES minecraft.players(id) ON DELETE RESTRICT);", false))
  47. {
  48. this.getModule().sendToConsole("Die Jobdatenbank wurde erstellt.");
  49. }
  50. }
  51. else
  52. {
  53. this.getModule().sendToConsole("Die Jobdatenbank wurde gefunden.");
  54. }
  55. }
  56. // -------------------------------------------------------------------------
  57. // Job-Level
  58. // -------------------------------------------------------------------------
  59. public Byte getLevel(EntityPlayer p, byte job)
  60. {
  61. return this.getFirstByte("SELECT level from jobs " +
  62. "LEFT JOIN players ON players.id = jobs.player_id " +
  63. "WHERE players.uuid = '" + p.getUniqueID() + "' AND " +
  64. "jobs.job=" + job + ";");
  65. }
  66. public void setLevel(EntityPlayer p, byte job, byte level)
  67. {
  68. this.update("INSERT INTO jobs (player_id,job,level) "
  69. + "SELECT id, " + job + ", " + level + " "
  70. + "FROM players WHERE uuid='" + p.getUniqueID() + "' "
  71. + "ON DUPLICATE KEY UPDATE level=" + level + ";", false);
  72. }
  73. // -------------------------------------------------------------------------
  74. // Jobs
  75. // -------------------------------------------------------------------------
  76. public boolean hasJob(EntityPlayer p, byte job)
  77. {
  78. return this.getFirstByte("SELECT job from currentjob " +
  79. "LEFT JOIN players ON players.id = currentjob.player_id " +
  80. "WHERE players.uuid = '" + p.getUniqueID() + "' AND " +
  81. "currentjob.job=" + job + ";") != null;
  82. }
  83. public ArrayList<Byte> getJobs(EntityPlayer p)
  84. {
  85. return this.getFirstByteColumn("SELECT job from currentjob " +
  86. "LEFT JOIN players ON players.id = currentjob.player_id " +
  87. "WHERE players.uuid = '" + p.getUniqueID() + "';");
  88. }
  89. public void setJob(EntityPlayer p, byte job, boolean b)
  90. {
  91. if(b)
  92. {
  93. this.update("INSERT INTO currentjob (player_id,job) " +
  94. "SELECT id, " + job + " " +
  95. "FROM players WHERE uuid='" + p.getUniqueID() + "' " +
  96. "ON DUPLICATE KEY UPDATE job=" + job + ";", false);
  97. return;
  98. }
  99. this.update("DELETE currentjob FROM currentjob " +
  100. "LEFT JOIN players ON players.id = currentjob.player_id " +
  101. "WHERE players.uuid = '" + p.getUniqueID() + "' AND job=" + job + ";", false);
  102. }
  103. // -------------------------------------------------------------------------
  104. // Job-XP
  105. // -------------------------------------------------------------------------
  106. public Integer getXp(EntityPlayer p, byte job)
  107. {
  108. return this.getFirst("SELECT xp from jobs " +
  109. "LEFT JOIN players ON players.id = jobs.player_id " +
  110. "WHERE players.uuid = '" + p.getUniqueID() + "' AND " +
  111. "jobs.job=" + job + ";", Integer.class);
  112. }
  113. public void setXp(EntityPlayer p, byte job, int xp)
  114. {
  115. this.update("INSERT INTO jobs (player_id,job,xp) " +
  116. "SELECT id, " + job + ", " + xp + " " +
  117. "FROM players WHERE uuid='" + p.getUniqueID() + "' " +
  118. "ON DUPLICATE KEY UPDATE xp=" + xp + ";", false);
  119. }
  120. }