diff options
Diffstat (limited to '')
-rw-r--r-- | OpenSim/Services/GridService/GridService.cs | 145 |
1 files changed, 45 insertions, 100 deletions
diff --git a/OpenSim/Services/GridService/GridService.cs b/OpenSim/Services/GridService/GridService.cs index 2229421..991acf2 100644 --- a/OpenSim/Services/GridService/GridService.cs +++ b/OpenSim/Services/GridService/GridService.cs | |||
@@ -35,6 +35,7 @@ using OpenSim.Framework; | |||
35 | using OpenSim.Framework.Console; | 35 | using OpenSim.Framework.Console; |
36 | using OpenSim.Data; | 36 | using OpenSim.Data; |
37 | using OpenSim.Services.Interfaces; | 37 | using OpenSim.Services.Interfaces; |
38 | using GridRegion = OpenSim.Services.Interfaces.GridRegion; | ||
38 | using OpenMetaverse; | 39 | using OpenMetaverse; |
39 | 40 | ||
40 | namespace OpenSim.Services.GridService | 41 | namespace OpenSim.Services.GridService |
@@ -48,33 +49,28 @@ namespace OpenSim.Services.GridService | |||
48 | public GridService(IConfigSource config) | 49 | public GridService(IConfigSource config) |
49 | : base(config) | 50 | : base(config) |
50 | { | 51 | { |
51 | MainConsole.Instance.Commands.AddCommand("kfs", false, | 52 | m_log.DebugFormat("[GRID SERVICE]: Starting..."); |
52 | "show digest", | ||
53 | "show digest <ID>", | ||
54 | "Show asset digest", HandleShowDigest); | ||
55 | |||
56 | MainConsole.Instance.Commands.AddCommand("kfs", false, | ||
57 | "delete asset", | ||
58 | "delete asset <ID>", | ||
59 | "Delete asset from database", HandleDeleteAsset); | ||
60 | |||
61 | } | 53 | } |
62 | 54 | ||
63 | #region IGridService | 55 | #region IGridService |
64 | 56 | ||
65 | public bool RegisterRegion(UUID scopeID, SimpleRegionInfo regionInfos) | 57 | public bool RegisterRegion(UUID scopeID, GridRegion regionInfos) |
66 | { | 58 | { |
67 | if (m_Database.Get(regionInfos.RegionID, scopeID) != null) | 59 | // This needs better sanity testing. What if regionInfo is registering in |
68 | { | 60 | // overlapping coords? |
69 | m_log.WarnFormat("[GRID SERVICE]: Region {0} already registered in scope {1}.", regionInfos.RegionID, scopeID); | 61 | RegionData region = m_Database.Get(regionInfos.RegionLocX, regionInfos.RegionLocY, scopeID); |
70 | return false; | 62 | if ((region != null) && (region.RegionID != regionInfos.RegionID)) |
71 | } | ||
72 | if (m_Database.Get((int)regionInfos.RegionLocX, (int)regionInfos.RegionLocY, scopeID) != null) | ||
73 | { | 63 | { |
74 | m_log.WarnFormat("[GRID SERVICE]: Region {0} tried to register in coordinates {1}, {2} which are already in use in scope {3}.", | 64 | m_log.WarnFormat("[GRID SERVICE]: Region {0} tried to register in coordinates {1}, {2} which are already in use in scope {3}.", |
75 | regionInfos.RegionID, regionInfos.RegionLocX, regionInfos.RegionLocY, scopeID); | 65 | regionInfos.RegionID, regionInfos.RegionLocX, regionInfos.RegionLocY, scopeID); |
76 | return false; | 66 | return false; |
77 | } | 67 | } |
68 | if ((region != null) && (region.RegionID == regionInfos.RegionID) && | ||
69 | ((region.posX != regionInfos.RegionLocX) || (region.posY != regionInfos.RegionLocY))) | ||
70 | { | ||
71 | // Region reregistering in other coordinates. Delete the old entry | ||
72 | m_Database.Delete(regionInfos.RegionID); | ||
73 | } | ||
78 | 74 | ||
79 | // Everything is ok, let's register | 75 | // Everything is ok, let's register |
80 | RegionData rdata = RegionInfo2RegionData(regionInfos); | 76 | RegionData rdata = RegionInfo2RegionData(regionInfos); |
@@ -88,22 +84,25 @@ namespace OpenSim.Services.GridService | |||
88 | return m_Database.Delete(regionID); | 84 | return m_Database.Delete(regionID); |
89 | } | 85 | } |
90 | 86 | ||
91 | public List<SimpleRegionInfo> GetNeighbours(UUID scopeID, UUID regionID) | 87 | public List<GridRegion> GetNeighbours(UUID scopeID, UUID regionID) |
92 | { | 88 | { |
93 | List<SimpleRegionInfo> rinfos = new List<SimpleRegionInfo>(); | 89 | List<GridRegion> rinfos = new List<GridRegion>(); |
94 | RegionData region = m_Database.Get(regionID, scopeID); | 90 | RegionData region = m_Database.Get(regionID, scopeID); |
95 | if (region != null) | 91 | if (region != null) |
96 | { | 92 | { |
97 | // Not really? Maybe? | 93 | // Not really? Maybe? |
98 | List<RegionData> rdatas = m_Database.Get(region.posX - 1, region.posY - 1, region.posX + 1, region.posY + 1, scopeID); | 94 | List<RegionData> rdatas = m_Database.Get(region.posX - (int)Constants.RegionSize, region.posY - (int)Constants.RegionSize, |
95 | region.posX + (int)Constants.RegionSize, region.posY + (int)Constants.RegionSize, scopeID); | ||
96 | |||
99 | foreach (RegionData rdata in rdatas) | 97 | foreach (RegionData rdata in rdatas) |
100 | rinfos.Add(RegionData2RegionInfo(rdata)); | 98 | if (rdata.RegionID != regionID) |
99 | rinfos.Add(RegionData2RegionInfo(rdata)); | ||
101 | 100 | ||
102 | } | 101 | } |
103 | return rinfos; | 102 | return rinfos; |
104 | } | 103 | } |
105 | 104 | ||
106 | public SimpleRegionInfo GetRegionByUUID(UUID scopeID, UUID regionID) | 105 | public GridRegion GetRegionByUUID(UUID scopeID, UUID regionID) |
107 | { | 106 | { |
108 | RegionData rdata = m_Database.Get(regionID, scopeID); | 107 | RegionData rdata = m_Database.Get(regionID, scopeID); |
109 | if (rdata != null) | 108 | if (rdata != null) |
@@ -112,16 +111,18 @@ namespace OpenSim.Services.GridService | |||
112 | return null; | 111 | return null; |
113 | } | 112 | } |
114 | 113 | ||
115 | public SimpleRegionInfo GetRegionByPosition(UUID scopeID, int x, int y) | 114 | public GridRegion GetRegionByPosition(UUID scopeID, int x, int y) |
116 | { | 115 | { |
117 | RegionData rdata = m_Database.Get(x, y, scopeID); | 116 | int snapX = (int)(x / Constants.RegionSize) * (int)Constants.RegionSize; |
117 | int snapY = (int)(y / Constants.RegionSize) * (int)Constants.RegionSize; | ||
118 | RegionData rdata = m_Database.Get(snapX, snapY, scopeID); | ||
118 | if (rdata != null) | 119 | if (rdata != null) |
119 | return RegionData2RegionInfo(rdata); | 120 | return RegionData2RegionInfo(rdata); |
120 | 121 | ||
121 | return null; | 122 | return null; |
122 | } | 123 | } |
123 | 124 | ||
124 | public SimpleRegionInfo GetRegionByName(UUID scopeID, string regionName) | 125 | public GridRegion GetRegionByName(UUID scopeID, string regionName) |
125 | { | 126 | { |
126 | List<RegionData> rdatas = m_Database.Get(regionName + "%", scopeID); | 127 | List<RegionData> rdatas = m_Database.Get(regionName + "%", scopeID); |
127 | if ((rdatas != null) && (rdatas.Count > 0)) | 128 | if ((rdatas != null) && (rdatas.Count > 0)) |
@@ -130,12 +131,12 @@ namespace OpenSim.Services.GridService | |||
130 | return null; | 131 | return null; |
131 | } | 132 | } |
132 | 133 | ||
133 | public List<SimpleRegionInfo> GetRegionsByName(UUID scopeID, string name, int maxNumber) | 134 | public List<GridRegion> GetRegionsByName(UUID scopeID, string name, int maxNumber) |
134 | { | 135 | { |
135 | List<RegionData> rdatas = m_Database.Get("%" + name + "%", scopeID); | 136 | List<RegionData> rdatas = m_Database.Get("%" + name + "%", scopeID); |
136 | 137 | ||
137 | int count = 0; | 138 | int count = 0; |
138 | List<SimpleRegionInfo> rinfos = new List<SimpleRegionInfo>(); | 139 | List<GridRegion> rinfos = new List<GridRegion>(); |
139 | 140 | ||
140 | if (rdatas != null) | 141 | if (rdatas != null) |
141 | { | 142 | { |
@@ -149,10 +150,15 @@ namespace OpenSim.Services.GridService | |||
149 | return rinfos; | 150 | return rinfos; |
150 | } | 151 | } |
151 | 152 | ||
152 | public List<SimpleRegionInfo> GetRegionRange(UUID scopeID, int xmin, int xmax, int ymin, int ymax) | 153 | public List<GridRegion> GetRegionRange(UUID scopeID, int xmin, int xmax, int ymin, int ymax) |
153 | { | 154 | { |
154 | List<RegionData> rdatas = m_Database.Get(xmin, ymin, xmax, ymax, scopeID); | 155 | int xminSnap = (int)(xmin / Constants.RegionSize) * (int)Constants.RegionSize; |
155 | List<SimpleRegionInfo> rinfos = new List<SimpleRegionInfo>(); | 156 | int xmaxSnap = (int)(xmax / Constants.RegionSize) * (int)Constants.RegionSize; |
157 | int yminSnap = (int)(ymin / Constants.RegionSize) * (int)Constants.RegionSize; | ||
158 | int ymaxSnap = (int)(ymax / Constants.RegionSize) * (int)Constants.RegionSize; | ||
159 | |||
160 | List<RegionData> rdatas = m_Database.Get(xminSnap, yminSnap, xmaxSnap, ymaxSnap, scopeID); | ||
161 | List<GridRegion> rinfos = new List<GridRegion>(); | ||
156 | foreach (RegionData rdata in rdatas) | 162 | foreach (RegionData rdata in rdatas) |
157 | rinfos.Add(RegionData2RegionInfo(rdata)); | 163 | rinfos.Add(RegionData2RegionInfo(rdata)); |
158 | 164 | ||
@@ -163,92 +169,31 @@ namespace OpenSim.Services.GridService | |||
163 | 169 | ||
164 | #region Data structure conversions | 170 | #region Data structure conversions |
165 | 171 | ||
166 | protected RegionData RegionInfo2RegionData(SimpleRegionInfo rinfo) | 172 | protected RegionData RegionInfo2RegionData(GridRegion rinfo) |
167 | { | 173 | { |
168 | RegionData rdata = new RegionData(); | 174 | RegionData rdata = new RegionData(); |
169 | rdata.posX = (int)rinfo.RegionLocX; | 175 | rdata.posX = (int)rinfo.RegionLocX; |
170 | rdata.posY = (int)rinfo.RegionLocY; | 176 | rdata.posY = (int)rinfo.RegionLocY; |
171 | rdata.RegionID = rinfo.RegionID; | 177 | rdata.RegionID = rinfo.RegionID; |
178 | rdata.RegionName = rinfo.RegionName; | ||
172 | rdata.Data = rinfo.ToKeyValuePairs(); | 179 | rdata.Data = rinfo.ToKeyValuePairs(); |
173 | //rdata.RegionName = rinfo.RegionName; | 180 | rdata.Data["regionHandle"] = Utils.UIntsToLong((uint)rdata.posX, (uint)rdata.posY); |
174 | |||
175 | return rdata; | 181 | return rdata; |
176 | } | 182 | } |
177 | 183 | ||
178 | protected SimpleRegionInfo RegionData2RegionInfo(RegionData rdata) | 184 | protected GridRegion RegionData2RegionInfo(RegionData rdata) |
179 | { | 185 | { |
180 | SimpleRegionInfo rinfo = new SimpleRegionInfo(rdata.Data); | 186 | GridRegion rinfo = new GridRegion(rdata.Data); |
181 | rinfo.RegionLocX = (uint)rdata.posX; | 187 | rinfo.RegionLocX = rdata.posX; |
182 | rinfo.RegionLocY = (uint)rdata.posY; | 188 | rinfo.RegionLocY = rdata.posY; |
183 | rinfo.RegionID = rdata.RegionID; | 189 | rinfo.RegionID = rdata.RegionID; |
184 | //rinfo.RegionName = rdata.RegionName; | 190 | rinfo.RegionName = rdata.RegionName; |
191 | rinfo.ScopeID = rdata.ScopeID; | ||
185 | 192 | ||
186 | return rinfo; | 193 | return rinfo; |
187 | } | 194 | } |
188 | 195 | ||
189 | #endregion | 196 | #endregion |
190 | 197 | ||
191 | void HandleShowDigest(string module, string[] args) | ||
192 | { | ||
193 | //if (args.Length < 3) | ||
194 | //{ | ||
195 | // MainConsole.Instance.Output("Syntax: show digest <ID>"); | ||
196 | // return; | ||
197 | //} | ||
198 | |||
199 | //AssetBase asset = Get(args[2]); | ||
200 | |||
201 | //if (asset == null || asset.Data.Length == 0) | ||
202 | //{ | ||
203 | // MainConsole.Instance.Output("Asset not found"); | ||
204 | // return; | ||
205 | //} | ||
206 | |||
207 | //int i; | ||
208 | |||
209 | //MainConsole.Instance.Output(String.Format("Name: {0}", asset.Name)); | ||
210 | //MainConsole.Instance.Output(String.Format("Description: {0}", asset.Description)); | ||
211 | //MainConsole.Instance.Output(String.Format("Type: {0}", asset.Type)); | ||
212 | //MainConsole.Instance.Output(String.Format("Content-type: {0}", asset.Metadata.ContentType)); | ||
213 | |||
214 | //for (i = 0 ; i < 5 ; i++) | ||
215 | //{ | ||
216 | // int off = i * 16; | ||
217 | // if (asset.Data.Length <= off) | ||
218 | // break; | ||
219 | // int len = 16; | ||
220 | // if (asset.Data.Length < off + len) | ||
221 | // len = asset.Data.Length - off; | ||
222 | |||
223 | // byte[] line = new byte[len]; | ||
224 | // Array.Copy(asset.Data, off, line, 0, len); | ||
225 | |||
226 | // string text = BitConverter.ToString(line); | ||
227 | // MainConsole.Instance.Output(String.Format("{0:x4}: {1}", off, text)); | ||
228 | //} | ||
229 | } | ||
230 | |||
231 | void HandleDeleteAsset(string module, string[] args) | ||
232 | { | ||
233 | //if (args.Length < 3) | ||
234 | //{ | ||
235 | // MainConsole.Instance.Output("Syntax: delete asset <ID>"); | ||
236 | // return; | ||
237 | //} | ||
238 | |||
239 | //AssetBase asset = Get(args[2]); | ||
240 | |||
241 | //if (asset == null || asset.Data.Length == 0) | ||
242 | // MainConsole.Instance.Output("Asset not found"); | ||
243 | // return; | ||
244 | //} | ||
245 | |||
246 | //Delete(args[2]); | ||
247 | |||
248 | ////MainConsole.Instance.Output("Asset deleted"); | ||
249 | //// TODO: Implement this | ||
250 | |||
251 | //MainConsole.Instance.Output("Asset deletion not supported by database"); | ||
252 | } | ||
253 | } | 198 | } |
254 | } | 199 | } |