(no commit message)
[utils] / crawler / kissweb / src / main / java / org / wamblee / crawler / kiss / servlet / Application.java
1 /*
2  * Copyright 2006 the original author or authors.
3  * 
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  * 
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  * 
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 package org.wamblee.crawler.kiss.servlet;
18
19 import javax.servlet.ServletContextEvent;
20 import javax.servlet.ServletContextListener;
21
22 import org.wamblee.crawler.kiss.scheduling.CrawlerScheduler;
23 import org.wamblee.general.BeanKernel;
24
25 /**
26  * The mechanism for kick starting the scheduling of the KiSS crawler. 
27  *
28  * @author Erik Brakkee
29  */
30 public class Application implements ServletContextListener {
31
32     /**
33      * Constructs the listener.
34      *
35      */
36     public Application() { 
37         // Empty. 
38     }
39
40     /*
41      * (non-Javadoc)
42      * 
43      * @see javax.servlet.ServletContextListener#contextInitialized(javax.servlet.ServletContextEvent)
44      */
45     public void contextInitialized(ServletContextEvent aEvent) {
46         aEvent.getServletContext().log("KiSS Crawler initializing");
47         try {
48             getScheduler().initialize();
49         } catch (Exception e) {
50             aEvent.getServletContext().log("Error scheduling job", e);
51             return; 
52         }
53         aEvent.getServletContext().log("KiSS Crawler initialized");
54     }
55
56     /*
57      * (non-Javadoc)
58      * 
59      * @see javax.servlet.ServletContextListener#contextDestroyed(javax.servlet.ServletContextEvent)
60      */
61     public void contextDestroyed(ServletContextEvent aEvent) {
62         aEvent.getServletContext().log("KiSS Crawler shutting down");
63         try {
64             getScheduler().shutdown();
65         } catch (Exception e) {
66             aEvent.getServletContext().log("Error scheduling job", e);
67             return; 
68         }
69         aEvent.getServletContext().log("KiSS Crawler shut down complete");
70     }
71
72     /**
73      * Gets the scheduler from Spring. 
74      * @return Scheduler. 
75      */
76     private CrawlerScheduler getScheduler() { 
77         return BeanKernel.getBeanFactory().find(CrawlerScheduler.class);
78     }
79
80     public static void main(String[] aArgs) throws Exception {
81         Application application = new Application();
82         application.getScheduler().initialize();
83     }
84 }