Application.java 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. package controllers;
  2. import static models.tables.Fortune.FORTUNE;
  3. import static models.tables.World.WORLD;
  4. import static play.mvc.Http.MimeTypes.JSON;
  5. import java.util.Collections;
  6. import java.util.List;
  7. import java.util.Random;
  8. import java.util.concurrent.ThreadLocalRandom;
  9. import javax.inject.Inject;
  10. import org.jooq.DSLContext;
  11. import org.jooq.JSONFormat;
  12. import org.jooq.JSONFormat.RecordFormat;
  13. import org.jooq.SQLDialect;
  14. import org.jooq.impl.DSL;
  15. import org.jooq.types.UInteger;
  16. import models.tables.records.FortuneRecord;
  17. import models.tables.records.WorldRecord;
  18. import play.db.Database;
  19. import play.mvc.Controller;
  20. import play.mvc.Result;
  21. public class Application extends Controller {
  22. private static final SQLDialect DIALECT = SQLDialect.MYSQL_5_7;
  23. private static final JSONFormat JSON_FORMAT = JSONFormat.DEFAULT_FOR_RECORDS.recordFormat(RecordFormat.OBJECT);
  24. private final Database db;
  25. @Inject
  26. public Application(final Database db) {
  27. this.db = db;
  28. }
  29. public Result db() {
  30. return ok(getRandomWorlds(1).get(0).formatJSON(JSON_FORMAT)).as(JSON);
  31. }
  32. public Result queries(final String queries) {
  33. return ok(getRandomWorlds(queryCount(queries)).formatJSON(JSON_FORMAT)).as(JSON);
  34. }
  35. public Result fortunes() {
  36. final List<FortuneRecord> fortunes = this.db.withConnection(connection -> {
  37. return DSL.using(connection, DIALECT).select(FORTUNE.ID, FORTUNE.MESSAGE).from(FORTUNE).fetchInto(FortuneRecord.class);
  38. });
  39. fortunes.add(new FortuneRecord(UInteger.valueOf(0), "Additional fortune added at request time."));
  40. Collections.sort(fortunes, (f1, f2) -> f1.getMessage().compareTo(f2.getMessage()));
  41. return ok(views.html.fortunes.render(fortunes));
  42. }
  43. public Result update(final String queries) {
  44. final org.jooq.Result<WorldRecord> worlds = getRandomWorlds(queryCount(queries));
  45. final Random random = ThreadLocalRandom.current();
  46. for (final WorldRecord world : worlds) {
  47. world.setRandomnumber((random.nextInt(10000) + 1));
  48. }
  49. final int batchSize = 25;
  50. final int batches = ((worlds.size() / batchSize) + 1);
  51. this.db.withConnection(connection -> {
  52. final DSLContext sql = DSL.using(connection, DIALECT);
  53. for ( int i = 0 ; i < batches ; ++i ) {
  54. sql.batchUpdate(worlds.subList(i * batchSize, Math.min((i + 1) * batchSize, worlds.size()))).execute();
  55. }
  56. return null;
  57. });
  58. return ok(worlds.formatJSON(JSON_FORMAT)).as(JSON);
  59. }
  60. private int queryCount(final String queryCountString) {
  61. int queryCount;
  62. try {
  63. queryCount = Integer.parseInt(queryCountString, 10);
  64. } catch (final NumberFormatException e) {
  65. queryCount = 1;
  66. }
  67. if (queryCount < 1) {
  68. queryCount = 1;
  69. } else if (queryCount > 500) {
  70. queryCount = 500;
  71. }
  72. return queryCount;
  73. }
  74. private org.jooq.Result<WorldRecord> getRandomWorlds(final int n) {
  75. final Random random = ThreadLocalRandom.current();
  76. org.jooq.Result<WorldRecord> worlds = null;
  77. for (int i = 0; i < n; ++i) {
  78. long randomId = random.nextInt(10000) + 1;
  79. final org.jooq.Result<WorldRecord> world = this.db.withConnection(connection -> {
  80. return DSL.using(connection, DIALECT).selectFrom(WORLD).where(WORLD.ID.eq(UInteger.valueOf(randomId))).fetch();
  81. });
  82. if(worlds == null) {
  83. worlds = world;
  84. } else {
  85. worlds.add(world.get(0));
  86. }
  87. }
  88. return worlds;
  89. }
  90. }