io.atlasmap.core.DefaultAtlasPropertyStrategy Maven / Gradle / Ivy
/**
* Copyright (C) 2017 Red Hat, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.atlasmap.core;
import java.util.Arrays;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import io.atlasmap.api.AtlasConversionException;
import io.atlasmap.api.AtlasConversionService;
import io.atlasmap.api.AtlasUnsupportedException;
import io.atlasmap.spi.AtlasPropertyStrategy;
import io.atlasmap.spi.AtlasPropertyType;
import io.atlasmap.v2.AtlasMapping;
import io.atlasmap.v2.AtlasModelFactory;
import io.atlasmap.v2.FieldType;
import io.atlasmap.v2.Property;
import io.atlasmap.v2.PropertyField;
public class DefaultAtlasPropertyStrategy implements AtlasPropertyStrategy {
private static final Logger logger = LoggerFactory.getLogger(DefaultAtlasPropertyStrategy.class);
private boolean environmentPropertiesEnabled = true;
private boolean systemPropertiesEnabled = true;
private boolean mappingDefinedPropertiesEnabled = true;
private boolean runtimePropertiesEnabled = true;
private List propertyOrder = Arrays.asList(AtlasPropertyType.ENVIRONMENT_VARIABLES,
AtlasPropertyType.JAVA_SYSTEM_PROPERTIES, AtlasPropertyType.MAPPING_DEFINED_PROPERTIES,
AtlasPropertyType.RUNTIME_PROPERTIES);
private AtlasConversionService atlasConversionService = null;
@Override
public void processPropertyField(AtlasMapping atlasMapping, PropertyField propertyField,
Map runtimeProperties) throws AtlasUnsupportedException, AtlasConversionException {
if (propertyField == null || propertyField.getName() == null || propertyField.getName().trim().length() == 0) {
if (logger.isDebugEnabled()) {
logger.debug(String.format("Null or empty PropertyField specified popertyField=%s",
AtlasModelFactory.toString(propertyField)));
}
return;
}
for (AtlasPropertyType propType : getPropertyOrder()) {
switch (propType) {
case ENVIRONMENT_VARIABLES:
processEnvironmentVariable(propertyField);
break;
case JAVA_SYSTEM_PROPERTIES:
processJavaSystemProperty(propertyField);
break;
case MAPPING_DEFINED_PROPERTIES:
processMappingDefinedProperties(propertyField, atlasMapping);
break;
case RUNTIME_PROPERTIES:
processRuntimeProperties(propertyField, runtimeProperties);
break;
default:
throw new AtlasUnsupportedException(
String.format("Unsupported PropertyType detected type=%s for field=%s", propType,
AtlasModelFactory.toString(propertyField)));
}
}
return;
}
protected void processEnvironmentVariable(PropertyField propertyField) {
if (!isEnvironmentPropertiesEnabled()) {
return;
}
try {
if (System.getenv(propertyField.getName()) != null) {
propertyField.setValue(System.getenv(propertyField.getName()));
if (logger.isDebugEnabled()) {
logger.debug(String.format("Assigned environment variable for property field name=%s value=%s",
propertyField.getName(), propertyField.getValue()));
}
}
} catch (SecurityException e) {
logger.error(String.format("SecurityException while processing environment variable for propertyField=%s",
AtlasModelFactory.toString(propertyField)), e);
}
}
protected void processJavaSystemProperty(PropertyField propertyField) {
if (!isSystemPropertiesEnabled()) {
return;
}
try {
if (System.getProperty(propertyField.getName()) != null) {
propertyField.setValue(System.getProperty(propertyField.getName()));
if (logger.isDebugEnabled()) {
logger.debug(String.format("Assigned Java system property for property field name=%s value=%s",
propertyField.getName(), propertyField.getValue()));
}
}
} catch (SecurityException e) {
logger.error(String.format("SecurityException while processing Java system property for propertyField=%s",
AtlasModelFactory.toString(propertyField)), e);
}
}
protected void processMappingDefinedProperties(PropertyField propertyField, AtlasMapping atlasMapping)
throws AtlasConversionException {
if (!isMappingDefinedPropertiesEnabled()) {
return;
}
if (atlasMapping == null || atlasMapping.getProperties() == null
|| atlasMapping.getProperties().getProperty() == null
|| atlasMapping.getProperties().getProperty().isEmpty()) {
return;
}
for (Property prop : atlasMapping.getProperties().getProperty()) {
if (propertyField.getName().equals(prop.getName())) {
if (getAtlasConversionService() != null
&& (propertyField.getFieldType() != null || prop.getFieldType() != null)) {
propertyField.setValue(getAtlasConversionService().convertType(prop.getValue(), FieldType.STRING,
(propertyField.getFieldType() != null ? propertyField.getFieldType()
: prop.getFieldType())));
if (logger.isDebugEnabled()) {
logger.debug(
String.format("Assigned Mapping defined property for property field name=%s value=%s",
propertyField.getName(), propertyField.getValue()));
}
return;
} else {
propertyField.setValue(prop.getValue());
if (logger.isDebugEnabled()) {
logger.debug(
String.format("Assigned Mapping defined property for property field name=%s value=%s",
propertyField.getName(), propertyField.getValue()));
}
return;
}
}
}
}
protected void processRuntimeProperties(PropertyField propertyField, Map runtimeProperties)
throws AtlasConversionException {
if (!isRuntimePropertiesEnabled()) {
return;
}
if (runtimeProperties == null || runtimeProperties.isEmpty()) {
return;
}
for (String key : runtimeProperties.keySet()) {
if (propertyField.getName().equals(key)) {
if (getAtlasConversionService() != null && propertyField.getFieldType() != null) {
propertyField.setValue(getAtlasConversionService().convertType(runtimeProperties.get(key),
getAtlasConversionService().fieldTypeFromClass(runtimeProperties.get(key).getClass()),
propertyField.getFieldType()));
if (logger.isDebugEnabled()) {
logger.debug(
String.format("Assigned Runtime defined property for property field name=%s value=%s",
propertyField.getName(), propertyField.getValue()));
}
return;
} else {
propertyField.setValue(runtimeProperties.get(key));
if (logger.isDebugEnabled()) {
logger.debug(
String.format("Assigned Runtime defined property for property field name=%s value=%s",
propertyField.getName(), propertyField.getValue()));
}
return;
}
}
}
}
public void setPropertyOrderValue(List propertyValues) {
List tmp = null;
for (String v : propertyValues) {
if (tmp == null) {
tmp = new LinkedList();
}
try {
tmp.add(AtlasPropertyType.fromValue(v));
} catch (IllegalArgumentException e) {
logger.error(String.format("Invalid AtlasPropertyType specified '%s'", v));
}
}
propertyOrder = null;
propertyOrder = tmp;
}
public boolean isEnvironmentPropertiesEnabled() {
return environmentPropertiesEnabled;
}
public void setEnvironmentPropertiesEnabled(boolean environmentPropertiesEnabled) {
this.environmentPropertiesEnabled = environmentPropertiesEnabled;
}
public boolean isSystemPropertiesEnabled() {
return systemPropertiesEnabled;
}
public void setSystemPropertiesEnabled(boolean systemPropertiesEnabled) {
this.systemPropertiesEnabled = systemPropertiesEnabled;
}
public boolean isMappingDefinedPropertiesEnabled() {
return mappingDefinedPropertiesEnabled;
}
public void setMappingDefinedPropertiesEnabled(boolean mappingDefinedPropertiesEnabled) {
this.mappingDefinedPropertiesEnabled = mappingDefinedPropertiesEnabled;
}
public boolean isRuntimePropertiesEnabled() {
return runtimePropertiesEnabled;
}
public void setRuntimePropertiesEnabled(boolean runtimePropertiesEnabled) {
this.runtimePropertiesEnabled = runtimePropertiesEnabled;
}
public List getPropertyOrder() {
return propertyOrder;
}
public void setPropertyOrder(List propertyOrder) {
this.propertyOrder = propertyOrder;
}
public AtlasConversionService getAtlasConversionService() {
return atlasConversionService;
}
public void setAtlasConversionService(AtlasConversionService atlasConversionService) {
this.atlasConversionService = atlasConversionService;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy