com.antelink.sourcesquare.server.servlet.TimeServlet.java Source code

Java tutorial

Introduction

Here is the source code for com.antelink.sourcesquare.server.servlet.TimeServlet.java

Source

/**
 * Copyright (C) 2009-2012 Antelink SAS
 *
 * This program is free software; you can redistribute it and/or modify it under
 * the terms of the GNU Affero General Public License Version 3 as published
 * by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License Version 3
 * for more details.
 *
 * You should have received a copy of the GNU Affero General Public License Version
 * 3 along with this program. If not, see http://www.gnu.org/licenses/agpl.html
 *
 * Additional permission under GNU AGPL version 3 section 7
 *
 * If you modify this Program, or any covered work, by linking or combining it with
 * Eclipse Java development tools (JDT) or Jetty (or a modified version of these
 * libraries), containing parts covered by the terms of Eclipse Public License 1.0,
 * the licensors of this Program grant you additional permission to convey the
 * resulting work. Corresponding Source for a non-source form of such a combination
 * shall include the source code for the parts of Eclipse Java development tools
 * (JDT) or Jetty used as well as that of the covered work.
 */
package com.antelink.sourcesquare.server.servlet;

import java.io.IOException;

import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

import com.antelink.sourcesquare.client.scan.ScanStatus;
import com.google.gson.Gson;

public class TimeServlet extends HttpServlet {

    private static final Log logger = LogFactory.getLog(StatusServlet.class);

    private static final long serialVersionUID = -424274857615445559L;

    /**
     * returns the estimated remaining time
     */
    @Override
    public void doGet(HttpServletRequest request, HttpServletResponse response) {
        try {
            Gson gson = new Gson();
            response.setContentType("application/json;charset=utf-8");
            response.getWriter().append(gson.toJson(computeTimeLeft()));

        } catch (IOException e) {
            logger.debug("Error dispatching time", e);
        }
    }

    private double computeTimeLeft() {
        if (ScanStatus.INSTANCE.getNbFilesScanned() <= 0) {
            return 0;
        }
        return (ScanStatus.INSTANCE.getNbFilesToScan() - ScanStatus.INSTANCE.getNbFilesScanned())
                * computeAvgTime();
    }

    private long computeAvgTime() {
        return ScanStatus.INSTANCE.getAverageScanningTime();
    }

}