clockwerk-opensim – Blame information for rev 1

Subversion Repositories:
Rev:
Rev Author Line No. Line
1 vero 1 /*
2 * Copyright (c) Contributors, http://opensimulator.org/
3 * See CONTRIBUTORS.TXT for a full list of copyright holders.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions are met:
7 * * Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * * Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
12 * * Neither the name of the OpenSimulator Project nor the
13 * names of its contributors may be used to endorse or promote products
14 * derived from this software without specific prior written permission.
15 *
16 * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
17 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19 * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
20 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
21 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
22 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
23 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
25 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 */
27 using System;
28 using System.Collections.Generic;
29 using System.Reflection;
30 using log4net;
31 using Nini.Config;
32 using Mono.Addins;
33 using OpenMetaverse;
34 using OpenSim.Framework;
35 using OpenSim.Framework.Communications;
36 using OpenSim.Framework.Servers;
37 using OpenSim.Framework.Client;
38 using OpenSim.Region.Framework.Interfaces;
39 using OpenSim.Region.Framework.Scenes;
40  
41 namespace OpenSim.Region.CoreModules.Avatar.InstantMessage
42 {
43 [Extension(Path = "/OpenSim/RegionModules", NodeName = "RegionModule", Id = "MuteListModule")]
44 public class MuteListModule : ISharedRegionModule
45 {
46 private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
47  
48 private bool enabled = true;
49 private List<Scene> m_SceneList = new List<Scene>();
50 private string m_RestURL = String.Empty;
51  
52 public void Initialise(IConfigSource config)
53 {
54 IConfig cnf = config.Configs["Messaging"];
55 if (cnf == null)
56 {
57 enabled = false;
58 return;
59 }
60  
61 if (cnf != null && cnf.GetString("MuteListModule", "None") !=
62 "MuteListModule")
63 {
64 enabled = false;
65 return;
66 }
67  
68 m_RestURL = cnf.GetString("MuteListURL", "");
69 if (m_RestURL == "")
70 {
71 m_log.Error("[MUTE LIST] Module was enabled, but no URL is given, disabling");
72 enabled = false;
73 return;
74 }
75 }
76  
77 public void AddRegion(Scene scene)
78 {
79 if (!enabled)
80 return;
81  
82 lock (m_SceneList)
83 {
84 m_SceneList.Add(scene);
85  
86 scene.EventManager.OnNewClient += OnNewClient;
87 }
88 }
89  
90 public void RegionLoaded(Scene scene)
91 {
92 }
93  
94 public void RemoveRegion(Scene scene)
95 {
96 if (!enabled)
97 return;
98  
99 lock (m_SceneList)
100 {
101 m_SceneList.Remove(scene);
102 }
103 }
104  
105 public void PostInitialise()
106 {
107 if (!enabled)
108 return;
109  
110 m_log.Debug("[MUTE LIST] Mute list enabled");
111 }
112  
113 public string Name
114 {
115 get { return "MuteListModule"; }
116 }
117  
118 public Type ReplaceableInterface
119 {
120 get { return null; }
121 }
122  
123 public void Close()
124 {
125 }
126  
127 private void OnNewClient(IClientAPI client)
128 {
129 client.OnMuteListRequest += OnMuteListRequest;
130 }
131  
132 private void OnMuteListRequest(IClientAPI client, uint crc)
133 {
134 m_log.DebugFormat("[MUTE LIST] Got mute list request for crc {0}", crc);
135 string filename = "mutes"+client.AgentId.ToString();
136  
137 IXfer xfer = client.Scene.RequestModuleInterface<IXfer>();
138 if (xfer != null)
139 {
140 xfer.AddNewFile(filename, new Byte[0]);
141 client.SendMuteListUpdate(filename);
142 }
143 }
144 }
145 }
146