====== Flow 정의 ======
=====개요=====
====Flow====
Flow란 상이한 상황(context)에서 실행될 수 있는 재사용이 가능한\\
여러 단계들의 흐름을 캡슐화한 것을 의미한다.\\
모든 Flow는 아래와 같은 Root 로 시작한다.
====Flow 의 구성===
SWF에서 Flow는 "Sate(state)"로 부르는 일련의 단계들로 구성된다. Flow로 진입하게 되는 Sate는 일반적으로 사용자에게 보여지는 뷰가 된다. \\
이 뷰에서는 Sate를 제어하게 되는 이벤트가 발생한다. 이들 이벤트는 결과적으로 다른 뷰로 이동하게 되는 Transition(transition)을 일으키게 된다.\\
모든 state 는 안에 정의하게 된다. 맨처음 정의되는 state가 Flow의 시작점이게 된다.
===Flow 의 작성법====
Flow 는 웹 애플리케이션 개발자가 XML 기반 Flow 정의 언어를 사용해서 작성된다.
=====설명=====
====Flow 의 필수적인 언어 구성요소 ====
* view-state: Flow 중 화면을 보여주는 Sate를 정의하는 구성요소
* 편의상 Flow 정의 파일이 있는 디렉터리 내에서 view-state id와 일치하는 화면 템플릿을 마춰 보게 됨
* transition: Sate 내에서 발생한 이벤트를 제어하는 구성 요소. 화면 이동을 일으킴.
* end-state: Flow의 결과를 정의
====Actions ====
대부분의 Flow는 화면 이동 로직 뿐만 아니라, 애플리케이션의 비즈니스 서비스나 다른 행동을 호출할 필요가 있을 수 있다.\\
Flow 내에서 Action을 취할 수 있는 여러 지점이 존재한다.\\
* Flow가 시작할 때
* Sate에 들어갈 때
* 화면을 보여줄 때
* Transition이 일어날 때
* Sate가 종료될 때
* Flow가 종료될 때
SWF 에서 Action은 기본적으로 Unified EL이라는 간결한 표현 언어를 사용해서 정의하게 된다.
==evaluate==
대부분 evaluate 구성요소를 사용하게 된다. 이를 통해 Spring Bean 에 있는 메소드나 다른 Flow 변수를 호출할 수 있다.\\
예를 들자면 아래와 같다.
아래 예에서는 Flow가 시작할 때 Flow 범위에 Booking 객체를 생성해 저장한다.
hotelId는 Flow의 입력 속성으로 받게 된다.
====입력/출력 매핑 ====
각각의 Flow는 잘 정의된 입력/출력 계약(input/output contract)를 갖고 있다. \\
Flow는 시작할 때 입력 속성을 건네 받게되고, 종료될 때 출력 속성을 반환하게 된다. 이처럼 Flow호출은 개념적으로 다음과 같은 메소드 호출과 비슷하다.
FlowOutcome flowId(Map inputAttributes);
반환되는 FlowOutcome은 다음과 같은 메소드 선언부를 갖게 된다.
public interface FlowOutcome {
public String getName();
public Map getOutputAttributes();
}
===입력===
===출력===
Flow 출력 속성은 output 구성요소를 사용한다. output 속성은 end-state 내에 선언한다.
출력 값은 속성의 이름으로 Flow 범위 내에서 얻어오게 된다.
===입력/출력 매핑:샘플===
위 Flow는 이제 hotelId를 입력 값으로 받아서, 새로운 예약이 끝나게 되면 bookingId 출력 속성을 결과로 반환하게 된다.\\
====변수들====
Flow에는 하나이상의 인스턴스 변수 선언이 가능하다. 이 변수들은 flow가 시작할 때 할당되며, \\
변수를 유지하게 되는 모든 @Autowired transient 참조는 Flow가 재시작될 때 다시 값이 할당(rewired)되게 된다.\\
var 구성 요소를 사용해서 Flow 변수를 선언하자.\\
변수로 사용하는 클래스가 Flow 요청 간 인스턴스의 Sate를 유지하기 위해서 java.io.Serializable을 interface로 가지고 있어야 함을 기억하자. \\
====Sub Flow 호출====
Flow 내에서 하위 Flow로써 또 다른 Flow 호출이 가능하다. 이 때 하위 Flow가 결과를 반활할 때까지 기존 Flow는 대기하게 된다.\\
==subflow-state==
subflow-state 구성요소를 사용해서 하위 Flow 호출을 하게 된다.\\
이 예제에서는 createGuest Flow를 호출하게 된다. guestCreated 출력이 반환되게 되면, 새로운 손님이 예약 손님 리스트에 추가되게 된다.\\
==subflow input 전달==
input 구성요소를 사용하면 하위 Flow에 입력값을 건낼 수 있다.\\
==subflow output 매핑==
출력 값의 이름으로 하위 Flow에서 출력하는 속성을 참조해서 Transition를 하게 된다.
..
이 예에서는 guestCreated 을 반환하게 될 때 gest 이름으로 넘어온 값을 booking 내의 guests (**currentEvent.attributes.guest**) 의 일부로 추가 해주고 있다. \\
===샘플:Sub Flow 호출하기===
아래는 샘플 코드이다.
===== 참고자료 =====
* [[http://docs.spring.io/spring-webflow/docs/2.3.3.RELEASE/reference/html/defining-flows.html|Spring Web Flow 2.3.3 Reference - Defining Flows]]