/[projects]/smsdaemon/PluginManager.cpp
ViewVC logotype

Diff of /smsdaemon/PluginManager.cpp

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

smsdaemon/plugins/PluginManager.cpp revision 45 by torben, Wed Jun 11 09:00:56 2008 UTC smsdaemon/PluginManager.cpp revision 208 by torben, Sun Dec 21 18:41:08 2008 UTC
# Line 1  Line 1 
           
1  #include "PluginManager.h"  #include "PluginManager.h"
2    
3  #include "common.h"  #include "Logger.h"
4    #include "ConfigFile.h"
5  #include "EchoPlugin.h"  #include "Common.h"
6  #include "SpamPlugin.h"  #include "Util.h"
7  #include "ShellExecPlugin.h"  
8    #include "plugins/EchoPlugin.h"
9    #include "plugins/SpamPlugin.h"
10    #include "plugins/ShellExecPlugin.h"
11    #include "plugins/TogPlugin.h"
12    #include "plugins/StatusPlugin.h"
13    #include "plugins/ListPlugin.h"
14    #include "plugins/HostStatusPlugin.h"
15    #include "plugins/WeatherPlugin.h"
16    #include "plugins/UrlTriggerPlugin.h"
17    
18  typedef std::map<std::string, Plugin*>::iterator MapIterator;  typedef std::map<std::string, Plugin*>::iterator MapIterator;
19    
20  PluginManager::PluginManager()  PluginManager::PluginManager()
21  {  {
22  }  }
23            
24  PluginManager::~PluginManager()  PluginManager::~PluginManager()
25  {  {
26  }  }
# Line 21  PluginManager::~PluginManager() Line 28  PluginManager::~PluginManager()
28    
29  void PluginManager::AddPlugin(Plugin* plugin)  void PluginManager::AddPlugin(Plugin* plugin)
30  {  {
         Common* cmn = Common::instance();  
   
31          if (plugin != 0)          if (plugin != 0)
32          {          {
33                  std::string command = plugin->GetCommand();                  if (plugin->IsHelper())
34                    {
35                  if ( _plugins[ command ] == 0)                          _helper_plugins.push_back(plugin);
36                          _plugins[ command ] = plugin;                  }
37                  else                  else
38                          cmn->logMessage( std::string("AddPlugin() -- already have a plugin called ") + command);                  {
39                            std::string command = plugin->GetCommand();
40    
41                            if ( _plugins[ command ] == 0)
42                                    _plugins[ command ] = plugin;
43                            else
44                                    Logger::logMessage( std::string("AddPlugin() -- already have a plugin called ") + command);
45                    }
46          }          }
47          else          else
48          {          {
49                  cmn->logMessage("AddPlugin() -- cannot register a null pointer");                  Logger::logMessage("AddPlugin() -- cannot register a null pointer");
50          }          }
51  }  }
52    
53  void PluginManager::LoadPlugins()  Plugin* PluginManager::CreatePlugin(const std::string& pluginName, const std::map<std::string,std::string>& args)
54  {  {
55          Common* cmn = Common::instance();          if (pluginName == "echo")
56                    return new EchoPlugin();
57    
58          static EchoPlugin echo;          if (pluginName == "spam")
59                    return new SpamPlugin();
60    
61          static SpamPlugin spam;          if (pluginName == "tog")
62                    return new TogPlugin();
63    
64            if (pluginName == "status")
65                    return new StatusPlugin();
66    
67            if (pluginName == "list")
68                    return new ListPlugin();
69    
70            if (pluginName == "hoststatus")
71                    return new HostStatusPlugin();
72    
73            if (pluginName == "weather")
74                    return new WeatherPlugin();
75    
76            if (pluginName == "shellexec")
77                    return new ShellExecPlugin(args);
78    
79            if (pluginName == "urltrigger")
80                    return new UrlTriggerPlugin(args);
81            
82            return 0;
83    }
84    
85          static ShellExecPlugin wake("wake", "/home/torben/bin/wake");  
86    void PluginManager::DestroyPlugins()
87    {
88            for (std::map<std::string,Plugin*>::iterator it=_plugins.begin(); it!=_plugins.end(); ++it)
89            {
90                    delete it->second;
91            }
92            _plugins.clear();
93    }
94    
95    void PluginManager::LoadPlugins()
96    {
97            Logger::logMessage("-------- PluginList --------");
98            std::vector<Value> pluginlist = Common::instance()->GetConfigfile()->GetValues("smsdaemon", "plugin");
99    
100            for (unsigned i=0; i<pluginlist.size(); i++)
101            {
102                    std::string current = pluginlist[i];
103                    
104                    std::string name;
105                    unsigned pos = current.find(' ');
106                    std::map<std::string,std::string> args;
107    
108                    std::string argstr;
109    
110                    if (pos == std::string::npos)
111                    {
112                            name = current;
113                    }
114                    else
115                    {
116                            name = Util::str_trim(current.substr(0,pos));
117                            argstr = Util::str_trim(current.substr(pos+1,1024));
118                            args = ConfigHelper::ParseArguments(argstr);
119                    }
120    
121                    Plugin* pl = 0;
122                    try
123                    {      
124                            pl = CreatePlugin(name, args );
125                    }
126                    catch (std::exception& e)
127                    {
128                            Logger::logMessage(std::string("Failed to load plugin ") + name + " with args: " + argstr);
129                            Logger::logMessage(std::string("Reason: ") + e.what());
130                            continue;
131                    }
132    
133                    if (pl)
134                            AddPlugin(pl);
135                    else
136                            Logger::logMessage( std::string("Unknown plugin: ")+name);
137                                    
138            }      
139    
140          for(MapIterator it = _plugins.begin(); it != _plugins.end(); ++it)  
141            for (MapIterator it = _plugins.begin(); it != _plugins.end(); ++it)
142          {          {
143                  Plugin* pl = (*it).second;                  Plugin* pl = (*it).second;
144                  if (pl != 0)                  if (pl != 0)
145                          cmn->logMessage( std::string("Loaded plugin \"") + pl->GetCommand() + "\" - " + pl->GetDescription() );                          Logger::logMessage( std::string("Loaded plugin \"") + pl->GetCommand() + "\" - " + pl->GetDescription() );
146          }          }
147  }  }
148    
149    
150  Plugin* PluginManager::GetPlugin(const std::string& pluginname)  Plugin* PluginManager::GetPlugin(const std::string& pluginname)
151  {  {
152          return _plugins[ pluginname ];          return _plugins[ pluginname ];

Legend:
Removed from v.45  
changed lines
  Added in v.208

  ViewVC Help
Powered by ViewVC 1.1.20