package org.jboss.ejb.plugins.cmp.jdbc.metadata;
import org.jboss.deployment.DeploymentException;
import org.jboss.metadata.MetaData;
import org.jboss.logging.Logger;
import org.w3c.dom.Element;
public final class JDBCAuditMetaData
{
final private JDBCCMPFieldMetaData createdPrincipalField;
final private JDBCCMPFieldMetaData createdTimeField;
final private JDBCCMPFieldMetaData updatedPrincipalField;
final private JDBCCMPFieldMetaData updatedTimeField;
final private Logger log;
public JDBCAuditMetaData(JDBCEntityMetaData entityMetaData, Element element)
throws DeploymentException
{
log = Logger.getLogger(entityMetaData.getName());
Element workElement;
if ((workElement = MetaData.getOptionalChild(element, "created-by")) != null)
{
createdPrincipalField = constructAuditField(entityMetaData, workElement, "audit_created_by");
log.debug("created-by: " + createdPrincipalField);
}
else
createdPrincipalField = null;
if ((workElement = MetaData.getOptionalChild(element, "created-time")) != null)
{
createdTimeField = constructAuditField(entityMetaData, workElement, "audit_created_time");
log.debug("created-time: " + createdTimeField);
}
else
createdTimeField = null;
if ((workElement = MetaData.getOptionalChild(element, "updated-by")) != null)
{
updatedPrincipalField = constructAuditField(entityMetaData, workElement, "audit_updated_by");
log.debug("updated-by: " + updatedPrincipalField);
}
else
updatedPrincipalField = null;
if ((workElement = MetaData.getOptionalChild(element, "updated-time")) != null)
{
updatedTimeField = constructAuditField(entityMetaData, workElement, "audit_updated_time");
log.debug("updated-time: " + updatedTimeField);
}
else
updatedTimeField = null;
}
public JDBCCMPFieldMetaData getCreatedPrincipalField()
{
return createdPrincipalField;
}
public JDBCCMPFieldMetaData getCreatedTimeField()
{
return createdTimeField;
}
public JDBCCMPFieldMetaData getUpdatedPrincipalField()
{
return updatedPrincipalField;
}
public JDBCCMPFieldMetaData getUpdatedTimeField()
{
return updatedTimeField;
}
private static JDBCCMPFieldMetaData constructAuditField(
JDBCEntityMetaData entity,
Element element,
String defaultName)
throws DeploymentException
{
String fieldName = MetaData.getOptionalChildContent(element, "field-name");
if (fieldName == null || fieldName.trim().length() < 1)
fieldName = defaultName;
String columnName = MetaData.getOptionalChildContent(element, "column-name");
if (columnName == null || columnName.trim().length() < 1)
columnName = defaultName;
Class fieldType;
String fieldTypeStr = MetaData.getOptionalChildContent(element, "field-type");
if (fieldTypeStr != null)
{
try
{
fieldType = GetTCLAction.getContextClassLoader().loadClass(fieldTypeStr);
}
catch(ClassNotFoundException e)
{
throw new DeploymentException(
"Could not load field type for audit field "
+ fieldName + ": " + fieldTypeStr);
}
}
else
{
if (defaultName.endsWith("by"))
fieldType = String.class;
else
fieldType = java.util.Date.class;
}
int jdbcType;
String sqlType;
String jdbcTypeName = MetaData.getOptionalChildContent(element, "jdbc-type");
if (jdbcTypeName != null)
{
jdbcType = JDBCMappingMetaData.getJdbcTypeFromName(jdbcTypeName);
sqlType = MetaData.getUniqueChildContent(element, "sql-type");
}
else
{
jdbcType = Integer.MIN_VALUE;
sqlType = null;
}
JDBCCMPFieldMetaData result = entity.getCMPFieldByName(fieldName);
if (result == null)
result = new JDBCCMPFieldMetaData(entity, fieldName, fieldType, columnName, jdbcType, sqlType);
return result;
}
}