* Total refactoring of Asset Server for massive win

* There is now a AssetServerBase
* lolcat in ur assets
afrisby
lbsa71 2007-10-19 07:46:03 +00:00
parent 2681bc46c4
commit 46700d3b7d
9 changed files with 352 additions and 573 deletions

View File

@ -91,7 +91,12 @@ namespace OpenSim.Framework.Communications.Cache
{ {
System.Console.WriteLine("Creating Asset cache"); System.Console.WriteLine("Creating Asset cache");
_assetServer = this.LoadAssetDll(assetServerDLLName); _assetServer = this.LoadAssetDll(assetServerDLLName);
// TODO: This actually does nothing to no IAssetServer implementor. Delete?
_assetServer.SetServerInfo(assetServerURL, assetServerKey); _assetServer.SetServerInfo(assetServerURL, assetServerKey);
_assetServer.SetReceiver(this); _assetServer.SetReceiver(this);
Assets = new Dictionary<LLUUID, AssetInfo>(); Assets = new Dictionary<LLUUID, AssetInfo>();
Textures = new Dictionary<LLUUID, TextureImage>(); Textures = new Dictionary<LLUUID, TextureImage>();
@ -159,7 +164,7 @@ namespace OpenSim.Framework.Communications.Cache
{ //texture { //texture
TextureImage textur = new TextureImage(asset); TextureImage textur = new TextureImage(asset);
this.Textures.Add(textur.FullID, textur); this.Textures.Add(textur.FullID, textur);
this._assetServer.CreateAsset(asset); this._assetServer.StoreAndCommitAsset(asset);
} }
else else
{ {
@ -173,7 +178,7 @@ namespace OpenSim.Framework.Communications.Cache
{ {
AssetInfo assetInf = new AssetInfo(asset); AssetInfo assetInf = new AssetInfo(asset);
this.Assets.Add(assetInf.FullID, assetInf); this.Assets.Add(assetInf.FullID, assetInf);
this._assetServer.CreateAsset(asset); this._assetServer.StoreAndCommitAsset(asset);
} }
} }
} }

View File

@ -24,370 +24,137 @@
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
* *
*/ */
using System; using System;
using System.IO; using System.Collections.Generic;
using System.Threading; using System.IO;
using Db4objects.Db4o; using System.Threading;
using Db4objects.Db4o.Query; using Db4objects.Db4o;
using libsecondlife; using Db4objects.Db4o.Query;
using Nini.Config; using libsecondlife;
using OpenSim.Framework.Console; using Nini.Config;
using OpenSim.Framework.Interfaces; using OpenSim.Framework.Communications.Cache;
using OpenSim.Framework.Types; using OpenSim.Framework.Console;
using OpenSim.Framework.Utilities; using OpenSim.Framework.Interfaces;
using OpenSim.Framework.Types;
namespace OpenSim.Framework.Communications.Caches using OpenSim.Framework.Utilities;
{
namespace OpenSim.Framework.Communications.Cache
public class LocalAssetServer : IAssetServer {
{ public class LocalAssetServer : AssetServerBase
private IAssetReceiver _receiver; {
private BlockingQueue<ARequest> _assetRequests; private IObjectContainer db;
private IObjectContainer db;
private Thread _localAssetServerThread; public LocalAssetServer()
{
public LocalAssetServer() bool yapfile;
{ yapfile = File.Exists(Path.Combine(Util.dataDir(), "regionassets.yap"));
System.Console.WriteLine("Starting Db4o asset storage system");
bool yapfile; db = Db4oFactory.OpenFile(Path.Combine(Util.dataDir(), "regionassets.yap"));
this._assetRequests = new BlockingQueue<ARequest>(); MainLog.Instance.Verbose("Db4 Asset database creation");
yapfile = File.Exists(Path.Combine(Util.dataDir(), "regionassets.yap"));
if (!yapfile)
MainLog.Instance.Verbose("Local Asset Server class created"); {
db = Db4oFactory.OpenFile(Path.Combine(Util.dataDir(), "regionassets.yap")); SetUpAssetDatabase();
MainLog.Instance.Verbose("Db4 Asset database creation"); }
if (!yapfile) this._localAssetServerThread = new Thread(new ThreadStart(RunRequests));
{ this._localAssetServerThread.IsBackground = true;
this.SetUpAssetDatabase(); this._localAssetServerThread.Start();
}
}
this._localAssetServerThread = new Thread(new ThreadStart(RunRequests));
this._localAssetServerThread.IsBackground = true; public void CreateAndCommitAsset(AssetBase asset)
this._localAssetServerThread.Start(); {
AssetStorage store = new AssetStorage();
} store.Data = asset.Data;
store.Name = asset.Name;
public void SetReceiver(IAssetReceiver receiver) store.UUID = asset.FullID;
{ db.Set(store);
this._receiver = receiver; db.Commit();
} }
public void FetchAsset(LLUUID assetID, bool isTexture) override public void Close()
{ {
ARequest req = new ARequest(); if (db != null)
req.AssetID = assetID; {
req.IsTexture = isTexture; MainLog.Instance.Verbose("Closing local asset server database");
this._assetRequests.Enqueue(req); db.Close();
} }
}
public void UpdateAsset(AssetBase asset)
{ private void RunRequests()
{
} while (true)
{
public void CreateAsset(AssetBase asset) byte[] idata = null;
{ bool found = false;
AssetStorage store = new AssetStorage(); AssetStorage foundAsset = null;
store.Data = asset.Data; ARequest req = this._assetRequests.Dequeue();
store.Name = asset.Name; IObjectSet result = db.Query(new AssetUUIDQuery(req.AssetID));
store.UUID = asset.FullID; if (result.Count > 0)
db.Set(store); {
db.Commit(); foundAsset = (AssetStorage)result.Next();
} found = true;
}
public void SetServerInfo(string ServerUrl, string ServerKey)
{ AssetBase asset = new AssetBase();
if (found)
} {
public void Close() asset.FullID = foundAsset.UUID;
{ asset.Type = foundAsset.Type;
if (db != null) asset.InvType = foundAsset.Type;
{ asset.Name = foundAsset.Name;
MainLog.Instance.Verbose("Closing local asset server database"); idata = foundAsset.Data;
db.Close(); asset.Data = idata;
} _receiver.AssetReceived(asset, req.IsTexture);
} }
else
private void RunRequests() {
{ //asset.FullID = ;
while (true) _receiver.AssetNotFound(req.AssetID);
{ }
byte[] idata = null;
bool found = false; }
AssetStorage foundAsset = null;
ARequest req = this._assetRequests.Dequeue(); }
IObjectSet result = db.Query(new AssetUUIDQuery(req.AssetID));
if (result.Count > 0) override protected void StoreAsset(AssetBase asset)
{ {
foundAsset = (AssetStorage)result.Next(); AssetStorage store = new AssetStorage();
found = true; store.Data = asset.Data;
} store.Name = asset.Name;
store.UUID = asset.FullID;
AssetBase asset = new AssetBase(); db.Set(store);
if (found)
{ CommitAssets();
asset.FullID = foundAsset.UUID; }
asset.Type = foundAsset.Type;
asset.InvType = foundAsset.Type; protected override void CommitAssets()
asset.Name = foundAsset.Name; {
idata = foundAsset.Data; db.Commit();
asset.Data = idata; }
_receiver.AssetReceived(asset, req.IsTexture);
} private void SetUpAssetDatabase()
else {
{ MainLog.Instance.Verbose("LOCAL ASSET SERVER", "Setting up asset database");
//asset.FullID = ;
_receiver.AssetNotFound(req.AssetID); ForEachDefaultAsset(this, StoreAsset);
} ForEachXmlAsset(this, StoreAsset);
}
} }
} public class AssetUUIDQuery : Predicate
{
private void SetUpAssetDatabase() private LLUUID _findID;
{
MainLog.Instance.Verbose("Setting up asset database"); public AssetUUIDQuery(LLUUID find)
{
AssetBase Image = new AssetBase(); _findID = find;
Image.FullID = new LLUUID("00000000-0000-0000-9999-000000000001"); }
Image.Name = "Bricks"; public bool Match(AssetStorage asset)
this.LoadAsset(Image, true, "bricks.jp2"); {
AssetStorage store = new AssetStorage(); return (asset.UUID == _findID);
store.Data = Image.Data; }
store.Name = Image.Name; }
store.UUID = Image.FullID; }
db.Set(store);
db.Commit();
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-0000-9999-000000000002");
Image.Name = "Plywood";
this.LoadAsset(Image, true, "plywood.jp2");
store = new AssetStorage();
store.Data = Image.Data;
store.Name = Image.Name;
store.UUID = Image.FullID;
db.Set(store);
db.Commit();
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-0000-9999-000000000003");
Image.Name = "Rocks";
this.LoadAsset(Image, true, "rocks.jp2");
store = new AssetStorage();
store.Data = Image.Data;
store.Name = Image.Name;
store.UUID = Image.FullID;
db.Set(store);
db.Commit();
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-0000-9999-000000000004");
Image.Name = "Granite";
this.LoadAsset(Image, true, "granite.jp2");
store = new AssetStorage();
store.Data = Image.Data;
store.Name = Image.Name;
store.UUID = Image.FullID;
db.Set(store);
db.Commit();
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-0000-9999-000000000005");
Image.Name = "Hardwood";
this.LoadAsset(Image, true, "hardwood.jp2");
store = new AssetStorage();
store.Data = Image.Data;
store.Name = Image.Name;
store.UUID = Image.FullID;
db.Set(store);
db.Commit();
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-0000-5005-000000000005");
Image.Name = "Prim Base Texture";
this.LoadAsset(Image, true, "plywood.jp2");
store = new AssetStorage();
store.Data = Image.Data;
store.Name = Image.Name;
store.UUID = Image.FullID;
db.Set(store);
db.Commit();
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-0000-9999-000000000006");
Image.Name = "Map Base Texture";
this.LoadAsset(Image, true, "map_base.jp2");
store = new AssetStorage();
store.Data = Image.Data;
store.Name = Image.Name;
store.UUID = Image.FullID;
db.Set(store);
db.Commit();
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-0000-9999-000000000007");
Image.Name = "Map Texture";
this.LoadAsset(Image, true, "map1.jp2");
store = new AssetStorage();
store.Data = Image.Data;
store.Name = Image.Name;
store.UUID = Image.FullID;
db.Set(store);
db.Commit();
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-1111-9999-000000000010");
Image.Name = "Female Body Texture";
this.LoadAsset(Image, true, "femalebody.jp2");
store = new AssetStorage();
store.Data = Image.Data;
store.Name = Image.Name;
store.UUID = Image.FullID;
db.Set(store);
db.Commit();
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-1111-9999-000000000011");
Image.Name = "Female Bottom Texture";
this.LoadAsset(Image, true, "femalebottom.jp2");
store = new AssetStorage();
store.Data = Image.Data;
store.Name = Image.Name;
store.UUID = Image.FullID;
db.Set(store);
db.Commit();
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-1111-9999-000000000012");
Image.Name = "Female Face Texture";
this.LoadAsset(Image, true, "femaleface.jp2");
store = new AssetStorage();
store.Data = Image.Data;
store.Name = Image.Name;
store.UUID = Image.FullID;
db.Set(store);
db.Commit();
Image = new AssetBase();
Image.FullID = new LLUUID("77c41e39-38f9-f75a-024e-585989bbabbb");
Image.Name = "Skin";
Image.Type = 13;
Image.InvType = 13;
this.LoadAsset(Image, false, "base_skin.dat");
store = new AssetStorage();
store.Data = Image.Data;
store.Name = Image.Name;
store.UUID = Image.FullID;
db.Set(store);
db.Commit();
Image = new AssetBase();
Image.FullID = new LLUUID("66c41e39-38f9-f75a-024e-585989bfab73");
Image.Name = "Shape";
Image.Type = 13;
Image.InvType = 13;
this.LoadAsset(Image, false, "base_shape.dat");
store = new AssetStorage();
store.Data = Image.Data;
store.Name = Image.Name;
store.UUID = Image.FullID;
db.Set(store);
db.Commit();
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-38f9-1111-024e-222222111110");
Image.Name = "Shirt";
Image.Type = 5;
Image.InvType = 18;
this.LoadAsset(Image, false, "newshirt.dat");
store = new AssetStorage();
store.Data = Image.Data;
store.Name = Image.Name;
store.UUID = Image.FullID;
db.Set(store);
db.Commit();
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-38f9-1111-024e-222222111120");
Image.Name = "Shirt";
Image.Type = 5;
Image.InvType = 18;
this.LoadAsset(Image, false, "newpants.dat");
store = new AssetStorage();
store.Data = Image.Data;
store.Name = Image.Name;
store.UUID = Image.FullID;
db.Set(store);
db.Commit();
string filePath = Path.Combine(Util.configDir(), "OpenSimAssetSet.xml");
if (File.Exists(filePath))
{
XmlConfigSource source = new XmlConfigSource(filePath);
ReadAssetDetails(source);
}
}
protected void ReadAssetDetails(IConfigSource source)
{
AssetBase newAsset = null;
for (int i = 0; i < source.Configs.Count; i++)
{
newAsset = new AssetBase();
newAsset.FullID = new LLUUID(source.Configs[i].GetString("assetID", LLUUID.Random().ToStringHyphenated()));
newAsset.Name = source.Configs[i].GetString("name", "");
newAsset.Type = (sbyte)source.Configs[i].GetInt("assetType", 0);
newAsset.InvType = (sbyte)source.Configs[i].GetInt("inventoryType", 0);
string fileName = source.Configs[i].GetString("fileName", "");
if (fileName != "")
{
this.LoadAsset(newAsset, false, fileName);
AssetStorage store = new AssetStorage();
store.Data = newAsset.Data;
store.Name = newAsset.Name;
store.UUID = newAsset.FullID;
db.Set(store);
db.Commit();
}
}
}
private void LoadAsset(AssetBase info, bool image, string filename)
{
//should request Asset from storage manager
//but for now read from file
string dataPath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "assets"); //+ folder;
string fileName = Path.Combine(dataPath, filename);
FileInfo fInfo = new FileInfo(fileName);
long numBytes = fInfo.Length;
FileStream fStream = new FileStream(fileName, FileMode.Open, FileAccess.Read);
byte[] idata = new byte[numBytes];
BinaryReader br = new BinaryReader(fStream);
idata = br.ReadBytes((int)numBytes);
br.Close();
fStream.Close();
info.Data = idata;
//info.loaded=true;
}
}
public class AssetUUIDQuery : Predicate
{
private LLUUID _findID;
public AssetUUIDQuery(LLUUID find)
{
_findID = find;
}
public bool Match(AssetStorage asset)
{
return (asset.UUID == _findID);
}
}
}

View File

@ -0,0 +1,180 @@
using System;
using System.Collections.Generic;
using System.IO;
using System.Threading;
using libsecondlife;
using Nini.Config;
using OpenSim.Framework.Console;
using OpenSim.Framework.Interfaces;
using OpenSim.Framework.Types;
using OpenSim.Framework.Utilities;
namespace OpenSim.Framework.Communications.Cache
{
public abstract class AssetServerBase : IAssetServer
{
protected IAssetReceiver _receiver;
protected BlockingQueue<ARequest> _assetRequests;
protected Thread _localAssetServerThread;
protected IAssetProvider m_assetProviderPlugin;
protected object syncLock = new object();
protected abstract void StoreAsset(AssetBase asset);
protected abstract void CommitAssets();
public void LoadDefaultAssets()
{
MainLog.Instance.Verbose("SQL ASSET SERVER", "Setting up asset database");
ForEachDefaultAsset( this, StoreAsset );
ForEachXmlAsset( this, StoreAsset );
CommitAssets();
}
public static AssetBase CreateAsset(IAssetServer assetServer, string assetIdStr, string name, string filename, bool isImage)
{
AssetBase asset = new AssetBase(
new LLUUID(assetIdStr),
name
);
if (!String.IsNullOrEmpty(filename))
{
MainLog.Instance.Verbose("ASSETS", "Loading: [{0}][{1}]", name, filename );
assetServer.LoadAsset(asset, isImage, filename);
}
else
{
MainLog.Instance.Verbose("ASSETS", "Instantiated: [{0}]", name );
}
return asset;
}
private static AssetBase CreateImageAsset(IAssetServer assetServer, string assetIdStr, string name, string filename)
{
return CreateAsset(assetServer, assetIdStr, name, filename, true);
}
public static List<AssetBase> GetDefaultAssets(IAssetServer assetServer)
{
List<AssetBase> assets = new List<AssetBase>();
assets.Add(CreateImageAsset(assetServer, "00000000-0000-0000-9999-000000000001", "Bricks", "bricks.jp2"));
assets.Add(CreateImageAsset(assetServer, "00000000-0000-0000-9999-000000000002", "Plywood", "plywood.jp2"));
assets.Add(CreateImageAsset(assetServer, "00000000-0000-0000-9999-000000000003", "Rocks", "rocks.jp2"));
assets.Add(CreateImageAsset(assetServer, "00000000-0000-0000-9999-000000000004", "Granite", "granite.jp2"));
assets.Add(CreateImageAsset(assetServer, "00000000-0000-0000-9999-000000000005", "Hardwood", "hardwood.jp2"));
assets.Add(CreateImageAsset(assetServer, "00000000-0000-0000-5005-000000000005", "Prim Base Texture", "plywood.jp2"));
assets.Add(CreateImageAsset(assetServer, "00000000-0000-0000-9999-000000000006", "Map Base Texture", "map_base.jp2"));
assets.Add(CreateImageAsset(assetServer, "00000000-0000-0000-9999-000000000007", "Map Texture", "map1.jp2"));
assets.Add(CreateImageAsset(assetServer, "00000000-0000-0000-9999-000000000010", "Female Body Texture", "femalebody.jp2"));
assets.Add(CreateImageAsset(assetServer, "00000000-0000-0000-9999-000000000011", "Female Bottom Texture", "femalebottom.jp2"));
assets.Add(CreateImageAsset(assetServer, "00000000-0000-0000-9999-000000000012", "Female Face Texture", "femaleface.jp2"));
assets.Add(CreateImageAsset(assetServer, "00000000-0000-0000-9999-000000000001", "Bricks", "bricks.jp2"));
assets.Add(CreateAsset(assetServer, "77c41e39-38f9-f75a-024e-585989bbabbb", "Skin", "base_skin.dat", false));
assets.Add(CreateAsset(assetServer, "66c41e39-38f9-f75a-024e-585989bfab73", "Shape", "base_shape.dat", false));
assets.Add(CreateAsset(assetServer, "00000000-38f9-1111-024e-222222111110", "Shirt", "newshirt.dat", false));
assets.Add(CreateAsset(assetServer, "00000000-38f9-1111-024e-222222111120", "Shirt", "newpants.dat", false));
return assets;
}
public static void ForEachDefaultAsset(IAssetServer assetServer, Action<AssetBase> action)
{
List<AssetBase> assets = GetDefaultAssets(assetServer);
assets.ForEach(action);
}
public AssetServerBase()
{
System.Console.WriteLine("Starting Db4o asset storage system");
this._assetRequests = new BlockingQueue<ARequest>();
}
public void LoadAsset(AssetBase info, bool image, string filename)
{
//should request Asset from storage manager
//but for now read from file
string dataPath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "assets"); //+ folder;
string fileName = Path.Combine(dataPath, filename);
FileInfo fInfo = new FileInfo(fileName);
long numBytes = fInfo.Length;
FileStream fStream = new FileStream(fileName, FileMode.Open, FileAccess.Read);
byte[] idata = new byte[numBytes];
BinaryReader br = new BinaryReader(fStream);
idata = br.ReadBytes((int)numBytes);
br.Close();
fStream.Close();
info.Data = idata;
//info.loaded=true;
}
public static void ForEachXmlAsset(IAssetServer assetServer, Action<AssetBase> action)
{
string filePath = Path.Combine(Util.configDir(), "OpenSimAssetSet.xml");
if (File.Exists(filePath))
{
XmlConfigSource source = new XmlConfigSource(filePath);
for (int i = 0; i < source.Configs.Count; i++)
{
string assetIdStr = source.Configs[i].GetString("assetID", LLUUID.Random().ToStringHyphenated());
string name = source.Configs[i].GetString("name", "");
sbyte type = (sbyte)source.Configs[i].GetInt("assetType", 0);
sbyte invType = (sbyte)source.Configs[i].GetInt("inventoryType", 0);
string fileName = source.Configs[i].GetString("fileName", "");
AssetBase newAsset = CreateAsset(assetServer, assetIdStr, name, fileName, false);
newAsset.Type = type;
newAsset.InvType = invType;
}
}
}
public void SetReceiver(IAssetReceiver receiver)
{
this._receiver = receiver;
}
public void FetchAsset(LLUUID assetID, bool isTexture)
{
ARequest req = new ARequest();
req.AssetID = assetID;
req.IsTexture = isTexture;
this._assetRequests.Enqueue(req);
}
public void UpdateAsset(AssetBase asset)
{
lock (syncLock)
{
m_assetProviderPlugin.UpdateAsset(asset);
m_assetProviderPlugin.CommitAssets();
}
}
public void StoreAndCommitAsset(AssetBase asset)
{
lock (syncLock)
{
StoreAsset(asset);
CommitAssets();
}
}
public void SetServerInfo(string ServerUrl, string ServerKey)
{
}
public abstract void Close();
}
}

View File

@ -36,32 +36,22 @@ using OpenSim.Framework.Interfaces;
using OpenSim.Framework.Types; using OpenSim.Framework.Types;
using OpenSim.Framework.Utilities; using OpenSim.Framework.Utilities;
namespace OpenSim.Framework.Communications.Caches namespace OpenSim.Framework.Communications.Cache
{ {
public class SQLAssetServer : AssetServerBase
public class SQLAssetServer : IAssetServer
{ {
private IAssetReceiver _receiver;
private BlockingQueue<ARequest> _assetRequests;
private Thread _localAssetServerThread;
protected IAssetProvider m_assetProviderPlugin;
private object syncLock = new object();
public SQLAssetServer(string pluginName) public SQLAssetServer(string pluginName)
{ {
_assetRequests = new BlockingQueue<ARequest>(); _assetRequests = new BlockingQueue<ARequest>();
AddPlugin(pluginName); AddPlugin(pluginName);
SetUpAssetDatabase();
this._localAssetServerThread = new Thread(new ThreadStart(RunRequests)); this._localAssetServerThread = new Thread(new ThreadStart(RunRequests));
this._localAssetServerThread.IsBackground = true; this._localAssetServerThread.IsBackground = true;
this._localAssetServerThread.Start(); this._localAssetServerThread.Start();
} }
public SQLAssetServer( IAssetProvider assetProvider ) public SQLAssetServer(IAssetProvider assetProvider)
{ {
m_assetProviderPlugin = assetProvider; m_assetProviderPlugin = assetProvider;
} }
@ -93,49 +83,15 @@ namespace OpenSim.Framework.Communications.Caches
pluginAssembly = null; pluginAssembly = null;
} }
public void SetReceiver(IAssetReceiver receiver)
{
this._receiver = receiver;
}
public void FetchAsset(LLUUID assetID, bool isTexture) public override void Close()
{
ARequest req = new ARequest();
req.AssetID = assetID;
req.IsTexture = isTexture;
this._assetRequests.Enqueue(req);
}
public void UpdateAsset(AssetBase asset)
{
lock (syncLock)
{
m_assetProviderPlugin.UpdateAsset(asset);
m_assetProviderPlugin.CommitAssets();
}
}
public void CreateAsset(AssetBase asset)
{
lock (syncLock)
{
m_assetProviderPlugin.CreateAsset(asset);
m_assetProviderPlugin.CommitAssets();
}
}
public void SetServerInfo(string ServerUrl, string ServerKey)
{
}
public void Close()
{ {
m_assetProviderPlugin.CommitAssets(); m_assetProviderPlugin.CommitAssets();
} }
private void RunRequests() private void RunRequests()
{ {
while (true) while (true)
{ {
ARequest req = this._assetRequests.Dequeue(); ARequest req = this._assetRequests.Dequeue();
@ -160,156 +116,14 @@ namespace OpenSim.Framework.Communications.Caches
} }
private void SetUpAssetDatabase() protected override void StoreAsset(AssetBase asset)
{ {
MainLog.Instance.Verbose("Setting up asset database"); m_assetProviderPlugin.CreateAsset(asset);
}
AssetBase Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-0000-9999-000000000001");
Image.Name = "Bricks";
this.LoadAsset(Image, true, "bricks.jp2");
m_assetProviderPlugin.CreateAsset(Image);
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-0000-9999-000000000002");
Image.Name = "Plywood";
this.LoadAsset(Image, true, "plywood.jp2");
m_assetProviderPlugin.CreateAsset(Image);
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-0000-9999-000000000003");
Image.Name = "Rocks";
this.LoadAsset(Image, true, "rocks.jp2");
m_assetProviderPlugin.CreateAsset(Image);
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-0000-9999-000000000004");
Image.Name = "Granite";
this.LoadAsset(Image, true, "granite.jp2");
m_assetProviderPlugin.CreateAsset(Image);
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-0000-9999-000000000005");
Image.Name = "Hardwood";
this.LoadAsset(Image, true, "hardwood.jp2");
m_assetProviderPlugin.CreateAsset(Image);
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-0000-5005-000000000005");
Image.Name = "Prim Base Texture";
this.LoadAsset(Image, true, "plywood.jp2");
m_assetProviderPlugin.CreateAsset(Image);
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-0000-9999-000000000006");
Image.Name = "Map Base Texture";
this.LoadAsset(Image, true, "map_base.jp2");
m_assetProviderPlugin.CreateAsset(Image);
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-0000-9999-000000000007");
Image.Name = "Map Texture";
this.LoadAsset(Image, true, "map1.jp2");
m_assetProviderPlugin.CreateAsset(Image);
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-1111-9999-000000000010");
Image.Name = "Female Body Texture";
this.LoadAsset(Image, true, "femalebody.jp2");
m_assetProviderPlugin.CreateAsset(Image);
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-1111-9999-000000000011");
Image.Name = "Female Bottom Texture";
this.LoadAsset(Image, true, "femalebottom.jp2");
m_assetProviderPlugin.CreateAsset(Image);
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-0000-1111-9999-000000000012");
Image.Name = "Female Face Texture";
this.LoadAsset(Image, true, "femaleface.jp2");
m_assetProviderPlugin.CreateAsset(Image);
Image = new AssetBase();
Image.FullID = new LLUUID("77c41e39-38f9-f75a-024e-585989bbabbb");
Image.Name = "Skin";
Image.Type = 13;
Image.InvType = 13;
this.LoadAsset(Image, false, "base_skin.dat");
m_assetProviderPlugin.CreateAsset(Image);
Image = new AssetBase();
Image.FullID = new LLUUID("66c41e39-38f9-f75a-024e-585989bfab73");
Image.Name = "Shape";
Image.Type = 13;
Image.InvType = 13;
this.LoadAsset(Image, false, "base_shape.dat");
m_assetProviderPlugin.CreateAsset(Image);
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-38f9-1111-024e-222222111110");
Image.Name = "Shirt";
Image.Type = 5;
Image.InvType = 18;
this.LoadAsset(Image, false, "newshirt.dat");
m_assetProviderPlugin.CreateAsset(Image);
Image = new AssetBase();
Image.FullID = new LLUUID("00000000-38f9-1111-024e-222222111120");
Image.Name = "Shirt";
Image.Type = 5;
Image.InvType = 18;
this.LoadAsset(Image, false, "newpants.dat");
m_assetProviderPlugin.CreateAsset(Image);
string filePath = Path.Combine(Util.configDir(), "OpenSimAssetSet.xml");
if (File.Exists(filePath))
{
XmlConfigSource source = new XmlConfigSource(filePath);
ReadAssetDetails(source);
}
protected override void CommitAssets()
{
m_assetProviderPlugin.CommitAssets(); m_assetProviderPlugin.CommitAssets();
} }
protected void ReadAssetDetails(IConfigSource source)
{
AssetBase newAsset = null;
for (int i = 0; i < source.Configs.Count; i++)
{
newAsset = new AssetBase();
newAsset.FullID = new LLUUID(source.Configs[i].GetString("assetID", LLUUID.Random().ToStringHyphenated()));
newAsset.Name = source.Configs[i].GetString("name", "");
newAsset.Type = (sbyte)source.Configs[i].GetInt("assetType", 0);
newAsset.InvType = (sbyte)source.Configs[i].GetInt("inventoryType", 0);
string fileName = source.Configs[i].GetString("fileName", "");
if (fileName != "")
{
MainLog.Instance.Verbose("Creating new asset: " + newAsset.Name);
this.LoadAsset(newAsset, false, fileName);
m_assetProviderPlugin.CreateAsset(newAsset);
}
}
}
private void LoadAsset(AssetBase info, bool image, string filename)
{
//should request Asset from storage manager
//but for now read from file
string dataPath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "assets"); //+ folder;
string fileName = Path.Combine(dataPath, filename);
FileInfo fInfo = new FileInfo(fileName);
long numBytes = fInfo.Length;
FileStream fStream = new FileStream(fileName, FileMode.Open, FileAccess.Read);
byte[] idata = new byte[numBytes];
BinaryReader br = new BinaryReader(fStream);
idata = br.ReadBytes((int)numBytes);
br.Close();
fStream.Close();
info.Data = idata;
//info.loaded=true;
}
} }
}
}

View File

@ -39,9 +39,10 @@ namespace OpenSim.Framework.Interfaces
void SetReceiver(IAssetReceiver receiver); void SetReceiver(IAssetReceiver receiver);
void FetchAsset(LLUUID assetID, bool isTexture); void FetchAsset(LLUUID assetID, bool isTexture);
void UpdateAsset(AssetBase asset); void UpdateAsset(AssetBase asset);
void CreateAsset(AssetBase asset); void StoreAndCommitAsset(AssetBase asset);
void SetServerInfo(string ServerUrl, string ServerKey); void SetServerInfo(string ServerUrl, string ServerKey);
void Close(); void Close();
void LoadAsset(AssetBase info, bool image, string filename);
} }
// could change to delegate? // could change to delegate?

View File

@ -44,5 +44,11 @@ namespace OpenSim.Framework.Types
{ {
} }
public AssetBase(LLUUID assetId, string name)
{
FullID = assetId;
Name = name;
}
} }
} }

View File

@ -30,13 +30,14 @@ using System;
using System.IO; using System.IO;
using libsecondlife; using libsecondlife;
using OpenSim.Framework.Communications.Cache;
using OpenSim.Framework.Configuration; using OpenSim.Framework.Configuration;
using OpenSim.Framework.Console; using OpenSim.Framework.Console;
using OpenSim.Framework.Servers; using OpenSim.Framework.Servers;
using OpenSim.Framework.Configuration; using OpenSim.Framework.Configuration;
using OpenSim.Framework.Interfaces; using OpenSim.Framework.Interfaces;
using OpenSim.Framework.Utilities; using OpenSim.Framework.Utilities;
using OpenSim.Framework.Communications.Caches;
/* /*
using System.Text; using System.Text;
using Db4objects.Db4o; using Db4objects.Db4o;
@ -114,7 +115,10 @@ namespace OpenSim.Grid.AssetServer
{ {
try try
{ {
m_assetServer = new SQLAssetServer(config.DatabaseProvider); SQLAssetServer assetServer = new SQLAssetServer(config.DatabaseProvider );
assetServer.LoadDefaultAssets();
m_assetServer = assetServer;
} }
catch (Exception e) catch (Exception e)
{ {

View File

@ -32,7 +32,6 @@ using System.IO;
using System.Text; using System.Text;
using Nini.Config; using Nini.Config;
using OpenSim.Framework.Communications.Cache; using OpenSim.Framework.Communications.Cache;
using OpenSim.Framework.Communications.Caches;
using OpenSim.Framework.Console; using OpenSim.Framework.Console;
using OpenSim.Framework.Interfaces; using OpenSim.Framework.Interfaces;
using OpenSim.Framework.Servers; using OpenSim.Framework.Servers;
@ -286,9 +285,14 @@ namespace OpenSim
} }
else else
{ {
assetServer = new SQLAssetServer(standaloneAssetPlugin); SQLAssetServer sqlAssetServer = new SQLAssetServer(standaloneAssetPlugin);
sqlAssetServer.LoadDefaultAssets();
assetServer = sqlAssetServer;
} }
// TODO: This actually does nothing to no IAssetServer implementor. Delete?
assetServer.SetServerInfo(m_networkServersInfo.AssetURL, m_networkServersInfo.AssetSendKey); assetServer.SetServerInfo(m_networkServersInfo.AssetURL, m_networkServersInfo.AssetSendKey);
m_assetCache = new AssetCache(assetServer); m_assetCache = new AssetCache(assetServer);
// m_assetCache = new assetCache("OpenSim.Region.GridInterfaces.Local.dll", m_networkServersInfo.AssetURL, m_networkServersInfo.AssetSendKey); // m_assetCache = new assetCache("OpenSim.Region.GridInterfaces.Local.dll", m_networkServersInfo.AssetURL, m_networkServersInfo.AssetSendKey);
} }

View File

@ -32,7 +32,6 @@ using System.IO;
using System.Net; using System.Net;
using libsecondlife; using libsecondlife;
using OpenSim.Framework.Communications.Cache; using OpenSim.Framework.Communications.Cache;
using OpenSim.Framework.Communications.Caches;
using OpenSim.Framework.Console; using OpenSim.Framework.Console;
using OpenSim.Framework.Types; using OpenSim.Framework.Types;
using OpenSim.Region.ClientStack; using OpenSim.Region.ClientStack;
@ -58,7 +57,6 @@ namespace SimpleApp
m_networkServersInfo = new NetworkServersInfo( 1000, 1000 ); m_networkServersInfo = new NetworkServersInfo( 1000, 1000 );
LocalAssetServer assetServer = new LocalAssetServer(); LocalAssetServer assetServer = new LocalAssetServer();
assetServer.SetServerInfo(m_networkServersInfo.AssetURL, "");
m_assetCache = new AssetCache(assetServer); m_assetCache = new AssetCache(assetServer);
} }