summaryrefslogtreecommitdiffstats
path: root/sca-java-2.x/contrib/samples/async-servlet-sca/src/main/java/sample/StockServlet.java
blob: 0c0cc6fb2ddbb3530cdae140e624706860885d62 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
/*
 * 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 sample;

import java.io.IOException;
import java.io.Writer;
import java.util.Timer;
import java.util.TimerTask;

import javax.servlet.AsyncContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.log4j.Logger;
import org.oasisopen.sca.annotation.Reference;

@WebServlet(asyncSupported = true, urlPatterns = "/stock")
public class StockServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
	private static final long MILLIS_PER_SECOND = 1000L;

	// @Reference
	private StockService service = new StockServiceImpl();
	private AsyncContext asyncContext;
	private Timer timer;
	private long updatePeriod = 1L; // default 1 sec 
	private Logger logger = Logger.getLogger(StockServlet.class);

	protected void doGet(HttpServletRequest req, HttpServletResponse resp)
			throws ServletException {
		logger.debug("Received request.");
		logger.debug("Starting async context...");
		asyncContext = req.startAsync();
		logger.debug("Service reference: " + service);
		logger.debug("Setting timer...");
		timer = new Timer();
		logger.debug("Setting update period...");
		this.updatePeriod = Long.parseLong(req.getParameter("period"));
		timer.scheduleAtFixedRate(new StockTask(), 0, updatePeriod * MILLIS_PER_SECOND);
		logger.debug("Exiting doGet method...");
	}
	
	public void updateClient() {
		try {
			logger.debug("Updating response...");
			asyncContext.getResponse().setContentType("text/plain");
			Writer writer = asyncContext.getResponse().getWriter();
			writer.write("Symbol: " + service.getSymbol() + ", Price "
					+ service.getValue() + "\n");
			writer.flush();
			asyncContext.getResponse().flushBuffer();
			logger.debug("Flushed response.");
		} catch (IOException e) {
			logger.debug(e.getMessage(), e);
			asyncContext.complete(); 
		}
	}

	//-----------------------------------------------------------
	
	public class StockTask extends TimerTask {

		@Override
		public void run() {
			updateClient();
		}
		
	}
	
}