/*
* Copyright 2008-2009 MOPAS(Ministry of Public Administration and Security).
*
* 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 egovframework.rte.itl.integration.type;
import java.util.Arrays;
import java.util.List;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.util.StringUtils;
/**
* 연계 서비스의 표준 메시지의 Type을 정의하기 위한 기본 클래스
* <p>
* <b>NOTE:</b> 전자정부 연계 서비스의 표준 메시지의 Type을 정의하기 위한 기본
* Class이다. 메시지를 형식(Type)을 정의하는 Class 의 최상위 Class 이다.
* @author 실행환경 개발팀 심상호
* @since 2009.06.01
* @version 1.0
* @see <pre>
* == 개정이력(Modification Information) ==
*
* 수정일 수정자 수정내용
* ------- -------- ---------------------------
* 2009.06.01 심상호 최초 생성
*
* </pre>
*/
public abstract class AbstractType implements Type {
private Log LOG = LogFactory.getLog(this.getClass());
/** Type Id */
protected String id;
/** Type Name */
protected String name;
/** Assign 가능한 Java Class들 */
protected List<Class<?>> assignableClasses;
/**
* Default Constructor
*/
protected AbstractType() {
super();
}
/**
* Argument <code>id</code>의 Type을 생성한다.
* @param id
* Type Id
* @param name
* Type Name
* @param assignableClasses
* assign할 수 있는 Java 객체의 Class들
* @throws IllegalArgumentException
* 1. Argument <code>id</code> 값이
* <code>null</code>이거나, 공백 문자로만 이루어진 경우 2.
* Argument <code>name</code> 값이
* <code>null</code>이거나, 공백 문자로만 이루어진 경우 3.
* Argument <code>assignableClasses</code>가
* <code>null</code>이거나 빈 Array인 경우
*/
protected AbstractType(final String id, final String name,
final Class<?>[] assignableClasses) {
this(id, name, Arrays.asList(assignableClasses));
}
/**
* Argument <code>id</code>의 Type을 생성한다.
* @param id
* Type Id
* @param name
* Type Name
* @param assignableClasses
* assign할 수 있는 Java 객체의 Class들
* @throws IllegalArgumentException
* 1. Argument <code>id</code> 값이
* <code>null</code>이거나, 공백 문자로만 이루어진 경우 2.
* Argument <code>name</code> 값이
* <code>null</code>이거나, 공백 문자로만 이루어진 경우 3.
* Argument <code>assignableClasses</code>가
* <code>null</code>이거나 빈 List인 경우
*/
protected AbstractType(final String id, final String name,
final List<Class<?>> assignableClasses) {
super();
if (StringUtils.hasText(id) == false) {
LOG.error("id does not have a text (id = \"" + id + "\")");
throw new IllegalArgumentException();
} else if (StringUtils.hasText(name) == false) {
LOG.error("name does not have a text (name = \"" + name + "\")");
throw new IllegalArgumentException();
} else if (assignableClasses == null || assignableClasses.size() == 0) {
LOG
.error("assignableClasses is null or empty (assignableClasses = "
+ assignableClasses + ")");
throw new IllegalArgumentException();
}
this.id = id;
this.name = name;
this.assignableClasses = assignableClasses;
}
public String getId() {
return id;
}
/**
* @param id
* the id to set
* @throws IllegalArgumentException
* Argument <code>id</code> 값이
* <code>null</code>이거나, 공백 문자로만 이루어진 경우
*/
public void setId(String id) {
if (StringUtils.hasText(id) == false) {
LOG.error("id does not have a text (id = \"" + id + "\")");
throw new IllegalArgumentException();
}
this.id = id;
}
public String getName() {
return name;
}
/**
* @param name
* the name to set
* @throws IllegalArgumentException
* Argument <code>name</code> 값이
* <code>null</code>이거나, 공백 문자로만 이루어진 경우
*/
public void setName(String name) {
if (StringUtils.hasText(name) == false) {
LOG.error("name does not have a text (name = \"" + name + "\")");
throw new IllegalArgumentException();
}
this.name = name;
}
/**
* @return the assignableClasses
*/
public List<Class<?>> getAssignableClasses() {
return assignableClasses;
}
/**
* @param assignableClasses
* the assignableClasses to set
* @throws IllegalArgumentException
* Argument <code>assignableClasses</code>
* 가 <code>null</code>이거나 빈 Array인 경우
*/
public void setAssignableClasses(List<Class<?>> assignableClasses) {
if (assignableClasses == null || assignableClasses.size() == 0) {
LOG
.error("assignableClasses is null or empty (assignableClasses = "
+ assignableClasses + ")");
throw new IllegalArgumentException();
}
this.assignableClasses = assignableClasses;
}
public boolean isAssignableFrom(final Class<?> clazz) {
if (clazz == null) {
LOG.error("Argument 'clazz' is null");
throw new IllegalArgumentException();
}
for (Class<?> assignableClass : assignableClasses) {
if (assignableClass.isAssignableFrom(clazz)) {
return true;
}
}
return false;
}
public boolean isValid() {
return (StringUtils.hasText(id) && StringUtils.hasText(name) && assignableClasses != null);
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((id == null) ? 0 : id.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
AbstractType other = (AbstractType) obj;
if (id == null) {
if (other.id != null)
return false;
} else if (!id.equals(other.id))
return false;
return true;
}
@Override
public String toString() {
return this.getClass().getName() + " {id = " + StringUtils.quote(id)
+ "}";
}
}