aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim
diff options
context:
space:
mode:
authordiva2009-03-26 22:17:57 +0000
committerdiva2009-03-26 22:17:57 +0000
commita423b3060b0149d5e5725307bf5edb7be88b238d (patch)
tree967c2640798fa1741e3f1bac95d516567a8d1a3d /OpenSim
parent* correct iar root folder location for saving of individual items (diff)
downloadopensim-SC-a423b3060b0149d5e5725307bf5edb7be88b238d.zip
opensim-SC-a423b3060b0149d5e5725307bf5edb7be88b238d.tar.gz
opensim-SC-a423b3060b0149d5e5725307bf5edb7be88b238d.tar.bz2
opensim-SC-a423b3060b0149d5e5725307bf5edb7be88b238d.tar.xz
Notecard updates bypassing the regions. (HGStandalone only)
Diffstat (limited to 'OpenSim')
-rw-r--r--OpenSim/Framework/Communications/Capabilities/Caps.cs8
-rw-r--r--OpenSim/Region/CoreModules/Hypergrid/HGStandaloneInventoryService.cs133
2 files changed, 114 insertions, 27 deletions
diff --git a/OpenSim/Framework/Communications/Capabilities/Caps.cs b/OpenSim/Framework/Communications/Capabilities/Caps.cs
index 8a4d145..db58975 100644
--- a/OpenSim/Framework/Communications/Capabilities/Caps.cs
+++ b/OpenSim/Framework/Communications/Capabilities/Caps.cs
@@ -112,6 +112,10 @@ namespace OpenSim.Framework.Communications.Capabilities
112 { 112 {
113 get { return m_httpListener.SSLCommonName; } 113 get { return m_httpListener.SSLCommonName; }
114 } 114 }
115 public CapsHandlers CapsHandlers
116 {
117 get { return m_capsHandlers; }
118 }
115 119
116 // These are callbacks which will be setup by the scene so that we can update scene data when we 120 // These are callbacks which will be setup by the scene so that we can update scene data when we
117 // receive capability calls 121 // receive capability calls
@@ -626,7 +630,9 @@ namespace OpenSim.Framework.Communications.Capabilities
626 public string NoteCardAgentInventory(string request, string path, string param, 630 public string NoteCardAgentInventory(string request, string path, string param,
627 OSHttpRequest httpRequest, OSHttpResponse httpResponse) 631 OSHttpRequest httpRequest, OSHttpResponse httpResponse)
628 { 632 {
629 m_log.Debug("[CAPS]: NoteCardAgentInventory Request in region: " + m_regionName); 633 m_log.Debug("[CAPS]: NoteCardAgentInventory Request in region: " + m_regionName + "\n" + request);
634 m_log.Debug("[CAPS]: NoteCardAgentInventory Request is: " + request);
635
630 //OpenMetaverse.StructuredData.OSDMap hash = (OpenMetaverse.StructuredData.OSDMap)OpenMetaverse.StructuredData.LLSDParser.DeserializeBinary(Utils.StringToBytes(request)); 636 //OpenMetaverse.StructuredData.OSDMap hash = (OpenMetaverse.StructuredData.OSDMap)OpenMetaverse.StructuredData.LLSDParser.DeserializeBinary(Utils.StringToBytes(request));
631 Hashtable hash = (Hashtable) LLSD.LLSDDeserialize(Utils.StringToBytes(request)); 637 Hashtable hash = (Hashtable) LLSD.LLSDDeserialize(Utils.StringToBytes(request));
632 LLSDItemUpdate llsdRequest = new LLSDItemUpdate(); 638 LLSDItemUpdate llsdRequest = new LLSDItemUpdate();
diff --git a/OpenSim/Region/CoreModules/Hypergrid/HGStandaloneInventoryService.cs b/OpenSim/Region/CoreModules/Hypergrid/HGStandaloneInventoryService.cs
index b67f6f3..3665a4b 100644
--- a/OpenSim/Region/CoreModules/Hypergrid/HGStandaloneInventoryService.cs
+++ b/OpenSim/Region/CoreModules/Hypergrid/HGStandaloneInventoryService.cs
@@ -37,6 +37,8 @@ using OpenSim.Data;
37using OpenSim.Framework; 37using OpenSim.Framework;
38using OpenSim.Framework.Communications; 38using OpenSim.Framework.Communications;
39using OpenSim.Framework.Communications.Cache; 39using OpenSim.Framework.Communications.Cache;
40using Caps = OpenSim.Framework.Communications.Capabilities.Caps;
41using LLSDHelpers = OpenSim.Framework.Communications.Capabilities.LLSDHelpers;
40using OpenSim.Framework.Servers; 42using OpenSim.Framework.Servers;
41using OpenSim.Framework.Servers.Interfaces; 43using OpenSim.Framework.Servers.Interfaces;
42using OpenSim.Region.Framework.Interfaces; 44using OpenSim.Region.Framework.Interfaces;
@@ -108,6 +110,8 @@ namespace OpenSim.Region.CoreModules.Hypergrid
108 private Scene m_scene; 110 private Scene m_scene;
109 private bool m_doLookup = false; 111 private bool m_doLookup = false;
110 private string m_thisInventoryUrl = "http://localhost:9000"; 112 private string m_thisInventoryUrl = "http://localhost:9000";
113 private string m_thisHostname = "127.0.0.1";
114 private uint m_thisPort = 9000;
111 115
112 public bool DoLookup 116 public bool DoLookup
113 { 117 {
@@ -124,6 +128,13 @@ namespace OpenSim.Region.CoreModules.Hypergrid
124 if (!m_thisInventoryUrl.EndsWith("/")) 128 if (!m_thisInventoryUrl.EndsWith("/"))
125 m_thisInventoryUrl += "/"; 129 m_thisInventoryUrl += "/";
126 130
131 Uri uri = new Uri(m_thisInventoryUrl);
132 if (uri != null)
133 {
134 m_thisHostname = uri.Host;
135 m_thisPort = (uint)uri.Port;
136 }
137
127 m_assetProvider = ((AssetServerBase)m_scene.CommsManager.AssetCache.AssetServer).AssetProviderPlugin; 138 m_assetProvider = ((AssetServerBase)m_scene.CommsManager.AssetCache.AssetServer).AssetProviderPlugin;
128 139
129 AddHttpHandlers(); 140 AddHttpHandlers();
@@ -494,9 +505,63 @@ namespace OpenSim.Region.CoreModules.Hypergrid
494 return true; 505 return true;
495 } 506 }
496 507
508 /// <summary>
509 /// <see>CapsUpdatedInventoryItemAsset(IClientAPI, UUID, byte[])</see>
510 /// </summary>
511 public UUID UpdateInventoryItemAsset(UUID userID, UUID itemID, byte[] data)
512 {
513 m_log.Debug("[HGStandaloneInvService]: UpdateInventoryitemAsset for user " + userID + " item " + itemID);
514 InventoryItemBase item = m_inventoryService.GetInventoryItem(itemID);
515
516 if (item != null)
517 {
518 // We're still not dealing with permissions
519 //if ((InventoryType)item.InvType == InventoryType.Notecard)
520 //{
521 // if (!Permissions.CanEditNotecard(itemID, UUID.Zero, userID))
522 // {
523 // //remoteClient.SendAgentAlertMessage("Insufficient permissions to edit notecard", false);
524 // return UUID.Zero;
525 // }
526
527 // //remoteClient.SendAgentAlertMessage("Notecard saved", false);
528 //}
529 //else if ((InventoryType)item.InvType == InventoryType.LSL)
530 //{
531 // if (!Permissions.CanEditScript(itemID, UUID.Zero, remoteClient.AgentId))
532 // {
533 // //remoteClient.SendAgentAlertMessage("Insufficient permissions to edit script", false);
534 // return UUID.Zero;
535 // }
536
537 // //remoteClient.SendAgentAlertMessage("Script saved", false);
538 //}
539
540 AssetBase asset = CreateAsset(item.Name, item.Description, (sbyte)item.AssetType, data);
541 PostAsset(asset);
542
543 item.AssetID = asset.FullID;
544
545 return (asset.FullID);
546 }
547 return UUID.Zero;
548 }
549
550 private AssetBase CreateAsset(string name, string description, sbyte assetType, byte[] data)
551 {
552 AssetBase asset = new AssetBase();
553 asset.Name = name;
554 asset.Description = description;
555 asset.Type = assetType;
556 asset.FullID = UUID.Random();
557 asset.Data = (data == null) ? new byte[1] : data;
558
559 return asset;
560 }
561
497 #region Caps 562 #region Caps
498 563
499 Dictionary<UUID, List<string>> invCaps = new Dictionary<UUID, List<string>>(); 564 Dictionary<UUID, Hashtable> invCaps = new Dictionary<UUID, Hashtable>();
500 565
501 public Hashtable CapHandler(Hashtable request) 566 public Hashtable CapHandler(Hashtable request)
502 { 567 {
@@ -573,10 +638,11 @@ namespace OpenSim.Region.CoreModules.Hypergrid
573 638
574 // Then establish secret service handlers 639 // Then establish secret service handlers
575 640
576 RegisterCaps(userID, authToken); 641 Hashtable usercaps = RegisterCaps(userID, authToken);
577 642
578 responsedata["int_response_code"] = 200; 643 responsedata["int_response_code"] = 200;
579 responsedata["str_response_string"] = "OK"; 644 //responsedata["str_response_string"] = "OK";
645 responsedata["str_response_string"] = SerializeHashtable(usercaps);
580 } 646 }
581 else 647 else
582 { 648 {
@@ -638,7 +704,17 @@ namespace OpenSim.Region.CoreModules.Hypergrid
638 return false; 704 return false;
639 } 705 }
640 706
641 void RegisterCaps(UUID userID, string authToken) 707 string SerializeHashtable(Hashtable hash)
708 {
709 string result = string.Empty;
710 foreach (object key in hash.Keys)
711 {
712 result += key.ToString() + "," + hash[key].ToString() + ";";
713 }
714 return result;
715 }
716
717 Hashtable RegisterCaps(UUID userID, string authToken)
642 { 718 {
643 IHttpServer httpServer = m_scene.CommsManager.HttpServer; 719 IHttpServer httpServer = m_scene.CommsManager.HttpServer;
644 720
@@ -652,58 +728,63 @@ namespace OpenSim.Region.CoreModules.Hypergrid
652 } 728 }
653 } 729 }
654 730
655 List<string> caps = new List<string>(); 731 Caps caps = new Caps(null, httpServer, m_thisHostname, m_thisPort, authToken, userID, false, "Inventory");
732 caps.RegisterInventoryServiceHandlers("/" + authToken + "/InventoryCap/");
733 caps.ItemUpdatedCall = UpdateInventoryItemAsset;
734 Hashtable capsHandlers = caps.CapsHandlers.CapsDetails;
656 735
657 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<Guid, InventoryCollection>( 736 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<Guid, InventoryCollection>(
658 "POST", AddAndGetCapUrl(authToken, "/GetInventory/", caps), GetUserInventory, CheckAuthSession)); 737 "POST", AddAndGetCapUrl(authToken, "GetInventory", capsHandlers), GetUserInventory, CheckAuthSession));
659 738
660 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryFolderBase, InventoryCollection>( 739 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryFolderBase, InventoryCollection>(
661 "POST", AddAndGetCapUrl(authToken, "/FetchDescendants/", caps), FetchDescendants, CheckAuthSession)); 740 "POST", AddAndGetCapUrl(authToken, "FetchDescendants", capsHandlers), FetchDescendants, CheckAuthSession));
662 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryFolderBase, bool>( 741 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryFolderBase, bool>(
663 "POST", AddAndGetCapUrl(authToken, "/NewFolder/", caps), m_inventoryService.AddFolder, CheckAuthSession)); 742 "POST", AddAndGetCapUrl(authToken, "NewFolder", capsHandlers), m_inventoryService.AddFolder, CheckAuthSession));
664 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryFolderBase, bool>( 743 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryFolderBase, bool>(
665 "POST", AddAndGetCapUrl(authToken, "/UpdateFolder/", caps), m_inventoryService.UpdateFolder, CheckAuthSession)); 744 "POST", AddAndGetCapUrl(authToken, "UpdateFolder", capsHandlers), m_inventoryService.UpdateFolder, CheckAuthSession));
666 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryFolderBase, bool>( 745 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryFolderBase, bool>(
667 "POST", AddAndGetCapUrl(authToken, "/MoveFolder/", caps), m_inventoryService.MoveFolder, CheckAuthSession)); 746 "POST", AddAndGetCapUrl(authToken, "MoveFolder", capsHandlers), m_inventoryService.MoveFolder, CheckAuthSession));
668 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryFolderBase, bool>( 747 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryFolderBase, bool>(
669 "POST", AddAndGetCapUrl(authToken, "/PurgeFolder/", caps), m_inventoryService.PurgeFolder, CheckAuthSession)); 748 "POST", AddAndGetCapUrl(authToken, "PurgeFolder", capsHandlers), m_inventoryService.PurgeFolder, CheckAuthSession));
670 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryFolderBase, bool>( 749 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryFolderBase, bool>(
671 "POST", AddAndGetCapUrl(authToken, "/RemoveFolder/", caps), RemoveFolder, CheckAuthSession)); 750 "POST", AddAndGetCapUrl(authToken, "RemoveFolder", capsHandlers), RemoveFolder, CheckAuthSession));
672 751
673 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryItemBase, InventoryItemBase>( 752 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryItemBase, InventoryItemBase>(
674 "POST", AddAndGetCapUrl(authToken, "/GetItem/", caps), GetInventoryItem, CheckAuthSession)); 753 "POST", AddAndGetCapUrl(authToken, "GetItem", capsHandlers), GetInventoryItem, CheckAuthSession));
675 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryItemBase, InventoryItemBase>( 754 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryItemBase, InventoryItemBase>(
676 "POST", AddAndGetCapUrl(authToken, "/NewItem/", caps), AddItem, CheckAuthSession)); 755 "POST", AddAndGetCapUrl(authToken, "NewItem", capsHandlers), AddItem, CheckAuthSession));
677 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryItemBase, InventoryItemBase>( 756 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryItemBase, InventoryItemBase>(
678 "POST", AddAndGetCapUrl(authToken, "/UpdateItem/", caps), UpdateItem, CheckAuthSession)); 757 "POST", AddAndGetCapUrl(authToken, "UpdateItem", capsHandlers), UpdateItem, CheckAuthSession));
679 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryItemBase, InventoryItemBase>( 758 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryItemBase, InventoryItemBase>(
680 "POST", AddAndGetCapUrl(authToken, "/MoveItem/", caps), MoveItem, CheckAuthSession)); 759 "POST", AddAndGetCapUrl(authToken, "MoveItem", capsHandlers), MoveItem, CheckAuthSession));
681 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryItemBase, InventoryItemBase>( 760 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryItemBase, InventoryItemBase>(
682 "POST", AddAndGetCapUrl(authToken, "/DeleteItem/", caps), DeleteItem, CheckAuthSession)); 761 "POST", AddAndGetCapUrl(authToken, "DeleteItem", capsHandlers), DeleteItem, CheckAuthSession));
683 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryItemBase, InventoryItemBase>( 762 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryItemBase, InventoryItemBase>(
684 "POST", AddAndGetCapUrl(authToken, "/CopyItem/", caps), CopyItem, CheckAuthSession)); 763 "POST", AddAndGetCapUrl(authToken, "CopyItem", capsHandlers), CopyItem, CheckAuthSession));
685 764
686 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryItemBase, AssetBase>( 765 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<InventoryItemBase, AssetBase>(
687 "POST", AddAndGetCapUrl(authToken, "/GetAsset/", caps), GetAsset, CheckAuthSession)); 766 "POST", AddAndGetCapUrl(authToken, "GetAsset", capsHandlers), GetAsset, CheckAuthSession));
688 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<AssetBase, bool>( 767 httpServer.AddStreamHandler(new RestDeserialiseSecureHandler<AssetBase, bool>(
689 "POST", AddAndGetCapUrl(authToken, "/PostAsset/", caps), PostAsset, CheckAuthSession)); 768 "POST", AddAndGetCapUrl(authToken, "PostAsset", capsHandlers), PostAsset, CheckAuthSession));
690 769
691 lock (invCaps) 770 lock (invCaps)
692 invCaps.Add(userID, caps); 771 invCaps.Add(userID, capsHandlers);
772
773 return capsHandlers;
693 } 774 }
694 775
695 string AddAndGetCapUrl(string authToken, string capType, List<string> caps) 776 string AddAndGetCapUrl(string authToken, string capType, Hashtable caps)
696 { 777 {
697 string capUrl = "/" + authToken + capType; 778 string capUrl = "/" + authToken + "/" + capType + "/";
698 779
699 m_log.Debug("[HGStandaloneInvService] Adding inventory cap " + capUrl); 780 m_log.Debug("[HGStandaloneInvService] Adding inventory cap " + capUrl);
700 caps.Add(capUrl); 781 caps.Add(capType, capUrl);
701 return capUrl; 782 return capUrl;
702 } 783 }
703 784
704 void DeregisterCaps(IHttpServer httpServer, List<string> caps) 785 void DeregisterCaps(IHttpServer httpServer, Hashtable caps)
705 { 786 {
706 foreach (string capUrl in caps) 787 foreach (string capUrl in caps.Values)
707 { 788 {
708 m_log.Debug("[HGStandaloneInvService] Removing inventory cap " + capUrl); 789 m_log.Debug("[HGStandaloneInvService] Removing inventory cap " + capUrl);
709 httpServer.RemoveStreamHandler("POST", capUrl); 790 httpServer.RemoveStreamHandler("POST", capUrl);