2022-04-29 05:19:14 +00:00
|
|
|
package emu.grasscutter.scripts;
|
|
|
|
|
|
|
|
import emu.grasscutter.game.dungeons.DungeonChallenge;
|
|
|
|
import emu.grasscutter.game.entity.EntityGadget;
|
|
|
|
import emu.grasscutter.game.entity.EntityMonster;
|
|
|
|
import emu.grasscutter.game.entity.GameEntity;
|
|
|
|
import emu.grasscutter.scripts.data.SceneGroup;
|
2022-04-30 08:08:38 +00:00
|
|
|
import emu.grasscutter.scripts.data.SceneRegion;
|
2022-05-07 13:47:13 +00:00
|
|
|
import emu.grasscutter.server.packet.send.PacketCanUseSkillNotify;
|
2022-04-29 05:19:14 +00:00
|
|
|
import emu.grasscutter.server.packet.send.PacketGadgetStateNotify;
|
|
|
|
import emu.grasscutter.server.packet.send.PacketWorktopOptionNotify;
|
2022-05-07 13:47:13 +00:00
|
|
|
import org.luaj.vm2.LuaTable;
|
|
|
|
import org.luaj.vm2.LuaValue;
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
|
|
|
|
import java.util.List;
|
|
|
|
import java.util.Optional;
|
2022-04-29 05:19:14 +00:00
|
|
|
|
|
|
|
public class ScriptLib {
|
2022-05-07 13:47:13 +00:00
|
|
|
public static final Logger logger = LoggerFactory.getLogger(ScriptLib.class);
|
2022-04-29 05:19:14 +00:00
|
|
|
private final SceneScriptManager sceneScriptManager;
|
|
|
|
|
|
|
|
public ScriptLib(SceneScriptManager sceneScriptManager) {
|
|
|
|
this.sceneScriptManager = sceneScriptManager;
|
|
|
|
}
|
|
|
|
|
|
|
|
public SceneScriptManager getSceneScriptManager() {
|
|
|
|
return sceneScriptManager;
|
|
|
|
}
|
2022-05-09 07:39:49 +00:00
|
|
|
|
|
|
|
private String printTable(LuaTable table){
|
|
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.append("{");
|
|
|
|
for(var meta : table.keys()){
|
|
|
|
sb.append(meta).append(":").append(table.get(meta)).append(",");
|
|
|
|
}
|
|
|
|
sb.append("}");
|
|
|
|
return sb.toString();
|
|
|
|
}
|
|
|
|
|
2022-04-29 05:19:14 +00:00
|
|
|
public int SetGadgetStateByConfigId(int configId, int gadgetState) {
|
2022-05-07 13:47:13 +00:00
|
|
|
logger.debug("[LUA] Call SetGadgetStateByConfigId with {},{}",
|
|
|
|
configId,gadgetState);
|
2022-04-29 05:19:14 +00:00
|
|
|
Optional<GameEntity> entity = getSceneScriptManager().getScene().getEntities().values().stream()
|
|
|
|
.filter(e -> e.getConfigId() == configId).findFirst();
|
|
|
|
|
|
|
|
if (entity.isEmpty()) {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!(entity.get() instanceof EntityGadget)) {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
EntityGadget gadget = (EntityGadget) entity.get();
|
|
|
|
gadget.setState(gadgetState);
|
|
|
|
|
|
|
|
getSceneScriptManager().getScene().broadcastPacket(new PacketGadgetStateNotify(gadget, gadgetState));
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
public int SetGroupGadgetStateByConfigId(int groupId, int configId, int gadgetState) {
|
2022-05-07 13:47:13 +00:00
|
|
|
logger.debug("[LUA] Call SetGroupGadgetStateByConfigId with {},{},{}",
|
|
|
|
groupId,configId,gadgetState);
|
2022-04-29 05:19:14 +00:00
|
|
|
List<GameEntity> list = getSceneScriptManager().getScene().getEntities().values().stream()
|
|
|
|
.filter(e -> e.getGroupId() == groupId).toList();
|
|
|
|
|
|
|
|
for (GameEntity entity : list) {
|
2022-04-29 07:52:40 +00:00
|
|
|
if (!(entity instanceof EntityGadget)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2022-04-29 05:19:14 +00:00
|
|
|
EntityGadget gadget = (EntityGadget) entity;
|
|
|
|
gadget.setState(gadgetState);
|
|
|
|
|
|
|
|
getSceneScriptManager().getScene().broadcastPacket(new PacketGadgetStateNotify(gadget, gadgetState));
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
public int SetWorktopOptionsByGroupId(int groupId, int configId, int[] options) {
|
2022-05-07 13:47:13 +00:00
|
|
|
logger.debug("[LUA] Call SetWorktopOptionsByGroupId with {},{},{}",
|
|
|
|
groupId,configId,options);
|
2022-04-29 05:19:14 +00:00
|
|
|
Optional<GameEntity> entity = getSceneScriptManager().getScene().getEntities().values().stream()
|
|
|
|
.filter(e -> e.getConfigId() == configId && e.getGroupId() == groupId).findFirst();
|
|
|
|
|
|
|
|
if (entity.isEmpty()) {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!(entity.get() instanceof EntityGadget)) {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
EntityGadget gadget = (EntityGadget) entity.get();
|
|
|
|
gadget.addWorktopOptions(options);
|
|
|
|
|
|
|
|
getSceneScriptManager().getScene().broadcastPacket(new PacketWorktopOptionNotify(gadget));
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
public int DelWorktopOptionByGroupId(int groupId, int configId, int option) {
|
2022-05-07 13:47:13 +00:00
|
|
|
logger.debug("[LUA] Call DelWorktopOptionByGroupId with {},{},{}",groupId,configId,option);
|
|
|
|
|
2022-04-29 05:19:14 +00:00
|
|
|
Optional<GameEntity> entity = getSceneScriptManager().getScene().getEntities().values().stream()
|
|
|
|
.filter(e -> e.getConfigId() == configId && e.getGroupId() == groupId).findFirst();
|
|
|
|
|
|
|
|
if (entity.isEmpty()) {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!(entity.get() instanceof EntityGadget)) {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
EntityGadget gadget = (EntityGadget) entity.get();
|
|
|
|
gadget.removeWorktopOption(option);
|
|
|
|
|
|
|
|
getSceneScriptManager().getScene().broadcastPacket(new PacketWorktopOptionNotify(gadget));
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Some fields are guessed
|
2022-05-07 13:47:13 +00:00
|
|
|
public int AutoMonsterTide(int challengeIndex, int groupId, Integer[] ordersConfigId, int tideCount, int sceneLimit, int param6) {
|
|
|
|
logger.debug("[LUA] Call AutoMonsterTide with {},{},{},{},{},{}",
|
|
|
|
challengeIndex,groupId,ordersConfigId,tideCount,sceneLimit,param6);
|
|
|
|
|
2022-04-29 05:19:14 +00:00
|
|
|
SceneGroup group = getSceneScriptManager().getGroupById(groupId);
|
2022-05-08 09:11:02 +00:00
|
|
|
|
2022-04-29 05:19:14 +00:00
|
|
|
if (group == null || group.monsters == null) {
|
|
|
|
return 1;
|
|
|
|
}
|
2022-05-07 13:47:13 +00:00
|
|
|
|
2022-05-09 07:39:49 +00:00
|
|
|
this.getSceneScriptManager().startMonsterTideInGroup(group, ordersConfigId, tideCount, sceneLimit);
|
2022-04-29 05:19:14 +00:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2022-04-29 09:38:25 +00:00
|
|
|
public int AddExtraGroupSuite(int groupId, int suite) {
|
2022-05-07 13:47:13 +00:00
|
|
|
logger.debug("[LUA] Call AddExtraGroupSuite with {},{}",
|
|
|
|
groupId,suite);
|
2022-04-29 07:52:40 +00:00
|
|
|
SceneGroup group = getSceneScriptManager().getGroupById(groupId);
|
|
|
|
|
|
|
|
if (group == null || group.monsters == null) {
|
|
|
|
return 1;
|
|
|
|
}
|
2022-05-08 09:11:02 +00:00
|
|
|
|
2022-05-09 16:05:01 +00:00
|
|
|
// avoid spawn wrong monster
|
|
|
|
if(getSceneScriptManager().getScene().getChallenge() != null)
|
|
|
|
if(!getSceneScriptManager().getScene().getChallenge().inProgress() ||
|
|
|
|
getSceneScriptManager().getScene().getChallenge().getGroup().id != groupId){
|
|
|
|
return 0;
|
|
|
|
}
|
2022-04-29 10:06:33 +00:00
|
|
|
this.getSceneScriptManager().spawnMonstersInGroup(group, suite);
|
2022-04-29 07:52:40 +00:00
|
|
|
|
2022-04-29 07:49:05 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2022-04-29 07:52:40 +00:00
|
|
|
// param3 (probably time limit for timed dungeons)
|
2022-05-07 13:47:13 +00:00
|
|
|
public int ActiveChallenge(int challengeId, int challengeIndex, int timeLimitOrGroupId, int groupId, int objectiveKills, int param5) {
|
|
|
|
logger.debug("[LUA] Call ActiveChallenge with {},{},{},{},{},{}",
|
|
|
|
challengeId,challengeIndex,timeLimitOrGroupId,groupId,objectiveKills,param5);
|
|
|
|
|
2022-04-29 05:19:14 +00:00
|
|
|
SceneGroup group = getSceneScriptManager().getGroupById(groupId);
|
2022-05-07 13:47:13 +00:00
|
|
|
var objective = objectiveKills;
|
|
|
|
|
|
|
|
if(group == null){
|
|
|
|
group = getSceneScriptManager().getGroupById(timeLimitOrGroupId);
|
|
|
|
objective = groupId;
|
|
|
|
}
|
2022-04-29 05:19:14 +00:00
|
|
|
|
|
|
|
if (group == null || group.monsters == null) {
|
|
|
|
return 1;
|
|
|
|
}
|
2022-05-08 09:11:02 +00:00
|
|
|
|
|
|
|
if(getSceneScriptManager().getScene().getChallenge() != null &&
|
|
|
|
getSceneScriptManager().getScene().getChallenge().inProgress())
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2022-05-09 16:05:01 +00:00
|
|
|
DungeonChallenge challenge = new DungeonChallenge(getSceneScriptManager().getScene(),
|
|
|
|
group, challengeId, challengeIndex, objective);
|
|
|
|
// set if tower first stage (6-1)
|
|
|
|
challenge.setStage(getSceneScriptManager().getVariables().getOrDefault("stage", -1) == 0);
|
|
|
|
|
2022-04-29 05:19:14 +00:00
|
|
|
getSceneScriptManager().getScene().setChallenge(challenge);
|
2022-05-09 16:05:01 +00:00
|
|
|
|
2022-04-29 05:19:14 +00:00
|
|
|
challenge.start();
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2022-04-29 09:38:25 +00:00
|
|
|
public int GetGroupMonsterCountByGroupId(int groupId) {
|
2022-05-07 13:47:13 +00:00
|
|
|
logger.debug("[LUA] Call GetGroupMonsterCountByGroupId with {}",
|
|
|
|
groupId);
|
2022-04-29 09:38:25 +00:00
|
|
|
return (int) getSceneScriptManager().getScene().getEntities().values().stream()
|
|
|
|
.filter(e -> e instanceof EntityMonster && e.getGroupId() == groupId)
|
|
|
|
.count();
|
|
|
|
}
|
|
|
|
|
2022-04-29 10:06:33 +00:00
|
|
|
public int GetGroupVariableValue(String var) {
|
2022-05-07 13:47:13 +00:00
|
|
|
logger.debug("[LUA] Call GetGroupVariableValue with {}",
|
|
|
|
var);
|
2022-04-29 10:06:33 +00:00
|
|
|
return getSceneScriptManager().getVariables().getOrDefault(var, 0);
|
2022-04-29 09:38:25 +00:00
|
|
|
}
|
|
|
|
|
2022-05-04 06:13:42 +00:00
|
|
|
public int SetGroupVariableValue(String var, int value) {
|
2022-05-07 13:47:13 +00:00
|
|
|
logger.debug("[LUA] Call SetGroupVariableValue with {},{}",
|
|
|
|
var, value);
|
2022-04-29 09:38:25 +00:00
|
|
|
getSceneScriptManager().getVariables().put(var, value);
|
2022-05-04 06:13:42 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
public LuaValue ChangeGroupVariableValue(String var, int value) {
|
2022-05-07 13:47:13 +00:00
|
|
|
logger.debug("[LUA] Call ChangeGroupVariableValue with {},{}",
|
|
|
|
var, value);
|
|
|
|
|
2022-05-04 06:13:42 +00:00
|
|
|
getSceneScriptManager().getVariables().put(var, getSceneScriptManager().getVariables().get(var) + value);
|
2022-04-29 09:38:25 +00:00
|
|
|
return LuaValue.ZERO;
|
|
|
|
}
|
2022-05-09 07:39:49 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the actions and triggers to designated group
|
|
|
|
*/
|
2022-04-29 05:19:14 +00:00
|
|
|
public int RefreshGroup(LuaTable table) {
|
2022-05-07 13:47:13 +00:00
|
|
|
logger.debug("[LUA] Call RefreshGroup with {}",
|
2022-05-09 07:39:49 +00:00
|
|
|
printTable(table));
|
2022-04-29 09:38:25 +00:00
|
|
|
// Kill and Respawn?
|
|
|
|
int groupId = table.get("group_id").toint();
|
|
|
|
int suite = table.get("suite").toint();
|
|
|
|
|
|
|
|
SceneGroup group = getSceneScriptManager().getGroupById(groupId);
|
|
|
|
|
|
|
|
if (group == null || group.monsters == null) {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2022-05-09 07:39:49 +00:00
|
|
|
getSceneScriptManager().refreshGroup(group, suite);
|
2022-04-29 09:38:25 +00:00
|
|
|
|
2022-04-29 05:19:14 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2022-04-30 08:08:38 +00:00
|
|
|
public int GetRegionEntityCount(LuaTable table) {
|
2022-05-07 13:47:13 +00:00
|
|
|
logger.debug("[LUA] Call GetRegionEntityCount with {}",
|
|
|
|
table);
|
2022-04-30 08:08:38 +00:00
|
|
|
int regionId = table.get("region_eid").toint();
|
|
|
|
int entityType = table.get("entity_type").toint();
|
|
|
|
|
|
|
|
SceneRegion region = this.getSceneScriptManager().getRegionById(regionId);
|
|
|
|
|
|
|
|
if (region == null) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (int) region.getEntities().intStream().filter(e -> e >> 24 == entityType).count();
|
|
|
|
}
|
|
|
|
|
2022-04-29 05:19:14 +00:00
|
|
|
public void PrintContextLog(String msg) {
|
2022-05-07 13:47:13 +00:00
|
|
|
logger.info("[LUA] " + msg);
|
2022-04-29 05:19:14 +00:00
|
|
|
}
|
2022-05-06 16:15:23 +00:00
|
|
|
|
2022-05-07 13:47:13 +00:00
|
|
|
public int TowerCountTimeStatus(int isDone, int var2){
|
|
|
|
logger.debug("[LUA] Call TowerCountTimeStatus with {},{}",
|
|
|
|
isDone,var2);
|
|
|
|
// TODO record time
|
2022-05-06 16:15:23 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
public int GetGroupMonsterCount(int var1){
|
2022-05-07 13:47:13 +00:00
|
|
|
logger.debug("[LUA] Call GetGroupMonsterCount with {}",
|
|
|
|
var1);
|
|
|
|
|
|
|
|
return (int) getSceneScriptManager().getScene().getEntities().values().stream()
|
2022-05-08 09:11:02 +00:00
|
|
|
.filter(e -> e instanceof EntityMonster && e.getGroupId() == getSceneScriptManager().getCurrentGroup().id)
|
2022-05-07 13:47:13 +00:00
|
|
|
.count();
|
2022-05-06 16:15:23 +00:00
|
|
|
}
|
|
|
|
public int SetMonsterBattleByGroup(int var1, int var2, int var3){
|
2022-05-07 13:47:13 +00:00
|
|
|
logger.debug("[LUA] Call SetMonsterBattleByGroup with {},{},{}",
|
|
|
|
var1,var2,var3);
|
2022-05-09 07:39:49 +00:00
|
|
|
// TODO
|
2022-05-06 16:15:23 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
public int CauseDungeonFail(int var1){
|
2022-05-07 13:47:13 +00:00
|
|
|
logger.debug("[LUA] Call CauseDungeonFail with {}",
|
|
|
|
var1);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
2022-05-09 07:39:49 +00:00
|
|
|
|
2022-05-08 09:11:02 +00:00
|
|
|
public int GetGroupVariableValueByGroup(String name, int groupId){
|
|
|
|
logger.debug("[LUA] Call GetGroupVariableValueByGroup with {},{}",
|
|
|
|
name,groupId);
|
2022-05-07 13:47:13 +00:00
|
|
|
|
2022-05-08 09:11:02 +00:00
|
|
|
return getSceneScriptManager().getVariables().getOrDefault(name, 0);
|
2022-05-07 13:47:13 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public int SetIsAllowUseSkill(int canUse, int var2){
|
|
|
|
logger.debug("[LUA] Call SetIsAllowUseSkill with {},{}",
|
|
|
|
canUse,var2);
|
|
|
|
|
|
|
|
getSceneScriptManager().getScene().broadcastPacket(new PacketCanUseSkillNotify(canUse == 1));
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
public int KillEntityByConfigId(LuaTable table){
|
|
|
|
logger.debug("[LUA] Call KillEntityByConfigId with {}",
|
2022-05-09 07:39:49 +00:00
|
|
|
printTable(table));
|
2022-05-07 13:47:13 +00:00
|
|
|
var configId = table.get("config_id");
|
|
|
|
if(configId == LuaValue.NIL){
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
var entity = getSceneScriptManager().getScene().getEntityByConfigId(configId.toint());
|
|
|
|
if(entity == null){
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
getSceneScriptManager().getScene().killEntity(entity, 0);
|
2022-05-06 16:15:23 +00:00
|
|
|
return 0;
|
|
|
|
}
|
2022-05-07 13:47:13 +00:00
|
|
|
|
2022-05-08 09:11:02 +00:00
|
|
|
public int SetGroupVariableValueByGroup(String key, int value, int groupId){
|
|
|
|
logger.debug("[LUA] Call SetGroupVariableValueByGroup with {},{},{}",
|
|
|
|
key,value,groupId);
|
|
|
|
|
2022-05-09 07:39:49 +00:00
|
|
|
getSceneScriptManager().getVariables().put(key, value);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
public int CreateMonster(LuaTable table){
|
|
|
|
logger.debug("[LUA] Call CreateMonster with {}",
|
|
|
|
printTable(table));
|
|
|
|
var configId = table.get("config_id").toint();
|
|
|
|
var delayTime = table.get("delay_time").toint();
|
|
|
|
|
|
|
|
getSceneScriptManager().spawnMonstersByConfigId(configId, delayTime);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
public int TowerMirrorTeamSetUp(int team, int var1) {
|
|
|
|
logger.debug("[LUA] Call TowerMirrorTeamSetUp with {},{}",
|
|
|
|
team,var1);
|
|
|
|
|
2022-05-09 16:05:01 +00:00
|
|
|
getSceneScriptManager().unloadCurrentMonsterTide();
|
2022-05-09 07:39:49 +00:00
|
|
|
getSceneScriptManager().getScene().getPlayers().get(0).getTowerManager().mirrorTeamSetUp(team-1);
|
|
|
|
|
2022-05-08 09:11:02 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2022-05-09 16:05:01 +00:00
|
|
|
public int CreateGadget(LuaTable table){
|
|
|
|
logger.debug("[LUA] Call CreateGadget with {}",
|
|
|
|
printTable(table));
|
|
|
|
var configId = table.get("config_id").toint();
|
|
|
|
|
|
|
|
//TODO
|
|
|
|
|
2022-05-15 11:19:24 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
public int CheckRemainGadgetCountByGroupId(LuaTable table){
|
|
|
|
logger.debug("[LUA] Call CheckRemainGadgetCountByGroupId with {}",
|
|
|
|
printTable(table));
|
|
|
|
var groupId = table.get("group_id").toint();
|
|
|
|
|
|
|
|
var count = getSceneScriptManager().getScene().getEntities().values().stream()
|
|
|
|
.filter(g -> g instanceof EntityGadget entityGadget && entityGadget.getGroupId() == groupId)
|
|
|
|
.count();
|
|
|
|
return (int)count;
|
|
|
|
}
|
|
|
|
|
|
|
|
public int GetGadgetStateByConfigId(int groupId, int configId){
|
|
|
|
logger.debug("[LUA] Call GetGadgetStateByConfigId with {},{}",
|
|
|
|
groupId, configId);
|
|
|
|
var gadget = getSceneScriptManager().getScene().getEntities().values().stream()
|
|
|
|
.filter(g -> g instanceof EntityGadget entityGadget && entityGadget.getGroupId() == groupId)
|
|
|
|
.filter(g -> g.getConfigId() == configId)
|
|
|
|
.findFirst();
|
|
|
|
if(gadget.isEmpty()){
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
var stat = ((EntityGadget)gadget.get()).getState();
|
|
|
|
return stat;
|
|
|
|
}
|
|
|
|
public int SetGadgetStateByConfigId(int configId, LuaTable gadgetState){
|
|
|
|
logger.debug("[LUA] Call SetGadgetStateByConfigId with {},{}",
|
|
|
|
configId, printTable(gadgetState));
|
|
|
|
|
2022-05-09 16:05:01 +00:00
|
|
|
return 0;
|
|
|
|
}
|
2022-04-29 05:19:14 +00:00
|
|
|
}
|