diff options
author | lbsa71 | 2009-02-20 02:26:27 +0000 |
---|---|---|
committer | lbsa71 | 2009-02-20 02:26:27 +0000 |
commit | 5e39e515f93649da113973835596749a94637689 (patch) | |
tree | 10210e2531261f643ba1950824fba7decb88eb71 /OpenSim/Framework/Servers/GetAssetStreamHandler.cs | |
parent | This moves the 2 friends-related interregion messages out of OGS1 and into th... (diff) | |
download | opensim-SC-5e39e515f93649da113973835596749a94637689.zip opensim-SC-5e39e515f93649da113973835596749a94637689.tar.gz opensim-SC-5e39e515f93649da113973835596749a94637689.tar.bz2 opensim-SC-5e39e515f93649da113973835596749a94637689.tar.xz |
* Another stab at removing AssetServer.exe dependencies
Diffstat (limited to '')
-rw-r--r-- | OpenSim/Framework/Servers/GetAssetStreamHandler.cs (renamed from OpenSim/Grid/AssetServer/RestService.cs) | 251 |
1 files changed, 95 insertions, 156 deletions
diff --git a/OpenSim/Grid/AssetServer/RestService.cs b/OpenSim/Framework/Servers/GetAssetStreamHandler.cs index 1e01c44..d278a05 100644 --- a/OpenSim/Grid/AssetServer/RestService.cs +++ b/OpenSim/Framework/Servers/GetAssetStreamHandler.cs | |||
@@ -1,156 +1,95 @@ | |||
1 | /* | 1 | using System; |
2 | * Copyright (c) Contributors, http://opensimulator.org/ | 2 | using System.IO; |
3 | * See CONTRIBUTORS.TXT for a full list of copyright holders. | 3 | using System.Reflection; |
4 | * | 4 | using System.Text; |
5 | * Redistribution and use in source and binary forms, with or without | 5 | using System.Xml; |
6 | * modification, are permitted provided that the following conditions are met: | 6 | using System.Xml.Serialization; |
7 | * * Redistributions of source code must retain the above copyright | 7 | using log4net; |
8 | * notice, this list of conditions and the following disclaimer. | 8 | using OpenMetaverse; |
9 | * * Redistributions in binary form must reproduce the above copyright | 9 | using OpenSim.Data; |
10 | * notice, this list of conditions and the following disclaimer in the | 10 | using OpenSim.Framework; |
11 | * documentation and/or other materials provided with the distribution. | 11 | using OpenSim.Framework.Servers; |
12 | * * Neither the name of the OpenSim Project nor the | 12 | using OpenSim.Framework.Statistics; |
13 | * names of its contributors may be used to endorse or promote products | 13 | |
14 | * derived from this software without specific prior written permission. | 14 | namespace OpenSim.Framework.Servers |
15 | * | 15 | { |
16 | * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY | 16 | public class GetAssetStreamHandler : BaseStreamHandler |
17 | * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | 17 | { |
18 | * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | 18 | private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); |
19 | * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY | 19 | |
20 | * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | 20 | // private OpenAsset_Main m_assetManager; |
21 | * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | 21 | private IAssetDataPlugin m_assetProvider; |
22 | * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | 22 | |
23 | * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 23 | /// <summary> |
24 | * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | 24 | /// Constructor. |
25 | * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 25 | /// </summary> |
26 | */ | 26 | /// <param name="assetManager"></param> |
27 | 27 | /// <param name="assetProvider"></param> | |
28 | using System; | 28 | public GetAssetStreamHandler(IAssetDataPlugin assetProvider) |
29 | using System.IO; | 29 | : base("GET", "/assets") |
30 | using System.Reflection; | 30 | { |
31 | using System.Text; | 31 | m_log.Info("[REST]: In Get Request"); |
32 | using System.Xml; | 32 | // m_assetManager = assetManager; |
33 | using System.Xml.Serialization; | 33 | m_assetProvider = assetProvider; |
34 | using log4net; | 34 | } |
35 | using OpenMetaverse; | 35 | |
36 | using OpenSim.Data; | 36 | public override byte[] Handle(string path, Stream request, |
37 | using OpenSim.Framework; | 37 | OSHttpRequest httpRequest, OSHttpResponse httpResponse) |
38 | using OpenSim.Framework.Servers; | 38 | { |
39 | using OpenSim.Framework.Statistics; | 39 | string param = GetParam(path); |
40 | 40 | byte[] result = new byte[] {}; | |
41 | namespace OpenSim.Grid.AssetServer | 41 | |
42 | { | 42 | string[] p = param.Split(new char[] {'/', '?', '&'}, StringSplitOptions.RemoveEmptyEntries); |
43 | public class GetAssetStreamHandler : BaseStreamHandler | 43 | |
44 | { | 44 | if (p.Length > 0) |
45 | private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); | 45 | { |
46 | 46 | UUID assetID = UUID.Zero; | |
47 | // private OpenAsset_Main m_assetManager; | 47 | |
48 | private IAssetDataPlugin m_assetProvider; | 48 | if (!UUID.TryParse(p[0], out assetID)) |
49 | 49 | { | |
50 | /// <summary> | 50 | m_log.InfoFormat( |
51 | /// Constructor. | 51 | "[REST]: GET:/asset ignoring request with malformed UUID {0}", p[0]); |
52 | /// </summary> | 52 | return result; |
53 | /// <param name="assetManager"></param> | 53 | } |
54 | /// <param name="assetProvider"></param> | 54 | |
55 | public GetAssetStreamHandler(IAssetDataPlugin assetProvider) | 55 | if (StatsManager.AssetStats != null) |
56 | : base("GET", "/assets") | 56 | StatsManager.AssetStats.AddRequest(); |
57 | { | 57 | |
58 | m_log.Info("[REST]: In Get Request"); | 58 | AssetBase asset = m_assetProvider.FetchAsset(assetID); |
59 | // m_assetManager = assetManager; | 59 | if (asset != null) |
60 | m_assetProvider = assetProvider; | 60 | { |
61 | } | 61 | XmlSerializer xs = new XmlSerializer(typeof (AssetBase)); |
62 | 62 | MemoryStream ms = new MemoryStream(); | |
63 | public override byte[] Handle(string path, Stream request, | 63 | XmlTextWriter xw = new XmlTextWriter(ms, Encoding.UTF8); |
64 | OSHttpRequest httpRequest, OSHttpResponse httpResponse) | 64 | xw.Formatting = Formatting.Indented; |
65 | { | 65 | xs.Serialize(xw, asset); |
66 | string param = GetParam(path); | 66 | xw.Flush(); |
67 | byte[] result = new byte[] {}; | 67 | |
68 | 68 | ms.Seek(0, SeekOrigin.Begin); | |
69 | string[] p = param.Split(new char[] {'/', '?', '&'}, StringSplitOptions.RemoveEmptyEntries); | 69 | //StreamReader sr = new StreamReader(ms); |
70 | 70 | ||
71 | if (p.Length > 0) | 71 | result = ms.GetBuffer(); |
72 | { | 72 | |
73 | UUID assetID = UUID.Zero; | 73 | //Ckrinke 1/11/09 Commenting out the succesful REST message as under heavy use there |
74 | 74 | //are multiple messages in a second and that is usually (in my experience) meaning | |
75 | if (!UUID.TryParse(p[0], out assetID)) | 75 | //the logging itself is slowing down the program. Leaving the unsuccesful message |
76 | { | 76 | //as we need to know about that path. |
77 | m_log.InfoFormat( | 77 | // m_log.InfoFormat( |
78 | "[REST]: GET:/asset ignoring request with malformed UUID {0}", p[0]); | 78 | // "[REST]: GET:/asset found {0} with name {1}, size {2} bytes", |
79 | return result; | 79 | // assetID, asset.Name, result.Length); |
80 | } | 80 | |
81 | 81 | Array.Resize<byte>(ref result, (int) ms.Length); | |
82 | if (StatsManager.AssetStats != null) | 82 | } |
83 | StatsManager.AssetStats.AddRequest(); | 83 | else |
84 | 84 | { | |
85 | AssetBase asset = m_assetProvider.FetchAsset(assetID); | 85 | if (StatsManager.AssetStats != null) |
86 | if (asset != null) | 86 | StatsManager.AssetStats.AddNotFoundRequest(); |
87 | { | 87 | |
88 | XmlSerializer xs = new XmlSerializer(typeof (AssetBase)); | 88 | m_log.InfoFormat("[REST]: GET:/asset failed to find {0}", assetID); |
89 | MemoryStream ms = new MemoryStream(); | 89 | } |
90 | XmlTextWriter xw = new XmlTextWriter(ms, Encoding.UTF8); | 90 | } |
91 | xw.Formatting = Formatting.Indented; | 91 | |
92 | xs.Serialize(xw, asset); | 92 | return result; |
93 | xw.Flush(); | 93 | } |
94 | 94 | } | |
95 | ms.Seek(0, SeekOrigin.Begin); | 95 | } \ No newline at end of file |
96 | //StreamReader sr = new StreamReader(ms); | ||
97 | |||
98 | result = ms.GetBuffer(); | ||
99 | |||
100 | //Ckrinke 1/11/09 Commenting out the succesful REST message as under heavy use there | ||
101 | //are multiple messages in a second and that is usually (in my experience) meaning | ||
102 | //the logging itself is slowing down the program. Leaving the unsuccesful message | ||
103 | //as we need to know about that path. | ||
104 | // m_log.InfoFormat( | ||
105 | // "[REST]: GET:/asset found {0} with name {1}, size {2} bytes", | ||
106 | // assetID, asset.Name, result.Length); | ||
107 | |||
108 | Array.Resize<byte>(ref result, (int) ms.Length); | ||
109 | } | ||
110 | else | ||
111 | { | ||
112 | if (StatsManager.AssetStats != null) | ||
113 | StatsManager.AssetStats.AddNotFoundRequest(); | ||
114 | |||
115 | m_log.InfoFormat("[REST]: GET:/asset failed to find {0}", assetID); | ||
116 | } | ||
117 | } | ||
118 | |||
119 | return result; | ||
120 | } | ||
121 | } | ||
122 | |||
123 | public class PostAssetStreamHandler : BaseStreamHandler | ||
124 | { | ||
125 | private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); | ||
126 | |||
127 | // private OpenAsset_Main m_assetManager; | ||
128 | private IAssetDataPlugin m_assetProvider; | ||
129 | |||
130 | public override byte[] Handle(string path, Stream request, | ||
131 | OSHttpRequest httpRequest, OSHttpResponse httpResponse) | ||
132 | { | ||
133 | string param = GetParam(path); | ||
134 | |||
135 | UUID assetId; | ||
136 | if (param.Length > 0) | ||
137 | UUID.TryParse(param, out assetId); | ||
138 | // byte[] txBuffer = new byte[4096]; | ||
139 | |||
140 | XmlSerializer xs = new XmlSerializer(typeof (AssetBase)); | ||
141 | AssetBase asset = (AssetBase) xs.Deserialize(request); | ||
142 | |||
143 | m_log.InfoFormat("[REST]: Creating asset {0}", asset.FullID); | ||
144 | m_assetProvider.CreateAsset(asset); | ||
145 | |||
146 | return new byte[] {}; | ||
147 | } | ||
148 | |||
149 | public PostAssetStreamHandler(IAssetDataPlugin assetProvider) | ||
150 | : base("POST", "/assets") | ||
151 | { | ||
152 | // m_assetManager = assetManager; | ||
153 | m_assetProvider = assetProvider; | ||
154 | } | ||
155 | } | ||
156 | } | ||