use of org.hibernate.metadata.ClassMetadata in project head by mifos.
the class InterceptHelper method readFurtherMeta.
private void readFurtherMeta(Object obj, String firstName, String state) {
Class clazz = getClazz(obj);
ClassMetadata customMeta = StaticHibernateUtil.getSessionFactory().getClassMetadata(clazz);
Object[] propertyValues = customMeta.getPropertyValues(obj, EntityMode.POJO);
String[] propertyNames = customMeta.getPropertyNames();
Type[] propertyTypes = customMeta.getPropertyTypes();
String prdStatusName = AuditConstants.PRDSTATUSPATH;
if (obj.getClass().getName().startsWith(prdStatusName)) {
Short id = ((PrdStatusEntity) obj).getOfferingStatusId();
setPrimaryKeyValues(id, firstName.concat(customMeta.getIdentifierPropertyName()), state);
} else {
setPrimaryKeyValues(customMeta, obj, firstName.concat(customMeta.getIdentifierPropertyName()), state);
}
for (int i = 0; i < propertyNames.length; i++) {
logger.debug("readFurtherMeta property : " + propertyNames[i]);
setColumnValues(propertyTypes[i], propertyNames[i], firstName, state, propertyValues[i]);
// Reading masterdata Types
if (propertyTypes[i].isEntityType() && !propertyTypes[i].isComponentType() && propertyValues[i] instanceof MasterDataEntity && AuditConfiguration.isObjectToBeLogged(entityName, propertyNames[i], firstName)) {
populateValueForObjectsOfTypeMasterDataEntity(propertyValues[i], state, firstName.concat(propertyNames[i]));
}
// Reading Collection Types
if (propertyTypes[i].isCollectionType() && AuditConfiguration.isObjectToBeLogged(entityName, propertyNames[i], firstName) && !AuditConfiguration.isObjectPropertiesToBeMerged(entityName, propertyNames[i], firstName)) {
Iterator iterator = ((Set) propertyValues[i]).iterator();
while (iterator.hasNext()) {
Object valueFromSet = iterator.next();
readFurtherMetaForCollectionType(valueFromSet, propertyNames[i], state);
}
}
// Reading Collection Types
if (propertyTypes[i].isCollectionType() && AuditConfiguration.isObjectToBeLogged(entityName, propertyNames[i], firstName) && AuditConfiguration.isObjectPropertiesToBeMerged(entityName, propertyNames[i], firstName)) {
populateAndMergeCollectionTypes(state, propertyValues[i], propertyNames[i], firstName);
}
// Reading further entity type
if (propertyTypes[i].isEntityType() && !propertyTypes[i].isComponentType() && !(propertyValues[i] instanceof MasterDataEntity) && AuditConfiguration.isObjectToBeLogged(entityName, propertyNames[i], firstName)) {
Object obj1 = propertyValues[i];
if (obj1 != null) {
if (obj1 instanceof MeetingBO) {
MeetingBO meeting = (MeetingBO) obj1;
if (propertyNames[i].equalsIgnoreCase("meeting") && meeting.getMeetingId() != null) {
readMeetingEntity(meeting, propertyNames[i], state);
} else {
readFurtherMeta(obj1, propertyNames[i], state);
}
} else {
readFurtherMeta(obj1, propertyNames[i], state);
}
}
}
// Reading further component type
if (!propertyTypes[i].isEntityType() && propertyTypes[i].isComponentType() && !(propertyValues[i] instanceof MasterDataEntity) && AuditConfiguration.isObjectToBeLogged(entityName, propertyNames[i], firstName)) {
Object obj1 = propertyValues[i];
if (obj1 != null) {
readFurtherComponenetMeta(obj1, propertyNames[i], state, propertyTypes[i]);
}
}
// Reading further Money type
if (!propertyTypes[i].isEntityType() && propertyTypes[i].isComponentType() && !(propertyValues[i] instanceof MasterDataEntity) && (propertyValues[i] instanceof Money)) {
Object obj1 = propertyValues[i];
if (obj1 != null) {
readFurtherMoneyType(obj1, firstName.concat(propertyNames[i]), state);
}
}
}
}
use of org.hibernate.metadata.ClassMetadata in project head by mifos.
the class InterceptHelper method hibernateMeta.
public Map hibernateMeta(Object object, String state) {
logger.debug("object : " + object);
ClassMetadata customMeta = StaticHibernateUtil.getSessionFactory().getClassMetadata(object.getClass());
Object[] propertyValues = customMeta.getPropertyValues(object, EntityMode.POJO);
String[] propertyNames = customMeta.getPropertyNames();
Type[] propertyTypes = customMeta.getPropertyTypes();
if (state.equalsIgnoreCase(AuditConstants.TRANSACTIONBEGIN)) {
// locale=((BusinessObject)object).getUserContext().getMfiLocale();
locale = ((AbstractBusinessObject) object).getUserContext().getCurrentLocale();
// localeId=((BusinessObject)object).getUserContext().getMfiLocaleId();
localeId = ((AbstractBusinessObject) object).getUserContext().getLocaleId();
logger.debug("initial path class: " + AuditConfiguration.getEntityToClassPath(object.getClass().getName()));
entityName = AuditConfiguration.getEntityToClassPath(object.getClass().getName());
entityId = Integer.valueOf(customMeta.getIdentifier(object, EntityMode.POJO).toString());
}
setPrimaryKeyValues(customMeta, object, customMeta.getIdentifierPropertyName(), state);
for (int i = 0; i < propertyNames.length; i++) {
if (!propertyTypes[i].isEntityType() && !propertyTypes[i].isCollectionType() && !propertyTypes[i].isComponentType()) {
if (state.equalsIgnoreCase(AuditConstants.TRANSACTIONBEGIN)) {
String name = propertyNames[i];
if (AuditConfiguration.checkForPropertyName(entityName, name, localeId)) {
String value = AuditConfiguration.getValueOfCorrespondingId(entityName, name, propertyValues[i], localeId);
initialValues.put(propertyNames[i], value);
} else {
if (propertyValues[i] instanceof Calendar && propertyValues[i] != null) {
initialValues.put(propertyNames[i], ((Calendar) propertyValues[i]).getTime());
} else if (propertyValues[i] instanceof byte[] && propertyValues[i] != null) {
initialValues.put(propertyNames[i], new String((byte[]) propertyValues[i]));
} else if (propertyValues[i] instanceof Date && propertyValues[i] != null) {
try {
Date date = (Date) propertyValues[i];
initialValues.put(propertyNames[i], DateUtils.getUserLocaleDate(locale, new java.sql.Date(date.getTime()).toString()));
} catch (Exception e) {
initialValues.put(propertyNames[i], propertyValues[i].toString());
}
} else {
initialValues.put(propertyNames[i], propertyValues[i]);
}
}
String columnName = AuditConfiguration.getColumnNameForPropertyName(entityName, name);
if (columnName != null && !columnName.equals("")) {
columnNames.put(propertyNames[i], columnName);
} else {
columnNames.put(propertyNames[i], propertyNames[i]);
}
} else {
String name = propertyNames[i];
logger.debug("c hibernateMeta " + name + " : " + propertyValues[i]);
if (AuditConfiguration.checkForPropertyName(entityName, name, localeId)) {
String value = AuditConfiguration.getValueOfCorrespondingId(entityName, name, propertyValues[i], localeId);
changedValues.put(propertyNames[i], value);
} else {
if (propertyValues[i] instanceof Calendar && propertyValues[i] != null) {
changedValues.put(propertyNames[i], ((Calendar) propertyValues[i]).getTime());
} else if (propertyValues[i] instanceof byte[] && propertyValues[i] != null) {
changedValues.put(propertyNames[i], new String((byte[]) propertyValues[i]));
} else if (propertyValues[i] instanceof Date && propertyValues[i] != null) {
try {
Date date = (Date) propertyValues[i];
changedValues.put(propertyNames[i], DateUtils.getUserLocaleDate(locale, new java.sql.Date(date.getTime()).toString()));
} catch (Exception e) {
changedValues.put(propertyNames[i], propertyValues[i].toString());
}
} else {
changedValues.put(propertyNames[i], propertyValues[i]);
}
}
String columnName = AuditConfiguration.getColumnNameForPropertyName(entityName, name);
if (columnName != null && !columnName.equals("")) {
columnNames.put(propertyNames[i], columnName);
} else {
columnNames.put(propertyNames[i], propertyNames[i]);
}
}
}
if (propertyTypes[i].isEntityType() && !propertyTypes[i].isComponentType() && propertyValues[i] instanceof MasterDataEntity && AuditConfiguration.isObjectToBeLogged(entityName, propertyNames[i], null)) {
String personnelStatusName = AuditConstants.PERSONNELSTATUSPATH;
String personnelLevelName = AuditConstants.PERSONNELLEVELPATH;
if (propertyValues[i].getClass().getName().startsWith(personnelStatusName)) {
Short id = ((PersonnelStatusEntity) propertyValues[i]).getId();
populateValueForObjectsOfTypeMasterDataEntity(id, state, propertyNames[i]);
} else if (propertyValues[i].getClass().getName().startsWith(personnelLevelName)) {
Short id = ((PersonnelLevelEntity) propertyValues[i]).getId();
populateValueForObjectsOfTypeMasterDataEntity(id, state, propertyNames[i]);
} else {
populateValueForObjectsOfTypeMasterDataEntity(propertyValues[i], state, propertyNames[i]);
}
}
// Reading Collection Types
if (propertyTypes[i].isCollectionType() && AuditConfiguration.isObjectToBeLogged(entityName, propertyNames[i], null) && AuditConfiguration.isObjectPropertiesToBeMerged(entityName, propertyNames[i], null)) {
populateAndMergeCollectionTypes(state, propertyValues[i], propertyNames[i], null);
}
if (propertyTypes[i].isCollectionType() && AuditConfiguration.isObjectToBeLogged(entityName, propertyNames[i], null) && !AuditConfiguration.isObjectPropertiesToBeMerged(entityName, propertyNames[i], null)) {
Iterator iterator = ((Set) propertyValues[i]).iterator();
while (iterator.hasNext()) {
Object obj = iterator.next();
if (obj != null) {
if (obj instanceof LoanOfferingFeesEntity) {
LoanOfferingFeesEntity loanOfferingFeesEntity = (LoanOfferingFeesEntity) obj;
if (propertyNames[i].equalsIgnoreCase("loanOfferingFees") && loanOfferingFeesEntity.getPrdOfferingFeeId() != null) {
readLoanOfferingFeesCollection(loanOfferingFeesEntity, state);
} else {
readFurtherMetaForCollectionType(obj, propertyNames[i], state);
}
} else {
readFurtherMetaForCollectionType(obj, propertyNames[i], state);
}
}
}
}
if (propertyTypes[i].isEntityType() && !propertyTypes[i].isComponentType() && !(propertyValues[i] instanceof MasterDataEntity) && AuditConfiguration.isObjectToBeLogged(entityName, propertyNames[i], null)) {
Object obj = propertyValues[i];
if (obj != null) {
readFurtherMeta(obj, propertyNames[i], state);
}
}
// Reading further Money type
if (!propertyTypes[i].isEntityType() && propertyTypes[i].isComponentType() && !(propertyValues[i] instanceof MasterDataEntity) && (propertyValues[i] instanceof Money)) {
Object obj1 = propertyValues[i];
if (obj1 != null) {
readFurtherMoneyType(obj1, propertyNames[i], state);
}
}
// Reading further component type
if (!propertyTypes[i].isEntityType() && propertyTypes[i].isComponentType() && !(propertyValues[i] instanceof MasterDataEntity) && AuditConfiguration.isObjectToBeLogged(entityName, propertyNames[i], null)) {
Object obj1 = propertyValues[i];
if (obj1 != null) {
readFurtherComponenetMeta(obj1, propertyNames[i], state, propertyTypes[i]);
}
}
}
if (state.equalsIgnoreCase(AuditConstants.TRANSACTIONBEGIN)) {
return initialValues;
} else {
return changedValues;
}
}
use of org.hibernate.metadata.ClassMetadata in project head by mifos.
the class InterceptHelper method populateValueForObjectsOfTypeMasterDataEntityInCollections.
private void populateValueForObjectsOfTypeMasterDataEntityInCollections(Object obj, String state, String name) {
Class clazz = getClazz(obj);
ClassMetadata customMeta = StaticHibernateUtil.getSessionFactory().getClassMetadata(clazz);
setPrimaryKeyValueForCollectionType(customMeta, obj, name, state);
}
use of org.hibernate.metadata.ClassMetadata in project head by mifos.
the class InterceptHelper method populateValueForObjectsOfTypeMasterDataEntity.
private void populateValueForObjectsOfTypeMasterDataEntity(Object obj, String state, String name) {
Class clazz = getClazz(obj);
ClassMetadata customMeta = StaticHibernateUtil.getSessionFactory().getClassMetadata(clazz);
setPrimaryKeyValues(customMeta, obj, name, state);
}
use of org.hibernate.metadata.ClassMetadata in project opennms by OpenNMS.
the class AbstractDaoHibernate method logExtraSaveOrUpdateExceptionInformation.
/**
* <p>Parse the {@link DataAccessException} to see if special problems were
* encountered while performing the query. See issue NMS-5029 for examples of
* stack traces that can be thrown from these calls.</p>
* {@see http://issues.opennms.org/browse/NMS-5029}
*/
private void logExtraSaveOrUpdateExceptionInformation(final T entity, final DataAccessException e) {
Throwable cause = e;
while (cause.getCause() != null) {
if (cause.getMessage() != null) {
if (cause.getMessage().contains("duplicate key value violates unique constraint")) {
final ClassMetadata meta = getSessionFactory().getClassMetadata(m_entityClass);
LOG.warn("Duplicate key constraint violation, class: {}, key value: {}", m_entityClass.getName(), meta.getPropertyValue(entity, meta.getIdentifierPropertyName(), EntityMode.POJO));
break;
} else if (cause.getMessage().contains("given object has a null identifier")) {
LOG.warn("Null identifier on object, class: {}: {}", m_entityClass.getName(), entity.toString());
break;
}
}
cause = cause.getCause();
}
}
Aggregations