add LSL_Integer osReplaceAgentEnvironment(LSL_Key agentkey, LSL_Integer transition, LSL_String environment). note this is a hack, we cant do the ll* one

master
UbitUmarov 2020-06-19 19:55:40 +01:00
parent d322248fd1
commit e3ecf0ddbe
7 changed files with 174 additions and 18 deletions

View File

@ -1179,18 +1179,19 @@ namespace OpenSim.Framework
IsLegacy = false; IsLegacy = false;
} }
public void CycleFromOSD(OSD osd) public bool CycleFromOSD(OSD osd)
{ {
OSDMap map = osd as OSDMap; OSDMap map = osd as OSDMap;
if (map == null) if (map == null)
return; return false;
if(!map.TryGetValue("type", out OSD tmp)) if(!map.TryGetValue("type", out OSD tmp))
return; return false;
string type = tmp.AsString(); string type = tmp.AsString();
if(type != "daycycle") if(type != "daycycle")
return; return false;
Cycle = new DayCycle(); Cycle = new DayCycle();
Cycle.FromOSD(map); Cycle.FromOSD(map);
return true;
} }
public OSD ToOSD() public OSD ToOSD()

View File

@ -255,14 +255,19 @@ namespace OpenSim.Region.CoreModules.World.LightShare
public void WindlightRefresh(int interpolate, bool notforparcel = true) public void WindlightRefresh(int interpolate, bool notforparcel = true)
{ {
List<byte[]> ls = null; List<byte[]> ls = null;
m_scene.ForEachClient(delegate (IClientAPI client) m_scene.ForEachRootScenePresence(delegate (ScenePresence sp)
{ {
if(!client.IsActive) if(sp.IsInTransit || sp.IsNPC)
return;
IClientAPI client = sp.ControllingClient;
if (!client.IsActive)
return; return;
uint vflags = client.GetViewerCaps(); uint vflags = client.GetViewerCaps();
if (notforparcel && (vflags & 0x8000) != 0 ) if (notforparcel && (vflags & 0x8000) != 0)
m_estateModule.HandleRegionInfoRequest(client); m_estateModule.HandleRegionInfoRequest(client);
else if ((vflags & 0x4000) != 0) else if ((vflags & 0x4000) != 0)
@ -270,13 +275,50 @@ namespace OpenSim.Region.CoreModules.World.LightShare
else else
{ {
if(ls == null) if (ls == null)
ls = MakeLightShareData(); ls = MakeLightShareData();
SendLightShare(client, ls); SendLightShare(client, ls);
} }
}); });
} }
public void WindlightRefresh(IScenePresence isp, int interpolate)
{
List<byte[]> ls = null;
IClientAPI client = isp.ControllingClient;
if (!client.IsActive)
return;
uint vflags = client.GetViewerCaps();
if ((vflags & 0x8000) != 0)
{
ScenePresence sp = isp as ScenePresence;
if(sp.Environment != null)
m_estateModule.HandleRegionInfoRequest(client);
else
{
ILandObject lo = m_scene.LandChannel.GetLandObject(sp.AbsolutePosition.X, sp.AbsolutePosition.Y);
if (lo != null && lo.LandData != null && lo.LandData.Environment != null)
lo.SendLandUpdateToClient(client);
else
m_estateModule.HandleRegionInfoRequest(client);
}
}
else if ((vflags & 0x4000) != 0)
m_eventQueue.WindlightRefreshEvent(interpolate, client.AgentId);
else
{
if (ls == null)
ls = MakeLightShareData();
SendLightShare(client, ls);
}
}
public void FromLightShare(RegionLightShareData ls) public void FromLightShare(RegionLightShareData ls)
{ {
if (!Enabled) if (!Enabled)
@ -397,7 +439,7 @@ namespace OpenSim.Region.CoreModules.World.LightShare
if (land != null && land.LandData != null) if (land != null && land.LandData != null)
{ {
land.StoreEnvironment(null); land.StoreEnvironment(null);
WindlightRefresh(0, false); WindlightRefresh(0);
} }
} }
@ -422,8 +464,17 @@ namespace OpenSim.Region.CoreModules.World.LightShare
} }
} }
ScenePresence sp = m_scene.GetScenePresence(agentID);
if (sp == null || sp.IsChildAgent || sp.IsNPC)
{
httpResponse.StatusCode = (int)HttpStatusCode.NotFound;
return;
}
ViewerEnvironment VEnv; ViewerEnvironment VEnv;
if (parcel == -1) if(sp.Environment != null)
VEnv = sp.Environment;
else if (parcel == -1)
VEnv = GetRegionEnvironment(); VEnv = GetRegionEnvironment();
else else
{ {
@ -431,7 +482,12 @@ namespace OpenSim.Region.CoreModules.World.LightShare
if (land != null && land.LandData != null && land.LandData.Environment != null) if (land != null && land.LandData != null && land.LandData.Environment != null)
VEnv = land.LandData.Environment; VEnv = land.LandData.Environment;
else else
VEnv = GetRegionEnvironment(); {
OSD def = ViewerEnvironment.DefaultToOSD(regionID, parcel);
httpResponse.RawBuffer = OSDParser.SerializeLLSDXmlToBytes(def);
httpResponse.StatusCode = (int)HttpStatusCode.OK;
return;
}
} }
OSDMap map = new OSDMap(); OSDMap map = new OSDMap();
@ -496,6 +552,7 @@ namespace OpenSim.Region.CoreModules.World.LightShare
} }
} }
ViewerEnvironment VEnv = m_scene.RegionEnvironment; ViewerEnvironment VEnv = m_scene.RegionEnvironment;
ILandObject lchannel; ILandObject lchannel;
if (parcel == -1) if (parcel == -1)
@ -634,11 +691,16 @@ namespace OpenSim.Region.CoreModules.World.LightShare
} }
ViewerEnvironment VEnv; ViewerEnvironment VEnv;
if (sp.Environment != null)
VEnv = sp.Environment;
else
{
ILandObject land = m_scene.LandChannel.GetLandObject(sp.AbsolutePosition.X, sp.AbsolutePosition.Y); ILandObject land = m_scene.LandChannel.GetLandObject(sp.AbsolutePosition.X, sp.AbsolutePosition.Y);
if (land != null && land.LandData != null && land.LandData.Environment != null) if (land != null && land.LandData != null && land.LandData.Environment != null)
VEnv = land.LandData.Environment; VEnv = land.LandData.Environment;
else else
VEnv = GetRegionEnvironment(); VEnv = GetRegionEnvironment();
}
OSD d = VEnv.ToWLOSD(UUID.Zero, regionID); OSD d = VEnv.ToWLOSD(UUID.Zero, regionID);
string env = OSDParser.SerializeLLSDXmlString(d); string env = OSDParser.SerializeLLSDXmlString(d);
@ -680,6 +742,12 @@ namespace OpenSim.Region.CoreModules.World.LightShare
return; return;
} }
if (sp.Environment != null)
{
fail_reason = "The environment you see is a forced one. Disable if on control object or tp out and back to region";
goto Error;
}
ILandObject land = m_scene.LandChannel.GetLandObject(sp.AbsolutePosition.X, sp.AbsolutePosition.Y); ILandObject land = m_scene.LandChannel.GetLandObject(sp.AbsolutePosition.X, sp.AbsolutePosition.Y);
if (land != null && land.LandData != null && land.LandData.Environment != null) if (land != null && land.LandData != null && land.LandData.Environment != null)
{ {
@ -691,13 +759,14 @@ namespace OpenSim.Region.CoreModules.World.LightShare
ViewerEnvironment VEnv = new ViewerEnvironment(); ViewerEnvironment VEnv = new ViewerEnvironment();
OSD env = OSDParser.Deserialize(request.InputStream); OSD env = OSDParser.Deserialize(request.InputStream);
VEnv.FromWLOSD(env); VEnv.FromWLOSD(env);
StoreOnRegion(VEnv); StoreOnRegion(VEnv);
success = true;
WindlightRefresh(0); WindlightRefresh(0);
m_log.InfoFormat("[{0}]: New Environment settings has been saved from agentID {1} in region {2}", m_log.InfoFormat("[{0}]: New Environment settings has been saved from agentID {1} in region {2}",
Name, agentID, m_scene.Name); Name, agentID, m_scene.Name);
success = true;
} }
catch (Exception e) catch (Exception e)
{ {
@ -825,11 +894,16 @@ namespace OpenSim.Region.CoreModules.World.LightShare
private void OnAvatarEnteringNewParcel(ScenePresence sp, int localLandID, UUID regionID) private void OnAvatarEnteringNewParcel(ScenePresence sp, int localLandID, UUID regionID)
{ {
if (sp.Environment != null)
return;
if (!m_scene.RegionInfo.EstateSettings.AllowEnvironmentOverride)
return;
IClientAPI client = sp.ControllingClient; IClientAPI client = sp.ControllingClient;
uint vflags = client.GetViewerCaps(); uint vflags = client.GetViewerCaps();
if((vflags & 0x8000) != 0) if((vflags & 0x8000) != 0)
return; return;
if(m_scene.RegionInfo.EstateSettings.AllowEnvironmentOverride)
m_eventQueue.WindlightRefreshEvent(1, client.AgentId); m_eventQueue.WindlightRefreshEvent(1, client.AgentId);
} }

View File

@ -37,6 +37,9 @@ namespace OpenSim.Region.Framework.Interfaces
RegionLightShareData ToLightShare(); RegionLightShareData ToLightShare();
byte[] GetDefaultAssetData(int type); byte[] GetDefaultAssetData(int type);
void WindlightRefresh(int interpolate, bool notforparcel = true); void WindlightRefresh(int interpolate, bool notforparcel = true);
void WindlightRefresh(IScenePresence sp, int interpolate);
ViewerEnvironment GetRegionEnvironment();
float GetRegionDayFractionTime(); float GetRegionDayFractionTime();
int GetRegionDayLength(); int GetRegionDayLength();

View File

@ -83,6 +83,31 @@ namespace OpenSim.Region.Framework.Scenes
// m_log.DebugFormat("[SCENE PRESENCE]: Destructor called on {0}", Name); // m_log.DebugFormat("[SCENE PRESENCE]: Destructor called on {0}", Name);
// } // }
public int EnvironmentVersion = -1;
private ViewerEnvironment m_environment;
public ViewerEnvironment Environment
{
get
{
return m_environment;
}
set
{
m_environment = value;
if (value == null)
EnvironmentVersion = -1;
else
{
if(EnvironmentVersion <= 0)
EnvironmentVersion = 0x7000000;
else
++EnvironmentVersion;
m_environment.version = EnvironmentVersion;
}
}
}
public void TriggerScenePresenceUpdated() public void TriggerScenePresenceUpdated()
{ {
if (m_scene != null) if (m_scene != null)

View File

@ -5882,5 +5882,52 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
{ {
return m_host.ClearObjectAnimations(); return m_host.ClearObjectAnimations();
} }
public LSL_Integer osReplaceAgentEnvironment(LSL_Key agentkey, LSL_Integer transition, LSL_String environment)
{
m_host.AddScriptLPS(1);
// if(!string.IsNullOrEmpty(CheckThreatLevelTest(ThreatLevel.Moderate, "osReplaceAgentEnvironment")))
// return -2;
if (!UUID.TryParse(agentkey, out UUID agentid))
return -4;
ScenePresence sp = World.GetScenePresence(agentid);
if(sp == null || sp.IsChildAgent || sp.IsNPC || sp.IsInTransit)
return -4;
if(string.IsNullOrEmpty(environment) || environment == UUID.Zero.ToString())
{
sp.Environment = null;
m_envModule.WindlightRefresh(sp, transition);
return 1;
}
UUID envID = ScriptUtils.GetAssetIdFromKeyOrItemName(m_host, environment);
if (envID == UUID.Zero)
return -3;
AssetBase asset = World.AssetService.Get(envID.ToString());
if(asset == null || asset.Type != (byte)AssetType.Settings)
return -3;
// cant use stupid broken asset flags for subtype
try
{
OSD oenv = OSDParser.Deserialize(asset.Data);
ViewerEnvironment VEnv = m_envModule.GetRegionEnvironment().Clone();
if(!VEnv.CycleFromOSD(oenv))
return -3;
sp.Environment = VEnv;
m_envModule.WindlightRefresh(sp, transition);
}
catch
{
sp.Environment = null;
m_envModule.WindlightRefresh(sp, transition);
return -9;
}
return 1;
}
} }
} }

View File

@ -578,5 +578,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api.Interfaces
LSL_String osGetApparentTimeString(LSL_Integer format24); LSL_String osGetApparentTimeString(LSL_Integer format24);
LSL_Float osGetApparentRegionTime(); LSL_Float osGetApparentRegionTime();
LSL_String osGetApparentRegionTimeString(LSL_Integer format24); LSL_String osGetApparentRegionTimeString(LSL_Integer format24);
LSL_Integer osReplaceAgentEnvironment(LSL_Key agentkey, LSL_Integer transition, LSL_String environment);
} }
} }

View File

@ -1502,5 +1502,9 @@ namespace OpenSim.Region.ScriptEngine.Shared.ScriptBase
return m_OSSL_Functions.osGetApparentRegionTimeString(format24); return m_OSSL_Functions.osGetApparentRegionTimeString(format24);
} }
public LSL_Integer osReplaceAgentEnvironment(LSL_Key agentkey, LSL_Integer transition, LSL_String environment)
{
return m_OSSL_Functions.osReplaceAgentEnvironment(agentkey, transition, environment);
}
} }
} }