/* * 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.jk.core; import java.util.Hashtable; import javax.management.ObjectName; /** * The controller object. It manages all other jk objects, acting as the root of * the jk object model. * * @author Gal Shachor * @author Henri Gomez [hgomez@apache.org] * @author Dan Milstein [danmil@shore.net] * @author Keith Wannamaker [Keith@Wannamaker.org] * @author Kevin Seguin * @author Costin Manolache */ public class WorkerEnv { Hashtable properties; public static final int ENDPOINT_NOTE=0; public static final int REQUEST_NOTE=1; public static final int SSL_CERT_NOTE=16; int noteId[]=new int[4]; String noteName[][]=new String[4][]; private Object notes[]=new Object[32]; Hashtable handlersMap=new Hashtable(); JkHandler handlersTable[]=new JkHandler[20]; int handlerCount=0; // base dir for the jk webapp String home; int localId=0; public WorkerEnv() { for( int i=0; i<noteId.length; i++ ) { noteId[i]=7; noteName[i]=new String[20]; } } public void setLocalId(int id) { localId=id; } public int getLocalId() { return localId; } public void setJkHome( String s ) { home=s; } public String getJkHome() { return home; } public final Object getNote(int i ) { return notes[i]; } public final void setNote(int i, Object o ) { notes[i]=o; } public int getNoteId( int type, String name ) { for( int i=0; i<noteId[type]; i++ ) { if( name.equals( noteName[type][i] )) return i; } int id=noteId[type]++; noteName[type][id]=name; return id; } public void addHandler( String name, JkHandler w ) { JkHandler oldH = getHandler(name); if(oldH == w) { // Already added return; } w.setWorkerEnv( this ); w.setName( name ); handlersMap.put( name, w ); if( handlerCount > handlersTable.length ) { JkHandler newT[]=new JkHandler[ 2 * handlersTable.length ]; System.arraycopy( handlersTable, 0, newT, 0, handlersTable.length ); handlersTable=newT; } if(oldH == null) { handlersTable[handlerCount]=w; w.setId( handlerCount ); handlerCount++; } else { handlersTable[oldH.getId()]=w; w.setId(oldH.getId()); } // Notify all other handlers of the new one // XXX Could be a Coyote action ? for( int i=0; i< handlerCount ; i++ ) { handlersTable[i].addHandlerCallback( w ); } } public final JkHandler getHandler( String name ) { return (JkHandler)handlersMap.get(name); } public final JkHandler getHandler( int id ) { return handlersTable[id]; } public final int getHandlerCount() { return handlerCount; } public ObjectName[] getHandlersObjectName() { ObjectName onames[]=new ObjectName[ handlerCount ]; for( int i=0; i<handlerCount; i++ ) { onames[i]=handlersTable[i].getObjectName(); } return onames; } }