/* * Copyright 2011 Google Inc. * * Licensed 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 com.google.gwt.sample.gaerequest.client; import com.google.gwt.http.client.Request; import com.google.gwt.http.client.RequestBuilder; import com.google.gwt.http.client.RequestCallback; import com.google.gwt.http.client.Response; import com.google.gwt.sample.gaerequest.shared.GaeHelper; import com.google.gwt.user.client.Window.Location; import com.google.web.bindery.event.shared.EventBus; import com.google.web.bindery.requestfactory.gwt.client.DefaultRequestTransport; import com.google.web.bindery.requestfactory.shared.ServerFailure; /** * Extends DefaultRequestTransport to handle the authentication failures * reported by {@link com.google.gwt.sample.gaerequest.server.GaeAuthFilter}. */ public class GaeAuthRequestTransport extends DefaultRequestTransport { private final EventBus eventBus; public GaeAuthRequestTransport(EventBus eventBus) { this.eventBus = eventBus; } @Override protected void configureRequestBuilder(RequestBuilder builder) { super.configureRequestBuilder(builder); /* * Add the redirect URL in case the user is logged out. * * /MobileWebApp.html?parem0=value0¶m1=value1#hash */ String redirectUrl = Location.getPath() + Location.getQueryString() + Location.getHash(); builder.setHeader(GaeHelper.REDIRECT_URL_HTTP_HEADER_NAME, redirectUrl); } @Override protected RequestCallback createRequestCallback(final TransportReceiver receiver) { final RequestCallback superCallback = super.createRequestCallback(receiver); return new RequestCallback() { @Override public void onError(Request request, Throwable exception) { superCallback.onError(request, exception); } @Override public void onResponseReceived(Request request, Response response) { /* * The GaeAuthFailure filter responds with Response.SC_UNAUTHORIZED and * adds a "login" url header if the user is not logged in. When we * receive that combo, post an event so that the app can handle things * as it sees fit. */ if (Response.SC_UNAUTHORIZED == response.getStatusCode()) { String loginUrl = response.getHeader("login"); if (loginUrl != null) { /* * Hand the receiver a non-fatal callback, so that * com.google.web.bindery.requestfactory.shared.Receiver will not * post a runtime exception. */ receiver .onTransportFailure(new ServerFailure("Unauthenticated user", null, null, false)); eventBus.fireEvent(new GaeAuthenticationFailureEvent(loginUrl)); return; } } superCallback.onResponseReceived(request, response); } }; } }