mirror of
https://github.com/jie65535/gc-opencommand-plugin.git
synced 2025-12-08 18:41:34 +08:00
Fixed player instance concurrency issue
This commit is contained in:
@@ -109,10 +109,17 @@ public final class OpenCommandHandler implements Router {
|
|||||||
} else {
|
} else {
|
||||||
if (req.action.equals("command")) {
|
if (req.action.equals("command")) {
|
||||||
// update token expire time
|
// update token expire time
|
||||||
tokenExpireTime.put(req.token, new Date(now.getTime() + 24 * 60 * 60 * 1000));
|
tokenExpireTime.put(req.token, new Date(now.getTime() + 4 * 60 * 60 * 1000));
|
||||||
var playerId = clients.get(req.token);
|
var playerId = clients.get(req.token);
|
||||||
var player = Grasscutter.getGameServer().getPlayerByUid(playerId);
|
var player = Grasscutter.getGameServer().getPlayerByUid(playerId);
|
||||||
var command = req.data.toString();
|
var command = req.data.toString();
|
||||||
|
if (player == null) {
|
||||||
|
response.json(new JsonResponse(404, "Player not found"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// Player MessageHandler do not support concurrency
|
||||||
|
//noinspection SynchronizationOnLocalVariableOrMethodParameter
|
||||||
|
synchronized (player) {
|
||||||
try {
|
try {
|
||||||
var resultCollector = new MessageHandler();
|
var resultCollector = new MessageHandler();
|
||||||
player.setMessageHandler(resultCollector);
|
player.setMessageHandler(resultCollector);
|
||||||
@@ -123,6 +130,7 @@ public final class OpenCommandHandler implements Router {
|
|||||||
} finally {
|
} finally {
|
||||||
player.setMessageHandler(null);
|
player.setMessageHandler(null);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user