示例#1
0
int proxenet_python_load_file(plugin_t* plugin)
{

        if (proxenet_python_initialize_function(plugin, REQUEST) < 0) {
                plugin->state = INACTIVE;
                xlog_python(LOG_ERROR, "Failed to init %s in %s\n", CFG_REQUEST_PLUGIN_FUNCTION, plugin->name);
                return -1;
        }

        if (proxenet_python_initialize_function(plugin, RESPONSE) < 0) {
                xlog_python(LOG_ERROR, "Failed to init %s in %s\n", CFG_RESPONSE_PLUGIN_FUNCTION, plugin->name);
                return -1;
        }

        return 0;
}
示例#2
0
文件: core.c 项目: steeve85/proxenet
void proxenet_initialize_plugins()
{
	plugin_t *plugin      = plugins_list;
	plugin_t *prec_plugin = NULL;
	plugin_t *next_plugin = NULL;


	while(plugin) {
		
		switch (plugin->type) {
			
#ifdef _PYTHON_PLUGIN
			case _PYTHON_:
				if (proxenet_python_initialize_vm(plugin) < 0) {
					plugin->state = INACTIVE;
					xlog(LOG_ERROR, "%s\n", "Failed to init Python VM");
					goto delete_plugin;
				}

				if (proxenet_python_initialize_function(plugin, REQUEST) < 0) {
					plugin->state = INACTIVE;
					xlog(LOG_ERROR, "Failed to init %s in %s\n", CFG_REQUEST_PLUGIN_FUNCTION, plugin->name);
					goto delete_plugin;
				}
				
				if (proxenet_python_initialize_function(plugin, RESPONSE) < 0) {
					plugin->state = INACTIVE;
					xlog(LOG_ERROR, "Failed to init %s in %s\n", CFG_RESPONSE_PLUGIN_FUNCTION, plugin->name);
					goto delete_plugin;
				}
				break;
#endif
				
#ifdef _C_PLUGIN
			case _C_:
				if (proxenet_c_initialize_vm(plugin) < 0) {
					plugin->state = INACTIVE;
					xlog(LOG_ERROR, "%s\n", "Failed to init C VM");
					goto delete_plugin;
				}
				
				if (proxenet_c_initialize_function(plugin, REQUEST) < 0) {
					plugin->state = INACTIVE;
					xlog(LOG_ERROR, "Failed to init %s in %s\n", CFG_REQUEST_PLUGIN_FUNCTION, plugin->name);
					goto delete_plugin;
				}
				
				if (proxenet_c_initialize_function(plugin, RESPONSE) < 0) {
					plugin->state = INACTIVE;
					xlog(LOG_ERROR, "Failed to init %s in %s\n", CFG_RESPONSE_PLUGIN_FUNCTION, plugin->name);
					goto delete_plugin;
				}
				break;
#endif

#ifdef _RUBY_PLUGIN
			case _RUBY_:
				if (proxenet_ruby_initialize_vm(plugin) < 0) {
					plugin->state = INACTIVE;
					xlog(LOG_ERROR, "%s\n", "Failed to init Ruby VM");
					goto delete_plugin;
				}
				if (proxenet_ruby_initialize_function(plugin, REQUEST) < 0) {
					plugin->state = INACTIVE;
					xlog(LOG_ERROR, "Failed to init %s in %s\n", CFG_REQUEST_PLUGIN_FUNCTION, plugin->name);
					goto delete_plugin;
				}
				
				if (proxenet_ruby_initialize_function(plugin, RESPONSE) < 0) {
					plugin->state = INACTIVE;
					xlog(LOG_ERROR, "Failed to init %s in %s\n", CFG_RESPONSE_PLUGIN_FUNCTION, plugin->name);
					goto delete_plugin;
				}
				
				break;
#endif

#ifdef _PERL_PLUGIN
			case _PERL_:
				if (proxenet_perl_initialize_vm(plugin) < 0) {
					plugin->state = INACTIVE;
					plugin->type = -1;
					xlog(LOG_ERROR, "%s\n", "Failed to init Perl VM");
					goto delete_plugin;
				}
				break;
#endif

#ifdef _LUA_PLUGIN
			case _LUA_:
				if (proxenet_lua_initialize_vm(plugin) < 0) {
					plugin->state = INACTIVE;
					xlog(LOG_ERROR, "%s\n", "Failed to init Lua VM");
					goto delete_plugin;
				}

				if (proxenet_lua_load_file(plugin) < 0) {
					plugin->state = INACTIVE;
					xlog(LOG_ERROR, "Failed to load %s\n", plugin->filename);
					goto delete_plugin;
				}
				
				break;
#endif
			default:
				break;
		}
		
		if (cfg->verbose > 1)
			xlog(LOG_INFO, "Successfully initialiazed '%s'\n", plugin->filename);

		prec_plugin = plugin;
		plugin = plugin->next;
		continue;
		
		
delete_plugin:
		if(prec_plugin) {
			prec_plugin->next = plugin->next;
		} else {
			plugins_list = plugin->next;
		}

		if (cfg->verbose > 1)
			xlog(LOG_ERROR, "Removing '%s' from plugin list\n", plugin->filename);

		next_plugin = plugin->next;
		proxenet_remove_plugin(plugin);
		plugin = next_plugin;
	}
	
}