/** * $Id: RedirectControllableEntityProviderMock.java 105077 2012-02-24 22:54:29Z ottenhoff@longsight.com $ * $URL: https://source.sakaiproject.org/svn/entitybroker/trunk/mocks/src/java/org/sakaiproject/entitybroker/mocks/RedirectControllableEntityProviderMock.java $ * RESTfulEntityProviderMock.java - entity-broker - Apr 9, 2008 10:31:13 AM - azeckoski ************************************************************************** * Copyright (c) 2008 The Sakai Foundation * * Licensed under the Educational Community 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.opensource.org/licenses/ECL-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 org.sakaiproject.entitybroker.mocks; import java.util.Map; import org.sakaiproject.entitybroker.EntityView; import org.sakaiproject.entitybroker.entityprovider.CoreEntityProvider; import org.sakaiproject.entitybroker.entityprovider.annotations.EntityURLRedirect; import org.sakaiproject.entitybroker.entityprovider.capabilities.CRUDable; import org.sakaiproject.entitybroker.entityprovider.capabilities.CollectionResolvable; import org.sakaiproject.entitybroker.entityprovider.capabilities.RESTful; import org.sakaiproject.entitybroker.entityprovider.capabilities.Resolvable; import org.sakaiproject.entitybroker.entityprovider.capabilities.RedirectControllable; import org.sakaiproject.entitybroker.entityprovider.extension.Formats; import org.sakaiproject.entitybroker.mocks.data.MyEntity; /** * Stub class to make it possible to test the {@link RedirectControllable} capabilities, will perform like the * actual class so it can be reliably used for testing<br/> * Will perform all {@link CRUDable} operations as well as allowing for internal data output processing<br/> * Returns {@link MyEntity} objects<br/> * Allows for testing {@link Resolvable} and {@link CollectionResolvable} as well, returns 2 {@link MyEntity} objects * if no search restrictions, 1 if "stuff" property is set, none if other properties are set * * @author Aaron Zeckoski (aaron@caret.cam.ac.uk) */ public class RedirectControllableEntityProviderMock extends RESTfulEntityProviderMock implements CoreEntityProvider, RESTful, RedirectControllable { public RedirectControllableEntityProviderMock(String prefix, String[] ids) { super(prefix, ids); } public String[] templates = new String[] { "/{prefix}/site/{siteId}/user/{userId}", "/{prefix}/{id}/{thing}/go", "/{prefix}/xml/{id}" }; public String[] defineHandledTemplatePatterns() { return templates; } // TODO handle infinite redirects public String handleRedirects(String matchedTemplate, String incomingURL, String[] incomingSegments, Map<String, String> values) { String redirectURL = null; if (matchedTemplate.equals(templates[0])) { redirectURL = values.get(EntityView.PREFIX) + EntityView.SEPARATOR + "siteuser?site=" + values.get("siteId") + "&user=" + values.get("userId"); } else if (matchedTemplate.equals(templates[1])) { redirectURL = "http://caret.cam.ac.uk/?prefix=" + values.get(EntityView.PREFIX) + "&thing=" + values.get("thing"); } else if (matchedTemplate.equals(templates[2])) { redirectURL = values.get(EntityView.PREFIX) + EntityView.SEPARATOR + values.get(EntityView.ID) + EntityView.PERIOD + Formats.XML; } return redirectURL; } @EntityURLRedirect("/{prefix}/going/nowhere") public String returningRedirector(String incomingURL, Map<String, String> values) { return ""; } @EntityURLRedirect("/{prefix}/keep/moving") public String neverRedirector(String incomingURL, Map<String, String> values) { return null; } }