
org.modeshape.web.jcr.rest.handler.RestNodeHandler Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of modeshape-web-jcr-rest
Show all versions of modeshape-web-jcr-rest
ModeShape REST support library
/*
* ModeShape (http://www.modeshape.org)
* See the COPYRIGHT.txt file distributed with this work for information
* regarding copyright ownership. Some portions may be licensed
* to Red Hat, Inc. under one or more contributor license agreements.
* See the AUTHORS.txt file in the distribution for a full listing of
* individual contributors.
*
* ModeShape is free software. Unless otherwise indicated, all code in ModeShape
* is licensed to you under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* ModeShape is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.modeshape.web.jcr.rest.handler;
import javax.jcr.Item;
import javax.jcr.ItemNotFoundException;
import javax.jcr.Node;
import javax.jcr.RepositoryException;
import javax.jcr.Session;
import javax.servlet.http.HttpServletRequest;
import org.codehaus.jettison.json.JSONException;
import org.codehaus.jettison.json.JSONObject;
import org.jboss.resteasy.spi.NotFoundException;
import org.jboss.resteasy.spi.UnauthorizedException;
import org.modeshape.common.util.StringUtil;
import org.modeshape.web.jcr.rest.model.RestItem;
/**
* An extension to the {@link ItemHandler} which is used by {@link org.modeshape.web.jcr.rest.ModeShapeRestService} to interact
* with properties and nodes.
*
* @author Horia Chiorean ([email protected])
*/
@SuppressWarnings( "deprecation" )
public final class RestNodeHandler extends ItemHandler {
/**
* Retrieves the JCR {@link Item} at the given path, returning its rest representation.
*
* @param request the servlet request; may not be null or unauthenticated
* @param repositoryName the URL-encoded repository name
* @param workspaceName the URL-encoded workspace name
* @param id the node identifier
* @param depth the depth of the node graph that should be returned if {@code path} refers to a node. @{code 0} means return
* the requested node only. A negative value indicates that the full subgraph under the node should be returned. This
* parameter defaults to {@code 0} and is ignored if {@code path} refers to a property.
* @return a the rest representation of the item, as a {@link RestItem} instance.
* @throws RepositoryException if any JCR operations fail.
*/
public RestItem nodeWithId( HttpServletRequest request,
String repositoryName,
String workspaceName,
String id,
int depth ) throws RepositoryException {
Session session = getSession(request, repositoryName, workspaceName);
Node node = nodeWithId(id, session);
return createRestItem(request, depth, session, node);
}
/**
* Updates the properties at the path.
*
* If path points to a property, this method expects the request content to be either a JSON array or a JSON string. The array
* or string will become the values or value of the property. If path points to a node, this method expects the request
* content to be a JSON object. The keys of the objects correspond to property names that will be set and the values for the
* keys correspond to the values that will be set on the properties.
*
*
* @param request the servlet request; may not be null or unauthenticated
* @param rawRepositoryName the URL-encoded repository name
* @param rawWorkspaceName the URL-encoded workspace name
* @param id the node identifier
* @param requestContent the JSON-encoded representation of the values and, possibly, properties to be set
* @return the JSON-encoded representation of the node on which the property or properties were set.
* @throws JSONException if there is an error encoding the node
* @throws RepositoryException if any error occurs at the repository level.
*/
public RestItem updateNodeWithId( HttpServletRequest request,
String rawRepositoryName,
String rawWorkspaceName,
String id,
String requestContent ) throws JSONException, RepositoryException {
Session session = getSession(request, rawRepositoryName, rawWorkspaceName);
Node node = nodeWithId(id, session);
node = updateNode(node, stringToJSONObject(requestContent));
session.save();
return createRestItem(request, 0, session, node);
}
private JSONObject stringToJSONObject( String requestBody ) throws JSONException {
return StringUtil.isBlank(requestBody) ? new JSONObject() : new JSONObject(requestBody);
}
/**
* Deletes the subgraph at the node with the specified id, including all descendants.
*
* @param request the servlet request; may not be null or unauthenticated
* @param rawRepositoryName the URL-encoded repository name
* @param rawWorkspaceName the URL-encoded workspace name
* @param id the node identifier
* @throws NotFoundException if no item exists at {@code path}
* @throws UnauthorizedException if the user does not have the access required to delete the node with this id.
* @throws RepositoryException if any other error occurs
*/
public void deleteNodeWithId( HttpServletRequest request,
String rawRepositoryName,
String rawWorkspaceName,
String id ) throws NotFoundException, UnauthorizedException, RepositoryException {
assert rawRepositoryName != null;
assert rawWorkspaceName != null;
assert id != null;
Session session = getSession(request, rawRepositoryName, rawWorkspaceName);
Node node = nodeWithId(id, session);
node.remove();
session.save();
}
@Override
protected Node nodeWithId( String id,
Session session ) throws RepositoryException {
try {
return session.getNodeByIdentifier(id);
} catch (ItemNotFoundException infe) {
throw new NotFoundException(infe.getMessage(), infe);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy