From e75e6f426bfc069e9185c8c72e8707399edfe299 Mon Sep 17 00:00:00 2001
From: MW
Date: Fri, 2 Feb 2007 17:23:56 +0000
Subject: Clean up. Added GridManager and teleport between regions/sims.
---
Agent_Manager.cs | 457 ++++++++++++++++++++++++++++-----------------------
AssemblyInfo.cs | 6 +-
Asset_manager.cs | 53 +++---
Controller.cs | 173 +++++++++++++------
Login_manager.cs | 74 +++++++--
Prim_manager.cs | 237 ++++++++++++++++++--------
Script_manager.cs | 46 ++++--
Second-server.csproj | 17 +-
Second-server.sln | 4 +-
Server.cs | 27 +--
Texture_manager.cs | 73 ++++----
11 files changed, 725 insertions(+), 442 deletions(-)
diff --git a/Agent_Manager.cs b/Agent_Manager.cs
index 3b05480..9aa8d7f 100644
--- a/Agent_Manager.cs
+++ b/Agent_Manager.cs
@@ -32,122 +32,173 @@ using libsecondlife.AssetSystem;
using System.IO;
using Axiom.MathLib;
-namespace Second_server
+namespace OpenSim
{
///
/// Description of Agent_Manager.
///
- public class Agent_Manager
+ public class AgentManager
{
- public Dictionary Agent_list;
- //public uint number_agents=0;
+ public Dictionary AgentList;
+
private uint local_numer=0;
private Server server;
- public Prim_manager prim_man;
- private byte [] data1;
+ public PrimManager Prim_Manager;
- private libsecondlife.Packets.RegionHandshakePacket reg;
+ private libsecondlife.Packets.RegionHandshakePacket RegionPacket;
private System.Text.Encoding enc = System.Text.Encoding.ASCII;
- public libsecondlife.Packets.ObjectUpdatePacket.ObjectDataBlock avatar_template;
- //private int appc=0;
-
- public Agent_Manager(Server serve)
+ public libsecondlife.Packets.ObjectUpdatePacket.ObjectDataBlock AvatarTemplate;
+
+ ///
+ ///
+ ///
+ ///
+ public AgentManager(Server serve)
{
- Agent_list=new Dictionary();
+ AgentList=new Dictionary();
server=serve;
this.initialise();
}
- //***************************************************
- public Avatar_data Get_Agent(LLUUID id)
+
+ ///
+ ///
+ ///
+ ///
+ ///
+ public AvatarData GetAgent(LLUUID id)
{
-
-
- if(!this.Agent_list.ContainsKey(id))
+ if(!this.AgentList.ContainsKey(id))
{
return null;
}
else
{
- Avatar_data ad=this.Agent_list[id];
+ AvatarData ad=this.AgentList[id];
return ad;
}
}
-
- public void Add_Agent(Avatar_data agent)
+ ///
+ ///
+ ///
+ ///
+ public void AddAgent(AvatarData agent)
{
- this.Agent_list.Add(agent.Full_ID,agent);
+ this.AgentList.Add(agent.FullID,agent);
}
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
- public bool New_Agent(User_Agent_info User_info)
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ public bool NewAgent(User_Agent_info User_info, string first, string last)
{
- Avatar_data ad=new Avatar_data();
- ad.Full_ID=User_info.AgentID;
- ad.Net_info=User_info;
- ad.pos=new LLVector3(100,100,22);
- this.Agent_list.Add(ad.Full_ID,ad);
+ AvatarData agent=new AvatarData();
+ agent.FullID=User_info.AgentID;
+ agent.NetInfo=User_info;
+ agent.NetInfo.first_name=first;
+ agent.NetInfo.last_name=last;
+ agent.Position=new LLVector3(100,100,22);
+ this.AgentList.Add(agent.FullID,agent);
return(true);
}
- public void Agent_join(User_Agent_info User_info)
+ ///
+ ///
+ ///
+ ///
+ public void RemoveAgent(User_Agent_info UserInfo)
+ {
+ this.AgentList.Remove(UserInfo.AgentID);
+
+ //tell other clients to delete this avatar
+ }
+
+ ///
+ ///
+ ///
+ ///
+ public void AgentJoin(User_Agent_info User_info)
{
//send region data
- server.SendPacket(reg,true,User_info);
+ server.SendPacket(RegionPacket,true,User_info);
//inform client of join comlete
libsecondlife.Packets.AgentMovementCompletePacket mov=new AgentMovementCompletePacket();
mov.AgentData.SessionID=User_info.SessionID;
mov.AgentData.AgentID=User_info.AgentID;
- mov.Data.RegionHandle=1096213093147648;
+ mov.Data.RegionHandle=Globals.Instance.RegionHandle;
mov.Data.Timestamp=1169838966;
mov.Data.Position=new LLVector3(100f,100f,22f);
mov.Data.LookAt=new LLVector3(0.99f,0.042f,0);
server.SendPacket(mov,true,User_info);
}
- public void tick()
+
+ ///
+ ///
+ ///
+ public void UpdatePositions()
{
//update positions
- foreach (KeyValuePair kp in this.Agent_list)
+ foreach (KeyValuePair kp in this.AgentList)
{
- kp.Value.pos.X+=(kp.Value.vel.X*0.2f);
- kp.Value.pos.Y+=(kp.Value.vel.Y*0.2f);
- kp.Value.pos.Z+=(kp.Value.vel.Z*0.2f);
+ kp.Value.Position.X+=(kp.Value.Velocity.X*0.2f);
+ kp.Value.Position.Y+=(kp.Value.Velocity.Y*0.2f);
+ kp.Value.Position.Z+=(kp.Value.Velocity.Z*0.2f);
}
}
- //**************************************************************
+
+ ///
+ ///
+ ///
private void initialise()
{
//Region data
- reg=new RegionHandshakePacket();
- reg.RegionInfo.BillableFactor=0;
- reg.RegionInfo.IsEstateManager=false;
- reg.RegionInfo.TerrainHeightRange00=60;
- reg.RegionInfo.TerrainHeightRange01=60;
- reg.RegionInfo.TerrainHeightRange10=60;
- reg.RegionInfo.TerrainHeightRange11=60;
- reg.RegionInfo.TerrainStartHeight00=20;
- reg.RegionInfo.TerrainStartHeight01=20;
- reg.RegionInfo.TerrainStartHeight10=20;
- reg.RegionInfo.TerrainStartHeight11=20;
- reg.RegionInfo.SimAccess=13;
- reg.RegionInfo.WaterHeight=5;
- reg.RegionInfo.RegionFlags=72458694;
- reg.RegionInfo.SimName=enc.GetBytes( "Test Sandbox\0");
- reg.RegionInfo.SimOwner=new LLUUID("00000000-0000-0000-0000-000000000000");
- reg.RegionInfo.TerrainBase0=new LLUUID("b8d3965a-ad78-bf43-699b-bff8eca6c975");
- reg.RegionInfo.TerrainBase1=new LLUUID("abb783e6-3e93-26c0-248a-247666855da3");
- reg.RegionInfo.TerrainBase2=new LLUUID("179cdabd-398a-9b6b-1391-4dc333ba321f");
- reg.RegionInfo.TerrainBase3=new LLUUID("beb169c7-11ea-fff2-efe5-0f24dc881df2");
- reg.RegionInfo.TerrainDetail0=new LLUUID("00000000-0000-0000-0000-000000000000");
- reg.RegionInfo.TerrainDetail1=new LLUUID("00000000-0000-0000-0000-000000000000");
- reg.RegionInfo.TerrainDetail2=new LLUUID("00000000-0000-0000-0000-000000000000");
- reg.RegionInfo.TerrainDetail3=new LLUUID("00000000-0000-0000-0000-000000000000");
- reg.RegionInfo.CacheID=new LLUUID("545ec0a5-5751-1026-8a0b-216e38a7ab33");
-
- this.setuptemplate("objectupate168.dat");
+ RegionPacket=new RegionHandshakePacket();
+ RegionPacket.RegionInfo.BillableFactor=0;
+ RegionPacket.RegionInfo.IsEstateManager=false;
+ RegionPacket.RegionInfo.TerrainHeightRange00=60;
+ RegionPacket.RegionInfo.TerrainHeightRange01=60;
+ RegionPacket.RegionInfo.TerrainHeightRange10=60;
+ RegionPacket.RegionInfo.TerrainHeightRange11=60;
+ RegionPacket.RegionInfo.TerrainStartHeight00=20;
+ RegionPacket.RegionInfo.TerrainStartHeight01=20;
+ RegionPacket.RegionInfo.TerrainStartHeight10=20;
+ RegionPacket.RegionInfo.TerrainStartHeight11=20;
+ RegionPacket.RegionInfo.SimAccess=13;
+ RegionPacket.RegionInfo.WaterHeight=5;
+ RegionPacket.RegionInfo.RegionFlags=72458694;
+ RegionPacket.RegionInfo.SimName=enc.GetBytes( Globals.Instance.RegionName);
+ RegionPacket.RegionInfo.SimOwner=new LLUUID("00000000-0000-0000-0000-000000000000");
+ RegionPacket.RegionInfo.TerrainBase0=new LLUUID("b8d3965a-ad78-bf43-699b-bff8eca6c975");
+ RegionPacket.RegionInfo.TerrainBase1=new LLUUID("abb783e6-3e93-26c0-248a-247666855da3");
+ RegionPacket.RegionInfo.TerrainBase2=new LLUUID("179cdabd-398a-9b6b-1391-4dc333ba321f");
+ RegionPacket.RegionInfo.TerrainBase3=new LLUUID("beb169c7-11ea-fff2-efe5-0f24dc881df2");
+ RegionPacket.RegionInfo.TerrainDetail0=new LLUUID("00000000-0000-0000-0000-000000000000");
+ RegionPacket.RegionInfo.TerrainDetail1=new LLUUID("00000000-0000-0000-0000-000000000000");
+ RegionPacket.RegionInfo.TerrainDetail2=new LLUUID("00000000-0000-0000-0000-000000000000");
+ RegionPacket.RegionInfo.TerrainDetail3=new LLUUID("00000000-0000-0000-0000-000000000000");
+ RegionPacket.RegionInfo.CacheID=new LLUUID("545ec0a5-5751-1026-8a0b-216e38a7ab37");
+
+ this.SetupTemplate("objectupate168.dat");
}
- public void setuptemplate(string name)
+ ///
+ ///
+ ///
+ ///
+ private void SetupTemplate(string name)
{
/*ObjectUpdatePacket objupdate=new ObjectUpdatePacket();
objupdate.RegionData.RegionHandle=1096213093147648;
@@ -184,95 +235,87 @@ namespace Second_server
Array.Copy(pb,0,objdata.ObjectData,16,pb.Length);
- avatar_template=objdata;
+ AvatarTemplate=objdata;
}
- //**********************************************************
- public void send_intial_data(User_Agent_info User_info)
+
+ ///
+ ///
+ ///
+ ///
+ public void SendInitialData(User_Agent_info User_info)
{
- //shouldn't really have to read all this in from disk for every new client?
+ //shouldn't have to read all this in from disk for every new client
string data_path=System.AppDomain.CurrentDomain.BaseDirectory + @"\layer_data\";
//send layerdata
LayerDataPacket layerpack=new LayerDataPacket();
layerpack.LayerID.Type=76;
- //layerpack.LayerData.ReadfromFile(data_path+@"layerdata0.dat");
- this.read_layerdata(User_info,ref layerpack,data_path+@"layerdata0.dat");
-
- //server.SendPacket(layerpack,true,User_info);
-
+ this.SendLayerData(User_info,ref layerpack,data_path+@"layerdata0.dat");
+
LayerDataPacket layerpack1=new LayerDataPacket();
layerpack1.LayerID.Type=76;
- //layerpack1.LayerData.ReadfromFile(data_path+@"layerdata1.dat");
- this.read_layerdata(User_info,ref layerpack,data_path+@"layerdata1.dat");
- //server.SendPacket(layerpack1,true,User_info);
+ this.SendLayerData(User_info,ref layerpack,data_path+@"layerdata1.dat");
LayerDataPacket layerpack2=new LayerDataPacket();
layerpack2.LayerID.Type=56;
- //layerpack2.LayerData.ReadfromFile(data_path+@"layerdata2.dat");
- this.read_layerdata(User_info,ref layerpack,data_path+@"layerdata2.dat");
- //server.SendPacket(layerpack2,true,User_info);
+ this.SendLayerData(User_info,ref layerpack,data_path+@"layerdata2.dat");
LayerDataPacket layerpack3=new LayerDataPacket();
layerpack3.LayerID.Type=55;
- //layerpack3.LayerData.ReadfromFile(data_path+@"layerdata3.dat");
- this.read_layerdata(User_info,ref layerpack,data_path+@"layerdata3.dat");
- //server.SendPacket(layerpack3,true,User_info);
+ this.SendLayerData(User_info,ref layerpack,data_path+@"layerdata3.dat");
LayerDataPacket layerpack4=new LayerDataPacket();
layerpack4.LayerID.Type=56;
- //layerpack4.LayerData.ReadfromFile(data_path+@"layerdata4.dat");
- this.read_layerdata(User_info,ref layerpack,data_path+@"layerdata4.dat");
- //server.SendPacket(layerpack4,true,User_info);
+ this.SendLayerData(User_info,ref layerpack,data_path+@"layerdata4.dat");
LayerDataPacket layerpack5=new LayerDataPacket();
layerpack5.LayerID.Type=55;
- //layerpack5.LayerData.ReadfromFile(data_path+@"layerdata5.dat");
- this.read_layerdata(User_info,ref layerpack,data_path+@"layerdata5.dat");
- //server.SendPacket(layerpack5,true,User_info);
-
+ this.SendLayerData(User_info,ref layerpack,data_path+@"layerdata5.dat");
//send intial set of captured prims data?
- this.prim_man.Read_Prim_database( "objectdatabase.ini",User_info);
+ this.Prim_Manager.ReadPrimDatabase( "objectdatabase.ini",User_info);
//send prims that have been created by users
//prim_man.send_existing_prims(User_info);
//send update about clients avatar
- this.send_intial_avatar_position(User_info);
+ this.SendInitialAvatarPosition(User_info);
//send updates about all other users
- //this.send_test_avatar_position(User_info);
- foreach (KeyValuePair kp in this.Agent_list)
+ foreach (KeyValuePair kp in this.AgentList)
{
- if(kp.Value.Net_info.AgentID!=User_info.AgentID)
+ if(kp.Value.NetInfo.AgentID!=User_info.AgentID)
{
- this.send_other_avatar_position(User_info,kp.Value);
+ this.SendOtherAvatarPosition(User_info,kp.Value);
}
- }
-
-
+ }
}
- public void send_intial_avatar_position(User_Agent_info User_info)
+
+ ///
+ ///
+ ///
+ ///
+ public void SendInitialAvatarPosition(User_Agent_info User_info)
{
//send a objectupdate packet with information about the clients avatar
ObjectUpdatePacket objupdate=new ObjectUpdatePacket();
- objupdate.RegionData.RegionHandle=1096213093147648;
+ objupdate.RegionData.RegionHandle=Globals.Instance.RegionHandle;
objupdate.RegionData.TimeDilation=64096;
objupdate.ObjectData=new libsecondlife.Packets.ObjectUpdatePacket.ObjectDataBlock[1];
- objupdate.ObjectData[0]=avatar_template;
+ objupdate.ObjectData[0]=AvatarTemplate;
//give this avatar object a local id and assign the user a name
objupdate.ObjectData[0].ID=8880000+this.local_numer;
User_info.localID=objupdate.ObjectData[0].ID;
//User_info.name="Test"+this.local_numer+" User";
- this.Get_Agent(User_info.AgentID).started=true;
+ this.GetAgent(User_info.AgentID).Started=true;
objupdate.ObjectData[0].FullID=User_info.AgentID;
- objupdate.ObjectData[0].NameValue=enc.GetBytes("FirstName STRING RW SV Test"+ this.local_numer+"\nLastName STRING RW SV User \0");
- User_info.name="FirstName STRING RW SV Test"+ this.local_numer+"\nLastName STRING RW SV User \0";
- User_info.last_name="User";
- User_info.first_name="Test"+this.local_numer;
+ objupdate.ObjectData[0].NameValue=enc.GetBytes("FirstName STRING RW SV "+User_info.first_name+"\nLastName STRING RW SV "+User_info.last_name+" \0");
+ User_info.name="FirstName STRING RW SV "+User_info.first_name+"\nLastName STRING RW SV "+User_info.last_name+" \0";
+ //User_info.last_name="User";
+ //User_info.first_name="Test"+this.local_numer;
libsecondlife.LLVector3 pos2=new LLVector3(100f,100.0f,22.0f);
byte[] pb=pos2.GetBytes();
@@ -283,36 +326,23 @@ namespace Second_server
server.SendPacket(objupdate,true,User_info);
//send this info to other existing clients
- foreach (KeyValuePair kp in this.Agent_list)
+ foreach (KeyValuePair kp in this.AgentList)
{
- if(kp.Value.Net_info.AgentID!=User_info.AgentID)
+ if(kp.Value.NetInfo.AgentID!=User_info.AgentID)
{
- server.SendPacket(objupdate,true,kp.Value.Net_info);
- this.send_other_apper(kp.Value.Net_info,objupdate.ObjectData[0].FullID);
+ server.SendPacket(objupdate,true,kp.Value.NetInfo);
+ this.SendOtherAppearance(kp.Value.NetInfo,objupdate.ObjectData[0].FullID);
}
}
}
- public void send_intial_avatar_apper(User_Agent_info user)
+
+ ///
+ ///
+ ///
+ ///
+ public void SendIntialAvatarAppearance(User_Agent_info user)
{
-
- //seems that we don't send a avatarapperance for ourself.
- /*AvatarAppearancePacket avp=new AvatarAppearancePacket();
-
- avp.VisualParam=new AvatarAppearancePacket.VisualParamBlock[218];
- avp.ObjectData.TextureEntry=this.avatar_template.TextureEntry;// br.ReadBytes((int)numBytes);
-
- AvatarAppearancePacket.VisualParamBlock avblock=null;
- for(int i=0; i<218; i++)
- {
- avblock=new AvatarAppearancePacket.VisualParamBlock();
- avblock.ParamValue=(byte)100;
- avp.VisualParam[i]=avblock;
- }
-
- avp.Sender.IsTrial=false;
- avp.Sender.ID=user.AgentID;
- */
AgentWearablesUpdatePacket aw=new AgentWearablesUpdatePacket();
aw.AgentData.AgentID=user.AgentID;
@@ -323,22 +353,18 @@ namespace Second_server
aw.WearableData= new AgentWearablesUpdatePacket.WearableDataBlock[13];
AgentWearablesUpdatePacket.WearableDataBlock awb=null;
awb=new AgentWearablesUpdatePacket.WearableDataBlock();
- awb.WearableType=(byte)0;
- awb.AssetID=new LLUUID("66c41e39-38f9-f75a-024e-585989bfab73");
- //awb.ItemID=new LLUUID("b7878000-0000-0000-0000-000000000000");
- awb.ItemID=new LLUUID("b7878441893b094917f791174bc8401c");
- //awb.ItemID=new LLUUID("00000000-0000-0000-0000-000000000000");
- aw.WearableData[0]=awb;
-
-
- /*awb=new AgentWearablesUpdatePacket.WearableDataBlock();
- awb.WearableType=(byte)1;
- awb.AssetID=new LLUUID("e0ee49b5a4184df8d3c9a65361fe7f49");
- awb.ItemID=new LLUUID("193f0876fc11d143797454352f9c9c26");
- //awb.ItemID=new LLUUID("00000000-0000-0000-0000-000000000000");
- aw.WearableData[1]=awb;*/
-
-
+ awb.WearableType=(byte)0;
+ awb.AssetID=new LLUUID("66c41e39-38f9-f75a-024e-585989bfab73");
+ awb.ItemID=new LLUUID("b7878441893b094917f791174bc8401c");
+ aw.WearableData[0]=awb;
+
+ /*awb=new AgentWearablesUpdatePacket.WearableDataBlock();
+ awb.WearableType=(byte)1;
+ awb.AssetID=new LLUUID("e0ee49b5a4184df8d3c9a65361fe7f49");
+ awb.ItemID=new LLUUID("193f0876fc11d143797454352f9c9c26");
+ //awb.ItemID=new LLUUID("00000000-0000-0000-0000-000000000000");
+ aw.WearableData[1]=awb;*/
+
for(int i=1; i<13; i++)
{
awb=new AgentWearablesUpdatePacket.WearableDataBlock();
@@ -348,13 +374,15 @@ namespace Second_server
aw.WearableData[i]=awb;
}
- //server.SendPacket(avp,true,user);
server.SendPacket(aw,true,user);
- //System.Console.WriteLine(avp);
-
-
}
- public void send_other_apper(User_Agent_info user,LLUUID id)
+
+ ///
+ ///
+ ///
+ ///
+ ///
+ public void SendOtherAppearance(User_Agent_info user,LLUUID id)
{
AvatarAppearancePacket avp=new AvatarAppearancePacket();
@@ -384,47 +412,25 @@ namespace Second_server
server.SendPacket(avp,true,user);
}
-
- public void send_test_avatar_position(User_Agent_info User_info)
- {
- //send a objectupdate packet with information about the clients avatar
- ObjectUpdatePacket objupdate=new ObjectUpdatePacket();
- objupdate.RegionData.RegionHandle=1096213093147648;
- objupdate.RegionData.TimeDilation=64500;
- objupdate.ObjectData=new libsecondlife.Packets.ObjectUpdatePacket.ObjectDataBlock[1];
-
- objupdate.ObjectData[0]=avatar_template;
- //give this avatar object a local id and assign the user a name
- objupdate.ObjectData[0].ID=8880000+this.local_numer;
- objupdate.ObjectData[0].FullID=new LLUUID("00000000-0000-0000-5665-000000000034");
- objupdate.ObjectData[0].NameValue=enc.GetBytes("FirstName STRING RW SV Test"+ this.local_numer+"\nLastName STRING RW SV User \0");
- libsecondlife.LLVector3 pos2=new LLVector3(120f,120.0f,22.0f);
-
- byte[] pb=pos2.GetBytes();
-
- Array.Copy(pb,0,objupdate.ObjectData[0].ObjectData,16,pb.Length);
- this.local_numer++;
-
- server.SendPacket(objupdate,true,User_info);
-
- this.send_other_apper(User_info,new LLUUID("00000000-0000-0000-5665-000000000034"));
-
- }
-
- public void send_other_avatar_position(User_Agent_info User_info, Avatar_data avd)
+ ///
+ ///
+ ///
+ ///
+ ///
+ public void SendOtherAvatarPosition(User_Agent_info User_info, AvatarData avd)
{
//send a objectupdate packet with information about the clients avatar
ObjectUpdatePacket objupdate=new ObjectUpdatePacket();
- objupdate.RegionData.RegionHandle=1096213093147648;
+ objupdate.RegionData.RegionHandle=Globals.Instance.RegionHandle;
objupdate.RegionData.TimeDilation=64500;
objupdate.ObjectData=new libsecondlife.Packets.ObjectUpdatePacket.ObjectDataBlock[1];
- objupdate.ObjectData[0]=avatar_template;
+ objupdate.ObjectData[0]=AvatarTemplate;
//give this avatar object a local id and assign the user a name
- objupdate.ObjectData[0].ID=avd.Net_info.localID;
- objupdate.ObjectData[0].FullID=avd.Net_info.AgentID;//new LLUUID("00000000-0000-0000-5665-000000000034");
- objupdate.ObjectData[0].NameValue=enc.GetBytes(avd.Net_info.name);//enc.GetBytes("FirstName STRING RW SV Test"+ this.local_numer+"\nLastName STRING RW SV User \0");
- libsecondlife.LLVector3 pos2=new LLVector3(avd.pos.X,avd.pos.Y,avd.pos.Z);
+ objupdate.ObjectData[0].ID=avd.NetInfo.localID;
+ objupdate.ObjectData[0].FullID=avd.NetInfo.AgentID;//new LLUUID("00000000-0000-0000-5665-000000000034");
+ objupdate.ObjectData[0].NameValue=enc.GetBytes(avd.NetInfo.name);//enc.GetBytes("FirstName STRING RW SV Test"+ this.local_numer+"\nLastName STRING RW SV User \0");
+ libsecondlife.LLVector3 pos2=new LLVector3(avd.Position.X,avd.Position.Y,avd.Position.Z);
byte[] pb=pos2.GetBytes();
@@ -433,11 +439,16 @@ namespace Second_server
server.SendPacket(objupdate,true,User_info);
- this.send_other_apper(User_info,avd.Net_info.AgentID);//new LLUUID("00000000-0000-0000-5665-000000000034"));
+ this.SendOtherAppearance(User_info,avd.NetInfo.AgentID);//new LLUUID("00000000-0000-0000-5665-000000000034"));
}
- //*************************************************************
- public void send_chat_message(User_Agent_info User_info, string line)
+
+ ///
+ ///
+ ///
+ ///
+ ///
+ public void SendChatMessage(User_Agent_info User_info, string line)
{
libsecondlife.Packets.ChatFromSimulatorPacket reply=new ChatFromSimulatorPacket();
reply.ChatData.Audible=1;
@@ -452,23 +463,33 @@ namespace Second_server
server.SendPacket(reply,true,User_info);
//send to all users
- foreach (KeyValuePair kp in this.Agent_list)
+ foreach (KeyValuePair kp in this.AgentList)
{
- if(kp.Value.Net_info.AgentID!=User_info.AgentID)
+ if(kp.Value.NetInfo.AgentID!=User_info.AgentID)
{
- server.SendPacket(reply,true,kp.Value.Net_info);
+ server.SendPacket(reply,true,kp.Value.NetInfo);
}
}
}
- //*************************************************************
- public void send_move_command(User_Agent_info user, bool stop,float x, float y, float z, uint av_id, libsecondlife.LLQuaternion body)
+
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ public void SendMoveCommand(User_Agent_info user, bool stop,float x, float y, float z, uint av_id, libsecondlife.LLQuaternion body)
{
uint ID=user.localID;
//ID=av_id;
byte[] bytes=new byte[60];
ImprovedTerseObjectUpdatePacket im=new ImprovedTerseObjectUpdatePacket();
- im.RegionData.RegionHandle=1096213093147648;
+ im.RegionData.RegionHandle=Globals.Instance.RegionHandle;;
im.RegionData.TimeDilation=64096;
im.ObjectData=new ImprovedTerseObjectUpdatePacket.ObjectDataBlock[1];
@@ -477,7 +498,7 @@ namespace Second_server
im.ObjectData[0]=dat;
- dat.TextureEntry=avatar_template.TextureEntry;
+ dat.TextureEntry=AvatarTemplate.TextureEntry;
libsecondlife.LLVector3 pos2=new LLVector3(x,y,z);
bytes[i++] = (byte)(ID % 256);
@@ -571,16 +592,22 @@ namespace Second_server
server.SendPacket(im,true,user);
//should send to all users.
- foreach (KeyValuePair kp in this.Agent_list)
+ foreach (KeyValuePair kp in this.AgentList)
{
- if(kp.Value.Net_info.AgentID!=user.AgentID)
+ if(kp.Value.NetInfo.AgentID!=user.AgentID)
{
- server.SendPacket(im,true,kp.Value.Net_info);
+ server.SendPacket(im,true,kp.Value.NetInfo);
}
}
}
- //*************************************************************
- public void read_layerdata(User_Agent_info User_info,ref LayerDataPacket lay,string name)
+
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ public void SendLayerData(User_Agent_info User_info,ref LayerDataPacket lay,string name)
{
FileInfo fInfo = new FileInfo(name);
@@ -590,7 +617,7 @@ namespace Second_server
BinaryReader br = new BinaryReader(fStream);
- data1 = br.ReadBytes((int)numBytes);
+ byte [] data1 = br.ReadBytes((int)numBytes);
br.Close();
@@ -601,18 +628,32 @@ namespace Second_server
}
}
- public class Avatar_data
+ public class AvatarData
{
- public User_Agent_info Net_info;
- public LLUUID Full_ID;
- public LLVector3 pos;
- public LLVector3 vel=new LLVector3(0,0,0);
- public bool walk=false;
- public bool started=false;
+ public User_Agent_info NetInfo;
+ public LLUUID FullID;
+ public LLVector3 Position;
+ public LLVector3 Velocity=new LLVector3(0,0,0);
+ //public LLQuaternion Rotation;
+ public bool Walk=false;
+ public bool Started=false;
+ //public TextureEntry TextureEntry;
- public Avatar_data()
+ public AvatarData()
{
}
}
+ /*
+ public class AvatarParams
+ {
+ public byte[] Params;
+
+ public AvatarParams()
+ {
+
+ }
+
+ }
+ */
}
diff --git a/AssemblyInfo.cs b/AssemblyInfo.cs
index 2738c92..3fc9cb3 100644
--- a/AssemblyInfo.cs
+++ b/AssemblyInfo.cs
@@ -36,11 +36,11 @@ using System.Runtime.InteropServices;
// change them to the information which is associated with the assembly
// you compile.
-[assembly: AssemblyTitle("Second-server")]
+[assembly: AssemblyTitle("OpenSim")]
[assembly: AssemblyDescription("")]
[assembly: AssemblyConfiguration("")]
[assembly: AssemblyCompany("")]
-[assembly: AssemblyProduct("Second-server")]
+[assembly: AssemblyProduct("OpenSim")]
[assembly: AssemblyCopyright("")]
[assembly: AssemblyTrademark("")]
[assembly: AssemblyCulture("")]
@@ -56,4 +56,4 @@ using System.Runtime.InteropServices;
// You can specify all values by your own or you can build default build and revision
// numbers with the '*' character (the default):
-[assembly: AssemblyVersion("1.0.*")]
+[assembly: AssemblyVersion("0.1.*")]
diff --git a/Asset_manager.cs b/Asset_manager.cs
index 3723e1d..20cf3a1 100644
--- a/Asset_manager.cs
+++ b/Asset_manager.cs
@@ -34,26 +34,26 @@ using libsecondlife.Packets;
using libsecondlife.AssetSystem;
using System.IO;
-namespace Second_server
+namespace OpenSim
{
///
/// Description of Asset_manager.
///
- public class Asset_manager
+ public class AssetManager
{
- public Dictionary Assets;
+ public Dictionary Assets;
public ArrayList requests=new ArrayList(); //should change to a generic
// public ArrayList uploads=new ArrayList();
private Server server;
- public Asset_manager(Server serve)
+ public AssetManager(Server serve)
{
server=serve;
- Assets=new Dictionary ();
+ Assets=new Dictionary ();
this.initialise();
}
- public void add_request(User_Agent_info user, LLUUID asset_id, TransferRequestPacket tran_req)
+ public void AddRequest(User_Agent_info user, LLUUID asset_id, TransferRequestPacket tran_req)
{
if(!this.Assets.ContainsKey(asset_id))
@@ -61,18 +61,18 @@ namespace Second_server
//not found asset
return;
}
- Asset_info info=this.Assets[asset_id];
+ AssetInfo info=this.Assets[asset_id];
System.Console.WriteLine("send asset : "+asset_id);
//for now as it will be only skin or shape request just send back the asset
- TransferInfoPacket tran_i=new TransferInfoPacket();
- tran_i.TransferInfo.ChannelType=2;
- tran_i.TransferInfo.Status=0;
- tran_i.TransferInfo.TargetType=0;
- tran_i.TransferInfo.Params=tran_req.TransferInfo.Params;
- tran_i.TransferInfo.Size=info.data.Length;
- tran_i.TransferInfo.TransferID=tran_req.TransferInfo.TransferID;
+ TransferInfoPacket Transfer=new TransferInfoPacket();
+ Transfer.TransferInfo.ChannelType=2;
+ Transfer.TransferInfo.Status=0;
+ Transfer.TransferInfo.TargetType=0;
+ Transfer.TransferInfo.Params=tran_req.TransferInfo.Params;
+ Transfer.TransferInfo.Size=info.data.Length;
+ Transfer.TransferInfo.TransferID=tran_req.TransferInfo.TransferID;
- server.SendPacket(tran_i,true,user);
+ server.SendPacket(Transfer,true,user);
TransferPacketPacket tran_p=new TransferPacketPacket();
tran_p.TransferData.Packet=0;
@@ -110,14 +110,17 @@ namespace Second_server
private void initialise()
{
//for now read in our test image
- Asset_info im=new Asset_info();
+ AssetInfo im=new AssetInfo();
im.filename="base_shape.dat";
im.Full_ID=new LLUUID("66c41e39-38f9-f75a-024e-585989bfab73");
- this.load_asset(im);
+ this.loadAsset(im);
this.Assets.Add(im.Full_ID,im);
}
- private void load_asset(Asset_info info)
+ private void loadAsset(AssetInfo info)
{
+ //should request Asset from storage manager
+ //but for now read from file
+
string data_path = System.AppDomain.CurrentDomain.BaseDirectory + @"\assets\";
string filename=data_path+@info.filename;
FileInfo fInfo = new FileInfo(filename);
@@ -135,21 +138,21 @@ namespace Second_server
}
}
- public class Asset_request
+ public class AssetRequest
{
- public User_Agent_info req_user;
- public LLUUID req_image;
- public Asset_info asset_inf;
+ public User_Agent_info RequestUser;
+ public LLUUID RequestImage;
+ public AssetInfo asset_inf;
public long data_pointer=0;
public int num_packets=0;
public int packet_counter=0;
- public Asset_request()
+ public AssetRequest()
{
}
}
- public class Asset_info
+ public class AssetInfo
{
public byte[] data;
public LLUUID Full_ID;
@@ -159,7 +162,7 @@ namespace Second_server
public ulong last_used; //need to add a tick/time counter and keep record
// of how often images are requested to unload unused ones.
- public Asset_info()
+ public AssetInfo()
{
}
diff --git a/Controller.cs b/Controller.cs
index 351ff65..f2bd85c 100644
--- a/Controller.cs
+++ b/Controller.cs
@@ -38,11 +38,12 @@ using System.IO;
using Axiom.MathLib;
using log4net;
-namespace Second_server {
+namespace OpenSim
+{
///
/// Description of MainForm.
///
- public partial class Controller : Server_callback {
+ public partial class Controller : ServerCallback {
@@ -54,51 +55,79 @@ namespace Second_server {
}
public Server server;
-
- private Agent_Manager agent_man;
- private Prim_manager prim_man;
- private Texture_manager texture_man;
- private Asset_manager asset_man;
- private Login_manager login_man; //built in login server
+ public Logon _login;
+ private AgentManager Agent_Manager;
+ private PrimManager Prim_Manager;
+ private TextureManager Texture_Manager;
+ private AssetManager Asset_Manager;
+ private GridManager Grid_Manager;
+ private LoginManager Login_Manager; //built in login server
private ulong time; //ticks
private Timer timer1 = new Timer();
public Controller() {
+ _login=new Logon(); // should create a list for these.
server = new Server( this );
- agent_man = new Agent_Manager( this.server );
- prim_man = new Prim_manager( this.server );
- texture_man = new Texture_manager( this.server );
- asset_man = new Asset_manager( this.server );
- prim_man.agent_man = agent_man;
- agent_man.prim_man = prim_man;
- login_man = new Login_manager(); // startup
- login_man.startup(); // login server
- timer1.Enabled = true;
+ Agent_Manager = new AgentManager( this.server );
+ Prim_Manager = new PrimManager( this.server );
+ Texture_Manager = new TextureManager( this.server );
+ Asset_Manager = new AssetManager( this.server );
+ Prim_Manager.Agent_Manager = Agent_Manager;
+ Agent_Manager.Prim_Manager = Prim_Manager;
+ Grid_Manager=new GridManager(this.server,Agent_Manager);
+ if(Globals.Instance.LoginSever)
+ {
+ Console.WriteLine("Starting login Server");
+ Login_Manager = new LoginManager(_login); // startup
+ Login_Manager.Startup(); // login server
+ }
+ timer1.Enabled = true;
timer1.Interval = 200;
timer1.Elapsed +=new ElapsedEventHandler( this.Timer1Tick );
}
- public void main_callback( Packet pack, User_Agent_info User_info ) {
- if( ( pack.Type != PacketType.StartPingCheck ) && ( pack.Type != PacketType.AgentUpdate ) ) {
- System.Console.WriteLine(pack.Type);
+ public void MainCallback( Packet pack, User_Agent_info User_info ) {
+ //System.Console.WriteLine(pack.Type);
+ if( ( pack.Type != PacketType.StartPingCheck ) && ( pack.Type != PacketType.AgentUpdate ) ) {
+ // System.Console.WriteLine(pack.Type);
//this.richTextBox1.Text=this.richTextBox1.Text+"\n "+pack.Type;
}
if( pack.Type == PacketType.AgentSetAppearance ) {
- System.Console.WriteLine(pack);
+ // System.Console.WriteLine(pack);
//this.richTextBox1.Text=this.richTextBox1.Text+"\n "+pack.Type;
}
+ if(pack.Type== PacketType.MapBlockRequest)
+ {
+ //int MinX, MinY, MaxX, MaxY;
+ MapBlockRequestPacket MapRequest=(MapBlockRequestPacket)pack;
+ this.Grid_Manager.RequestMapBlock(User_info,MapRequest.PositionData.MinX,MapRequest.PositionData.MinY,MapRequest.PositionData.MaxX,MapRequest.PositionData.MaxY);
+
+ }
+ if(pack.Type== PacketType.CloseCircuit)
+ {
+ this.Agent_Manager.RemoveAgent(User_info);
+ }
+ if(pack.Type== PacketType.MapLayerRequest)
+ {
+ this.Grid_Manager.RequestMapLayer(User_info);
+
+ }
+ if((pack.Type== PacketType.TeleportRequest ) ||(pack.Type== PacketType.TeleportLocationRequest))
+ {
+ TeleportLocationRequestPacket Request=(TeleportLocationRequestPacket)pack;
+
+ this.Grid_Manager.RequestTeleport(User_info,Request);
+
+ }
if( pack.Type == PacketType.TransferRequest ) {
TransferRequestPacket tran = (TransferRequestPacket)pack;
LLUUID id = new LLUUID( tran.TransferInfo.Params, 0 );
if( ( id == new LLUUID( "66c41e39-38f9-f75a-024e-585989bfab73" ) ) || ( id == new LLUUID( "e0ee49b5a4184df8d3c9a65361fe7f49" ) ) ) {
- //System.Console.WriteLine(pack);
- //System.Console.WriteLine(tran.TransferInfo.TransferID);
- asset_man.add_request( User_info, id, tran );
- //this.richTextBox1.Text=this.richTextBox1.Text+"\n "+pack.Type;
+ Asset_Manager.AddRequest( User_info, id, tran );
}
}
@@ -111,23 +140,23 @@ namespace Second_server {
}
if( pack.Type == PacketType.CompleteAgentMovement ) {
// new client
- agent_man.Agent_join( User_info );
+ Agent_Manager.AgentJoin( User_info );
}
if( pack.Type == PacketType.RequestImage ) {
RequestImagePacket image_req = (RequestImagePacket)pack;
for( int i = 0; i < image_req.RequestImage.Length; i++ ) {
- this.texture_man.add_request( User_info, image_req.RequestImage[ i ].Image );
+ this.Texture_Manager.AddRequest( User_info, image_req.RequestImage[ i ].Image );
}
}
if( pack.Type == PacketType.RegionHandshakeReply ) {
//recieved regionhandshake so can now start sending info
- agent_man.send_intial_data( User_info );
+ Agent_Manager.SendInitialData( User_info );
//this.setuptemplates("objectupate164.dat",User_info,false);
}
if( pack.Type == PacketType.ObjectAdd ) {
ObjectAddPacket ad = (ObjectAddPacket)pack;
- prim_man.create_prim( User_info, ad.ObjectData.RayEnd, ad );
+ Prim_Manager.CreatePrim( User_info, ad.ObjectData.RayEnd, ad );
//this.send_prim(User_info,ad.ObjectData.RayEnd, ad);
}
if( pack.Type == PacketType.ObjectPosition ) {
@@ -141,46 +170,55 @@ namespace Second_server {
if( mupd.ObjectData[ i ].Type == 9 ) //change position
{
libsecondlife.LLVector3 pos = new LLVector3( mupd.ObjectData[ i ].Data, 0 );
-
- prim_man.update_prim_position( User_info, pos.X, pos.Y, pos.Z, mupd.ObjectData[ i ].ObjectLocalID );
+ // libsecondlife.LLQuaternion rot=new LLQuaternion(mupd.ObjectData[i].Data,12,true);
+ Prim_Manager.UpdatePrimPosition( User_info, pos, mupd.ObjectData[ i ].ObjectLocalID ,false ,libsecondlife.LLQuaternion.Identity);
//should update stored position of the prim
}
+ else if( mupd.ObjectData[ i ].Type == 10 )
+ {
+ //System.Console.WriteLine(mupd.ObjectData[ i ].Type);
+ //System.Console.WriteLine(mupd);
+ libsecondlife.LLVector3 pos = new LLVector3(100,100,22);
+ libsecondlife.LLQuaternion rot=new LLQuaternion(mupd.ObjectData[i].Data,0,true);
+ Prim_Manager.UpdatePrimPosition( User_info, pos, mupd.ObjectData[ i ].ObjectLocalID ,true ,rot);
+
+ }
}
}
if( pack.Type == PacketType.AgentWearablesRequest ) {
- agent_man.send_intial_avatar_apper( User_info );
+ Agent_Manager.SendIntialAvatarAppearance( User_info );
}
if( pack.Type == PacketType.AgentUpdate ) {
AgentUpdatePacket ag = (AgentUpdatePacket)pack;
uint mask = ag.AgentData.ControlFlags & ( 1 );
- Avatar_data m_av = agent_man.Get_Agent( User_info.AgentID );
+ AvatarData m_av = Agent_Manager.GetAgent( User_info.AgentID );
if( m_av != null ) {
- if( m_av.started ) {
+ if( m_av.Started ) {
if( mask == ( 1 ) ) {
- if( !m_av.walk ) {
+ if( !m_av.Walk ) {
//start walking
- agent_man.send_move_command( User_info, false, m_av.pos.X, m_av.pos.Y, m_av.pos.Z, 0, ag.AgentData.BodyRotation );
+ Agent_Manager.SendMoveCommand( User_info, false, m_av.Position.X, m_av.Position.Y, m_av.Position.Z, 0, ag.AgentData.BodyRotation );
Axiom.MathLib.Vector3 v3 = new Axiom.MathLib.Vector3( 1, 0, 0 );
Axiom.MathLib.Quaternion q = new Axiom.MathLib.Quaternion( ag.AgentData.BodyRotation.W, ag.AgentData.BodyRotation.X, ag.AgentData.BodyRotation.Y, ag.AgentData.BodyRotation.Z );
Axiom.MathLib.Vector3 direc = q * v3;
direc.Normalize();
direc = direc * ( ( 0.03f ) * 128f );
- m_av.vel.X = direc.x;
- m_av.vel.Y = direc.y;
- m_av.vel.Z = direc.z;
- m_av.walk = true;
+ m_av.Velocity.X = direc.x;
+ m_av.Velocity.Y = direc.y;
+ m_av.Velocity.Z = direc.z;
+ m_av.Walk = true;
}
}
else {
- if( m_av.walk ) {
+ if( m_av.Walk ) {
//walking but key not pressed so need to stop
- agent_man.send_move_command( User_info, true, m_av.pos.X, m_av.pos.Y, m_av.pos.Z, 0, ag.AgentData.BodyRotation );
- m_av.walk = false;
- m_av.vel.X = 0;
- m_av.vel.Y = 0;
- m_av.vel.Z = 0;
+ Agent_Manager.SendMoveCommand( User_info, true, m_av.Position.X, m_av.Position.Y, m_av.Position.Z, 0, ag.AgentData.BodyRotation );
+ m_av.Walk = false;
+ m_av.Velocity.X = 0;
+ m_av.Velocity.Y = 0;
+ m_av.Velocity.Z = 0;
}
}
}
@@ -205,25 +243,52 @@ namespace Second_server {
else if( comp[ 0 ] == "veloc" ) {
}
else {
- agent_man.send_chat_message( User_info, line );
+ Agent_Manager.SendChatMessage( User_info, line );
}
}
}
}
- public void new_user( User_Agent_info User_info ) {
- Console.WriteLine( "new user - {0} - has joined [session {1}]", User_info.AgentID.ToString(), User_info.SessionID.ToString() );
- agent_man.New_Agent( User_info );
+ public void NewUserCallback( User_Agent_info UserInfo ) {
+ Console.WriteLine( "new user - {0} - has joined [session {1}]", UserInfo.AgentID.ToString(), UserInfo.SessionID.ToString() +"curcuit used"+UserInfo.circuitCode);
+ string first,last;
+ lock(_login)
+ {
+ first=_login.first;
+ last=_login.last;
+
+ //should get agentid and sessionid so they can be checked.
+ }
+ Agent_Manager.NewAgent( UserInfo ,first,last);
+ //now because of the lack of Global account management (User server etc)
+ //we need to reset the names back to default incase a teleport happens
+ //which will not have a Login name set, so they will use default names
+ lock(_login)
+ {
+ _login.first="Test";
+ _login.last="User";
+ }
}
- public void error( string text ) {
+ public void ErrorCallback( string text ) {
Console.WriteLine( "error report: {0}", text );
}
void Timer1Tick( object sender, System.EventArgs e ) {
this.time++;
- agent_man.tick();
- texture_man.Do_work( time );
+ Agent_Manager.UpdatePositions();
+ Texture_Manager.DoWork( time );
}
}
-}
\ No newline at end of file
+ public class Logon
+ {
+ public string first="Test";
+ public string last="User";
+ public LLUUID Agent;
+ public LLUUID Session;
+ public Logon()
+ {
+
+ }
+ }
+}
diff --git a/Login_manager.cs b/Login_manager.cs
index 84f475d..a41bde3 100644
--- a/Login_manager.cs
+++ b/Login_manager.cs
@@ -25,7 +25,7 @@
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
-
+using Nwc.XmlRpc;
using System;
using System.IO;
using System.Net;
@@ -33,24 +33,27 @@ using System.Net.Sockets;
using System.Text;
using System.Text.RegularExpressions;
using System.Threading;
+using System.Collections;
+using libsecondlife;
-namespace Second_server
+namespace OpenSim
{
///
/// Description of Login_manager.
///
- public class Login_manager
+ public class LoginManager
{
- public Login_manager()
+ public LoginManager(Logon login)
{
-
+ Login=login;
}
-
+ public Logon Login;
public ushort loginPort = 8080;
public IPAddress clientAddress = IPAddress.Loopback;
public IPAddress remoteAddress = IPAddress.Any;
private Socket loginServer;
private Random RandomClass = new Random();
+ private int NumClients;
// InitializeLoginProxy: initialize the login proxy
private void InitializeLoginProxy() {
@@ -59,7 +62,7 @@ namespace Second_server
loginServer.Listen(1);
}
- public void startup()
+ public void Startup()
{
this.InitializeLoginProxy();
Thread runLoginProxy = new Thread(new ThreadStart(RunLoginProxy));
@@ -67,7 +70,7 @@ namespace Second_server
runLoginProxy.Start();
}
- private void RunLoginProxy() {
+ private void RunLoginProxy() {
try {
for (;;) {
Socket client = loginServer.Accept();
@@ -121,11 +124,52 @@ namespace Second_server
if (match.Success)
contentLength = Convert.ToInt32(match.Groups[1].Captures[0].ToString());
} while (line != "");
- System.Console.WriteLine(line);
+
// read the HTTP body into a buffer
char[] content = new char[contentLength];
reader.Read(content, 0, contentLength);
-
+ // System.Text.Encoding enc = System.Text.Encoding.ASCII;
+ XmlRpcRequest request = (XmlRpcRequest)(new XmlRpcRequestDeserializer()).Deserialize(new String(content));
+ Hashtable requestData = (Hashtable)request.Params[0];
+
+ string first;
+ string last;
+ LLUUID Agent;
+ LLUUID Session;
+
+ //get login name
+ if(requestData.Contains("first"))
+ {
+ first=(string)requestData["first"];
+ }
+ else
+ {
+ first="test";
+ }
+ if(requestData.Contains("last"))
+ {
+ last=(string)requestData["last"];
+ }
+ else
+ {
+ last="User"+NumClients.ToString();
+ }
+ NumClients++;
+
+ //create a agent and session LLUUID
+ int AgentRand=this.RandomClass.Next(1,9999);
+ Agent=new LLUUID("99998888-"+AgentRand.ToString("0000")+"-4f52-8ec1-0b1d5cd6aead");
+ int SessionRand=this.RandomClass.Next(1,999);
+ Session=new LLUUID("aaaabbbb-8932-"+SessionRand.ToString("0000")+"-8664-58f53e442797");
+
+ //copy data to login object
+ lock(Login)
+ {
+ Login.first=first;
+ Login.last=last;
+ Login.Agent=Agent;
+ Login.Session=Session;
+ }
// forward the XML-RPC response to the client
writer.WriteLine("HTTP/1.0 200 OK");
@@ -138,16 +182,16 @@ namespace Second_server
SR=File.OpenText("login.dat");
lines=SR.ReadLine();
writer.WriteLine(lines);
- lines=SR.ReadLine();
- int ran=this.RandomClass.Next(1,9999);
- lines="session_id99998888-"+ran.ToString("0000")+"-4f52-8ec1-0b1d5cd6aead";
+ lines=SR.ReadLine();
+ //lines="session_id"+Agent.ToString()+"";
+ lines="session_id99998888-"+AgentRand.ToString("0000")+"-4f52-8ec1-0b1d5cd6aead";
writer.WriteLine(lines);
lines=SR.ReadLine();
writer.WriteLine(lines);
lines=SR.ReadLine();
- ran=this.RandomClass.Next(1,9999);
- lines="agent_idaaaabbbb-8932-"+ran.ToString("0000")+"-8664-58f53e442797";
+ //lines="agent_id"+Session.ToString()+"";
+ lines="agent_idaaaabbbb-8932-"+SessionRand.ToString("0000")+"-8664-58f53e442797";
writer.WriteLine(lines);
lines=SR.ReadLine();
diff --git a/Prim_manager.cs b/Prim_manager.cs
index da1d626..1dc075b 100644
--- a/Prim_manager.cs
+++ b/Prim_manager.cs
@@ -35,53 +35,63 @@ using libsecondlife.AssetSystem;
using System.IO;
using Axiom.MathLib;
-namespace Second_server
+namespace OpenSim
{
///
/// Description of Prim_manager.
///
- public class Prim_manager
+ public class PrimManager
{
private Server server;
- public Agent_Manager agent_man;
+ public AgentManager Agent_Manager;
private uint prim_count;
- public libsecondlife.Packets.ObjectUpdatePacket.ObjectDataBlock object_template;
- public Dictionary Prim_list;
- public Prim_manager(Server serve)
+ public libsecondlife.Packets.ObjectUpdatePacket.ObjectDataBlock PrimTemplate;
+ public Dictionary PrimList;
+
+ ///
+ ///
+ ///
+ ///
+ public PrimManager(Server serve)
{
server=serve;
- Prim_list=new Dictionary ();
- this.setuptemplates("objectupate164.dat");
+ PrimList=new Dictionary ();
+ this.SetupTemplates("objectupate164.dat");
+
}
-
-
- //*********************************************************************
- public void create_prim(User_Agent_info User_info, libsecondlife.LLVector3 p1, ObjectAddPacket add_pack)
+
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ public void CreatePrim(User_Agent_info User_info, libsecondlife.LLVector3 p1, ObjectAddPacket add_pack)
{
ObjectUpdatePacket objupdate=new ObjectUpdatePacket();
- objupdate.RegionData.RegionHandle=1096213093147648;
+ objupdate.RegionData.RegionHandle=Globals.Instance.RegionHandle;
objupdate.RegionData.TimeDilation=64096;
objupdate.ObjectData=new libsecondlife.Packets.ObjectUpdatePacket.ObjectDataBlock[1];
-
- objupdate.ObjectData[0]=this.object_template;
- objupdate.ObjectData[0].OwnerID=User_info.AgentID;
- objupdate.ObjectData[0].PCode=add_pack.ObjectData.PCode;
- objupdate.ObjectData[0].PathBegin=add_pack.ObjectData.PathBegin;
- objupdate.ObjectData[0].PathEnd=add_pack.ObjectData.PathEnd;
- objupdate.ObjectData[0].PathScaleX=add_pack.ObjectData.PathScaleX;
- objupdate.ObjectData[0].PathScaleY=add_pack.ObjectData.PathScaleY;
- objupdate.ObjectData[0].PathShearX=add_pack.ObjectData.PathShearX;
- objupdate.ObjectData[0].PathShearY=add_pack.ObjectData.PathShearY;
- objupdate.ObjectData[0].PathSkew=add_pack.ObjectData.PathSkew;
- objupdate.ObjectData[0].ProfileBegin=add_pack.ObjectData.ProfileBegin;
- objupdate.ObjectData[0].ProfileEnd=add_pack.ObjectData.ProfileEnd;
- objupdate.ObjectData[0].Scale=add_pack.ObjectData.Scale;//new LLVector3(1,1,1);
- objupdate.ObjectData[0].PathCurve=add_pack.ObjectData.PathCurve;
- objupdate.ObjectData[0].ProfileCurve=add_pack.ObjectData.ProfileCurve;
- objupdate.ObjectData[0].ParentID=0;
- objupdate.ObjectData[0].ProfileHollow=add_pack.ObjectData.ProfileHollow;
+ PrimData PData=new PrimData();
+ objupdate.ObjectData[0]=this.PrimTemplate;
+ PData.OwnerID=objupdate.ObjectData[0].OwnerID=User_info.AgentID;
+ PData.PCode=objupdate.ObjectData[0].PCode=add_pack.ObjectData.PCode;
+ PData.PathBegin=objupdate.ObjectData[0].PathBegin=add_pack.ObjectData.PathBegin;
+ PData.PathEnd=objupdate.ObjectData[0].PathEnd=add_pack.ObjectData.PathEnd;
+ PData.PathScaleX=objupdate.ObjectData[0].PathScaleX=add_pack.ObjectData.PathScaleX;
+ PData.PathScaleY=objupdate.ObjectData[0].PathScaleY=add_pack.ObjectData.PathScaleY;
+ PData.PathShearX=objupdate.ObjectData[0].PathShearX=add_pack.ObjectData.PathShearX;
+ PData.PathShearY=objupdate.ObjectData[0].PathShearY=add_pack.ObjectData.PathShearY;
+ PData.PathSkew=objupdate.ObjectData[0].PathSkew=add_pack.ObjectData.PathSkew;
+ PData.ProfileBegin=objupdate.ObjectData[0].ProfileBegin=add_pack.ObjectData.ProfileBegin;
+ PData.ProfileEnd=objupdate.ObjectData[0].ProfileEnd=add_pack.ObjectData.ProfileEnd;
+ PData.Scale=objupdate.ObjectData[0].Scale=add_pack.ObjectData.Scale;//new LLVector3(1,1,1);
+ PData.PathCurve=objupdate.ObjectData[0].PathCurve=add_pack.ObjectData.PathCurve;
+ PData.ProfileCurve=objupdate.ObjectData[0].ProfileCurve=add_pack.ObjectData.ProfileCurve;
+ PData.ParentID=objupdate.ObjectData[0].ParentID=0;
+ PData.ProfileHollow=objupdate.ObjectData[0].ProfileHollow=add_pack.ObjectData.ProfileHollow;
//finish off copying rest of shape data
objupdate.ObjectData[0].ID=(uint)(702000+prim_count);
@@ -95,30 +105,40 @@ namespace Second_server
server.SendPacket(objupdate,true,User_info);
//should send to all users
- foreach (KeyValuePair kp in agent_man.Agent_list)
+ foreach (KeyValuePair kp in Agent_Manager.AgentList)
{
- if(kp.Value.Net_info.AgentID!=User_info.AgentID)
+ if(kp.Value.NetInfo.AgentID!=User_info.AgentID)
{
- server.SendPacket(objupdate,true,kp.Value.Net_info);
+ server.SendPacket(objupdate,true,kp.Value.NetInfo);
}
}
//should store this infomation
- prim_info n_prim=new prim_info();
- n_prim.full_ID=objupdate.ObjectData[0].FullID;
- n_prim.local_ID=objupdate.ObjectData[0].ID;
- n_prim.pos=p1;
+ PrimInfo NewPrim=new PrimInfo();
+ NewPrim.FullID=objupdate.ObjectData[0].FullID;
+ NewPrim.LocalID=objupdate.ObjectData[0].ID;
+ NewPrim.Position=p1;
+ NewPrim.data=PData;
- this.Prim_list.Add(n_prim.full_ID,n_prim);
+ this.PrimList.Add(NewPrim.FullID,NewPrim);
//store rest of data
}
- public void update_prim_position(User_Agent_info user,float x, float y, float z,uint l_id)
+
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ public void UpdatePrimPosition(User_Agent_info User,LLVector3 position,uint LocalID,bool setRotation, LLQuaternion rotation)
{
- prim_info pri=null;
- foreach (KeyValuePair kp in this.Prim_list)
+ PrimInfo pri=null;
+ foreach (KeyValuePair kp in this.PrimList)
{
- if(kp.Value.local_ID==l_id)
+ if(kp.Value.LocalID==LocalID)
{
pri=kp.Value;
}
@@ -127,18 +147,37 @@ namespace Second_server
{
return;
}
- uint ID=pri.local_ID;
+ uint ID=pri.LocalID;
+ libsecondlife.LLVector3 pos2=new LLVector3(position.X,position.Y,position.Z);
+ libsecondlife.LLQuaternion rotation2;
+ if(!setRotation)
+ {
+ pri.Position=pos2;
+ rotation2=new LLQuaternion(pri.Rotation.X,pri.Rotation.Y,pri.Rotation.Z,pri.Rotation.W);
+ }
+ else
+ {
+ rotation2=new LLQuaternion(rotation.X,rotation.Y,rotation.Z,rotation.W);
+
+ pos2=pri.Position;
+ pri.Rotation=rotation;
+ }
+ rotation2.W+=1;
+ rotation2.X+=1;
+ rotation2.Y+=1;
+ rotation2.Z+=1;
+
byte[] bytes=new byte[60];
ImprovedTerseObjectUpdatePacket im=new ImprovedTerseObjectUpdatePacket();
- im.RegionData.RegionHandle=1096213093147648;
+ im.RegionData.RegionHandle=Globals.Instance.RegionHandle;
im.RegionData.TimeDilation=64096;
im.ObjectData=new ImprovedTerseObjectUpdatePacket.ObjectDataBlock[1];
int i=0;
ImprovedTerseObjectUpdatePacket.ObjectDataBlock dat=new ImprovedTerseObjectUpdatePacket.ObjectDataBlock();
im.ObjectData[0]=dat;
- dat.TextureEntry=object_template.TextureEntry;
- libsecondlife.LLVector3 pos2=new LLVector3(x,y,z);
+ dat.TextureEntry=PrimTemplate.TextureEntry;
+ //System.Console.WriteLine("new position is :"+position);
bytes[i++] = (byte)(ID % 256);
bytes[i++] = (byte)((ID >> 8) % 256);
@@ -151,7 +190,7 @@ namespace Second_server
// bytes[i++]=128;
// bytes[i++]=63;
byte[] pb=pos2.GetBytes();
- pri.pos=pos2;
+ pri.Position=pos2;
Array.Copy(pb,0,bytes,i,pb.Length);
i+=12;
ushort ac=32767;
@@ -172,7 +211,27 @@ namespace Second_server
bytes[i++] = (byte)(ac % 256);
bytes[i++] = (byte)((ac >> 8) % 256);
+ //if(setRotation)
+ //{
+
+ ushort rw, rx,ry,rz;
+ rw=(ushort)(32768*rotation2.W);
+ rx=(ushort)(32768*rotation2.X);
+ ry=(ushort)(32768*rotation2.Y);
+ rz=(ushort)(32768*rotation2.Z);
+
//rot
+ bytes[i++] = (byte)(rx % 256);
+ bytes[i++] = (byte)((rx >> 8) % 256);
+ bytes[i++] = (byte)(ry % 256);
+ bytes[i++] = (byte)((ry >> 8) % 256);
+ bytes[i++] = (byte)(rz % 256);
+ bytes[i++] = (byte)((rz >> 8) % 256);
+ bytes[i++] = (byte)(rw % 256);
+ bytes[i++] = (byte)((rw >> 8) % 256);
+ //}
+ /*else
+ {
bytes[i++] = (byte)(ac % 256);
bytes[i++] = (byte)((ac >> 8) % 256);
bytes[i++] = (byte)(ac % 256);
@@ -181,7 +240,7 @@ namespace Second_server
bytes[i++] = (byte)((ac >> 8) % 256);
bytes[i++] = (byte)(ac % 256);
bytes[i++] = (byte)((ac >> 8) % 256);
-
+ }*/
//rotation vel
bytes[i++] = (byte)(ac % 256);
bytes[i++] = (byte)((ac >> 8) % 256);
@@ -193,23 +252,32 @@ namespace Second_server
dat.Data=bytes;
//server.SendPacket(im,true,user);
//should send to all users.
- foreach (KeyValuePair kp in agent_man.Agent_list)
+ foreach (KeyValuePair kp in Agent_Manager.AgentList)
{
- if(kp.Value.Net_info.AgentID!=user.AgentID)
+ if(kp.Value.NetInfo.AgentID!=User.AgentID)
{
- server.SendPacket(im,true,kp.Value.Net_info);
+ server.SendPacket(im,true,kp.Value.NetInfo);
}
}
}
- public void send_existing_prims(User_Agent_info user)
+
+ ///
+ ///
+ ///
+ ///
+ public void SendExistingPrims(User_Agent_info user)
{
//send data for already created prims to a new joining user
}
- //**************************************************************
- public void setuptemplates(string name)
+
+ ///
+ ///
+ ///
+ ///
+ public void SetupTemplates(string name)
{
ObjectUpdatePacket objupdate=new ObjectUpdatePacket();
- objupdate.RegionData.RegionHandle=1096213093147648;
+ objupdate.RegionData.RegionHandle=Globals.Instance.RegionHandle;
objupdate.RegionData.TimeDilation=64096;
objupdate.ObjectData=new libsecondlife.Packets.ObjectUpdatePacket.ObjectDataBlock[1];
@@ -224,7 +292,7 @@ namespace Second_server
libsecondlife.Packets.ObjectUpdatePacket.ObjectDataBlock objdata=new libsecondlife.Packets.ObjectUpdatePacket.ObjectDataBlock(data1,ref i);
objupdate.ObjectData[0]=objdata;
- this.object_template=objdata;
+ this.PrimTemplate=objdata;
objdata.UpdateFlags=objdata.UpdateFlags+12-16+32+256;
objdata.OwnerID=new LLUUID("00000000-0000-0000-0000-000000000000");
//test adding a new texture to object , to test image downloading
@@ -235,8 +303,13 @@ namespace Second_server
objdata.TextureEntry=ntex.ToBytes();
}
- //********************************************************************
- public void Read_Prim_database(string name,User_Agent_info user)
+
+ ///
+ ///
+ ///
+ ///
+ ///
+ public void ReadPrimDatabase(string name,User_Agent_info user)
{
StreamReader SR;
string line;
@@ -253,7 +326,7 @@ namespace Second_server
int num=Convert.ToInt32(comp[2]);
int start=Convert.ToInt32(comp[1]);
ObjectUpdatePacket objupdate=new ObjectUpdatePacket();
- objupdate.RegionData.RegionHandle=1096213093147648;
+ objupdate.RegionData.RegionHandle=Globals.Instance.RegionHandle;
objupdate.RegionData.TimeDilation=64096;
objupdate.ObjectData=new libsecondlife.Packets.ObjectUpdatePacket.ObjectDataBlock[num];
@@ -285,24 +358,44 @@ namespace Second_server
}
}
- public class prim_info
+ public class PrimInfo
{
- public LLVector3 pos;
- public LLVector3 vel;
- public uint local_ID;
- public LLUUID full_ID;
- public prim_data data;
+ public LLVector3 Position;
+ public LLVector3 Velocity;
+ public LLQuaternion Rotation=LLQuaternion.Identity;
+ public uint LocalID;
+ public LLUUID FullID;
+ public PrimData data;
- public prim_info()
+ public PrimInfo()
{
- pos=new LLVector3(0,0,0);
- vel=new LLVector3(0,0,0);
- data=new prim_data();
+ Position=new LLVector3(0,0,0);
+ Velocity=new LLVector3(0,0,0);
+ //data=new PrimData();
}
}
- public class prim_data
+ public class PrimData
{
- public prim_data()
+ public LLUUID OwnerID;
+ public byte PCode;
+ public byte PathBegin;
+ public byte PathEnd;
+ public byte PathScaleX;
+ public byte PathScaleY;
+ public byte PathShearX;
+ public byte PathShearY;
+ public sbyte PathSkew;
+ public byte ProfileBegin;
+ public byte ProfileEnd;
+ public LLVector3 Scale;
+ public byte PathCurve;
+ public byte ProfileCurve;
+ public uint ParentID=0;
+ public byte ProfileHollow;
+
+ public bool DataBaseStorage=false;
+
+ public PrimData()
{
}
diff --git a/Script_manager.cs b/Script_manager.cs
index 87f2eca..354247b 100644
--- a/Script_manager.cs
+++ b/Script_manager.cs
@@ -33,18 +33,18 @@ using System.Collections;
//using LuaInterface;
using libsecondlife;
-namespace Second_server
+namespace OpenSim
{
///
/// Description of Script_manager.
///
- public class Script_manager
+ public class ScriptManager
{
//public LuaInterface.Lua Lu;
//private ArrayList scripts;
//private prim_info current_prim;
- public Script_manager()
+ public ScriptManager()
{
}
@@ -54,36 +54,52 @@ namespace Second_server
//register any lua routines , like check finish script one
Lu.OpenMathLib();
}*/
- public void script_register( script_object_interface script)
+
+ private void RegisterFunctions()
{
- //called by scripts to register themselves
+ //lu.RegisterFunction( "RegisterScript",this,this.GetType().GetMethod("ScriptRegister"));
+ //lu.RegisterFunction( "MoveObject",this,this.GetType().GetMethod("MoveObject"));
+ //lu.RegisterFunction( "Say",this,this.GetType().GetMethod("Say"));
+
}
- public void Call_tick(prim_info prim)
+ public void Call_tick(PrimInfo prim)
{
//set current prim and then call tick function in linked script
}
- public void Call_click(prim_info prim)
+ public void Call_touch(PrimInfo prim)
{
//set current prim and then call clicked function in linked script
}
- private void Register_functions()
+ public void Call_on_rex(PrimInfo prim)
{
- //lu.RegisterFunction( "register_script",this,this.GetType().GetMethod("script_register"));
- //lu.RegisterFunction( "Move_object",this,this.GetType().GetMethod("Move_object"));
-
+ //set current prim and then call clicked function in linked script
+
}
- //Lua registered functions
- public void Move_object(float x ,float y, float z)
+
+ #region Lua Functions
+
+ public void ScriptRegister( script_object_interface script)
+ {
+ //called by scripts to register themselves
+ }
+ public void MoveObject(float x ,float y, float z)
{
}
+ public void Say(string message)
+ {
+
+ }
+ #endregion
+
}
public interface script_object_interface
{
- void Frame_tick();
- void clicked();
+ void frame_tick();
+ void touch(int num);
+ void on_rex(int num);
}
}
diff --git a/Second-server.csproj b/Second-server.csproj
index 79db97f..bb1c558 100644
--- a/Second-server.csproj
+++ b/Second-server.csproj
@@ -1,8 +1,8 @@
Exe
- Controller
- Second-server
+ OpenSim
+ OpenSim
Debug
AnyCPU
{132A6E3E-8F2D-4BF5-BDFB-8555F53F334E}
@@ -35,6 +35,10 @@
+
+ bin\Release\libsecondlife.dll
+ False
+
@@ -47,12 +51,9 @@
-
-
-
- {D9CDEDFB-8169-4B03-B57F-0DF638F044EC}
- libsecondlife
-
+
+
+
\ No newline at end of file
diff --git a/Second-server.sln b/Second-server.sln
index 9cdd672..2575f51 100644
--- a/Second-server.sln
+++ b/Second-server.sln
@@ -1,6 +1,6 @@
Microsoft Visual Studio Solution File, Format Version 9.00
-# Visual Studio 2005
+# SharpDevelop 2.1.0.2017
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Second-server", "Second-server.csproj", "{132A6E3E-8F2D-4BF5-BDFB-8555F53F334E}"
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "libsecondlife", "..\..\libsecondlife\libsecondlife-cs\libsecondlife.csproj", "{D9CDEDFB-8169-4B03-B57F-0DF638F044EC}"
@@ -27,6 +27,8 @@ Global
{D9CDEDFB-8169-4B03-B57F-0DF638F044EC}.Release|.NET 1.1.Build.0 = Release|.NET 1.1
{D9CDEDFB-8169-4B03-B57F-0DF638F044EC}.Release|Any CPU.ActiveCfg = Release|Any CPU
{D9CDEDFB-8169-4B03-B57F-0DF638F044EC}.Release|Any CPU.Build.0 = Release|Any CPU
+ {132A6E3E-8F2D-4BF5-BDFB-8555F53F334E}.Debug|.NET 1.1.Build.0 = Debug|.NET 1.1
+ {132A6E3E-8F2D-4BF5-BDFB-8555F53F334E}.Release|.NET 1.1.Build.0 = Release|.NET 1.1
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
diff --git a/Server.cs b/Server.cs
index 7bc4050..342592a 100644
--- a/Server.cs
+++ b/Server.cs
@@ -37,16 +37,17 @@ using System.Timers;
//really hacked , messy code
-namespace Second_server
+namespace OpenSim
{
///
/// Description of Server.
///
- public interface Server_callback
+ public interface ServerCallback
{
- void main_callback(Packet pack, User_Agent_info User_info);
- void new_user(User_Agent_info User_info);
- void error(string text);
+ //should replace with delegates
+ void MainCallback(Packet pack, User_Agent_info User_info);
+ void NewUserCallback(User_Agent_info User_info);
+ void ErrorCallback(string text);
}
public class Server
{
@@ -91,7 +92,7 @@ namespace Second_server
get { return connected; }
}
- private Server_callback callback_object;
+ private ServerCallback CallbackObject;
//private NetworkManager Network;
// private Dictionary> Callbacks;
private uint Sequence = 0;
@@ -125,10 +126,10 @@ namespace Second_server
///
///
///
- public Server(Server_callback s_callback)
+ public Server(ServerCallback s_callback)
{
- this.callback_object=s_callback;
+ this.CallbackObject=s_callback;
// Client = client;
// Network = client.Network;
// Callbacks = callbacks;
@@ -148,7 +149,7 @@ namespace Second_server
// Create an endpoint that we will be communicating with (need it in two
// types due to .NET weirdness)
// ipEndPoint = new IPEndPoint(ip, port);
- ipEndPoint = new IPEndPoint(IPAddress.Any, 1000);
+ ipEndPoint = new IPEndPoint(IPAddress.Any, Globals.Instance.IpPort);
endPoint = (EndPoint)ipEndPoint;
@@ -486,7 +487,7 @@ namespace Second_server
new_user.endpoint=epSender;
new_user.Inbox = new Queue(Settings.INBOX_SIZE);
- this.callback_object.new_user(new_user);
+ this.CallbackObject.NewUserCallback(new_user);
this.User_agents.Add(new_user);
}
@@ -526,14 +527,14 @@ namespace Second_server
{
//error finding agent
- this.callback_object.error("no user found");
+ this.CallbackObject.ErrorCallback("no user found");
return;
}
// Fail-safe check
if (packet == null)
{
- this.callback_object.error("couldn't build packet");
+ this.CallbackObject.ErrorCallback("couldn't build packet");
// Client.Log("Couldn't build a message from the incoming data", Helpers.LogLevel.Warning);
return;
}
@@ -615,7 +616,7 @@ namespace Second_server
}
// this.callback_object.error("calling callback");
- this.callback_object.main_callback(packet,User_info);
+ this.CallbackObject.MainCallback(packet,User_info);
// this.callback_object.error("finished");
// Fire the registered packet events
#region FireCallbacks
diff --git a/Texture_manager.cs b/Texture_manager.cs
index 1321358..0d88041 100644
--- a/Texture_manager.cs
+++ b/Texture_manager.cs
@@ -36,26 +36,26 @@ using libsecondlife.AssetSystem;
using System.IO;
-namespace Second_server
+namespace OpenSim
{
///
/// Description of Texture_manager.
///
- public class Texture_manager
+ public class TextureManager
{
- public Dictionary textures;
+ public Dictionary textures;
public ArrayList requests=new ArrayList(); //should change to a generic
public ArrayList uploads=new ArrayList();
private Server server;
- public Texture_manager(Server serve)
+ public TextureManager(Server serve)
{
server=serve;
- textures=new Dictionary ();
+ textures=new Dictionary ();
this.initialise();
}
- public void add_request(User_Agent_info user, LLUUID image_id)
+ public void AddRequest(User_Agent_info user, LLUUID image_id)
{
if(!this.textures.ContainsKey(image_id))
@@ -66,10 +66,10 @@ namespace Second_server
server.SendPacket(im_not,true,user);
return;
}
- Texture_image imag=this.textures[image_id];
- Texture_request req=new Texture_request();
- req.req_user=user;
- req.req_image=image_id;
+ TextureImage imag=this.textures[image_id];
+ TextureRequest req=new TextureRequest();
+ req.RequestUser=user;
+ req.RequestImage=image_id;
req.image_info=imag;
if(imag.data.LongLength>1000) //should be bigger or smaller?
@@ -87,11 +87,11 @@ namespace Second_server
}
- public void add_texture(LLUUID image_id, string name, byte[] data)
+ public void AddTexture(LLUUID image_id, string name, byte[] data)
{
}
- public void Do_work(ulong time)
+ public void DoWork(ulong time)
{
if(this.requests.Count==0)
{
@@ -109,10 +109,10 @@ namespace Second_server
{
num=5;
}
- Texture_request req;
+ TextureRequest req;
for(int i=0; i