/**
* Copyright 2005-2014 Restlet
*
* The contents of this file are subject to the terms of one of the following
* open source licenses: Apache 2.0 or or EPL 1.0 (the "Licenses"). You can
* select the license that you prefer but you may not use this file except in
* compliance with one of these Licenses.
*
* You can obtain a copy of the Apache 2.0 license at
* http://www.opensource.org/licenses/apache-2.0
*
* You can obtain a copy of the EPL 1.0 license at
* http://www.opensource.org/licenses/eclipse-1.0
*
* See the Licenses for the specific language governing permissions and
* limitations under the Licenses.
*
* Alternatively, you can obtain a royalty free commercial license with less
* limitations, transferable or non-transferable, directly at
* http://restlet.com/products/restlet-framework
*
* Restlet is a registered trademark of Restlet S.A.S.
*/
package org.restlet.test.ext.jaxrs.services.resources;
import java.util.List;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.Context;
import javax.ws.rs.core.UriInfo;
/**
* @author Stephan Koops
* @see org.restlet.test.ext.jaxrs.services.tests.MatchedTest
* @see UriInfo#getMatchedResources()
* @see UriInfo#getMatchedURIs()
*/
@Path("ancestorTest")
public class MatchedUriTestResource {
@Context
private UriInfo mainUriInfo;
@GET
@Produces("text/plain")
public String get(@Context
UriInfo uriInfo) {
final int uriSize = uriInfo.getMatchedURIs().size();
final int resourcesSize = uriInfo.getMatchedResources().size();
return uriSize + "\n" + resourcesSize;
}
@GET
@Produces("text/plain")
@Path("sub")
public String getResources(@Context
UriInfo uriInfo) {
final StringBuilder stb = new StringBuilder();
final List<Object> resources = uriInfo.getMatchedResources();
stb.append(resources.size());
for (final Object resource : resources) {
stb.append('\n');
stb.append(resource.getClass().getName());
}
return stb.toString();
}
}