game_machine 0.0.11 → 1.0.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (274) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +12 -1
  3. data/Gemfile.lock +32 -47
  4. data/Rakefile +0 -27
  5. data/bin/bundle_run.sh +1 -0
  6. data/bin/game_machine +29 -27
  7. data/config/cluster.conf +6 -5
  8. data/config/default.conf +164 -0
  9. data/config/game_machine.sql +33 -0
  10. data/config/game_messages.proto +87 -25
  11. data/config/gamecloud.conf +140 -0
  12. data/config/messages.proto +46 -53
  13. data/config/test.conf +149 -0
  14. data/game_machine.gemspec +10 -5
  15. data/games/boot.rb +3 -0
  16. data/games/example/data/game_data.yml +4 -4
  17. data/games/example/lib/aggressive_npc.rb +1 -1
  18. data/games/example/lib/game.rb +1 -2
  19. data/games/example/lib/player_register.rb +1 -1
  20. data/games/routes.rb +9 -0
  21. data/games/tutorial/boot.rb +12 -0
  22. data/games/tutorial/item_manager.rb +256 -0
  23. data/games/tutorial/object_store.rb +55 -0
  24. data/games/tutorial/seed.rb +52 -0
  25. data/games/tutorial/sql_store.rb +30 -0
  26. data/java/project/build.gradle +134 -0
  27. data/java/project/component.erb +719 -0
  28. data/java/{gradle.properties → project/gradle.properties} +1 -1
  29. data/java/project/gradle/wrapper/gradle-wrapper.jar +0 -0
  30. data/java/{gradle → project/gradle}/wrapper/gradle-wrapper.properties +2 -2
  31. data/java/{gradlew → project/gradlew} +0 -0
  32. data/java/{gradlew.bat → project/gradlew.bat} +0 -0
  33. data/java/project/local_lib/AdminUi.jar +0 -0
  34. data/java/{local_lib/protostuff-compiler-1.0.7-jarjar.jar → project/local_lib/protostuff-compiler-1.0.8-jarjar.jar} +0 -0
  35. data/java/project/local_lib/sigar/libsigar-amd64-freebsd-6.so +0 -0
  36. data/java/project/local_lib/sigar/libsigar-amd64-linux.so +0 -0
  37. data/java/project/local_lib/sigar/libsigar-amd64-solaris.so +0 -0
  38. data/java/project/local_lib/sigar/libsigar-ia64-hpux-11.sl +0 -0
  39. data/java/project/local_lib/sigar/libsigar-ia64-linux.so +0 -0
  40. data/java/project/local_lib/sigar/libsigar-pa-hpux-11.sl +0 -0
  41. data/java/project/local_lib/sigar/libsigar-ppc-aix-5.so +0 -0
  42. data/java/project/local_lib/sigar/libsigar-ppc-linux.so +0 -0
  43. data/java/project/local_lib/sigar/libsigar-ppc64-aix-5.so +0 -0
  44. data/java/project/local_lib/sigar/libsigar-ppc64-linux.so +0 -0
  45. data/java/project/local_lib/sigar/libsigar-s390x-linux.so +0 -0
  46. data/java/project/local_lib/sigar/libsigar-sparc-solaris.so +0 -0
  47. data/java/project/local_lib/sigar/libsigar-sparc64-solaris.so +0 -0
  48. data/java/project/local_lib/sigar/libsigar-universal-macosx.dylib +0 -0
  49. data/java/project/local_lib/sigar/libsigar-universal64-macosx.dylib +0 -0
  50. data/java/project/local_lib/sigar/libsigar-x86-freebsd-5.so +0 -0
  51. data/java/project/local_lib/sigar/libsigar-x86-freebsd-6.so +0 -0
  52. data/java/project/local_lib/sigar/libsigar-x86-linux.so +0 -0
  53. data/java/project/local_lib/sigar/libsigar-x86-solaris.so +0 -0
  54. data/java/project/local_lib/sigar/sigar-amd64-winnt.dll +0 -0
  55. data/java/project/local_lib/sigar/sigar-x86-winnt.dll +0 -0
  56. data/java/project/local_lib/sigar/sigar-x86-winnt.lib +0 -0
  57. data/java/project/model.erb +99 -0
  58. data/java/{settings.gradle → project/settings.gradle} +0 -0
  59. data/java/project/src/main/java/com/game_machine/authentication/DefaultAuthenticator.java +28 -0
  60. data/java/project/src/main/java/com/game_machine/authentication/PlayerAuthenticator.java +6 -0
  61. data/java/project/src/main/java/com/game_machine/authentication/PublicAuthenticator.java +20 -0
  62. data/java/{src → project/src}/main/java/com/game_machine/core/ActorFactory.java +0 -0
  63. data/java/{src → project/src}/main/java/com/game_machine/core/ActorUtil.java +13 -0
  64. data/java/project/src/main/java/com/game_machine/core/AuthorizedPlayers.java +23 -0
  65. data/java/project/src/main/java/com/game_machine/core/ClientMessageDecoder.java +36 -0
  66. data/java/project/src/main/java/com/game_machine/core/ClientMessageEncoder.java +19 -0
  67. data/java/project/src/main/java/com/game_machine/core/CloudClient.java +298 -0
  68. data/java/{src → project/src}/main/java/com/game_machine/core/CommandProxy.java +0 -0
  69. data/java/project/src/main/java/com/game_machine/core/Commands.java +20 -0
  70. data/java/project/src/main/java/com/game_machine/core/DatastoreCommands.java +43 -0
  71. data/java/project/src/main/java/com/game_machine/core/DbConnectionPool.java +72 -0
  72. data/java/project/src/main/java/com/game_machine/core/DefaultMovementVerifier.java +56 -0
  73. data/java/{src → project/src}/main/java/com/game_machine/core/EntitySerializer.java +0 -0
  74. data/java/project/src/main/java/com/game_machine/core/EntityTracking.java +119 -0
  75. data/java/{src → project/src}/main/java/com/game_machine/core/EventStreamHandler.java +1 -1
  76. data/java/project/src/main/java/com/game_machine/core/GameActor.java +73 -0
  77. data/java/project/src/main/java/com/game_machine/core/GameMachineLoader.java +43 -0
  78. data/java/project/src/main/java/com/game_machine/core/GameMessageActor.java +44 -0
  79. data/java/project/src/main/java/com/game_machine/core/Grid.java +255 -0
  80. data/java/{src → project/src}/main/java/com/game_machine/core/GridValue.java +0 -0
  81. data/java/project/src/main/java/com/game_machine/core/Hashring.java +66 -0
  82. data/java/{src → project/src}/main/java/com/game_machine/core/IActorFactory.java +0 -0
  83. data/java/project/src/main/java/com/game_machine/core/LocalLinkedBuffer.java +20 -0
  84. data/java/project/src/main/java/com/game_machine/core/MessageGateway.java +120 -0
  85. data/java/project/src/main/java/com/game_machine/core/MessagePersister.java +26 -0
  86. data/java/project/src/main/java/com/game_machine/core/MonoProxy.java +39 -0
  87. data/java/project/src/main/java/com/game_machine/core/MovementVerifier.java +7 -0
  88. data/java/{src → project/src}/main/java/com/game_machine/core/NetMessage.java +10 -6
  89. data/java/project/src/main/java/com/game_machine/core/PersistentMessage.java +9 -0
  90. data/java/project/src/main/java/com/game_machine/core/PlayerCommands.java +31 -0
  91. data/java/project/src/main/java/com/game_machine/core/TcpServer.java +100 -0
  92. data/java/project/src/main/java/com/game_machine/core/TcpServerHandler.java +54 -0
  93. data/java/project/src/main/java/com/game_machine/core/TcpServerInitializer.java +32 -0
  94. data/java/project/src/main/java/com/game_machine/core/UdpClient.java +86 -0
  95. data/java/{src → project/src}/main/java/com/game_machine/core/UdpServer.java +18 -27
  96. data/java/{src → project/src}/main/java/com/game_machine/core/UdpServerHandler.java +23 -26
  97. data/java/project/src/main/java/com/game_machine/core/Vector3.java +159 -0
  98. data/java/project/src/main/java/com/game_machine/orm/models/PlayerItem.java +118 -0
  99. data/java/project/src/main/java/com/game_machine/orm/models/TestObject.java +110 -0
  100. data/java/project/src/main/java/com/game_machine/tutorial/LootGenerator.java +26 -0
  101. data/java/{src → project/src}/main/resources/game_machine.java.stg +3 -1
  102. data/java/project/src/main/resources/logback.properties +13 -0
  103. data/java/project/src/main/resources/logback.xml +76 -0
  104. data/java/{src → project/src}/main/resources/protostuff.properties +0 -0
  105. data/java/src/main/java/game/MyGameActor.java +26 -0
  106. data/lib/game_machine.rb +17 -16
  107. data/lib/game_machine/actor.rb +1 -1
  108. data/lib/game_machine/actor/base.rb +8 -31
  109. data/lib/game_machine/actor/builder.rb +5 -6
  110. data/lib/game_machine/actor/game_actor.rb +55 -0
  111. data/lib/game_machine/actor/reloadable.rb +6 -1
  112. data/lib/game_machine/akka.rb +26 -32
  113. data/lib/game_machine/app_config.rb +39 -26
  114. data/lib/game_machine/application.rb +56 -62
  115. data/lib/game_machine/client_manager.rb +14 -8
  116. data/lib/game_machine/cloud_updater.rb +51 -0
  117. data/lib/game_machine/cluster_monitor.rb +3 -3
  118. data/lib/game_machine/commands.rb +1 -1
  119. data/lib/game_machine/commands/misc_commands.rb +4 -8
  120. data/lib/game_machine/commands/player_commands.rb +8 -0
  121. data/lib/game_machine/console.rb +1 -0
  122. data/lib/game_machine/console/build.rb +57 -24
  123. data/lib/game_machine/console/bundle.rb +95 -0
  124. data/lib/game_machine/console/deploy.rb +30 -0
  125. data/lib/game_machine/console/install.rb +70 -36
  126. data/lib/game_machine/console/server.rb +2 -69
  127. data/lib/game_machine/data_store.rb +111 -15
  128. data/lib/game_machine/data_stores/couchbase.rb +8 -3
  129. data/lib/game_machine/data_stores/gamecloud.rb +93 -0
  130. data/lib/game_machine/data_stores/jdbc.rb +98 -0
  131. data/lib/game_machine/default_handlers.rb +2 -0
  132. data/lib/game_machine/default_handlers/team_handler.rb +51 -0
  133. data/lib/game_machine/default_handlers/zone_manager.rb +30 -0
  134. data/lib/game_machine/endpoints.rb +0 -4
  135. data/lib/game_machine/endpoints/udp_incoming.rb +13 -5
  136. data/lib/game_machine/endpoints/udp_outgoing.rb +15 -9
  137. data/lib/game_machine/game_systems.rb +0 -2
  138. data/lib/game_machine/game_systems/agents/controller.rb +2 -2
  139. data/lib/game_machine/game_systems/entity_tracking.rb +0 -3
  140. data/lib/game_machine/game_systems/region_manager.rb +3 -2
  141. data/lib/game_machine/game_systems/region_service.rb +2 -2
  142. data/lib/game_machine/game_systems/remote_echo.rb +10 -0
  143. data/lib/game_machine/game_systems/team_manager.rb +2 -11
  144. data/lib/game_machine/grid.rb +5 -18
  145. data/lib/game_machine/handlers/authentication.rb +1 -9
  146. data/lib/game_machine/handlers/game.rb +27 -2
  147. data/lib/game_machine/handlers/player_authentication.rb +87 -0
  148. data/lib/game_machine/handlers/request.rb +9 -11
  149. data/lib/game_machine/hocon_config.rb +81 -0
  150. data/lib/game_machine/java_lib.rb +14 -1
  151. data/lib/game_machine/logger.rb +10 -23
  152. data/lib/game_machine/models.rb +1 -0
  153. data/lib/game_machine/mono_server.rb +6 -1
  154. data/lib/game_machine/object_db.rb +12 -6
  155. data/lib/game_machine/protobuf.rb +1 -1
  156. data/lib/game_machine/protobuf/game_messages.rb +13 -3
  157. data/lib/game_machine/protobuf/generate.rb +107 -5
  158. data/lib/game_machine/restart_watcher.rb +1 -1
  159. data/lib/game_machine/routes.rb +23 -0
  160. data/lib/game_machine/scheduler.rb +1 -1
  161. data/lib/game_machine/securerandom.rb +2 -0
  162. data/lib/game_machine/system_stats.rb +28 -7
  163. data/lib/game_machine/version.rb +1 -1
  164. data/lib/game_machine/wavefront_ext.rb +47 -0
  165. data/lib/game_machine/write_behind_cache.rb +24 -9
  166. data/mono/server/Makefile +1 -1
  167. data/mono/server/Newtonsoft.Json.dll +0 -0
  168. data/mono/server/build.bat +1 -1
  169. data/mono/server/callable.cs +9 -0
  170. data/mono/server/echo.cs +17 -0
  171. data/mono/server/message_router.cs +16 -23
  172. data/mono/server/messages.cs +1792 -417
  173. data/mono/server/protobuf-net.dll +0 -0
  174. data/mono/server/server.cs +120 -0
  175. data/mono/server/server.exe +0 -0
  176. data/pathfinding/astar.cpp +149 -0
  177. data/pathfinding/build.sh +6 -0
  178. data/pathfinding/build.txt +16 -0
  179. data/pathfinding/crowd.cpp +194 -0
  180. data/pathfinding/include/astar.h +49 -0
  181. data/pathfinding/include/common.h +5 -0
  182. data/pathfinding/include/crowd.h +43 -0
  183. data/pathfinding/include/micropather.h +511 -0
  184. data/pathfinding/include/navmesh.h +114 -0
  185. data/pathfinding/include/pathfinder.h +24 -0
  186. data/pathfinding/main.cpp +108 -17
  187. data/pathfinding/micropather.cpp +1062 -0
  188. data/pathfinding/navmesh.cpp +408 -0
  189. data/pathfinding/overrides/DetourCrowd.cpp +1446 -0
  190. data/pathfinding/overrides/DetourNavMeshQuery.cpp +3551 -0
  191. data/pathfinding/overrides/DetourNavMeshQuery.h +538 -0
  192. data/pathfinding/pathfinder.cpp +117 -0
  193. data/pathfinding/{bin → premake}/premake4 +0 -0
  194. data/pathfinding/premake/premake4.exe +0 -0
  195. data/pathfinding/premake4.lua +12 -3
  196. data/spec/actor/actor_spec.rb +0 -7
  197. data/spec/client_manager_spec.rb +1 -1
  198. data/spec/couchproxy_spec.rb +38 -0
  199. data/spec/entity_persistence_spec.rb +129 -0
  200. data/spec/game_systems/team_manager_spec.rb +2 -2
  201. data/spec/hashring_spec.rb +17 -39
  202. data/spec/java_grid_spec.rb +0 -2
  203. data/spec/misc_spec.rb +111 -0
  204. data/spec/mono_spec.rb +50 -3
  205. data/spec/reliable_message_spec.rb +38 -0
  206. data/spec/spec_helper.rb +4 -4
  207. data/spec/spec_helper_minimal.rb +10 -0
  208. data/web/app.rb +108 -86
  209. data/web/config/trinidad.yml +1 -0
  210. data/web/views/add_player.erb +25 -0
  211. data/web/views/index.erb +0 -0
  212. data/web/views/layout.erb +48 -0
  213. data/web/views/login.erb +25 -0
  214. data/web/views/players.erb +24 -0
  215. metadata +209 -94
  216. data/config/config.example.yml +0 -100
  217. data/config/regions.example.yml +0 -9
  218. data/games/example/lib/authentication_handler.rb +0 -69
  219. data/games/models.rb +0 -3
  220. data/games/models/clan_member.rb +0 -8
  221. data/games/models/clan_profile.rb +0 -9
  222. data/games/models/player.rb +0 -7
  223. data/games/plugins.rb +0 -1
  224. data/games/plugins/team_handler.rb +0 -49
  225. data/games/preload.rb +0 -13
  226. data/java/.gitignore +0 -1
  227. data/java/build.gradle +0 -95
  228. data/java/component.erb +0 -396
  229. data/java/gradle/wrapper/gradle-wrapper.jar +0 -0
  230. data/java/src/main/java/com/game_machine/core/GameMachineLoader.java +0 -25
  231. data/java/src/main/java/com/game_machine/core/Grid.java +0 -195
  232. data/java/src/main/resources/logback.xml +0 -14
  233. data/java/src/main/resources/logging.properties +0 -3
  234. data/lib/game_machine/actor/mono_actor.rb +0 -89
  235. data/lib/game_machine/auth_handlers/base.rb +0 -21
  236. data/lib/game_machine/auth_handlers/public.rb +0 -34
  237. data/lib/game_machine/endpoints/mono_gateway.rb +0 -87
  238. data/lib/game_machine/endpoints/tcp.rb +0 -51
  239. data/lib/game_machine/endpoints/tcp_handler.rb +0 -75
  240. data/lib/game_machine/endpoints/udp.rb +0 -88
  241. data/lib/game_machine/game_loader.rb +0 -46
  242. data/lib/game_machine/game_systems/region_settings.rb +0 -13
  243. data/lib/game_machine/hashring.rb +0 -48
  244. data/lib/game_machine/settings.rb +0 -11
  245. data/mono/server/actor.cs +0 -37
  246. data/mono/server/iactor.cs +0 -11
  247. data/mono/server/message_util.cs +0 -29
  248. data/mono/server/proxy_client.cs +0 -73
  249. data/mono/server/proxy_server.cs +0 -30
  250. data/mono/server/test_actor.cs +0 -33
  251. data/pathfinding/include/pathfind.h +0 -167
  252. data/pathfinding/pathfind.cpp +0 -174
  253. data/pathfinding/pathfinder.cs +0 -66
  254. data/script/server.sh +0 -109
  255. data/script/watch.sh +0 -11
  256. data/spec/commands/navigation_commands_spec.rb +0 -51
  257. data/spec/game_systems/entity_tracking_spec.rb +0 -64
  258. data/spec/navigation/detour_navmesh_spec.rb +0 -34
  259. data/spec/navigation/detour_path_spec.rb +0 -25
  260. data/spec/udp_server_spec.rb +0 -10
  261. data/web/controllers/auth_controller.rb +0 -19
  262. data/web/controllers/base_controller.rb +0 -16
  263. data/web/controllers/index_controller.rb +0 -7
  264. data/web/controllers/log_controller.rb +0 -47
  265. data/web/controllers/messages_controller.rb +0 -59
  266. data/web/controllers/player_register_controller.rb +0 -15
  267. data/web/views/game_messages.haml +0 -45
  268. data/web/views/index.haml +0 -6
  269. data/web/views/layout.haml +0 -41
  270. data/web/views/logs.haml +0 -32
  271. data/web/views/player_register.haml +0 -22
  272. data/web/views/player_registered.haml +0 -2
  273. data/web/views/register_layout.haml +0 -22
  274. data/web/views/restart.haml +0 -35
@@ -0,0 +1,26 @@
1
+ package com.game_machine.core;
2
+
3
+ import akka.actor.UntypedActor;
4
+ import akka.event.Logging;
5
+ import akka.event.LoggingAdapter;
6
+
7
+
8
+ public class MessagePersister extends UntypedActor {
9
+
10
+ public static String name = "message_persister";
11
+ LoggingAdapter log = Logging.getLogger(getContext().system(), this);
12
+
13
+ @Override
14
+ public void onReceive(Object message) throws Exception {
15
+
16
+ if (message instanceof PersistentMessage) {
17
+ PersistentMessage persistentMessage = (PersistentMessage)message;
18
+ String action = persistentMessage.getPersistAction();
19
+ if (action.equals("save")) {
20
+ persistentMessage.dbSave(persistentMessage.getPersistPlayerId());
21
+ } else if (action.equals("delete")) {
22
+ persistentMessage.dbDelete(persistentMessage.getPersistPlayerId());
23
+ }
24
+ }
25
+ }
26
+ }
@@ -0,0 +1,39 @@
1
+ package com.game_machine.core;
2
+
3
+ import GameMachine.Messages.Entity;
4
+ import GameMachine.Messages.MonoMessage;
5
+
6
+ public class MonoProxy {
7
+
8
+ private static class LazyHolder {
9
+ private static final MonoProxy INSTANCE = new MonoProxy();
10
+ }
11
+
12
+ public static MonoProxy getInstance() {
13
+ return LazyHolder.INSTANCE;
14
+ }
15
+
16
+ private MonoProxy() {
17
+ udpClient = new UdpClient(24320,1);
18
+ if (!udpClient.connect()) {
19
+ throw new RuntimeException("Unable to connect to mono");
20
+ }
21
+ }
22
+
23
+ private UdpClient udpClient;
24
+
25
+
26
+ public Entity call(String klass, Entity entity) {
27
+ MonoMessage message = new MonoMessage();
28
+ message.setKlass(klass);
29
+ message.setEntity(entity);
30
+ byte[] bytes = udpClient.send(message.toByteArray());
31
+ if (bytes == null) {
32
+ return null;
33
+ } else {
34
+ message = MonoMessage.parseFrom(bytes);
35
+ return message.entity;
36
+ }
37
+ }
38
+
39
+ }
@@ -0,0 +1,7 @@
1
+ package com.game_machine.core;
2
+
3
+ import GameMachine.Messages.TrackData;
4
+
5
+ public interface MovementVerifier {
6
+ boolean verify(TrackData trackData);
7
+ }
@@ -1,5 +1,9 @@
1
1
  package com.game_machine.core;
2
2
 
3
+ import java.net.InetSocketAddress;
4
+
5
+ import GameMachine.Messages.ClientMessage;
6
+ import io.netty.buffer.ByteBuf;
3
7
  import io.netty.channel.ChannelHandlerContext;
4
8
 
5
9
  public class NetMessage {
@@ -9,20 +13,20 @@ public class NetMessage {
9
13
  public static final int UDT = 1;
10
14
  public static final int TCP = 2;
11
15
 
12
- public final byte[] bytes;
16
+ public byte[] bytes;
17
+ public ByteBuf buf;
18
+ public ClientMessage clientMessage;
13
19
  public final String host;
14
20
  public final int port;
15
21
  public final int protocol;
16
- public final String clientId;
17
22
  public final ChannelHandlerContext ctx;
23
+ public InetSocketAddress address;
18
24
 
19
- public NetMessage(String clientId, int protocol, byte[] bytes, String host, int port, ChannelHandlerContext ctx) {
20
- this.clientId = clientId;
21
- this.bytes = bytes;
25
+ public NetMessage(int protocol, String host, int port, ChannelHandlerContext ctx) {
22
26
  this.host = host;
23
27
  this.port = port;
24
28
  this.protocol = protocol;
25
29
  this.ctx = ctx;
26
30
  }
27
-
31
+
28
32
  }
@@ -0,0 +1,9 @@
1
+ package com.game_machine.core;
2
+
3
+ public interface PersistentMessage {
4
+ void dbSaveAsync(String playerId);
5
+ Boolean dbSave(String playerId);
6
+ Boolean dbDelete(String playerId);
7
+ String getPersistPlayerId();
8
+ String getPersistAction();
9
+ }
@@ -0,0 +1,31 @@
1
+ package com.game_machine.core;
2
+
3
+ import akka.actor.ActorSelection;
4
+ import GameMachine.Messages.Entity;
5
+ import GameMachine.Messages.GameMessage;
6
+ import GameMachine.Messages.GameMessages;
7
+ import GameMachine.Messages.Player;
8
+
9
+ public class PlayerCommands {
10
+
11
+ public static void sendGameMessage(GameMessage gameMessage, String playerId) {
12
+ GameMessages gameMessages = new GameMessages();
13
+ gameMessages.addGameMessage(gameMessage);
14
+ Entity entity = new Entity();
15
+ entity.setId("0");
16
+ entity.setGameMessages(gameMessages);
17
+ PlayerCommands.sendToPlayer(entity, playerId);
18
+ }
19
+
20
+ public static void sendToPlayer(Entity entity, String playerId) {
21
+ if (!entity.hasPlayer()) {
22
+ Player player = new Player();
23
+ player.setId(playerId);
24
+ entity.setPlayer(player);
25
+ }
26
+ entity.setSendToPlayer(true);
27
+
28
+ ActorSelection sel = ActorUtil.getSelectionByName("GameMachine::ClientManager");
29
+ sel.tell(entity, null);
30
+ }
31
+ }
@@ -0,0 +1,100 @@
1
+ package com.game_machine.core;
2
+ import java.net.InetSocketAddress;
3
+ import java.security.cert.CertificateException;
4
+
5
+ import javax.net.ssl.SSLException;
6
+
7
+ import org.slf4j.Logger;
8
+ import org.slf4j.LoggerFactory;
9
+
10
+ import io.netty.bootstrap.ServerBootstrap;
11
+ import io.netty.channel.ChannelOption;
12
+ import io.netty.channel.EventLoopGroup;
13
+ import io.netty.channel.nio.NioEventLoopGroup;
14
+ import io.netty.channel.socket.nio.NioServerSocketChannel;
15
+ import io.netty.handler.logging.LogLevel;
16
+ import io.netty.handler.logging.LoggingHandler;
17
+ import io.netty.handler.ssl.SslContext;
18
+ import io.netty.handler.ssl.util.SelfSignedCertificate;
19
+
20
+ public class TcpServer implements Runnable {
21
+ static final boolean SSL = System.getProperty("nossl") != null;
22
+ static final int PORT = Integer.parseInt(System.getProperty("port", "8463"));
23
+
24
+ private static final Logger log = LoggerFactory.getLogger(UdpServer.class);
25
+ private static Thread serverThread;
26
+
27
+ private static TcpServer tcpServer;
28
+
29
+ private final String hostname;
30
+ private final int port;
31
+
32
+ public static TcpServer getTcpServer() {
33
+ return tcpServer;
34
+ }
35
+
36
+ public static void start(String host, Integer port) {
37
+
38
+ // Don't try to start an already running server
39
+ if (tcpServer != null) {
40
+ return;
41
+ }
42
+
43
+ tcpServer = new TcpServer(host, port);
44
+ serverThread = new Thread(tcpServer);
45
+ serverThread.start();
46
+ }
47
+
48
+ public static void stop() {
49
+ log.info("Stopping TCP server");
50
+ // Don't try to stop a server that's not running
51
+ if (tcpServer == null) {
52
+ return;
53
+ }
54
+
55
+ }
56
+
57
+ public TcpServer(final String hostname, final int port) {
58
+ this.port = port;
59
+ this.hostname = hostname;
60
+ }
61
+
62
+ @Override
63
+ public void run() {
64
+ // Configure SSL.
65
+ final SslContext sslCtx;
66
+ if (SSL) {
67
+ SelfSignedCertificate ssc;
68
+ try {
69
+ ssc = new SelfSignedCertificate();
70
+ sslCtx = SslContext.newServerContext(ssc.certificate(), ssc.privateKey());
71
+ } catch (CertificateException | SSLException e) {
72
+ e.printStackTrace();
73
+ return;
74
+ }
75
+ } else {
76
+ sslCtx = null;
77
+ }
78
+
79
+ EventLoopGroup bossGroup = new NioEventLoopGroup(1);
80
+ EventLoopGroup workerGroup = new NioEventLoopGroup();
81
+ try {
82
+ ServerBootstrap b = new ServerBootstrap();
83
+ b.group(bossGroup, workerGroup)
84
+ .channel(NioServerSocketChannel.class)
85
+ .childOption(ChannelOption.TCP_NODELAY, true)
86
+ .childOption(ChannelOption.SO_REUSEADDR, true)
87
+ .handler(new LoggingHandler(LogLevel.INFO))
88
+ .childHandler(new TcpServerInitializer(sslCtx));
89
+
90
+ InetSocketAddress address = new InetSocketAddress(hostname,port);
91
+ b.bind(address).sync().channel().closeFuture().sync();
92
+ } catch (InterruptedException e) {
93
+ e.printStackTrace();
94
+ } finally {
95
+ bossGroup.shutdownGracefully();
96
+ workerGroup.shutdownGracefully();
97
+ }
98
+ }
99
+
100
+ }
@@ -0,0 +1,54 @@
1
+ package com.game_machine.core;
2
+ import java.net.InetSocketAddress;
3
+
4
+ import org.slf4j.Logger;
5
+ import org.slf4j.LoggerFactory;
6
+
7
+ import GameMachine.Messages.ClientMessage;
8
+ import akka.actor.ActorSelection;
9
+ import io.netty.channel.ChannelHandlerContext;
10
+ import io.netty.channel.SimpleChannelInboundHandler;
11
+
12
+ public class TcpServerHandler extends SimpleChannelInboundHandler<ClientMessage> {
13
+
14
+ private ActorSelection inbound;
15
+
16
+ private static final Logger log = LoggerFactory
17
+ .getLogger(TcpServerHandler.class);
18
+
19
+ public TcpServerHandler() {
20
+ this.inbound = ActorUtil
21
+ .getSelectionByName("message_gateway");
22
+ }
23
+
24
+ public static void sendClientMessage(ClientMessage clientMessage,ChannelHandlerContext ctx) {
25
+ ctx.write(clientMessage);
26
+ ctx.flush();
27
+ }
28
+
29
+ @Override
30
+ public void channelRead0(ChannelHandlerContext ctx, ClientMessage clientMessage) throws Exception {
31
+ InetSocketAddress address = (InetSocketAddress)ctx.channel().remoteAddress();
32
+
33
+ NetMessage netMessage = new NetMessage(NetMessage.TCP, address.getHostString(), address.getPort(), ctx);
34
+ netMessage.clientMessage = clientMessage;
35
+ this.inbound.tell(netMessage, null);
36
+ }
37
+
38
+ @Override
39
+ public void channelActive(final ChannelHandlerContext ctx) {
40
+ log.info("Tcp server active");
41
+ }
42
+
43
+ @Override
44
+ public void channelReadComplete(ChannelHandlerContext ctx) {
45
+ ctx.flush();
46
+ }
47
+
48
+ @Override
49
+ public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) {
50
+ //cause.printStackTrace();
51
+ ctx.close();
52
+ }
53
+
54
+ }
@@ -0,0 +1,32 @@
1
+ package com.game_machine.core;
2
+ import io.netty.channel.ChannelInitializer;
3
+ import io.netty.channel.ChannelPipeline;
4
+ import io.netty.channel.socket.SocketChannel;
5
+ import io.netty.handler.codec.protobuf.ProtobufEncoder;
6
+ import io.netty.handler.codec.protobuf.ProtobufVarint32FrameDecoder;
7
+ import io.netty.handler.codec.protobuf.ProtobufVarint32LengthFieldPrepender;
8
+ import io.netty.handler.ssl.SslContext;
9
+
10
+ public class TcpServerInitializer extends ChannelInitializer<SocketChannel> {
11
+ private final SslContext sslCtx;
12
+
13
+ public TcpServerInitializer(SslContext sslCtx) {
14
+ this.sslCtx = sslCtx;
15
+ }
16
+
17
+ @Override
18
+ public void initChannel(SocketChannel ch) throws Exception {
19
+ ChannelPipeline p = ch.pipeline();
20
+ if (sslCtx != null) {
21
+ p.addLast(sslCtx.newHandler(ch.alloc()));
22
+ }
23
+
24
+ p.addLast(new ProtobufVarint32FrameDecoder());
25
+ p.addLast(new ClientMessageDecoder());
26
+
27
+ //p.addLast(new ProtobufVarint32LengthFieldPrepender());
28
+ p.addLast(new ClientMessageEncoder());
29
+
30
+ p.addLast(new TcpServerHandler());
31
+ }
32
+ }
@@ -0,0 +1,86 @@
1
+ package com.game_machine.core;
2
+
3
+ import java.io.IOException;
4
+ import java.net.DatagramPacket;
5
+ import java.net.DatagramSocket;
6
+ import java.net.InetAddress;
7
+ import java.net.SocketException;
8
+ import java.net.SocketTimeoutException;
9
+ import java.util.Arrays;
10
+
11
+ import org.slf4j.Logger;
12
+ import org.slf4j.LoggerFactory;
13
+
14
+ public class UdpClient {
15
+
16
+ private static final Logger log = LoggerFactory.getLogger(UdpClient.class);
17
+ private int port;
18
+ private InetAddress hostAddress;
19
+ private DatagramSocket s;
20
+ private DatagramPacket dp;
21
+ private int timeout;
22
+
23
+ public UdpClient(int port, int timeout) {
24
+ this.port = port;
25
+ this.timeout = timeout;
26
+
27
+ hostAddress = InetAddress.getLoopbackAddress();
28
+ byte[] in = new byte[2048];
29
+ dp = new DatagramPacket(in, in.length);
30
+ }
31
+
32
+ public Boolean connect() {
33
+
34
+ try {
35
+ s = new DatagramSocket();
36
+ s.setSoTimeout(timeout);
37
+ return true;
38
+ } catch (SocketException e) {
39
+ e.printStackTrace();
40
+ return false;
41
+ }
42
+ }
43
+
44
+ public byte[] send(byte[] bytes) {
45
+ try {
46
+
47
+ int retryCount = 0;
48
+ int retryLimit = 3;
49
+
50
+ DatagramPacket out = new DatagramPacket(bytes, bytes.length,
51
+ hostAddress, port);
52
+
53
+
54
+ while (true) {
55
+ s.send(out);
56
+
57
+ try {
58
+ s.receive(dp);
59
+ byte[] received = Arrays.copyOfRange(dp.getData(),
60
+ dp.getOffset(), dp.getOffset() + dp.getLength());
61
+ return received;
62
+ } catch (SocketTimeoutException e) {
63
+ try {
64
+ Thread.sleep(retryCount + 1, 0);
65
+ } catch (InterruptedException e1) {
66
+ e1.printStackTrace();
67
+ }
68
+ if (retryCount > retryLimit) {
69
+ log.warn("Timeout retry limit exceeded " + e + " "
70
+ + retryCount);
71
+ return null;
72
+ }
73
+ retryCount++;
74
+ }
75
+ }
76
+
77
+ } catch (SocketException e1) {
78
+ log.warn("Socket closed " + e1);
79
+ return null;
80
+
81
+ } catch (IOException e) {
82
+ e.printStackTrace();
83
+ return null;
84
+ }
85
+ }
86
+ }
@@ -1,23 +1,16 @@
1
1
  package com.game_machine.core;
2
2
 
3
- import org.slf4j.Logger;
4
- import org.slf4j.LoggerFactory;
5
-
6
3
  import io.netty.bootstrap.Bootstrap;
7
- import io.netty.channel.ChannelFuture;
8
4
  import io.netty.channel.ChannelHandlerContext;
9
- import io.netty.channel.ChannelInitializer;
10
5
  import io.netty.channel.ChannelOption;
11
- import io.netty.channel.ChannelPipeline;
12
6
  import io.netty.channel.EventLoopGroup;
13
- import io.netty.channel.group.ChannelGroup;
14
- import io.netty.channel.group.ChannelGroupFuture;
15
- import io.netty.channel.group.DefaultChannelGroup;
16
7
  import io.netty.channel.nio.NioEventLoopGroup;
17
8
  import io.netty.channel.socket.nio.NioDatagramChannel;
18
- import io.netty.util.concurrent.DefaultEventExecutorGroup;
19
9
 
20
- import com.game_machine.core.NetMessage;
10
+ import java.net.InetSocketAddress;
11
+
12
+ import org.slf4j.Logger;
13
+ import org.slf4j.LoggerFactory;
21
14
 
22
15
  public final class UdpServer implements Runnable {
23
16
 
@@ -31,7 +24,6 @@ public final class UdpServer implements Runnable {
31
24
 
32
25
  private final UdpServerHandler handler;
33
26
 
34
-
35
27
  public static UdpServer getUdpServer() {
36
28
  return udpServer;
37
29
  }
@@ -68,30 +60,29 @@ public final class UdpServer implements Runnable {
68
60
  }
69
61
 
70
62
  public void run() {
71
- log.info("Starting UdpServer port=" + this.port + " hostname=" + this.hostname);
63
+ log.info("Starting UdpServer port=" + this.port + " hostname="
64
+ + this.hostname);
72
65
  Thread.currentThread().setName("udp-server");
73
66
  EventLoopGroup group = new NioEventLoopGroup();
74
67
  try {
75
- Bootstrap boot = new Bootstrap();
76
- boot.channel(NioDatagramChannel.class);
77
- boot.group(group);
78
- boot.option(ChannelOption.SO_BROADCAST, false);
79
- boot.handler(new UdpServerHandler());
80
-
81
- boot.bind(this.port).sync().channel().closeFuture().await();
82
-
68
+ Bootstrap boot = new Bootstrap();
69
+ boot.channel(NioDatagramChannel.class);
70
+ boot.group(group);
71
+ boot.option(ChannelOption.SO_BROADCAST, false);
72
+ boot.handler(new UdpServerHandler());
73
+
74
+ InetSocketAddress address = new InetSocketAddress(hostname,port);
75
+ boot.bind(address).sync().channel().closeFuture().await();
76
+
83
77
  } catch (InterruptedException e) {
84
- // TODO Auto-generated catch block
85
78
  e.printStackTrace();
86
79
  } finally {
87
- group.shutdownGracefully();
80
+ group.shutdownGracefully();
88
81
  }
89
82
  }
90
83
 
91
- public void sendToClient(byte[] bytes, String host, int port, ChannelHandlerContext ctx) {
92
- handler.send(bytes, host, port, ctx);
84
+ public void sendToClient(InetSocketAddress address, byte[] bytes, ChannelHandlerContext ctx) {
85
+ handler.send(address, bytes, ctx);
93
86
  }
94
87
 
95
-
96
-
97
88
  }