/* * 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.fdl.cmmn.exception.manager; import egovframework.rte.fdl.cmmn.exception.handler.ExceptionHandler; import javax.annotation.Resource; import org.springframework.context.MessageSource; import org.springframework.util.PathMatcher; /** * AbsExceptionHandleManager * 사용자 ExceptionHandleManager 구현시 상속되는 추상클래스이다. * ExceptionHandlerService 인터페이스의 메소드를 거의 다 구현해 놓은 추상클래스이기 때문에 사용자가 구현시 * run(Exception exception) 만 구현을 해주면 된다. * <p> * 본 클래스는 eGovFrame 3.2부터 Deprecated 된다. * 기존 AbsExceptionHandleManager를 사용하고 있다면 AbstractExceptionHandleManager 클래스로 변경하는 것을 권장한다. * (AbsExceptionHandleManager는 향후 제거될 예정) * </p> * @deprecated AbstractExceptionHandleManager로 대체 * @author Judd Cho (horanghi@gmail.com) * @since 2009.06.01 * @version 1.0 * @see * * <pre> * << 개정이력(Modification Information) >> * * 수정일 수정자 수정내용 * ------- -------- --------------------------- * 2009.05.30 Judd Cho 최초 생성 * 2015.01.31 Vincent Han 코드 품질 개선 (deprecated 처리) * * </pre> */ //CHECKSTYLE:OFF @Deprecated public abstract class AbsExceptionHandleManager { @Resource(name = "messageSource") protected MessageSource messageSource; protected Exception ex; protected String thisPackageName; protected String[] patterns; protected ExceptionHandler[] handlers; protected PathMatcher pm; /** * setPatterns 메소드 * * 패키지,클래스 이름으로 패턴등록(Ant형식의 매칭) * @param patterns 패턴리스트 */ public void setPatterns(String[] patterns) { this.patterns = patterns; } /** * setHandlers 메소드 * ExceptionHandler 리스트 등록 * @param handlers handler리스트 */ public void setHandlers(ExceptionHandler[] handlers) { this.handlers = handlers; } /** * setPackageName 메소드 * 비교할 클래스 정보 * * @param canonicalName 비교할 클래스명 */ public void setPackageName(String canonicalName) { this.thisPackageName = canonicalName; } public String getPackageName() { return this.thisPackageName; } /** * setException 메소드 * * @param be Exception */ public void setException(Exception be) { this.ex = be; } /** * setReqExpMatcher 메소드 * * @param pm 별도의 PathMatcher */ public void setReqExpMatcher(PathMatcher pm) { this.pm = pm; } /** * hasReqExpMatcher 메소드 * PathMatcher 가 있는지 여부 반환 * @return boolean true|false */ public boolean hasReqExpMatcher() { return this.enableMatcher(); } /** * enableMatcher 메소드 * PathMatcher 가 있는지 여부 반환 * @return boolean true|false */ public boolean enableMatcher() { return (this.pm == null) ? false : true; } /** * run 메소드 * * 상속받아 구현해야할 메스드 하지만 미리구현은 먼저 해둠. 실 구현체에서 override 하여 구현해야 함. * @param exception 발생한 Exception * @return boolean 실행성공여부 */ public boolean run(Exception exception) throws Exception { if (!enableMatcher()) return false; for (String pattern : patterns) { if (pm.match(pattern, thisPackageName)) { for (ExceptionHandler eh : handlers) { eh.occur(exception, getPackageName()); } break; } } return true; } }