001    /**
002     *
003     *  Licensed to the Apache Software Foundation (ASF) under one or more
004     *  contributor license agreements.  See the NOTICE file distributed with
005     *  this work for additional information regarding copyright ownership.
006     *  The ASF licenses this file to You under the Apache License, Version 2.0
007     *  (the "License"); you may not use this file except in compliance with
008     *  the License.  You may obtain a copy of the License at
009     *
010     *     http://www.apache.org/licenses/LICENSE-2.0
011     *
012     *  Unless required by applicable law or agreed to in writing, software
013     *  distributed under the License is distributed on an "AS IS" BASIS,
014     *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
015     *  See the License for the specific language governing permissions and
016     *  limitations under the License.
017     */
018    package org.apache.geronimo.jetty.requestlog;
019    
020    import org.apache.geronimo.gbean.GBeanInfo;
021    import org.apache.geronimo.gbean.GBeanInfoBuilder;
022    import org.apache.geronimo.gbean.GBeanLifecycle;
023    import org.apache.geronimo.j2ee.j2eeobjectnames.NameFactory;
024    import org.apache.geronimo.jetty.JettyContainer;
025    import org.apache.geronimo.system.serverinfo.ServerInfo;
026    
027    /**
028     * @version $Rev: 470597 $ $Date: 2006-11-02 15:30:55 -0800 (Thu, 02 Nov 2006) $
029     */
030    public class NCSARequestLog implements GBeanLifecycle, JettyRequestLog {
031        private final JettyContainer container;
032        private final ServerInfo serverInfo;
033        private final org.mortbay.http.NCSARequestLog requestLog;
034        private boolean preferProxiedForAddress;
035        private String filename;
036    
037        public NCSARequestLog(JettyContainer container, ServerInfo serverInfo) {
038            this.container = container;
039            this.serverInfo = serverInfo;
040            requestLog = new org.mortbay.http.NCSARequestLog();
041        }
042    
043        public void setFilename(String filename) {
044            this.filename = filename;
045        }
046    
047        public String getFilename() {
048            return filename;
049        }
050    
051        public void setLogDateFormat(String format) {
052            requestLog.setLogDateFormat(format);
053        }
054    
055        public String getLogDateFormat() {
056            return requestLog.getLogDateFormat();
057        }
058    
059        public void setLogTimeZone(String tz) {
060            requestLog.setLogTimeZone(tz);
061        }
062    
063        public String getLogTimeZone() {
064            return requestLog.getLogTimeZone();
065        }
066    
067        public int getRetainDays() {
068            return requestLog.getRetainDays();
069        }
070    
071        public void setRetainDays(int retainDays) {
072            requestLog.setRetainDays(retainDays);
073        }
074    
075        public boolean isExtended() {
076            return requestLog.isExtended();
077        }
078    
079        public void setExtended(boolean e) {
080            requestLog.setExtended(e);
081        }
082    
083        public boolean isAppend() {
084            return requestLog.isAppend();
085        }
086    
087        public void setAppend(boolean a) {
088            requestLog.setAppend(a);
089        }
090    
091        public void setIgnorePaths(String[] ignorePaths) {
092            requestLog.setIgnorePaths(ignorePaths);
093        }
094    
095        public String[] getIgnorePaths() {
096            return requestLog.getIgnorePaths();
097        }
098    
099        public void setPreferProxiedForAddress(boolean value) {
100            this.preferProxiedForAddress = value;
101            requestLog.setPreferProxiedForAddress(value);
102        }
103    
104        public boolean isPreferProxiedForAddress() {
105            return preferProxiedForAddress;
106        }
107    
108        public String getAbsoluteFilePath() {
109            return requestLog == null ? null : requestLog.getDatedFilename();
110        }
111    
112        public void doStart() throws Exception {
113            requestLog.setFilename(serverInfo.resolveServerPath(filename));
114            container.setRequestLog(requestLog);
115            requestLog.start();
116        }
117    
118        public void doStop() throws Exception {
119            requestLog.stop();
120            container.setRequestLog(null);
121        }
122    
123        public void doFail() {
124            container.setRequestLog(null);
125            requestLog.stop();
126        }
127    
128        public static final GBeanInfo GBEAN_INFO;
129    
130        static {
131            GBeanInfoBuilder infoFactory = GBeanInfoBuilder.createStatic("NCSA Request Log", NCSARequestLog.class);
132            infoFactory.addReference("JettyContainer", JettyContainer.class, NameFactory.GERONIMO_SERVICE);
133            infoFactory.addReference("ServerInfo", ServerInfo.class, NameFactory.GERONIMO_SERVICE);
134    
135            infoFactory.addInterface(JettyRequestLog.class, new String[]{"filename", "logDateFormat", "logTimeZone",
136                    "retainDays", "extended", "append", "ignorePaths", "preferProxiedForAddress", });
137    
138            infoFactory.setConstructor(new String[]{"JettyContainer", "ServerInfo"});
139            GBEAN_INFO = infoFactory.getBeanInfo();
140        }
141    
142        public static GBeanInfo getGBeanInfo() {
143            return GBEAN_INFO;
144        }
145    }