123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163 |
-
- #region Header
- #endregion Header
- using System;
- using System.Collections.Generic;
- using System.Threading;
- using OpenMetaverse;
- using Nini.Config;
- using OpenSim;
- using OpenSim.Framework;
- using OpenSim.Region.Framework.Interfaces;
- using OpenSim.Region.Framework.Scenes;
- using OpenSim.Region.Physics.Manager;
- using log4net;
- namespace OpenSim.Region.OptionalModules.ContentManagement
- {
- public class ContentManagementModule : IRegionModule
- {
- #region Static Fields
- private static readonly log4net.ILog m_log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
- #endregion Static Fields
- #region Fields
- bool initialised = false;
- CMController m_control = null;
- bool m_enabled = false;
- CMModel m_model = null;
- bool m_posted = false;
- CMView m_view = null;
- #endregion Fields
- #region Public Properties
- public bool IsSharedModule
- {
- get { return true; }
- }
- public string Name
- {
- get { return "ContentManagementModule"; }
- }
- #endregion Public Properties
- #region Public Methods
- public void Close()
- {
- }
- public void Initialise(Scene scene, IConfigSource source)
- {
- string databaseDir = "./";
- string database = "FileSystemDatabase";
- int channel = 345;
- try
- {
- if (source.Configs["CMS"] == null)
- return;
- m_enabled = source.Configs["CMS"].GetBoolean("enabled", false);
- databaseDir = source.Configs["CMS"].GetString("directory", databaseDir);
- database = source.Configs["CMS"].GetString("database", database);
- channel = source.Configs["CMS"].GetInt("channel", channel);
- if (database != "FileSystemDatabase" && database != "GitDatabase")
- {
- m_log.ErrorFormat("[Content Management]: The Database attribute must be defined as either FileSystemDatabase or GitDatabase");
- m_enabled = false;
- }
- }
- catch (Exception e)
- {
- m_log.ErrorFormat("[Content Management]: Exception thrown while reading parameters from configuration file. Message: " + e);
- m_enabled = false;
- }
- if (!m_enabled)
- {
- m_log.Info("[Content Management]: Content Management System is not Enabled.");
- return;
- }
- lock (this)
- {
- if (!initialised)
- {
- m_view = new CMView();
- m_model = new CMModel();
- m_control = new CMController(m_model, m_view, scene, channel);
- m_model.Initialise(database);
- m_view.Initialise(m_model);
- initialised = true;
- m_model.InitialiseDatabase(scene, databaseDir);
- }
- else
- {
- m_model.InitialiseDatabase(scene, databaseDir);
- m_control.RegisterNewRegion(scene);
- }
- }
- }
- public void PostInitialise()
- {
- if (! m_enabled)
- return;
- lock (this)
- {
- if (!m_posted)
- {
- m_model.PostInitialise();
- m_posted = true;
- }
- }
- }
- #endregion Public Methods
- }
- }
|