|
|
@ -21,10 +21,12 @@ package org.wso2.carbon.device.mgt.analytics.data.publisher.service;
|
|
|
|
|
|
|
|
|
|
|
|
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.context.PrivilegedCarbonContext;
|
|
|
|
import org.wso2.carbon.databridge.agent.DataPublisher;
|
|
|
|
import org.wso2.carbon.databridge.agent.DataPublisher;
|
|
|
|
import org.wso2.carbon.databridge.commons.utils.DataBridgeCommonsUtils;
|
|
|
|
import org.wso2.carbon.databridge.commons.utils.DataBridgeCommonsUtils;
|
|
|
|
import org.wso2.carbon.device.mgt.analytics.data.publisher.DeviceDataPublisher;
|
|
|
|
import org.wso2.carbon.device.mgt.analytics.data.publisher.DeviceDataPublisher;
|
|
|
|
import org.wso2.carbon.device.mgt.analytics.data.publisher.exception.DataPublisherConfigurationException;
|
|
|
|
import org.wso2.carbon.device.mgt.analytics.data.publisher.exception.DataPublisherConfigurationException;
|
|
|
|
|
|
|
|
import org.wso2.carbon.utils.multitenancy.MultitenantConstants;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* This is the implementation of Osgi Service which can be used to publish and retireved
|
|
|
|
* This is the implementation of Osgi Service which can be used to publish and retireved
|
|
|
@ -39,23 +41,37 @@ public class EventsPublisherServiceImpl implements EventsPublisherService {
|
|
|
|
* @param metaDataArray - meta data that needs to pushed
|
|
|
|
* @param metaDataArray - meta data that needs to pushed
|
|
|
|
* @param correlationDataArray - correlation data that needs to be pushed
|
|
|
|
* @param correlationDataArray - correlation data that needs to be pushed
|
|
|
|
* @param payloadDataArray - payload data that needs to be pushed
|
|
|
|
* @param payloadDataArray - payload data that needs to be pushed
|
|
|
|
* @return
|
|
|
|
* @return if success returns true
|
|
|
|
* @throws DataPublisherConfigurationException
|
|
|
|
* @throws DataPublisherConfigurationException
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
public boolean publishEvent(String streamName, String version, Object[] metaDataArray,
|
|
|
|
public boolean publishEvent(String streamName, String version, Object[] metaDataArray,
|
|
|
|
Object[] correlationDataArray,
|
|
|
|
Object[] correlationDataArray,
|
|
|
|
Object[] payloadDataArray) throws DataPublisherConfigurationException {
|
|
|
|
Object[] payloadDataArray) throws DataPublisherConfigurationException {
|
|
|
|
DataPublisher dataPublisher = DeviceDataPublisher.getInstance().getDataPublisher();
|
|
|
|
String tenantDomain = PrivilegedCarbonContext.getThreadLocalCarbonContext().getTenantDomain();
|
|
|
|
if (dataPublisher != null) {
|
|
|
|
if (!tenantDomain.equals(MultitenantConstants.SUPER_TENANT_DOMAIN_NAME)) {
|
|
|
|
String streamId = DataBridgeCommonsUtils.generateStreamId(streamName, version);
|
|
|
|
if (metaDataArray == null || metaDataArray.length == 0) {
|
|
|
|
return dataPublisher.tryPublish(streamId, System.currentTimeMillis(), metaDataArray, correlationDataArray,
|
|
|
|
throw new DataPublisherConfigurationException("meta data[0] should have the device Id field");
|
|
|
|
payloadDataArray);
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
metaDataArray[0] = tenantDomain + "@" + metaDataArray[0];
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
PrivilegedCarbonContext.startTenantFlow();
|
|
|
|
|
|
|
|
PrivilegedCarbonContext.getThreadLocalCarbonContext()
|
|
|
|
|
|
|
|
.setTenantDomain(MultitenantConstants.SUPER_TENANT_DOMAIN_NAME, true);
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
DataPublisher dataPublisher = DeviceDataPublisher.getInstance().getDataPublisher();
|
|
|
|
|
|
|
|
if (dataPublisher != null) {
|
|
|
|
|
|
|
|
String streamId = DataBridgeCommonsUtils.generateStreamId(streamName, version);
|
|
|
|
|
|
|
|
return dataPublisher.tryPublish(streamId, System.currentTimeMillis(), metaDataArray,
|
|
|
|
|
|
|
|
correlationDataArray,
|
|
|
|
|
|
|
|
payloadDataArray);
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
} finally {
|
|
|
|
|
|
|
|
PrivilegedCarbonContext.endTenantFlow();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|