Show Menu
화제×

워크플로우 모델 만들기

클래식 UI를 사용하려면 AEM 6. 3 설명서를 참조하십시오.
사용자가 워크플로우를 시작할 때 실행되는 일련의 단계를 정의하는 워크플로우 모델을 만듭니다. 워크플로우가 일시적인지 또는 여러 리소스를 사용하는지 여부와 같은 모델 속성을 정의할 수도 있습니다.
사용자가 워크플로우를 시작하면 인스턴스가 시작됩니다.변경 내용을 동기화할 때 생성된 해당 런타임 모델입니다.

새 워크플로우 만들기

새 워크플로우 모델을 처음 만들면 다음과 같은 내용이 포함됩니다.
  • 흐름 시작 및 흐름 종료 단계입니다 . 워크플로우의 시작과 끝을 나타냅니다. 이러한 단계는 필수이며 편집/제거할 수 없습니다.
  • 단계 1 이라는 참가자 단계의 예 . 이 단계는 작업 항목을 워크플로우 개시자에게 할당하도록 구성됩니다. 이 단계를 편집하거나 삭제하고 필요에 따라 단계를 추가합니다.
편집기로 새 워크플로우를 만들려면
  1. 워크플로우 모델 콘솔을 엽니다.도구 , ​워크플로우 , ​모델 또는 예를 들면 다음과 같습니다. https://localhost:4502/aem/workflow
  2. Select Create , then Create Model .
  3. 워크플로우 모델 추가 대화 상자가 나타납니다. 완료를 선택하기 전에 제목 및 이름 (선택 사항)을 입력합니다 .
  4. 새 모델은 워크플로우 모델 콘솔에 나열됩니다.
  5. 새 워크플로우를 선택한 다음 편집을 사용하여 **구성을​**위해 엽니다 .
프로그래밍 방식으로 모델을 만드는 경우(crx 패키지 사용) 다음 내에서 하위 폴더를 만들 수도 있습니다.
/var/workflow/models
예, /var/workflow/models/prototypes
그런 다음 이 폴더를 사용하여 해당 폴더의 모델에 대한 액세스를 관리할 수 있습니다.

워크플로우 편집

기존 워크플로우 모델을 편집하여 다음을 수행할 수 있습니다.
기본 및/또는 기존​ 가능) 워크플로우를 편집하면 변경 전에 안전한 복사본이생성되는지 확인하는 추가 단계가 있습니다.
워크플로우에 대한 업데이트가 완료되면 #를 사용하여 런타임 모델 생성을 사용해야 합니다 . 자세한 내용은 워크플로우 동기화를 참조하십시오.

워크플로우 동기화 - 런타임 모델 생성

동기화 (편집기 도구 모음에서 바로)는 런타임 모델을 생성합니다. 런타임 모델은 사용자가 워크플로우를 시작할 때 실제로 사용되는 모델입니다. 변경 내용을 동기화하지 않으면 변경 내용을 런타임에 사용할 수 없습니다.
사용자(또는 다른 사용자)가 작업 과정을 변경하면 개별 대화 상자 (예: 단계)에 자체 저장 옵션이 있는 경우에도 Sync를 사용하여 런타임 모델을 생성해야 합니다.
변경 사항이 런타임(저장된) 모델과 동기화되면 동기화된 것이 대신 표시됩니다.
일부 단계에는 필수 필드 및/또는 유효성 검사가 내장되어 있습니다. 이러한 조건이 충족되지 않으면 모델 동기화를 시도하면 오류가 표시됩니다 . 예를 들어 참가자 단계에 대해 정의된 참가자가 없는 경우 :

처음 기본 또는 이전 워크플로우 편집

편집을 위해 기본 및/ 또는 이전 모델을 열 때:
  • 단계 브라우저를 사용할 수 없습니다(왼쪽).
  • 도구 모음( 오른쪽 )에서 사용 가능한 편집 작업이 있습니다.
  • 처음에는 모델 및 해당 속성이 다음과 같이 읽기 전용 모드로 표시됩니다.
    • 기본 워크플로우는 /libs
    • 기존 워크플로우는 편집 /etc 대상 선택에 있습니다 .
  • 워크플로우의 사본을 /conf
  • 단계 브라우저를 사용할 수 있도록 설정
  • 변경을 수행할 수 있도록 설정
자세한 내용은 워크플로우 모델의 위치를 참조하십시오.

모델에 단계 추가

수행할 활동을 나타내려면 모델에 단계를 추가해야 합니다. 각 단계는 특정 활동을 수행합니다. 선택한 단계 구성 요소는 표준 AEM 인스턴스에서 사용할 수 있습니다.
모델을 편집할 때 사용 가능한 단계가 단계 브라우저의 다양한 그룹에 표시됩니다 . 예:
AEM과 함께 설치되는 기본 단계 구성 요소에 대한 자세한 내용은 워크플로우 단계 참조를 참조하십시오 .
워크플로우 모델에 단계를 추가하려면:
  1. 편집할 기존 워크플로우 모델을 엽니다. 워크플로우 모델 콘솔에서 필요한 모델을 선택한 다음 편집을 선택합니다 .
  2. 단계 브라우저를 엽니다.상단 도구 모음의 맨 ​왼쪽에 있는 #을 사용합니다. 여기에서 다음을 수행할 수 있습니다.
    • 특정 단계에 대해 필터링합니다 .
    • 드롭다운 선택기를 사용하여 선택 사항을 특정 단계 그룹으로 제한합니다.
    • 설명 표시 아이콘 선택하여 해당 단계에 대한 자세한 내용을 표시합니다.
  3. 적절한 단계를 모델의 필요한 위치로 드래그합니다.
    예를 들어 참가자 단계 .
    흐름에 추가되면 단계를 구성할 수 있습니다 .
  4. 필요에 따라 단계 또는 기타 업데이트를 추가할 수 있습니다.
    런타임에 단계는 모델에 나타나는 순서대로 실행됩니다. 단계 구성 요소를 추가한 후 모델의 다른 위치로 드래그할 수 있습니다.
    기존 단계를 복사, 잘라내기, 붙여넣기, 그룹 또는 삭제할 수도 있습니다.를 페이지 편집기와 함께 사용할 수 있습니다.
    도구 모음 옵션을 사용하여 분할 단계를 축소/확장할 수도 있습니다.
  5. 동기화(편집기 도구 모음 )를 사용하여 변경 사항을 확인하여 런타임 모델을 생성합니다.
    자세한 내용은 워크플로우 동기화를 참조하십시오.

워크플로우 단계 구성

단계 속성 대화 상자를 사용하여 워크플로우 단계의 동작을 구성하고 사용자 지정할 있습니다.
  1. 단계 속성 대화 상자를 열려면 다음 중 하나를 수행합니다.
    • 워크플로우 모델에서* *단계를 클릭/탭하고 구성 요소 도구 모음에서 구성을 선택합니다.
    • 단계를 두 번 클릭합니다.
    AEM과 함께 설치되는 기본 단계 구성 요소에 대한 자세한 내용은 워크플로우 단계 참조를 참조하십시오 .
  2. 필요에 따라 단계 속성을 구성합니다.사용 가능한 속성은 단계 유형에 따라 다르며, 사용 가능한 여러 탭이 있을 수도 있습니다. 예를 들어, 기본 참가자 단계가 ​새 워크플로우에 있는 Step 1 경우
  3. 확인 표시를 사용하여 업데이트를 확인합니다.
  4. 동기화(편집기 도구 모음 )를 사용하여 변경 사항을 확인하여 런타임 모델을 생성합니다.
    자세한 내용은 워크플로우 동기화를 참조하십시오.

임시 워크플로우 만들기

새 모델을 생성하거나 기존 모델을 편집하여 임시 워크플로우 모델을 생성할 수 있습니다.
  1. 워크플로우 모델을 열어 편집합니다 .
  2. 도구 모음에서 워크플로우 모델 속성을 선택합니다.
  3. 대화 상자에서 임시 워크플로우 활성화 (또는 필요한 경우 비활성화):
  4. 저장 및 닫기로 변경 사항을 확인합니다 .다음으로 동기화 (편집기 도구 모음)를 사용하여 런타임 모델을 생성합니다.
    자세한 내용은 워크플로우 동기화를 참조하십시오.
임시 모드에서 워크플로우를 실행할 때 AEM은 워크플로우 내역을 저장하지 않습니다. 따라서 타임라인에는 해당 워크플로우와 관련된 정보가 표시되지 않습니다. 타임라인

Touch UI에서 워크플로우 모델 사용 가능

워크플로우 모델이 클래식 UI에 있지만 터치 UI의 타임라인 레일의 선택 팝업 메뉴에 없는 경우 구성에 따라 사용 가능하게 만듭니다. 다음 단계는 활성화 요청이라는 워크플로우 모델을 사용하는 것을 보여줍니다 .
  1. 모델이 터치 지원 UI에서 사용할 수 없는지 확인합니다. 경로를 사용하여 자산에 /assets.html/content/dam 액세스합니다. 자산을 선택합니다. 왼쪽 레일에서 타임라인을 엽니다. 워크플로우 시작을 클릭하고 활성화 모델이 팝업 목록에 없는지 확인합니다.
  2. 도구 > 일반 > 태깅을 탐색합니다 . 워크플로우를 선택합니다 .
  3. 만들기 > 태그 만들기를 선택합니다 . 제목으로 이름을 DAM 설정합니다 dam . 제출 ​을 선택합니다.
  4. 도구 > 워크플로우 > 모델로 이동합니다 . 활성화 요청을 ​선택한 다음 편집을 선택합니다 .
  5. [ 페이지 정보 ] 메뉴를 선택하고 [ # 열기]를 선택한 다음 #** 열려 있지 않은 경우).
  6. 태그에 Workflow : DAM 추가 필드 확인(확인 표시)으로 선택을 확인합니다.
  7. 저장 및 닫기로 태그 추가를 확인합니다 .
  8. 동기화를 사용하여 프로세스를 완료합니다 . 이제 터치 지원 UI에서 워크플로우를 사용할 수 있습니다.

다중 리소스 지원을 위한 워크플로우 구성

새 모델을 만들거나 기존 모델을 편집할 때 다중 리소스 지원에 대한 워크플로우 모델을 구성할 수 있습니다.
  1. 워크플로우 모델을 열어 편집합니다 .
  2. 도구 모음에서 워크플로우 모델 속성을 선택합니다.
  3. 대화 상자에서 다중 리소스 지원 활성화 (또는 필요한 경우 비활성화):
  4. 저장 및 닫기로 변경 사항을 확인합니다 .다음으로 동기화 (편집기 도구 모음)를 사용하여 런타임 모델을 생성합니다.
    자세한 내용은 워크플로우 동기화를 참조하십시오.

워크플로우 단계 구성(워크플로우 진행 상태 표시)

워크플로우 단계는 작업을 처리할 때 워크플로우의 진행 상황을 시각화하는 데 도움이 됩니다.
워크플로우 단계가 페이지 속성에 ​정의되었지만 워크플로우 단계에 사용되지 않는 경우 현재 워크플로우 단계에 상관없이 진행률 표시줄은 아무런 진행도 표시하지 않습니다.
사용 가능한 단계는 워크플로우 모델에서 정의됩니다.기존 워크플로우 모델을 업데이트하여 단계 정의를 포함할 수 있습니다. 워크플로우 모델에 대해 원하는 단계 수를 정의할 수 있습니다.
워크플로우의 단계를 정의하려면
  1. 편집할 워크플로우 모델을 엽니다.
  2. 도구 모음에서 워크플로우 모델 속성을 선택합니다. 그런 다음 단계 탭을 엽니다.
  3. 필요한 단계를 추가(및 배치) 합니다 . 워크플로우 모델에 대해 원하는 단계 수를 정의할 수 있습니다.
    예:
  4. 저장 닫기를 클릭하여 속성을 저장합니다.
  5. 워크플로우 모델의 각 단계에 스테이지를 지정합니다. 예:
    스테이지를 둘 이상의 단계에 할당할 수 있습니다. 예:
    단계
    단계
    1단계
    만들기
    2단계
    만들기
    3단계
    리뷰
    4단계
    승인
    5단계
    승인
    6단계
    완료
  6. 동기화(편집기 도구 모음 )를 사용하여 변경 사항을 확인하여 런타임 모델을 생성합니다.
    자세한 내용은 워크플로우 동기화를 참조하십시오.

패키지에서 워크플로우 모델 내보내기

패키지에서 워크플로우 모델을 내보내려면
  1. 패키지 관리자를 사용하여 새 패키지를 만듭니다 .
    1. 도구, 배포, 패키지를 통해 패키지 ​관리자로 이동합니다 .
    2. 패키지 만들기를 클릭합니다 .
    3. 패키지 이름 ​및 기타 세부 사항을 필요에 따라 지정합니다.
    4. 확인 ​을 클릭합니다.
  2. 패키지의 도구 모음에서 편집을 클릭합니다.
  3. Open the Filters tab.
  4. 필터 추가를 선택하고 워크플로우 모델 디자인의 ​경로를 지정합니다.
    /conf/global/settings/workflow/models/<*your-model-name*>
    완료를 클릭합니다 .
  5. 필터 추가를 선택하고 런타임 워크플로우 모델의 경로를 지정합니다.
    /var/workflow/models/<*your-model-name*>
    완료를 클릭합니다 .
  6. 모델에서 사용되는 사용자 정의 스크립트에 대한 필터를 추가합니다.
  7. 저장을 클릭하여 필터 정의를 확인합니다.
  8. 패키지 정의의 도구 모음에서 빌드를 선택합니다.
  9. 패키지 도구 모음에서 다운로드를 선택합니다.

워크플로우를 사용하여 양식 제출 처리

선택한 워크플로우에서 처리할 양식을 구성할 수 있습니다. 사용자가 양식을 제출하면 새 워크플로우 인스턴스가 만들어지고 양식 제출 데이터가 페이로드로 만들어집니다.
양식에 사용할 워크플로우를 구성하려면 다음을 수행하십시오.
  1. 새 페이지를 만들고 열어 편집합니다.
  2. Add a Form component to the page.
  3. 페이지에 표시되는 양식 시작 구성 요소를 구성합니다.
  4. 워크플로우 시작을 사용하여 사용 가능한 워크플로우 중에서 원하는 워크플로우를 선택합니다.
  5. 눈금으로 새 양식 구성을 확인합니다.

테스트 워크플로우

다양한 페이로드 유형을 사용하기 위해 워크플로우를 테스트할 때는 좋은 방법입니다.또한 개발된 유형과 다른 유형을 포함할 수 있습니다. 예를 들어, 워크플로우를 통해 자산을 처리하려면 페이지를 페이로드로 설정하여 테스트하고 오류가 발생하지 않도록 하십시오.
예를 들어 다음과 같이 새 워크플로우를 테스트합니다.
  1. 페이로드 정의 및 확인
  2. 워크플로우가 진행되도록 필요한 작업을 수행합니다.
  3. 워크플로가 실행되는 동안 로그 파일을 모니터링합니다.
로그 파일에 디버그 메시지를 표시하도록 AEM을 구성할 수도 있습니다. 자세한 내용은 로깅을 참조하고 개발이 완료되면 로그 수준을 다시 정보로 설정합니다 .

예:게시 요청을 수락하거나 거부하는 간단한 워크플로우 만들기

워크플로우 만들기의 몇 가지 가능성을 설명하기 위해 다음 예제에서는 다양한 Publish Example 워크플로우를 만듭니다.
  1. 새 워크플로우에는 다음이 포함됩니다.
    • 플로우 시작
    • Step 1
    • 플로우 끝
  2. 삭제 Step 1 (이 예제의 잘못된 단계 유형이므로):
    • 단계를 클릭하고 구성 요소 도구 모음에서 삭제를 선택합니다. 동작을 확인합니다.
  3. 단계 브라우저의 워크플로우 선택 사항에서 참가자 단계를 워크플로우로 드래그한 다음 흐름 시작 및 흐름 ​간에배치할수있습니다.
  4. 속성 대화 상자를 열려면 다음 중 하나를 수행합니다.
    • 참가자 단계를 클릭하고 구성 요소 도구 모음에서 구성을 선택합니다.
    • 참가자 단계를 두 번 클릭합니다.
  5. 일반 탭에서 제목 및 설명 Validate Content 모두에 대해 입력합니다 .
  6. 사용자/ 그룹 탭을 엽니다.
    • Activate Notify user via email .
    • 사용자/그룹 Administrator 필드에 대해 ( admin ) 선택합니다.
  7. 확인 표시를 사용하여 업데이트를 확인합니다.
    워크플로우 모델의 개요로 돌아갑니다. 이 경우 참가자 단계의 이름이 Validate Content 로 변경됩니다.
  8. 워크플로우로 또는 분할을 드래그한 다음 흐름 Validate Content 끝과 흐름 끝 사이에 배치합니다 .
  9. 구성을 위해 또는 분할을 엽니다.
  10. 구성:
    • 일반 :분할 이름을 지정합니다.
    • 분기 1 :기본 경로를 선택합니다 .
    • 분기 2 :기본 경로를 선택하지 않았는지 확인합니다.
  11. OR 분할에 대한 업데이트를 확인합니다 .
  12. 참가자 단계를 왼쪽 분기로 드래그하여 속성을 열고 다음 값을 지정한 다음 변경 사항을 확인합니다.
    • 제목 : Reject Publish Request
    • 사용자/그룹 :예를 들면 projects-administrators
    • 이메일을 ​통해 사용자에게 알림:활성화하여 사용자가 이메일로 알림을 받도록 하십시오.
  13. 프로세스 단계를 오른쪽 분기로 드래그하여 속성을 열고 다음 값을 지정한 다음 변경 사항을 확인합니다.
    • 제목 : Publish Page as Requested
    • 프로세스 :을 Activate Page 선택합니다. 이 프로세스에서는 선택한 페이지를 게시자 인스턴스에 게시합니다.
  14. 동기화( 편집기 도구 모음)를 클릭하여 런타임 모델을 생성합니다.
    자세한 내용은 워크플로우 동기화를 참조하십시오.
    새로운 워크플로우 모델은 다음과 같습니다.
  15. 사용자가 컨텐츠 유효성 확인 단계를 완료하기 이동할 때 페이지를 요청된 상태로 게시할지 또는 게시 ​요청 거부를 선택할 수 ​있도록이 워크플로우를 페이지에 적용합니다.

예:ECMA 스크립트를 사용하여 OR 분할에 대한 규칙 정의

또는 분할 단계를 통해 조건부 처리 경로를 워크플로우에 적용할 수 있습니다.
OR 규칙을 정의하려면 다음과 같이 진행하십시오.
  1. 두 개의 스크립트를 만들어 다음과 같이 보관소에 저장합니다.
    /apps/myapp/workflow/scripts
    스크립트에는 부울 값을 반환하는 함수가 있어야 합니다.
  2. 워크플로우를 편집하고 모델에 OR 분할을 추가합니다.
  3. OR 분할의 분기 1 속성을 편집합니다 .
    • 값을 로 설정하여 이 경로를 기본 경로로 true 정의합니다.
    • 규칙으로 스크립트 경로를 설정합니다. 예: /apps/myapp/workflow/scripts/myscript1.ecma
    필요한 경우 분기 주문을 전환할 수 있습니다.
  4. OR 분할의 분기 2 속성을 편집합니다 .
    • 규칙을 사용하여 경로를 다른 스크립트로 설정합니다. 예: /apps/myapp/workflow/scripts/myscript2.ecma
  5. 각 분기에서 개별 단계의 속성을 설정합니다. 사용자/ 그룹이 설정되어 있는지 확인합니다.
  6. 동기화( 편집기 도구 모음)를 클릭하여 런타임 모델에 대한 변경 사항을 유지합니다.
    자세한 내용은 워크플로우 동기화를 참조하십시오.

Function Check()

다음 샘플 스크립트는 노드가 다음 아래에 true 있는 JCR_PATH 경우 반환됩니다 /content/we-retail/us/en .
function check() {
    if (workflowData.getPayloadType() == "JCR_PATH") {
      var path = workflowData.getPayload().toString();
      var node = jcrSession.getItem(path);

      if (node.getPath().indexOf("/content/we-retail/us/en") >= 0) {
       return true;
      } else {
       return false;
      }
     } else {
      return false;
     }
}

예:사용자 정의 활성화 요청

즉시 사용 가능한 워크플로우를 사용자 정의할 수 있습니다. 사용자 지정된 동작을 만들려면 적절한 워크플로우의 세부 사항을 오버레이합니다.
예를 들어 활성화 요청 . 이 워크플로우는 사이트 내에서 페이지를 게시하는 사용되며 컨텐츠 작성자에게 적절한 복제 권한이 없을 때 자동으로 트리거됩니다. 자세한 내용은 페이지 작성 사용자 지정 - 활성화 요청 워크플로우 사용자 정의를 참조하십시오.