diff options
Diffstat (limited to '')
-rw-r--r-- | OpenSim/Region/CoreModules/Avatar/ObjectCaps/UploadObjectAssetModule.cs | 124 |
1 files changed, 76 insertions, 48 deletions
diff --git a/OpenSim/Region/CoreModules/Avatar/ObjectCaps/UploadObjectAssetModule.cs b/OpenSim/Region/CoreModules/Avatar/ObjectCaps/UploadObjectAssetModule.cs index f1f219b..d5c6e9d 100644 --- a/OpenSim/Region/CoreModules/Avatar/ObjectCaps/UploadObjectAssetModule.cs +++ b/OpenSim/Region/CoreModules/Avatar/ObjectCaps/UploadObjectAssetModule.cs | |||
@@ -126,6 +126,14 @@ namespace OpenSim.Region.CoreModules.Avatar.ObjectCaps | |||
126 | 126 | ||
127 | #endregion | 127 | #endregion |
128 | 128 | ||
129 | |||
130 | /// <summary> | ||
131 | /// Parses ad request | ||
132 | /// </summary> | ||
133 | /// <param name="request"></param> | ||
134 | /// <param name="AgentId"></param> | ||
135 | /// <param name="cap"></param> | ||
136 | /// <returns></returns> | ||
129 | public Hashtable ProcessAdd(Hashtable request, UUID AgentId, Caps cap) | 137 | public Hashtable ProcessAdd(Hashtable request, UUID AgentId, Caps cap) |
130 | { | 138 | { |
131 | Hashtable responsedata = new Hashtable(); | 139 | Hashtable responsedata = new Hashtable(); |
@@ -147,9 +155,7 @@ namespace OpenSim.Region.CoreModules.Avatar.ObjectCaps | |||
147 | } | 155 | } |
148 | catch (Exception ex) | 156 | catch (Exception ex) |
149 | { | 157 | { |
150 | m_log.Error("[UploadObjectAssetModule]: Error deserializing message"); | 158 | m_log.Error("[UploadObjectAssetModule]: Error deserializing message " + ex.ToString()); |
151 | // TODO: Remove this ugly multiline-friendly debug! | ||
152 | Console.WriteLine(ex.ToString()); | ||
153 | message = null; | 159 | message = null; |
154 | } | 160 | } |
155 | 161 | ||
@@ -163,18 +169,25 @@ namespace OpenSim.Region.CoreModules.Avatar.ObjectCaps | |||
163 | 169 | ||
164 | return responsedata; | 170 | return responsedata; |
165 | } | 171 | } |
166 | 172 | ||
167 | Vector3 pos = avatar.AbsolutePosition + (Vector3.UnitX * avatar.Rotation); | 173 | Vector3 pos = avatar.AbsolutePosition + (Vector3.UnitX * avatar.Rotation); |
168 | Quaternion rot = Quaternion.Identity; | 174 | Quaternion rot = Quaternion.Identity; |
175 | Vector3 rootpos = Vector3.Zero; | ||
176 | Quaternion rootrot = Quaternion.Identity; | ||
169 | 177 | ||
170 | 178 | SceneObjectGroup rootGroup = null; | |
171 | 179 | SceneObjectGroup[] allparts = new SceneObjectGroup[message.Objects.Length]; | |
172 | SceneObjectGroup grp = new SceneObjectGroup(); | ||
173 | for (int i = 0; i < message.Objects.Length; i++) | 180 | for (int i = 0; i < message.Objects.Length; i++) |
174 | { | 181 | { |
175 | UploadObjectAssetMessage.Object obj = message.Objects[i]; | 182 | UploadObjectAssetMessage.Object obj = message.Objects[i]; |
176 | PrimitiveBaseShape pbs = PrimitiveBaseShape.CreateBox(); | 183 | PrimitiveBaseShape pbs = PrimitiveBaseShape.CreateBox(); |
177 | 184 | ||
185 | if (i == 0) | ||
186 | { | ||
187 | rootpos = obj.Position; | ||
188 | rootrot = obj.Rotation; | ||
189 | |||
190 | } | ||
178 | // Combine the extraparams data into it's ugly blob again.... | 191 | // Combine the extraparams data into it's ugly blob again.... |
179 | int bytelength = 0; | 192 | int bytelength = 0; |
180 | for (int extparams = 0; extparams < obj.ExtraParams.Length; extparams++) | 193 | for (int extparams = 0; extparams < obj.ExtraParams.Length; extparams++) |
@@ -186,34 +199,35 @@ namespace OpenSim.Region.CoreModules.Avatar.ObjectCaps | |||
186 | 199 | ||
187 | for (int extparams = 0; extparams < obj.ExtraParams.Length; extparams++) | 200 | for (int extparams = 0; extparams < obj.ExtraParams.Length; extparams++) |
188 | { | 201 | { |
189 | Buffer.BlockCopy(obj.ExtraParams[extparams].ExtraParamData, 0, extraparams, position, obj.ExtraParams[extparams].ExtraParamData.Length); | 202 | Buffer.BlockCopy(obj.ExtraParams[extparams].ExtraParamData, 0, extraparams, position, |
203 | obj.ExtraParams[extparams].ExtraParamData.Length); | ||
190 | 204 | ||
191 | position += obj.ExtraParams[extparams].ExtraParamData.Length; | 205 | position += obj.ExtraParams[extparams].ExtraParamData.Length; |
192 | } | 206 | } |
193 | 207 | ||
194 | pbs.ExtraParams = extraparams; | 208 | pbs.ExtraParams = extraparams; |
195 | 209 | ||
196 | pbs.PathBegin = (ushort)obj.PathBegin; | 210 | pbs.PathBegin = (ushort) obj.PathBegin; |
197 | pbs.PathCurve = (byte)obj.PathCurve; | 211 | pbs.PathCurve = (byte) obj.PathCurve; |
198 | pbs.PathEnd = (ushort)obj.PathEnd; | 212 | pbs.PathEnd = (ushort) obj.PathEnd; |
199 | pbs.PathRadiusOffset = (sbyte)obj.RadiusOffset; | 213 | pbs.PathRadiusOffset = (sbyte) obj.RadiusOffset; |
200 | pbs.PathRevolutions = (byte)obj.Revolutions; | 214 | pbs.PathRevolutions = (byte) obj.Revolutions; |
201 | pbs.PathScaleX = (byte)obj.ScaleX; | 215 | pbs.PathScaleX = (byte) obj.ScaleX; |
202 | pbs.PathScaleY = (byte)obj.ScaleY; | 216 | pbs.PathScaleY = (byte) obj.ScaleY; |
203 | pbs.PathShearX = (byte)obj.ShearX; | 217 | pbs.PathShearX = (byte) obj.ShearX; |
204 | pbs.PathShearY = (byte)obj.ShearY; | 218 | pbs.PathShearY = (byte) obj.ShearY; |
205 | pbs.PathSkew = (sbyte)obj.Skew; | 219 | pbs.PathSkew = (sbyte) obj.Skew; |
206 | pbs.PathTaperX = (sbyte)obj.TaperX; | 220 | pbs.PathTaperX = (sbyte) obj.TaperX; |
207 | pbs.PathTaperY = (sbyte)obj.TaperY; | 221 | pbs.PathTaperY = (sbyte) obj.TaperY; |
208 | pbs.PathTwist = (sbyte)obj.Twist; | 222 | pbs.PathTwist = (sbyte) obj.Twist; |
209 | pbs.PathTwistBegin = (sbyte)obj.TwistBegin; | 223 | pbs.PathTwistBegin = (sbyte) obj.TwistBegin; |
210 | pbs.HollowShape = (HollowShape)obj.ProfileHollow; | 224 | pbs.HollowShape = (HollowShape) obj.ProfileHollow; |
211 | pbs.PCode = (byte)PCode.Prim; | 225 | pbs.PCode = (byte) PCode.Prim; |
212 | pbs.ProfileBegin = (ushort)obj.ProfileBegin; | 226 | pbs.ProfileBegin = (ushort) obj.ProfileBegin; |
213 | pbs.ProfileCurve = (byte)obj.ProfileCurve; | 227 | pbs.ProfileCurve = (byte) obj.ProfileCurve; |
214 | pbs.ProfileEnd = (ushort)obj.ProfileEnd; | 228 | pbs.ProfileEnd = (ushort) obj.ProfileEnd; |
215 | pbs.Scale = obj.Scale; | 229 | pbs.Scale = obj.Scale; |
216 | pbs.State = (byte)0; | 230 | pbs.State = (byte) 0; |
217 | SceneObjectPart prim = new SceneObjectPart(); | 231 | SceneObjectPart prim = new SceneObjectPart(); |
218 | prim.UUID = UUID.Random(); | 232 | prim.UUID = UUID.Random(); |
219 | prim.CreatorID = AgentId; | 233 | prim.CreatorID = AgentId; |
@@ -229,13 +243,14 @@ namespace OpenSim.Region.CoreModules.Avatar.ObjectCaps | |||
229 | prim.PayPrice[2] = -2; | 243 | prim.PayPrice[2] = -2; |
230 | prim.PayPrice[3] = -2; | 244 | prim.PayPrice[3] = -2; |
231 | prim.PayPrice[4] = -2; | 245 | prim.PayPrice[4] = -2; |
232 | Primitive.TextureEntry tmp = new Primitive.TextureEntry(UUID.Parse("89556747-24cb-43ed-920b-47caed15465f")); | 246 | Primitive.TextureEntry tmp = |
247 | new Primitive.TextureEntry(UUID.Parse("89556747-24cb-43ed-920b-47caed15465f")); | ||
233 | 248 | ||
234 | for (int j = 0; j < obj.Faces.Length; j++) | 249 | for (int j = 0; j < obj.Faces.Length; j++) |
235 | { | 250 | { |
236 | UploadObjectAssetMessage.Object.Face face = obj.Faces[j]; | 251 | UploadObjectAssetMessage.Object.Face face = obj.Faces[j]; |
237 | 252 | ||
238 | Primitive.TextureEntryFace primFace = tmp.CreateFace((uint)j); | 253 | Primitive.TextureEntryFace primFace = tmp.CreateFace((uint) j); |
239 | 254 | ||
240 | primFace.Bump = face.Bump; | 255 | primFace.Bump = face.Bump; |
241 | primFace.RGBA = face.Color; | 256 | primFace.RGBA = face.Color; |
@@ -249,7 +264,7 @@ namespace OpenSim.Region.CoreModules.Avatar.ObjectCaps | |||
249 | primFace.OffsetV = face.OffsetT; | 264 | primFace.OffsetV = face.OffsetT; |
250 | primFace.RepeatU = face.ScaleS; | 265 | primFace.RepeatU = face.ScaleS; |
251 | primFace.RepeatV = face.ScaleT; | 266 | primFace.RepeatV = face.ScaleT; |
252 | primFace.TexMapType = (MappingType)(face.MediaFlags & 6); | 267 | primFace.TexMapType = (MappingType) (face.MediaFlags & 6); |
253 | } | 268 | } |
254 | pbs.TextureEntry = tmp.GetBytes(); | 269 | pbs.TextureEntry = tmp.GetBytes(); |
255 | prim.Shape = pbs; | 270 | prim.Shape = pbs; |
@@ -257,34 +272,47 @@ namespace OpenSim.Region.CoreModules.Avatar.ObjectCaps | |||
257 | prim.Shape.SculptEntry = true; | 272 | prim.Shape.SculptEntry = true; |
258 | prim.Shape.SculptTexture = obj.SculptID; | 273 | prim.Shape.SculptTexture = obj.SculptID; |
259 | prim.Shape.SculptType = (byte) SculptType.Mesh; | 274 | prim.Shape.SculptType = (byte) SculptType.Mesh; |
260 | 275 | ||
276 | SceneObjectGroup grp = new SceneObjectGroup(); | ||
277 | |||
278 | grp.SetRootPart(prim); | ||
279 | prim.ParentID = 0; | ||
261 | if (i == 0) | 280 | if (i == 0) |
262 | { | 281 | { |
263 | grp.SetRootPart(prim); | 282 | rootGroup = grp; |
264 | prim.ParentID = 0; | 283 | |
265 | } | 284 | } |
266 | else | 285 | grp.AttachToScene(m_scene); |
286 | grp.AbsolutePosition = obj.Position; | ||
287 | prim.RotationOffset = obj.Rotation; | ||
288 | |||
289 | grp.RootPart.IsAttachment = false; | ||
290 | // Required for linking | ||
291 | grp.RootPart.UpdateFlag = 0; | ||
292 | |||
293 | if (m_scene.Permissions.CanRezObject(1, avatar.UUID, pos)) | ||
267 | { | 294 | { |
268 | prim.SetParent(grp); | 295 | m_scene.AddSceneObject(grp); |
269 | grp.AddPart(prim); | 296 | grp.AbsolutePosition = obj.Position; |
270 | } | 297 | } |
271 | 298 | allparts[i] = grp; | |
299 | |||
272 | } | 300 | } |
273 | pos = m_scene.GetNewRezLocation(Vector3.Zero, pos, UUID.Zero, rot, (byte)1 , 1 , true, grp.GroupScale(), false); | 301 | |
274 | grp.AttachToScene(m_scene); | 302 | for (int j = 1; j < allparts.Length; j++) |
275 | grp.AbsolutePosition = pos; | ||
276 | grp.ClearPartAttachmentData(); | ||
277 | grp.RootPart.IsAttachment = false; | ||
278 | |||
279 | if (m_scene.Permissions.CanRezObject(1, avatar.UUID, pos)) | ||
280 | { | 303 | { |
281 | m_scene.AddSceneObject(grp); | 304 | rootGroup.RootPart.UpdateFlag = 0; |
305 | allparts[j].RootPart.UpdateFlag = 0; | ||
306 | rootGroup.LinkToGroup(allparts[j]); | ||
282 | } | 307 | } |
283 | grp.ScheduleGroupForFullUpdate(); | 308 | |
309 | rootGroup.ScheduleGroupForFullUpdate(); | ||
310 | pos = m_scene.GetNewRezLocation(Vector3.Zero, rootpos, UUID.Zero, rot, (byte)1, 1, true, allparts[0].GroupScale(), false); | ||
311 | |||
284 | responsedata["int_response_code"] = 200; //501; //410; //404; | 312 | responsedata["int_response_code"] = 200; //501; //410; //404; |
285 | responsedata["content_type"] = "text/plain"; | 313 | responsedata["content_type"] = "text/plain"; |
286 | responsedata["keepalive"] = false; | 314 | responsedata["keepalive"] = false; |
287 | responsedata["str_response_string"] = String.Format("<llsd><map><key>local_id</key>{0}</map></llsd>", ConvertUintToBytes(grp.LocalId)); | 315 | responsedata["str_response_string"] = String.Format("<llsd><map><key>local_id</key>{0}</map></llsd>", ConvertUintToBytes(allparts[0].LocalId)); |
288 | 316 | ||
289 | return responsedata; | 317 | return responsedata; |
290 | 318 | ||