"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const MapInfoReply_1 = require("../../events/MapInfoReply"); const Message_1 = require("../../enums/Message"); const MapBlockRequest_1 = require("../messages/MapBlockRequest"); const UUID_1 = require("../UUID"); const MapItemRequest_1 = require("../messages/MapItemRequest"); const Utils_1 = require("../Utils"); const PacketFlags_1 = require("../../enums/PacketFlags"); const GridItemType_1 = require("../../enums/GridItemType"); const CommandsBase_1 = require("./CommandsBase"); const AvatarPickerRequest_1 = require("../messages/AvatarPickerRequest"); const FilterResponse_1 = require("../../enums/FilterResponse"); const MapNameRequest_1 = require("../messages/MapNameRequest"); const GridLayerType_1 = require("../../enums/GridLayerType"); const RegionInfoReply_1 = require("../../events/RegionInfoReply"); class GridCommands extends CommandsBase_1.CommandsBase { getRegionByName(regionName) { return new Promise((resolve, reject) => { const circuit = this.currentRegion.circuit; const response = new MapInfoReply_1.MapInfoReply(); const msg = new MapNameRequest_1.MapNameRequestMessage(); msg.AgentData = { AgentID: this.agent.agentID, SessionID: circuit.sessionID, Flags: GridLayerType_1.GridLayerType.Objects, EstateID: 0, Godlike: false }; msg.NameData = { Name: Utils_1.Utils.StringToBuffer(regionName) }; circuit.sendMessage(msg, PacketFlags_1.PacketFlags.Reliable); circuit.waitForMessage(Message_1.Message.MapBlockReply, 10000, (packet) => { const filterMsg = packet.message; let found = false; filterMsg.Data.forEach((region) => { const name = Utils_1.Utils.BufferToStringSimple(region.Name); if (name.trim().toLowerCase() === regionName.trim().toLowerCase()) { found = true; } }); if (found) { return FilterResponse_1.FilterResponse.Finish; } return FilterResponse_1.FilterResponse.NoMatch; }).then((packet) => { const responseMsg = packet.message; responseMsg.Data.forEach((region) => { const name = Utils_1.Utils.BufferToStringSimple(region.Name); if (name.trim().toLowerCase() === regionName.trim().toLowerCase() && !(region.X === 0 && region.Y === 0)) { const reply = new RegionInfoReply_1.RegionInfoReply(); reply.access = region.Access; reply.X = region.X; reply.Y = region.Y; reply.name = name; reply.regionFlags = region.RegionFlags; reply.waterHeight = region.WaterHeight; reply.agents = region.Agents; reply.mapImageID = region.MapImageID; reply.handle = Utils_1.Utils.RegionCoordinatesToHandle(region.X * 256, region.Y * 256); resolve(reply); } }); }).catch((err) => { reject(err); }); }); } getRegionMapInfo(gridX, gridY) { return new Promise((resolve, reject) => { const circuit = this.currentRegion.circuit; const response = new MapInfoReply_1.MapInfoReply(); const msg = new MapBlockRequest_1.MapBlockRequestMessage(); msg.AgentData = { AgentID: this.agent.agentID, SessionID: circuit.sessionID, Flags: 65536, EstateID: 0, Godlike: false }; msg.PositionData = { MinX: (gridX / 256), MaxX: (gridX / 256), MinY: (gridY / 256), MaxY: (gridY / 256) }; circuit.sendMessage(msg, PacketFlags_1.PacketFlags.Reliable); circuit.waitForMessage(Message_1.Message.MapBlockReply, 10000, (packet) => { const filterMsg = packet.message; let found = false; filterMsg.Data.forEach((data) => { if (data.X === (gridX / 256) && data.Y === (gridY / 256)) { found = true; } }); if (found) { return FilterResponse_1.FilterResponse.Finish; } return FilterResponse_1.FilterResponse.NoMatch; }).then((packet) => { const responseMsg = packet.message; responseMsg.Data.forEach((data) => { if (data.X === (gridX / 256) && data.Y === (gridY / 256)) { response.name = Utils_1.Utils.BufferToStringSimple(data.Name); response.accessFlags = data.Access; response.mapImage = data.MapImageID; } }); const regionHandle = Utils_1.Utils.RegionCoordinatesToHandle(gridX, gridY); const mi = new MapItemRequest_1.MapItemRequestMessage(); mi.AgentData = { AgentID: this.agent.agentID, SessionID: circuit.sessionID, Flags: 2, EstateID: 0, Godlike: false }; mi.RequestData = { ItemType: GridItemType_1.GridItemType.AgentLocations, RegionHandle: regionHandle }; circuit.sendMessage(mi, PacketFlags_1.PacketFlags.Reliable); const minX = Math.floor(gridX / 256) * 256; const maxX = minX + 256; const minY = Math.floor(gridY / 256) * 256; const maxY = minY + 256; response.avatars = []; circuit.waitForMessage(Message_1.Message.MapItemReply, 10000, (packet) => { const filterMsg = packet.message; let found = false; filterMsg.Data.forEach((data) => { if (data.X >= minX && data.X <= maxX && data.Y >= minY && data.Y <= maxY) { found = true; } }); if (found) { return FilterResponse_1.FilterResponse.Finish; } else { return FilterResponse_1.FilterResponse.NoMatch; } }).then((packet2) => { const responseMsg2 = packet2.message; responseMsg2.Data.forEach((data) => { response.avatars.push({ X: data.X, Y: data.Y }); }); resolve(response); }).catch((err) => { reject(err); }); }).catch((err) => { reject(err); }); }); } name2Key(name) { const check = name.split('.'); if (check.length > 1) { name = check.join(' '); } else { name += ' resident'; } name = name.toLowerCase(); const queryID = UUID_1.UUID.random(); return new Promise((resolve, reject) => { const aprm = new AvatarPickerRequest_1.AvatarPickerRequestMessage(); aprm.AgentData = { AgentID: this.agent.agentID, SessionID: this.circuit.sessionID, QueryID: queryID }; aprm.Data = { Name: Utils_1.Utils.StringToBuffer(name) }; this.circuit.sendMessage(aprm, PacketFlags_1.PacketFlags.Reliable); this.circuit.waitForMessage(Message_1.Message.AvatarPickerReply, 10000, (packet) => { const apr = packet.message; if (apr.AgentData.QueryID.toString() === queryID.toString()) { return FilterResponse_1.FilterResponse.Finish; } else { return FilterResponse_1.FilterResponse.NoMatch; } }).then((packet) => { let found = null; const apr = packet.message; apr.Data.forEach((dataBlock) => { const resultName = (Utils_1.Utils.BufferToStringSimple(dataBlock.FirstName) + ' ' + Utils_1.Utils.BufferToStringSimple(dataBlock.LastName)).toLowerCase(); if (resultName === name) { found = dataBlock.AvatarID; } }); if (found !== null) { resolve(found); } else { reject('Name not found'); } }).catch((err) => { reject(err); }); }); } } exports.GridCommands = GridCommands; //# sourceMappingURL=GridCommands.js.map