mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-14 17:58:59 +00:00
Merged HEAD-QA to HEAD (4.2) (including moving test classes into separate folders)
51903 to 54309 git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@54310 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -0,0 +1,69 @@
|
||||
/*
|
||||
* Copyright (C) 2005-2012 Alfresco Software Limited.
|
||||
*
|
||||
* This file is part of Alfresco
|
||||
*
|
||||
* Alfresco is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU Lesser General Public License as published by
|
||||
* the Free Software Foundation, either version 3 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* Alfresco 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 Alfresco. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
package org.alfresco.rest.api;
|
||||
|
||||
import javax.servlet.http.HttpServletRequest;
|
||||
|
||||
import org.alfresco.repo.tenant.TenantUtil;
|
||||
import org.alfresco.repo.web.scripts.TenantWebScriptServletRequest;
|
||||
import org.springframework.extensions.config.ServerProperties;
|
||||
import org.springframework.extensions.webscripts.Match;
|
||||
import org.springframework.extensions.webscripts.Runtime;
|
||||
|
||||
public class PublicApiTenantWebScriptServletRequest extends TenantWebScriptServletRequest
|
||||
{
|
||||
public static final String NETWORKS_PATH = "networks";
|
||||
public static final String NETWORK_PATH = "network";
|
||||
|
||||
public PublicApiTenantWebScriptServletRequest(Runtime container, HttpServletRequest req, Match serviceMatch, ServerProperties serverProperties)
|
||||
{
|
||||
super(container, req, serviceMatch, serverProperties);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void parse()
|
||||
{
|
||||
String realPathInfo = getRealPathInfo();
|
||||
|
||||
if(realPathInfo.equals("") || realPathInfo.equals("/"))
|
||||
{
|
||||
// no tenant - "index" request
|
||||
tenant = TenantUtil.DEFAULT_TENANT;
|
||||
pathInfo = NETWORKS_PATH;
|
||||
}
|
||||
else
|
||||
{
|
||||
// optimisation - don't need to lowercase the whole path
|
||||
if(realPathInfo.substring(0, 5).toLowerCase().equals("/cmis"))
|
||||
{
|
||||
// cmis service document, pass through as is and set tenant to "-default-".
|
||||
tenant = TenantUtil.DEFAULT_TENANT;
|
||||
pathInfo = realPathInfo;
|
||||
}
|
||||
else
|
||||
{
|
||||
int idx = realPathInfo.indexOf('/', 1);
|
||||
|
||||
// remove tenant
|
||||
tenant = realPathInfo.substring(1, idx == -1 ? realPathInfo.length() : idx);
|
||||
pathInfo = realPathInfo.substring(tenant.length() + 1);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user