package org.red5.server.plugin.admin; /* * RED5 Open Source Flash Server - http://www.osflash.org/red5 * * Copyright (c) 2006-2009 by respective authors (see below). All rights reserved. * * This library is free software; you can redistribute it and/or modify it under the * terms of the GNU Lesser General Public License as published by the Free Software * Foundation; either version 2.1 of the License, or (at your option) any later * version. * * This library is distributed in the hope that it will be useful, but WITHOUT ANY * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A * PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License along * with this library; if not, write to the Free Software Foundation, Inc., * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ import org.red5.logging.Red5LoggerFactory; import org.red5.server.Context; import org.red5.server.MappingStrategy; import org.red5.server.api.scope.IScope; import org.red5.server.plugin.Red5Plugin; import org.red5.server.plugin.admin.AdminHandler; import org.red5.server.plugin.admin.client.AuthClientRegistry; import org.red5.server.scope.GlobalScope; import org.red5.server.scope.Scope; import org.red5.server.scope.ScopeResolver; import org.red5.server.service.ServiceInvoker; import org.red5.server.util.ScopeUtils; import org.slf4j.Logger; import org.springframework.context.ApplicationContext; import org.springframework.context.support.FileSystemXmlApplicationContext; /** * Admin for Red5 * * @author Paul Gregoire * @author Dan Rossi */ public class AdminPlugin extends Red5Plugin { private static Logger log = Red5LoggerFactory.getLogger(AdminPlugin.class, "admin"); private AdminHandler handler = null; private ApplicationContext adminContext; private String hostName = "localhost"; @Override public void doStart() throws Exception { super.doStart(); //create a handler handler = new AdminHandler(); //create app context adminContext = new FileSystemXmlApplicationContext(new String[]{"classpath:/admin-security.xml"}, true, context); //set the context handler.setContext(adminContext); //get a ref to the "default" global scope GlobalScope global = (GlobalScope) server.getGlobal("default"); //create a scope resolver ScopeResolver scopeResolver = new ScopeResolver(); scopeResolver.setGlobalScope(global); AuthClientRegistry registry = (AuthClientRegistry) adminContext.getBean("authClientRegistry"); //create a context - this takes the place of the previous web context Context ctx = new Context(adminContext, "admin"); ctx.setClientRegistry(registry); ctx.setMappingStrategy(new MappingStrategy()); ctx.setPersistanceStore(global.getStore()); ctx.setScopeResolver(scopeResolver); ctx.setServiceInvoker(new ServiceInvoker()); //create a scope for the admin // Scope scope = new Scope.Builder((IScope) global, "scope", "admin", false).build(); // // scope.setContext(ctx); // scope.setHandler(handler); // // //set the scope on the handler // handler.setScope(scope); server.addMapping(hostName, "admin", "default"); // if (global.addChildScope(scope)) { // log.info("Admin scope was added to global (default) scope"); // // } else { // log.warn("Admin scope was not added to global (default) scope"); // } } @Override public void doStop() throws Exception { super.doStop(); //clean up / unregister everything server.removeMapping(hostName, "admin"); handler.stop(null); } @Override public String getName() { return "adminPlugin"; } @Override public void init() { log.debug("Initializing"); super.init(); } public String getHostName() { return hostName; } public void setHostName(String hostName) { this.hostName = hostName; } }