view flys-client/src/main/java/de/intevation/flys/client/server/ProxyServlet.java @ 3719:e82acd5c86f7

Merged revisions 5495-5496,5509,5514-5515,5521-5526 via svnmerge from file:///home/clients/bsh/bsh-generischer-viewer/Material/SVN/flys-client/trunk ........ r5495 | ingo | 2012-09-17 14:55:09 +0200 (Mo, 17 Sep 2012) | 1 line Added missing i18n strings for minfo state description. ........ r5496 | ingo | 2012-09-17 15:47:43 +0200 (Mo, 17 Sep 2012) | 1 line Tagged 'flys-client' as 2.9.1 ........ r5509 | teichmann | 2012-09-18 17:54:37 +0200 (Di, 18 Sep 2012) | 1 line Removed trailing whitespace. ........ r5514 | bricks | 2012-09-19 09:56:42 +0200 (Mi, 19 Sep 2012) | 2 lines Add missing Changelog entry for r5472 ........ r5515 | bricks | 2012-09-19 09:59:35 +0200 (Mi, 19 Sep 2012) | 2 lines Implement a scrolling gauge info tree ........ r5521 | bricks | 2012-09-19 14:41:48 +0200 (Mi, 19 Sep 2012) | 2 lines Add station info to the gauges ........ r5522 | bricks | 2012-09-19 14:43:43 +0200 (Mi, 19 Sep 2012) | 2 lines Improve the handling of the GaugePanel in the ParameterList ........ r5523 | bricks | 2012-09-19 14:51:02 +0200 (Mi, 19 Sep 2012) | 4 lines Improve the GaugePanel Be locale aware and only load the gauge info if the river name changes. ........ r5524 | bricks | 2012-09-19 15:14:46 +0200 (Mi, 19 Sep 2012) | 5 lines Fix a NullPointerException When iterating over a list it must be checked if the reference to the list is valid. ........ r5525 | bricks | 2012-09-19 15:16:24 +0200 (Mi, 19 Sep 2012) | 2 lines Don't display the GaugePanel if no river is selected ........ r5526 | bricks | 2012-09-19 15:18:36 +0200 (Mi, 19 Sep 2012) | 2 lines Use the wstunit from the river as unit for the Pegelnullpunkt ........ flys-client/tags/2.9.1@5528 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author Ingo Weinzierl <ingo.weinzierl@intevation.de>
date Wed, 19 Sep 2012 14:42:48 +0000
parents 92239b53823f
children
line wrap: on
line source
package de.intevation.flys.client.server;

import java.io.InputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.util.Enumeration;

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

import org.apache.http.Header;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.StatusLine;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.DefaultHttpClient;

import org.apache.log4j.Logger;

import de.intevation.flys.client.server.auth.User;

/**
 * Implements a Proxy for HTTP Requests
 */
public class ProxyServlet
extends HttpServlet
{
    private static Logger logger = Logger.getLogger(ProxyServlet.class);
    private String remoteurl;

    @Override
    public void init(ServletConfig config) {
        this.remoteurl = config.getInitParameter("remoteurl");
    }

    @Override
    public void doPost(HttpServletRequest req, HttpServletResponse resp) {
    }

    @Override
    public void doGet(HttpServletRequest req, HttpServletResponse resp)
    throws IOException {
        HttpClient httpclient = new DefaultHttpClient();

        String requesturi = req.getRequestURI();
        String query = req.getQueryString();

        HttpGet httpget = new HttpGet(this.remoteurl + "?" + query);

        boolean debug = logger.isDebugEnabled();

        for (Enumeration e = req.getHeaderNames(); e.hasMoreElements();) {
            String name = (String)e.nextElement();
            for (Enumeration f = req.getHeaders(name); f.hasMoreElements();) {
                String value = (String)f.nextElement();
                if (debug) {
                    logger.debug(
                        "Adding request header " + name + " : " + value);
                }
                httpget.addHeader(name, value);
            }
        }

        HttpResponse response = httpclient.execute(httpget);

        StatusLine statusline = response.getStatusLine();
        if (debug) {
            logger.debug("Response statuscode " + statusline.getStatusCode());
        }
        resp.setStatus(statusline.getStatusCode());

        Header[] headers = response.getAllHeaders();
        for(Header header : headers) {
            if (debug) {
                logger.debug(
                    "Adding response header " + header.getName() +
                    " : " + header.getValue());
            }
            resp.setHeader(header.getName(), header.getValue());
        }

        HttpEntity entity = response.getEntity();
        if (entity != null) {
            InputStream instream = entity.getContent();
            byte [] buf = new byte[4096];
            try {
                OutputStream outstream = resp.getOutputStream();
                try {
                    int read;
                    while ((read = instream.read(buf)) >= 0) {
                        outstream.write(buf, 0, read);
                    }
                    outstream.flush();
                }
                finally {
                    outstream.close();
                }
            }
            finally {
                instream.close();
            }
        }
    }

    private User getUser(HttpServletRequest req) {
            HttpSession session = req.getSession();
            return (User)session.getAttribute("user");
    }
}

http://dive4elements.wald.intevation.org