/*
* Copyright 2005 Werner Guttmann
*
* 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 org.castor.jdo.jpa.processors.fieldprocessors;
import java.lang.annotation.Annotation;
import java.lang.reflect.AnnotatedElement;
import java.lang.reflect.Field;
import java.lang.reflect.Member;
import java.lang.reflect.Method;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.OneToMany;
import javax.persistence.OneToOne;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.castor.core.nature.BaseNature;
import org.castor.jdo.jpa.natures.JPAFieldNature;
import org.castor.jdo.jpa.processors.BaseJPAAnnotationProcessor;
/**
* Processes the JPA annotation {@link JoinColumn}. After this processor is
* done, all joincolumn related methods of {@link JPAFieldNature} will return
* valid values.
*
* @author Peter Schmidt
* @version 02.02.2009
*
*/
public class JPAJoinColumnProcessor extends BaseJPAAnnotationProcessor {
/**
* The <a href="http://jakarta.apache.org/commons/logging/">Jakarta Commons
* Logging</a> instance used for all logging.
*/
private static Log _log = LogFactory.getFactory().getInstance(
JPAJoinColumnProcessor.class);
/**
* {@inheritDoc}
*
* @see org.castor.core.annotationprocessing.AnnotationProcessor#forAnnotationClass()
*/
public Class<? extends Annotation> forAnnotationClass() {
return JoinColumn.class;
}
/**
* {@inheritDoc}
*
* @see org.castor.core.annotationprocessing.TargetAwareAnnotationProcessor#
* processAnnotation(BaseNature, AnnotatedElement)
*/
public <I extends BaseNature, A extends Annotation> boolean processAnnotation(
final I info, final A annotation, final AnnotatedElement target) {
if ((info instanceof JPAFieldNature)
&& (annotation instanceof JoinColumn)
&& ((target instanceof Field) || (target instanceof Method))) {
_log.debug("processing field annotation " + annotation.toString());
boolean targetValid = false;
if (target.getAnnotation(OneToOne.class) != null) {
targetValid = true;
}
if (target.getAnnotation(ManyToOne.class) != null) {
targetValid = true;
}
if (target.getAnnotation(OneToMany.class) != null) {
targetValid = true;
}
if (!targetValid) {
_log
.error("JoinTable annotation on "
+ ((Member) target).getName()
+ " is not valid! Needs a relationship annotation! Ignoring @JoinTable!");
return false;
}
JPAFieldNature jpaFieldNature = (JPAFieldNature) info;
JoinColumn joinColumn = (JoinColumn) annotation;
jpaFieldNature.setJoinColumnName(joinColumn.name());
jpaFieldNature.setJoinColumnReferencedColumnName(joinColumn
.referencedColumnName());
jpaFieldNature.setJoinColumnUnique(joinColumn.unique());
jpaFieldNature.setJoinColumnNullable(joinColumn.nullable());
jpaFieldNature.setJoinColumnInsertable(joinColumn.insertable());
jpaFieldNature.setJoinColumnUpdatable(joinColumn.updatable());
jpaFieldNature.setJoinColumnColumnDefinition(joinColumn
.columnDefinition());
jpaFieldNature.setJoinColumnTable(joinColumn.table());
return true;
}
return false;
}
}