Package org.apache.cocoon.auth

Source Code of org.apache.cocoon.auth.StandardApplication

/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements.  See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License.  You may obtain a copy of the License at
*
*      http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.cocoon.auth;

import java.util.HashMap;
import java.util.Map;

import org.apache.avalon.framework.activity.Disposable;
import org.apache.avalon.framework.configuration.Configurable;
import org.apache.avalon.framework.configuration.Configuration;
import org.apache.avalon.framework.configuration.ConfigurationException;
import org.apache.avalon.framework.logger.AbstractLogEnabled;
import org.apache.avalon.framework.service.ServiceException;
import org.apache.avalon.framework.service.ServiceManager;
import org.apache.avalon.framework.service.Serviceable;
import org.apache.avalon.framework.thread.ThreadSafe;
import org.apache.cocoon.auth.impl.AnonymousSecurityHandler;

/**
* This is the default implementation for an {@link Application}.
*
* @version $Id: StandardApplication.java 433543 2006-08-22 06:22:54Z crossley $
*/
public class StandardApplication
    extends AbstractLogEnabled
    implements Application, Configurable, Serviceable, Disposable, ThreadSafe {

    /** This prefix is used to lookup security handlers. */
    protected static final String HANDLER_CONFIG_PREFIX =
                                        SecurityHandler.class.getName() + '/';
    /** This prefix is used to lookup application stores. */
    protected static final String STORE_CONFIG_PREFIX =
                                        ApplicationStore.class.getName() + '/';

    /** The service manager. */
    protected ServiceManager manager;

    /** The security handler. */
    protected SecurityHandler handler;

    /** Attributes. */
    protected final Map attributes = new HashMap();

    /** Application store. */
    protected ApplicationStore store;

    /**
     * @see org.apache.avalon.framework.service.Serviceable#service(org.apache.avalon.framework.service.ServiceManager)
     */
    public void service(final ServiceManager aManager) throws ServiceException {
        this.manager = aManager;
    }

    /**
     * @see org.apache.avalon.framework.configuration.Configurable#configure(org.apache.avalon.framework.configuration.Configuration)
     */
    public void configure(final Configuration conf)
    throws ConfigurationException {
        String handlerName = conf.getAttribute("security-handler", null);
        String storeName = conf.getAttribute("store", null);
        try {
            if ( handlerName == null ) {
                this.handler = new AnonymousSecurityHandler();
            } else {
                if ( !handlerName.startsWith(HANDLER_CONFIG_PREFIX) ) {
                    handlerName = HANDLER_CONFIG_PREFIX + handlerName;
                }
                this.handler = (SecurityHandler)this.manager.lookup(handlerName);
            }
            if ( storeName != null ) {
                if ( !storeName.startsWith(STORE_CONFIG_PREFIX) ) {
                    storeName = STORE_CONFIG_PREFIX + storeName;
                }
                this.store = (ApplicationStore)this.manager.lookup(storeName);
            }
        } catch (ServiceException se) {
            throw new ConfigurationException("Unable to look up component.", se);
        }
        this.configureAttributes(conf);
    }

    /**
     * This method is invoked during configuration of the application. The
     * default behaviour is to add all children of the configuration object
     * as key value pairs. The name of the child is the key, and the value
     * of the tag is the value (as a string).
     * Subclasses can override this method, if a different/additional
     * behaviour is wanted.
     * @param conf The application configuration.
     */
    protected void configureAttributes(final Configuration conf) {
        Configuration[] children = conf.getChildren();
        for(int i=0; i<children.length; i++) {
            final String name = children[i].getName();
            final String value = children[i].getValue(null);
            if ( value != null && value.trim().length() > 0 ) {
                this.setAttribute(name, value.trim());
            }
        }
    }

    /**
     * @see org.apache.avalon.framework.activity.Disposable#dispose()
     */
    public void dispose() {
        if ( this.manager != null) {
            this.manager.release(this.store);
            if ( !(this.handler instanceof AnonymousSecurityHandler) ) {
                this.manager.release(this.handler);
            }
            this.store = null;
            this.handler = null;
            this.manager = null;
        }
    }

    /**
     * @see org.apache.cocoon.auth.Application#getSecurityHandler()
     */
    public SecurityHandler getSecurityHandler() {
        return this.handler;
    }

    /**
     * @see org.apache.cocoon.auth.Application#getApplicationStore()
     */
    public ApplicationStore getApplicationStore() {
        return this.store;
    }

    /**
     * @see org.apache.cocoon.auth.Application#setAttribute(java.lang.String, java.lang.Object)
     */
    public void setAttribute(final String key, final Object value) {
        this.attributes.put(key, value);
    }

    /**
     * @see org.apache.cocoon.auth.Application#removeAttribute(java.lang.String)
     */
    public void removeAttribute(final String key) {
        this.attributes.remove(key);
    }

    /**
     * @see org.apache.cocoon.auth.Application#getAttribute(java.lang.String)
     */
    public Object getAttribute(final String key) {
        return this.attributes.get(key);
    }

    /**
     * @see org.apache.cocoon.auth.Application#userDidLogin(org.apache.cocoon.auth.User, java.util.Map)
     */
    public void userDidLogin(final User user, final Map context) {
        // nothing to do here
    }

    /**
     * @see org.apache.cocoon.auth.Application#userWillLogout(org.apache.cocoon.auth.User, java.util.Map)
     */
    public void userWillLogout(final User user, final Map context) {
        // nothing to do here
    }

    /**
     * @see org.apache.cocoon.auth.Application#userIsAccessing(org.apache.cocoon.auth.User)
     */
    public void userIsAccessing(final User user) {
        // nothing to do here
    }
}
TOP

Related Classes of org.apache.cocoon.auth.StandardApplication

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.