|
|
@ -21,12 +21,18 @@ package org.wso2.carbon.apimgt.application.extension.api.util;
|
|
|
|
import org.apache.commons.logging.Log;
|
|
|
|
import org.apache.commons.logging.Log;
|
|
|
|
import org.apache.commons.logging.LogFactory;
|
|
|
|
import org.apache.commons.logging.LogFactory;
|
|
|
|
import org.wso2.carbon.apimgt.application.extension.APIManagementProviderService;
|
|
|
|
import org.wso2.carbon.apimgt.application.extension.APIManagementProviderService;
|
|
|
|
|
|
|
|
import org.wso2.carbon.base.MultitenantConstants;
|
|
|
|
import org.wso2.carbon.context.PrivilegedCarbonContext;
|
|
|
|
import org.wso2.carbon.context.PrivilegedCarbonContext;
|
|
|
|
import org.wso2.carbon.device.mgt.common.DeviceManagementException;
|
|
|
|
import org.wso2.carbon.device.mgt.common.DeviceManagementException;
|
|
|
|
import org.wso2.carbon.device.mgt.core.service.DeviceManagementProviderService;
|
|
|
|
import org.wso2.carbon.device.mgt.core.service.DeviceManagementProviderService;
|
|
|
|
|
|
|
|
import org.wso2.carbon.registry.api.Resource;
|
|
|
|
|
|
|
|
import org.wso2.carbon.registry.core.Registry;
|
|
|
|
|
|
|
|
import org.wso2.carbon.registry.core.exceptions.RegistryException;
|
|
|
|
|
|
|
|
import org.wso2.carbon.registry.core.service.RegistryService;
|
|
|
|
import org.wso2.carbon.user.core.service.RealmService;
|
|
|
|
import org.wso2.carbon.user.core.service.RealmService;
|
|
|
|
|
|
|
|
|
|
|
|
import java.util.List;
|
|
|
|
import java.util.List;
|
|
|
|
|
|
|
|
import java.util.StringTokenizer;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* This class provides utility functions used by REST-API.
|
|
|
|
* This class provides utility functions used by REST-API.
|
|
|
@ -35,6 +41,8 @@ public class APIUtil {
|
|
|
|
|
|
|
|
|
|
|
|
private static Log log = LogFactory.getLog(APIUtil.class);
|
|
|
|
private static Log log = LogFactory.getLog(APIUtil.class);
|
|
|
|
private static final String DEFAULT_CDMF_API_TAG = "device_management";
|
|
|
|
private static final String DEFAULT_CDMF_API_TAG = "device_management";
|
|
|
|
|
|
|
|
private static final String DEFAULT_CERT_API_TAG = "scep_management";
|
|
|
|
|
|
|
|
public static final String PERMISSION_PROPERTY_NAME = "name";
|
|
|
|
|
|
|
|
|
|
|
|
public static String getAuthenticatedUser() {
|
|
|
|
public static String getAuthenticatedUser() {
|
|
|
|
PrivilegedCarbonContext threadLocalCarbonContext = PrivilegedCarbonContext.getThreadLocalCarbonContext();
|
|
|
|
PrivilegedCarbonContext threadLocalCarbonContext = PrivilegedCarbonContext.getThreadLocalCarbonContext();
|
|
|
@ -48,8 +56,7 @@ public class APIUtil {
|
|
|
|
|
|
|
|
|
|
|
|
public static String getTenantDomainOftheUser() {
|
|
|
|
public static String getTenantDomainOftheUser() {
|
|
|
|
PrivilegedCarbonContext threadLocalCarbonContext = PrivilegedCarbonContext.getThreadLocalCarbonContext();
|
|
|
|
PrivilegedCarbonContext threadLocalCarbonContext = PrivilegedCarbonContext.getThreadLocalCarbonContext();
|
|
|
|
String tenantDomain = threadLocalCarbonContext.getTenantDomain();
|
|
|
|
return threadLocalCarbonContext.getTenantDomain();
|
|
|
|
return tenantDomain;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public static APIManagementProviderService getAPIManagementProviderService() {
|
|
|
|
public static APIManagementProviderService getAPIManagementProviderService() {
|
|
|
@ -92,6 +99,55 @@ public class APIUtil {
|
|
|
|
//Todo get allowed cdmf service tags from config.
|
|
|
|
//Todo get allowed cdmf service tags from config.
|
|
|
|
List<String> allowedApisTags = getDeviceManagementProviderService().getAvailableDeviceTypes();
|
|
|
|
List<String> allowedApisTags = getDeviceManagementProviderService().getAvailableDeviceTypes();
|
|
|
|
allowedApisTags.add(DEFAULT_CDMF_API_TAG);
|
|
|
|
allowedApisTags.add(DEFAULT_CDMF_API_TAG);
|
|
|
|
|
|
|
|
allowedApisTags.add(DEFAULT_CERT_API_TAG);
|
|
|
|
return allowedApisTags;
|
|
|
|
return allowedApisTags;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static void putPermission(String permission) {
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
StringTokenizer tokenizer = new StringTokenizer(permission, "/");
|
|
|
|
|
|
|
|
String lastToken = "", currentToken, tempPath;
|
|
|
|
|
|
|
|
while (tokenizer.hasMoreTokens()) {
|
|
|
|
|
|
|
|
currentToken = tokenizer.nextToken();
|
|
|
|
|
|
|
|
tempPath = lastToken + "/" + currentToken;
|
|
|
|
|
|
|
|
if (!checkResourceExists(tempPath)) {
|
|
|
|
|
|
|
|
createRegistryCollection(tempPath, currentToken);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
lastToken = tempPath;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
} catch (org.wso2.carbon.registry.api.RegistryException e) {
|
|
|
|
|
|
|
|
log.error("Failed to creation permission in registry" + permission, e);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static void createRegistryCollection(String path, String resourceName)
|
|
|
|
|
|
|
|
throws org.wso2.carbon.registry.api.RegistryException {
|
|
|
|
|
|
|
|
Resource resource = getGovernanceRegistry().newCollection();
|
|
|
|
|
|
|
|
resource.addProperty(PERMISSION_PROPERTY_NAME, resourceName);
|
|
|
|
|
|
|
|
getGovernanceRegistry().beginTransaction();
|
|
|
|
|
|
|
|
getGovernanceRegistry().put(path, resource);
|
|
|
|
|
|
|
|
getGovernanceRegistry().commitTransaction();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static boolean checkResourceExists(String path)
|
|
|
|
|
|
|
|
throws RegistryException {
|
|
|
|
|
|
|
|
return getGovernanceRegistry().resourceExists(path);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static Registry getGovernanceRegistry() throws RegistryException {
|
|
|
|
|
|
|
|
return getRegistryService().getGovernanceSystemRegistry(MultitenantConstants.SUPER_TENANT_ID);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static RegistryService getRegistryService() {
|
|
|
|
|
|
|
|
PrivilegedCarbonContext ctx = PrivilegedCarbonContext.getThreadLocalCarbonContext();
|
|
|
|
|
|
|
|
RegistryService registryService =
|
|
|
|
|
|
|
|
(RegistryService) ctx.getOSGiService(RegistryService.class, null);
|
|
|
|
|
|
|
|
if (registryService == null) {
|
|
|
|
|
|
|
|
String msg = "registry service has not initialized.";
|
|
|
|
|
|
|
|
log.error(msg);
|
|
|
|
|
|
|
|
throw new IllegalStateException(msg);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
return registryService;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|