¿Cómo averiguar la IP de la solicitud RESTful entrante utilizando JAX-RS en Heroku?

Estoy escribiendo un servicio RESTful de Java alojado en Heroku basado en un ejemplo ->https://api.heroku.com/myapps/template-java-jaxrs/clone

Mi servicio de muestra es:

package com.example.services;

import com.example.models.Time;

import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;

@Path("/time")
@Produces(MediaType.APPLICATION_JSON)
public class TimeService {

    @GET
    public Time get() {
        return new Time();
    }

}

Mi principal es:

public class Main {

    public static final String BASE_URI = getBaseURI();

    /**
     * @param args
     */
    public static void main(String[] args) throws Exception{
        final Map<String, String> initParams = new HashMap<String, String>();
        initParams.put("com.sun.jersey.config.property.packages","services.contracts"); 

        System.out.println("Starting grizzly...");
        SelectorThread threadSelector = GrizzlyWebContainerFactory.create(BASE_URI, initParams);
        System.out.println(String.format("Jersey started with WADL available at %sapplication.wadl.",BASE_URI, BASE_URI));
    }

    private static String getBaseURI() 
    {
        return "http://localhost:"+(System.getenv("PORT")!=null?System.getenv("PORT"):"9998")+"/";      
    }

}

Mi pregunta es ¿cómo puedo encontrar en mi servicio la combinación de dirección IP y puerto de la que proviene la solicitud? He leído cosas en @Context que inyecta javax.ws.rs.core.HttpHeaders, javax.ws.rs.core.Request, etc. Sin embargo, no hay información de IP o puerto entrante.

Sé que si implementas com.sun.grizzly.tcp.Adapter, puedes hacer algo como:

public static void main(String[] args) {
    SelectorThread st = new SelectorThread();
    st.setPort(8282);
    st.setAdapter(new EmbeddedServer());
    try {
        st.initEndpoint();
        st.startEndpoint();
    } catch (Exception e) {
        System.out.println("Exception in SelectorThread: " + e);
    } finally {
        if (st.isRunning()) {
            st.stopEndpoint();
        }
    }
}

public void service(Request request, Response response)
        throws Exception {
    String requestURI = request.requestURI().toString();

    System.out.println("New incoming request with URI: " + requestURI);
    System.out.println("Request Method is: " + request.method());

    if (request.method().toString().equalsIgnoreCase("GET")) {
        response.setStatus(HttpURLConnection.HTTP_OK);
        byte[] bytes = "Here is my response text".getBytes();

        ByteChunk chunk = new ByteChunk();
        response.setContentLength(bytes.length);
        response.setContentType("text/plain");
        chunk.append(bytes, 0, bytes.length);
        OutputBuffer buffer = response.getOutputBuffer();
        buffer.doWrite(chunk, response);
        response.finish();
    }
}

public void afterService(Request request, Response response)
        throws Exception {
    request.recycle();
    response.recycle();
}

y acceso

    request.remoteAddr()

Pero realmente me gustaría separar mi API RESTful de una manera más estructurada como en mi primera implementación.

Cualquier ayuda sería muy apreciada. ¡Gracias!

Respuestas a la pregunta(3)

Su respuesta a la pregunta