/******************************************************************************* * Copyright (c) 2014 IBM Corporation and others * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * IBM Corporation - initial API and implementation *******************************************************************************/ package org.eclipse.orion.server.cf.handlers.v1; import org.eclipse.orion.internal.server.servlets.ServletResourceHandler; import org.eclipse.orion.server.core.IOUtilities; import java.net.URL; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.eclipse.core.runtime.CoreException; import org.eclipse.core.runtime.IStatus; import org.eclipse.orion.server.cf.CFActivator; import org.eclipse.orion.server.cf.CFProtocolConstants; import org.eclipse.orion.server.cf.commands.GetOrgsCommand; import org.eclipse.orion.server.cf.jobs.CFJob; import org.eclipse.orion.server.cf.objects.Target; import org.eclipse.orion.server.cf.servlets.AbstractRESTHandler; import org.eclipse.orion.server.cf.utils.HttpUtil; import org.eclipse.orion.server.core.ServerStatus; import org.eclipse.osgi.util.NLS; import org.json.JSONObject; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class OrgsHandlerV1 extends AbstractRESTHandler<Target> { private final Logger logger = LoggerFactory.getLogger("org.eclipse.orion.server.cf"); //$NON-NLS-1$ public OrgsHandlerV1(ServletResourceHandler<IStatus> statusHandler) { super(statusHandler); } @Override protected Target buildResource(HttpServletRequest request, String path) throws CoreException { return null; } @Override protected CFJob handleGet(Target target, HttpServletRequest request, HttpServletResponse response, final String path) { final JSONObject targetJSON = extractJSONData(IOUtilities.getQueryParameter(request, CFProtocolConstants.KEY_TARGET)); return new CFJob(request, false) { @Override protected IStatus performJob() { try { URL targetUrl = null; if (targetJSON != null) { try { targetUrl = new URL(targetJSON.getString(CFProtocolConstants.KEY_URL)); } catch (Exception e) { // do nothing } } Target target = CFActivator.getDefault().getTargetRegistry().getTarget(userId, targetUrl); if (target == null) { return HttpUtil.createErrorStatus(IStatus.WARNING, "CF-TargetNotSet", "Target not set"); } return new GetOrgsCommand(this.userId, target).doIt(); } catch (Exception e) { String msg = NLS.bind("Failed to handle request for {0}", path); //$NON-NLS-1$ ServerStatus status = new ServerStatus(IStatus.ERROR, HttpServletResponse.SC_INTERNAL_SERVER_ERROR, msg, e); logger.error(msg, e); return status; } } }; } }