본문 바로가기

SAP ABAP

마스터 패스워드 관리 프로그램

모듈 : BC
기능 설명 : 시스템 별 패스워드 관리 마스터 프로그램
사용 예시 : 여러 시스템의 각기 다른 패스워드를 한군데에서 일괄 관리하는 프로그램


1. 소스 코드

***********************************************************************
* Report            : ZBC_MASTER_PASSWORD                             *
* Module/Sub-Module : BC                                              *
* Description       : Master Password Management                      *
***********************************************************************
*                          MODIFICATION LOG                           *
*                                                                     *
* DATE       AUTHORS            DESCRIPTION                           *
* ---------- ------------------ ------------------------------------- *
*             YHJ               Initial Release                       *
***********************************************************************

REPORT ZBC_MASTER_PASSWORD.


*----------------------------------------------------------------------*
* TYPE-POOLS
*----------------------------------------------------------------------*
TYPE-POOLS: SLIS, ICON.


*----------------------------------------------------------------------*
* TABLES
*----------------------------------------------------------------------*
TABLES: SSCRFIELDS.
TABLES: ZBC_MASTER_PW.


*----------------------------------------------------------------------*
* DATA
*----------------------------------------------------------------------*

*DATA: GT_DATA LIKE TABLE OF ZBC_MASTER_PW WITH HEADER LINE.

DATA: BEGIN OF GT_DATA OCCURS 0,
        SEL(1)        TYPE C,
        LINECOLOR(4)  TYPE C.
        INCLUDE STRUCTURE ZBC_MASTER_PW.
DATA: END OF GT_DATA.

DATA: TEMP_DATA LIKE TABLE OF GT_DATA WITH HEADER LINE.

DATA: GV_SET_SYS(5)   TYPE C,
      GV_SET_SID(3)   TYPE C,
      GV_SET_ROLE(3)  TYPE C,
      GV_SET_TAG1(10) TYPE C,
      GV_SET_TAG2(10) TYPE C.

DATA: GV_ALV_HEADER   TYPE LVC_TITLE.

DATA: GV_FLAG(1)      TYPE C,
      SEARCH_MOD(1)   TYPE C,
      SAVE_CHECK(1)   TYPE C,
      POPUP_RET(1)    TYPE C,
      VIEW_ALL(1)     TYPE C.

DATA: FUNCTXT         TYPE SMP_DYNTXT.
DATA: IT_FIELDS       LIKE SVAL OCCURS 0 WITH HEADER LINE.


"### 마스터 패스워드 형태 지정 ####################################
"### _ 표시는 시퀸셜 위치 (ex. Password1! - Password2! - Password3! ...)
DATA: BEGIN OF MASTER_PASSWORD_SHAPE OCCURS 0,
        PWD_SHAPE(20)   TYPE C  VALUE 'Password_!'.
DATA: END OF MASTER_PASSWORD_SHAPE.
"############################################################


"### 패스워드 정책 #############################################
"### SECPOL 설정 정책에 따라 자동으로 값 설정
DATA: BEGIN OF PWD_POLICY OCCURS 0,
        LINECOLOR(4)    TYPE C,
        PARAM(15)       TYPE C,
        VALUE(10)       TYPE C.
DATA: END OF PWD_POLICY.

*CONSTANTS : UPPER_CASE(1) VALUE 1.
*CONSTANTS : LOWER_CASE(1) VALUE 1.
*CONSTANTS : SPECIALS(1)   VALUE 1.
*CONSTANTS : DIGITS(1)     VALUE 1.
*CONSTANTS : LENGTH(2)     VALUE 10.
"############################################################

*----------------------------------------------------------------------*
* SELECTION-SCREEN
*----------------------------------------------------------------------*
SELECTION-SCREEN BEGIN OF BLOCK b1 WITH FRAME TITLE t001.

  SELECTION-SCREEN SKIP 1.

  SELECTION-SCREEN BEGIN OF BLOCK b2 WITH FRAME TITLE t002.

    SELECTION-SCREEN SKIP 1.

    SELECTION-SCREEN BEGIN OF BLOCK b3 WITH FRAME TITLE t003.

        SELECTION-SCREEN BEGIN OF LINE.
          PARAMETERS: C_SYS1 RADIOBUTTON GROUP RAD3 DEFAULT 'X' USER-COMMAND FLAG.
          SELECTION-SCREEN COMMENT (15) t301 FOR FIELD C_SYS1.
          PARAMETERS: C_SYS2 RADIOBUTTON GROUP RAD3.
          SELECTION-SCREEN COMMENT (15) t302 FOR FIELD C_SYS2.
          PARAMETERS: C_SYS3 RADIOBUTTON GROUP RAD3.
          SELECTION-SCREEN COMMENT (15) t303 FOR FIELD C_SYS3.
          PARAMETERS: C_SYS4  RADIOBUTTON GROUP RAD3.
          SELECTION-SCREEN COMMENT (15) t304 FOR FIELD C_SYS4.
          PARAMETERS: C_SYS5  RADIOBUTTON GROUP RAD3.
          SELECTION-SCREEN COMMENT (15) t305 FOR FIELD C_SYS5.
          PARAMETERS: C_SYS6  RADIOBUTTON GROUP RAD3.
          SELECTION-SCREEN COMMENT (15) t306 FOR FIELD C_SYS6.
        SELECTION-SCREEN END OF LINE.

        SELECTION-SCREEN BEGIN OF LINE.
          PARAMETERS: C_SYS7 RADIOBUTTON GROUP RAD3.
          SELECTION-SCREEN COMMENT (15) t307 FOR FIELD C_SYS7.
          PARAMETERS: C_SYS8 RADIOBUTTON GROUP RAD3.
          SELECTION-SCREEN COMMENT (15) t308 FOR FIELD C_SYS8.
          PARAMETERS: C_SYS9 RADIOBUTTON GROUP RAD3.
          SELECTION-SCREEN COMMENT (15) t309 FOR FIELD C_SYS9.
          PARAMETERS: C_SYS10 RADIOBUTTON GROUP RAD3.
          SELECTION-SCREEN COMMENT (15) t310 FOR FIELD C_SYS10.
          PARAMETERS: C_SYS11 RADIOBUTTON GROUP RAD3.
          SELECTION-SCREEN COMMENT (15) t311 FOR FIELD C_SYS11.
          PARAMETERS: C_ETC RADIOBUTTON GROUP RAD3.
          SELECTION-SCREEN COMMENT (15) t312 FOR FIELD C_ETC.
        SELECTION-SCREEN END OF LINE.

    SELECTION-SCREEN END OF BLOCK b3.

    SELECTION-SCREEN BEGIN OF BLOCK b4 WITH FRAME TITLE t003.

      SELECTION-SCREEN BEGIN OF LINE.

        PARAMETERS: R_ALL RADIOBUTTON GROUP RAD1 DEFAULT 'X'.
        SELECTION-SCREEN COMMENT (15) t041 FOR FIELD R_ALL.
        PARAMETERS: R_ABAP RADIOBUTTON GROUP RAD1.
        SELECTION-SCREEN COMMENT (15) t042 FOR FIELD R_ABAP.
        PARAMETERS: R_JAVA RADIOBUTTON GROUP RAD1.
        SELECTION-SCREEN COMMENT (15) t043 FOR FIELD R_JAVA.
        PARAMETERS: R_OS RADIOBUTTON GROUP RAD1.
        SELECTION-SCREEN COMMENT (15) t044 FOR FIELD R_OS.
        PARAMETERS: R_DB RADIOBUTTON GROUP RAD1.
        SELECTION-SCREEN COMMENT (15) t045 FOR FIELD R_DB.
*        PARAMETERS: R_ETC RADIOBUTTON GROUP RAD1.
*        SELECTION-SCREEN COMMENT (15) t046 FOR FIELD R_ETC.
      SELECTION-SCREEN END OF LINE.

    SELECTION-SCREEN END OF BLOCK b4.

    SELECTION-SCREEN BEGIN OF BLOCK b5 WITH FRAME TITLE t005.

      SELECTION-SCREEN BEGIN OF LINE.

        PARAMETERS: C2_ALL RADIOBUTTON GROUP RAD2 DEFAULT 'X'.
        SELECTION-SCREEN COMMENT (15) t041 FOR FIELD C2_ALL.
        PARAMETERS: C2_PRD RADIOBUTTON GROUP RAD2.
        SELECTION-SCREEN COMMENT (15) t052 FOR FIELD C2_PRD.
        PARAMETERS: C2_QAS RADIOBUTTON GROUP RAD2.
        SELECTION-SCREEN COMMENT (15) t053 FOR FIELD C2_QAS.
        PARAMETERS: C2_DEV RADIOBUTTON GROUP RAD2.
        SELECTION-SCREEN COMMENT (15) t054 FOR FIELD C2_DEV.
      SELECTION-SCREEN END OF LINE.

    SELECTION-SCREEN END OF BLOCK b5.

  SELECTION-SCREEN END OF BLOCK b2.

  SELECTION-SCREEN SKIP 1.

  SELECTION-SCREEN BEGIN OF BLOCK b6 WITH FRAME TITLE t006.

  SELECT-OPTIONS: S_SID   FOR ZBC_MASTER_PW-SID,
                  S_UID   FOR ZBC_MASTER_PW-ID,
                  S_IP    FOR ZBC_MASTER_PW-IP,
                  S_HN    FOR ZBC_MASTER_PW-HOSTNAME,
                  S_VC    FOR ZBC_MASTER_PW-PW_VC,
                  S_TAG1  FOR ZBC_MASTER_PW-TAG1,
                  S_TAG2  FOR ZBC_MASTER_PW-TAG2.

  SELECTION-SCREEN SKIP 1.


  SELECTION-SCREEN END OF BLOCK b6.

SELECTION-SCREEN END OF BLOCK b1.


SELECTION-SCREEN: FUNCTION KEY 1, FUNCTION KEY 2, FUNCTION KEY 3, FUNCTION KEY 4, FUNCTION KEY 5.


AT SELECTION-SCREEN.
  PERFORM MENU_SELECT.

AT SELECTION-SCREEN OUTPUT.
  PERFORM MODIFY_SCREEN.


*----------------------------------------------------------------------*
* INITIALIZATION                                                       
*----------------------------------------------------------------------*
INITIALIZATION.
  PERFORM MENU_BAR.
  PERFORM SET_PWD_POLICY.

  MOVE 'SAP Password Master' TO t001.
    MOVE 'Simple Search'       TO t002.
      MOVE 'ERP'                 TO t003.
        MOVE 'SYS1'                TO t301.
        MOVE 'SYS2'                TO t302.
        MOVE 'SYS3'                TO t303.
        MOVE 'SYS4'                TO t304.
        MOVE 'SYS5'                TO t305.
        MOVE 'SYS6'                TO t306.
        MOVE 'SYS7'                TO t307.
        MOVE 'SYS8'                TO t308.
        MOVE 'SYS9'                TO t309.
        MOVE 'SYS10'               TO t310.
        MOVE 'SYS11'               TO t311.
        MOVE 'Etc System'          TO t312.  
  
      MOVE 'System'              TO t004.
        MOVE 'ALL'                 TO t041.
        MOVE 'ABAP'                TO t042.
        MOVE 'JAVA'                TO t043.
        MOVE 'OS'                  TO t044.
        MOVE 'DB'                  TO t045.
        MOVE 'ETC'                 TO t046.

      MOVE 'Role'                TO t005.
        *MOVE 'ALL'                 TO t041.
        MOVE 'Prd'                 TO t052.
        MOVE 'Qas'                 TO t053.
        MOVE 'Dev'                 TO t054.
      
    MOVE 'Deep Search'         TO t006.

*----------------------------------------------------------------------*
* START-OF-SELECTION.
*----------------------------------------------------------------------*
START-OF-SELECTION.

  "### 배치잡 수행일때 동작
  IF SY-BATCH = 'X'.


  "### 프론트 수행일떄 동작
  ELSE.

    "### 1. 조회 조건 값을 DB에서 읽을 수 있게, 값 세팅
    PERFORM SET_CONDITION.

    "### 2. 데이터 조회 전, 전체 데이터에 대해서 클리닝 작업
    PERFORM DATA_CLEANING.

    "### 3. 세팅된 조회값으로 DB에서 데이터 셀렉트
    PERFORM SELECT_DATA.

    "### 4. 셀렉트된 데이터를 기반으로 ALV 리스트 출력
    PERFORM RESULT_VIEW TABLES GT_DATA.

  ENDIF.

*----------------------------------------------------------------------*
* END-OF-SELECTION.
*----------------------------------------------------------------------*
END-OF-SELECTION.



*&---------------------------------------------------------------------*
*& ZBC_MASTER_PASSWORD_F01
*&---------------------------------------------------------------------*

*&---------------------------------------------------------------------*
*&      Form  MODIFY_SCREEN
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM MODIFY_SCREEN .

  %_S_SID_%_APP_%-TEXT   = 'SID'.
  %_S_UID_%_APP_%-TEXT   = 'SAP ID'.
  %_S_IP_%_APP_%-TEXT    = 'IP'.
  %_S_HN_%_APP_%-TEXT    = 'HostName'.
  %_S_VC_%_APP_%-TEXT    = 'Vaild Check'.
  %_S_TAG1_%_APP_%-TEXT  = 'Tag_1'.
  %_S_TAG2_%_APP_%-TEXT  = 'Tag_2'.

  LOOP AT SCREEN.

    IF C_ETC = 'X'.

      IF ( SCREEN-NAME CP 'R_*' ) OR ( SCREEN-NAME CP 'C2_*' ).

        IF SCREEN-NAME = 'R_ALL'.  CLEAR: R_ALL, R_ABAP, R_JAVA, R_OS, R_DB. R_ALL  = 'X'. ENDIF.
        IF SCREEN-NAME = 'C2_ALL'. CLEAR: C2_ALL, C2_PRD, C2_QAS, C2_DEV.    C2_ALL = 'X'. ENDIF.

        SCREEN-INPUT = 0.

      ENDIF.
    ENDIF.

    MODIFY SCREEN.

  ENDLOOP.



ENDFORM.

*&---------------------------------------------------------------------*
*&      Form  SET_CONDITION
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM SET_CONDITION .

  DATA: CK_ERP(20)   TYPE C,
        CK_ROL(5)    TYPE C.

  CLEAR: GV_SET_SYS, GV_SET_ROLE, GV_SET_SID, GV_ALV_HEADER, SEARCH_MOD.

  "### 간편 검색인지, 상세 검색인지 체크
  "### 상세 검색의 모든 필드에 값이 없다면, 간편 검색으로 인식.
  IF S_SID IS INITIAL AND S_UID  IS INITIAL AND
     S_IP  IS INITIAL AND S_HN   IS INITIAL AND
     S_VC  IS INITIAL AND S_TAG1 IS INITIAL AND S_TAG2 IS INITIAL.

    "### SELECT_DATA 폼에서 쓸 서치모드 A 설정(간편 검색)
    SEARCH_MOD = 'A'.

    "### SYS 키값 세팅
    IF R_ALL = 'X'.
      GV_SET_SYS = '%'.
    ELSEIF R_ABAP = 'X'.
      GV_SET_SYS = 'ABAP'.
    ELSEIF R_JAVA = 'X'.
      GV_SET_SYS = 'JAVA'.
    ELSEIF R_OS = 'X'.
      GV_SET_SYS = 'OS'.
    ELSEIF R_DB = 'X'.
      GV_SET_SYS = 'DB'.
    ENDIF.

    "### ERP /ROLE 키값 세팅
    "### ERP 의 ROLE 개발/품질/운영에 따라 SID 값 세팅
    IF C_SYS1 = 'X'.
      CK_ERP = 'SYSTEM1 ERP'.
      GV_SET_TAG1 = 'G01'.
      GV_SET_TAG2 = 'SY1'.
      IF C2_PRD = 'X'. GV_SET_ROLE = 'PRD'. ENDIF.
      IF C2_QAS = 'X'. GV_SET_ROLE = 'QAS'. ENDIF.
      IF C2_DEV = 'X'. GV_SET_ROLE = 'DEV'. ENDIF.

    ELSEIF C_SYS2 = 'X'.
      CK_ERP = 'SYSTEM2 ERP'.
      GV_SET_TAG1 = 'G01'.
      GV_SET_TAG2 = 'SY2'.
      IF C2_PRD = 'X'. GV_SET_ROLE = 'PRD'. ENDIF.
      IF C2_QAS = 'X'. GV_SET_ROLE = 'QAS'. ENDIF.
      IF C2_DEV = 'X'. GV_SET_ROLE = 'DEV'. ENDIF.

    ELSEIF C_SYS3 = 'X'.
      CK_ERP = 'SYSTEM3 ERP'.
      GV_SET_TAG1 = 'G01'.
      GV_SET_TAG2 = 'SY3'.
      IF C2_PRD = 'X'. GV_SET_ROLE = 'PRD'. ENDIF.
      IF C2_QAS = 'X'. GV_SET_ROLE = 'QAS'. ENDIF.
      IF C2_DEV = 'X'. GV_SET_ROLE = 'DEV'. ENDIF.

    ELSEIF C_SYS4 = 'X'.
      CK_ERP = 'SYSTEM4 ERP'.
      GV_SET_TAG1 = 'G01'.
      GV_SET_TAG2 = 'SY4'.
      IF C2_PRD = 'X'. GV_SET_ROLE = 'PRD'. ENDIF.
      IF C2_QAS = 'X'. GV_SET_ROLE = 'QAS'. ENDIF.
      IF C2_DEV = 'X'. GV_SET_ROLE = 'DEV'. ENDIF.

    ELSEIF C_SYS5 = 'X'.
      CK_ERP = 'SYSTEM5 ERP'.
      GV_SET_TAG1 = 'G01'.
      GV_SET_TAG2 = 'SY5'.
      IF C2_PRD = 'X'. GV_SET_ROLE = 'PRD'. ENDIF.
      IF C2_QAS = 'X'. GV_SET_ROLE = 'QAS'. ENDIF.
      IF C2_DEV = 'X'. GV_SET_ROLE = 'DEV'. ENDIF.

    ELSEIF C_SYS6 = 'X'.
      CK_ERP = 'SYSTEM6 ERP'.
      GV_SET_TAG1 = 'G01'.
      GV_SET_TAG2 = 'SY6'.
      IF C2_PRD = 'X'. GV_SET_ROLE = 'PRD'. ENDIF.
      IF C2_QAS = 'X'. GV_SET_ROLE = 'QAS'. ENDIF.
      IF C2_DEV = 'X'. GV_SET_ROLE = 'DEV'. ENDIF.

    ELSEIF C_SYS7 = 'X'.
      CK_ERP = 'SYSTEM7 ERP'.
      GV_SET_TAG1 = 'G02'.
      GV_SET_TAG2 = '%'.
      IF C2_PRD = 'X'. GV_SET_ROLE = 'PRD'. ENDIF.
      IF C2_QAS = 'X'. GV_SET_ROLE = 'QAS'. ENDIF.
      IF C2_DEV = 'X'. GV_SET_ROLE = 'DEV'. ENDIF.

    ELSEIF C_SYS8 = 'X'.
      CK_ERP = 'SYSTEM8 ERP'.
      GV_SET_TAG1 = 'G03'.
      GV_SET_TAG2 = '%'.
      IF C2_PRD = 'X'. GV_SET_ROLE = 'PRD'. ENDIF.
      IF C2_QAS = 'X'. GV_SET_ROLE = 'QAS'. ENDIF.
      IF C2_DEV = 'X'. GV_SET_ROLE = 'DEV'. ENDIF.

    ELSEIF C_SYS9 = 'X'.
      CK_ERP = 'SYSTEM9 ERP'.
      GV_SET_TAG1 = 'G04'.
      GV_SET_TAG2 = '%'.
      IF C2_PRD = 'X'. GV_SET_ROLE = 'PRD'. ENDIF.
      IF C2_QAS = 'X'. GV_SET_ROLE = 'QAS'. ENDIF.
      IF C2_DEV = 'X'. GV_SET_ROLE = 'DEV'. ENDIF.

    ELSEIF C_SYS10 = 'X'.
      CK_ERP = 'SYSTEM10 ERP'.
      GV_SET_TAG1 = 'G05'.
      GV_SET_TAG2 = '%'.
      IF C2_PRD = 'X'. GV_SET_ROLE = 'PRD'. ENDIF.
      IF C2_QAS = 'X'. GV_SET_ROLE = 'QAS'. ENDIF.
      IF C2_DEV = 'X'. GV_SET_ROLE = 'DEV'. ENDIF.

    ELSEIF C_SYS11 = 'X'.
      CK_ERP = 'SYSTEM11 ERP'.
      GV_SET_TAG1 = 'G06'.
      GV_SET_TAG2 = '%'.
      IF C2_PRD = 'X'. GV_SET_ROLE = 'PRD'. ENDIF.
      IF C2_QAS = 'X'. GV_SET_ROLE = 'QAS'. ENDIF.
      IF C2_DEV = 'X'. GV_SET_ROLE = 'DEV'. ENDIF.

    ELSEIF C_ETC = 'X'.
      CK_ERP = '기타 시스템'.

    ENDIF.

    CASE GV_SET_ROLE.
      WHEN 'PRD'. CK_ROL = '운영'.
      WHEN 'QAS'. CK_ROL = '품질'.
      WHEN 'DEV'. CK_ROL = '개발'.
      WHEN OTHERS. CK_ROL = 'ALL'.
    ENDCASE.

    "### 선택된 조회 조건을 조합하여, ALV 리스트 헤더값 생성 (조회조건 출력)
    CONCATENATE 'SYSTEM :' GV_SET_SYS '| ERP :' CK_ERP '| ROLE :' CK_ROL INTO GV_ALV_HEADER SEPARATED BY SPACE.


  "### 상세 검색 필드 중 하나라도 값이 들어가 있다면 상세 검색으로 인식, 간편 검색 조건은 무시
  ELSE.

    "### SELECT_DATA 폼에서 쓸 서치모드 B 설정(상세 검색)
    SEARCH_MOD = 'B'.

  ENDIF.



ENDFORM.
*&---------------------------------------------------------------------*
*&      Form  SELECT_DATA
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM SELECT_DATA .

  REFRESH: GT_DATA, TEMP_DATA. CLEAR: GT_DATA, TEMP_DATA.

  "### 간편 검색 데이터 SELECT 구문
  IF SEARCH_MOD = 'A'.

    "### 전체 역할 조회의 경우, 데이터 정렬을 DEV-QAS-PRD 순으로 맞추기 위해, 각각의 순서대로 데이터 셀렉트 후, 이어붙이기
    IF C2_ALL = 'X'.

      SELECT * INTO CORRESPONDING FIELDS OF TABLE TEMP_DATA
        FROM ZBC_MASTER_PW
        WHERE SYS  LIKE GV_SET_SYS
          AND ROLE    = 'DEV'
          AND TAG1    = GV_SET_TAG1
          AND TAG2 LIKE GV_SET_TAG2.

      GT_DATA[] = TEMP_DATA[].
      REFRESH: TEMP_DATA. CLEAR: TEMP_DATA.

      SELECT * INTO CORRESPONDING FIELDS OF TABLE TEMP_DATA
        FROM ZBC_MASTER_PW
        WHERE SYS  LIKE GV_SET_SYS
          AND ROLE    = 'QAS'
          AND TAG1    = GV_SET_TAG1
          AND TAG2 LIKE GV_SET_TAG2.

      LOOP AT TEMP_DATA. MOVE-CORRESPONDING TEMP_DATA TO GT_DATA. APPEND GT_DATA. CLEAR GT_DATA. ENDLOOP.
      REFRESH: TEMP_DATA. CLEAR: TEMP_DATA.

      SELECT * INTO CORRESPONDING FIELDS OF TABLE TEMP_DATA
        FROM ZBC_MASTER_PW
        WHERE SYS  LIKE GV_SET_SYS
          AND ROLE    = 'PRD'
          AND TAG1    = GV_SET_TAG1
          AND TAG2 LIKE GV_SET_TAG2.

      LOOP AT TEMP_DATA. MOVE-CORRESPONDING TEMP_DATA TO GT_DATA. APPEND GT_DATA. CLEAR GT_DATA. ENDLOOP.
      REFRESH: TEMP_DATA. CLEAR: TEMP_DATA.

    "### 개별 역활 조회의 경우, 추가 로직(TAG2 활용)을 통해 데이터 조회
    ELSE.

      "### TAG1, 2 를 사용하여 검색 깊이를 높여서 검색
      SELECT * INTO CORRESPONDING FIELDS OF TABLE GT_DATA
        FROM ZBC_MASTER_PW
        WHERE SYS  LIKE GV_SET_SYS
          AND ROLE    = GV_SET_ROLE
          AND ( ROLE  = 'DEV' OR ROLE = 'QAS' OR ROLE = 'PRD' )
          AND TAG1    = GV_SET_TAG1
          AND TAG2 LIKE GV_SET_TAG2.

    ENDIF.

    "### 기타 시스템 조회를 메뉴바에서 간편검색 라디오 버튼으로 변경.
    IF C_ETC = 'X'.

      REFRESH: GT_DATA. CLEAR: GT_DATA, VIEW_ALL.
      VIEW_ALL = 'X'.

      "### 입력된 나머지 조건은 전부 무시하고, TAG1 ETC 시스템만 전체 조회
      SELECT * INTO CORRESPONDING FIELDS OF TABLE GT_DATA
        FROM ZBC_MASTER_PW
        WHERE TAG1 = 'ETC'.

      SORT GT_DATA BY SYS SID ROLE TYPE ID.

    ENDIF.

  "### 상세 검색 데이터 SELECT 구문
  ELSEIF SEARCH_MOD = 'B'.

    SELECT * INTO CORRESPONDING FIELDS OF TABLE GT_DATA
      FROM ZBC_MASTER_PW
      WHERE SID      IN S_SID
        AND ID       IN S_UID
        AND IP       IN S_IP
        AND HOSTNAME IN S_HN
        AND PW_VC    IN S_VC
        AND TAG1     IN S_TAG1
        AND TAG2     IN S_TAG2.

  ENDIF.

ENDFORM.

*&---------------------------------------------------------------------*
*&      Form  RESULT_VIEW
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*      -->P_GT_DATA  text
*----------------------------------------------------------------------*
FORM RESULT_VIEW  TABLES P_GT_DATA .

  DATA: LT_FIELDCAT TYPE SLIS_T_FIELDCAT_ALV WITH HEADER LINE,
        LT_LAYOUT   TYPE SLIS_LAYOUT_ALV,
        LT_EVENT    TYPE SLIS_T_EVENT.

  "### ALV Field Catalog 설정 (Table 에 맞게 순서와 너비 등등을 설정)
  LT_FIELDCAT-FIELDNAME   = 'SYS'.
  LT_FIELDCAT-SELTEXT_M   = 'SYS'.
  LT_FIELDCAT-KEY         = 'X'.
  LT_FIELDCAT-OUTPUTLEN   = 5.
  LT_FIELDCAT-COL_POS     = 0.
  APPEND LT_FIELDCAT. CLEAR  LT_FIELDCAT.

  LT_FIELDCAT-FIELDNAME   = 'SID'.
  LT_FIELDCAT-SELTEXT_M   = 'SID'.
  LT_FIELDCAT-KEY         = 'X'.
  LT_FIELDCAT-OUTPUTLEN   = 5.
  LT_FIELDCAT-COL_POS     = 1.
  APPEND LT_FIELDCAT. CLEAR  LT_FIELDCAT.

  LT_FIELDCAT-FIELDNAME   = 'ROLE'.
  LT_FIELDCAT-SELTEXT_M   = 'ROLE'.
  LT_FIELDCAT-KEY         = 'X'.
  LT_FIELDCAT-OUTPUTLEN   = 5.
  LT_FIELDCAT-COL_POS     = 2.
  APPEND LT_FIELDCAT. CLEAR  LT_FIELDCAT.

  LT_FIELDCAT-FIELDNAME   = 'TYPE'.
  LT_FIELDCAT-SELTEXT_M   = 'TYPE'.
  LT_FIELDCAT-KEY         = 'X'.
  LT_FIELDCAT-OUTPUTLEN   = 10.
  LT_FIELDCAT-COL_POS     = 3.
  APPEND LT_FIELDCAT. CLEAR  LT_FIELDCAT.

  LT_FIELDCAT-FIELDNAME   = 'ID'.
  LT_FIELDCAT-SELTEXT_M   = 'ID'.
  LT_FIELDCAT-KEY         = 'X'.
  LT_FIELDCAT-OUTPUTLEN   = 15.
  LT_FIELDCAT-COL_POS     = 4.
  APPEND LT_FIELDCAT. CLEAR  LT_FIELDCAT.

  LT_FIELDCAT-FIELDNAME   = 'PASSWORD'.
  LT_FIELDCAT-SELTEXT_M   = 'PASSWORD'.
  LT_FIELDCAT-LOWERCASE   = 'X'.
  LT_FIELDCAT-OUTPUTLEN   = 12.
  LT_FIELDCAT-COL_POS     = 5.
  "### Password 값을 선택에 따라, 변경할 수 있도록 세팅 (GV_FLAG 값으로 확인)
  IF GV_FLAG = 'E'. LT_FIELDCAT-EDIT = 'X'. LT_FIELDCAT-INPUT = 'X'. ENDIF.
  APPEND LT_FIELDCAT. CLEAR  LT_FIELDCAT.

  LT_FIELDCAT-FIELDNAME   = 'IP'.
  LT_FIELDCAT-SELTEXT_M   = 'IP'.
  LT_FIELDCAT-OUTPUTLEN   = 14.
  LT_FIELDCAT-COL_POS     = 6.
  APPEND LT_FIELDCAT. CLEAR  LT_FIELDCAT.

  LT_FIELDCAT-FIELDNAME   = 'HOSTNAME'.
  LT_FIELDCAT-SELTEXT_M   = 'HOSTNAME'.
  LT_FIELDCAT-OUTPUTLEN   = 12.
  LT_FIELDCAT-COL_POS     = 7.
  APPEND LT_FIELDCAT. CLEAR  LT_FIELDCAT.

  LT_FIELDCAT-FIELDNAME   = 'DESC_LOG'.
  LT_FIELDCAT-SELTEXT_M   = 'DESC_LOG'.
  LT_FIELDCAT-OUTPUTLEN   = 30.
  LT_FIELDCAT-COL_POS     = 8.
  APPEND LT_FIELDCAT. CLEAR  LT_FIELDCAT.

  LT_FIELDCAT-FIELDNAME   = 'PW_VC'.
  LT_FIELDCAT-SELTEXT_M   = 'VC'.
  LT_FIELDCAT-JUST        = 'C'.
  LT_FIELDCAT-OUTPUTLEN   = 3.
  LT_FIELDCAT-COL_POS     = 9.
  APPEND LT_FIELDCAT. CLEAR  LT_FIELDCAT.

  LT_FIELDCAT-FIELDNAME   = 'AENAM'.
  LT_FIELDCAT-SELTEXT_M   = 'NAME'.
  LT_FIELDCAT-JUST        = 'C'.
  LT_FIELDCAT-OUTPUTLEN   = 10.
  LT_FIELDCAT-COL_POS     = 10.
  APPEND LT_FIELDCAT. CLEAR  LT_FIELDCAT.

  LT_FIELDCAT-FIELDNAME   = 'AEDAT'.
  LT_FIELDCAT-SELTEXT_M   = 'DATE'.
  LT_FIELDCAT-JUST        = 'C'.
  LT_FIELDCAT-OUTPUTLEN   = 10.
  LT_FIELDCAT-COL_POS     = 11.
  APPEND LT_FIELDCAT. CLEAR  LT_FIELDCAT.

  LT_FIELDCAT-FIELDNAME   = 'AEZET'.
  LT_FIELDCAT-SELTEXT_M   = 'TIME'.
  LT_FIELDCAT-JUST        = 'C'.
  LT_FIELDCAT-OUTPUTLEN   = 10.
  LT_FIELDCAT-COL_POS     = 12.
  APPEND LT_FIELDCAT. CLEAR  LT_FIELDCAT.

  LT_FIELDCAT-FIELDNAME   = 'TAG1'.
  LT_FIELDCAT-SELTEXT_M   = 'TAG1'.
  LT_FIELDCAT-JUST        = 'C'.
  LT_FIELDCAT-OUTPUTLEN   = 5.
  LT_FIELDCAT-COL_POS     = 13.
  APPEND LT_FIELDCAT. CLEAR  LT_FIELDCAT.

  LT_FIELDCAT-FIELDNAME   = 'TAG2'.
  LT_FIELDCAT-SELTEXT_M   = 'TAG2'.
  LT_FIELDCAT-JUST        = 'C'.
  LT_FIELDCAT-OUTPUTLEN   = 5.
  LT_FIELDCAT-COL_POS     = 14.
  APPEND LT_FIELDCAT. CLEAR  LT_FIELDCAT.

  LT_FIELDCAT-FIELDNAME   = 'URL'.
  LT_FIELDCAT-SELTEXT_M   = 'URL'.
  LT_FIELDCAT-OUTPUTLEN   = 50.
  LT_FIELDCAT-COL_POS     = 15.
  APPEND LT_FIELDCAT. CLEAR  LT_FIELDCAT.

  "### ALV Layout 설정
  LT_LAYOUT-ZEBRA = 'X'.
  LT_LAYOUT-BOX_FIELDNAME = 'SEL'.
  LT_LAYOUT-BOX_TABNAME = 'P_GT_DATA'.
  LT_LAYOUT-INFO_FIELDNAME = 'LINECOLOR'.

  SAVE_CHECK = 'X'.

  "### 위에 설정된 Field Catalog 와 Layout 을 사용하여 ALV 리스트 출력 펑션 콜
  CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'
    EXPORTING
      I_CALLBACK_PROGRAM       = SY-REPID
      I_CALLBACK_USER_COMMAND  = 'USER_COMMAND'
      I_CALLBACK_PF_STATUS_SET = 'SET_PF_STATUS'
      I_GRID_TITLE             = GV_ALV_HEADER
*      I_CALLBACK_TOP_OF_PAGE   = 'TOP-OF-PAGE'
      IT_FIELDCAT              = LT_FIELDCAT[]
      IS_LAYOUT                = LT_LAYOUT
*      I_SAVE = 'A'
    TABLES
      T_OUTTAB = P_GT_DATA.

  CLEAR: GV_FLAG.

ENDFORM.
*&---------------------------------------------------------------------*
*&      Form  MENU_BAR
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM MENU_BAR .

  FUNCTXT-ICON_ID = ICON_DISPLAY_TEXT.
  FUNCTXT-QUICKINFO = 'ALL List'.
  FUNCTXT-ICON_TEXT = 'ALL List'.
  SSCRFIELDS-FUNCTXT_01 = FUNCTXT.

  FUNCTXT-ICON_ID = ICON_REPORT.
  FUNCTXT-QUICKINFO = 'Password Policy'.
  FUNCTXT-ICON_TEXT = 'Password policy'.
  SSCRFIELDS-FUNCTXT_02 = FUNCTXT.

  FUNCTXT-ICON_ID = ICON_PATIENT_SMARTCARD.
  FUNCTXT-QUICKINFO = 'Master PWD Shape'.
  FUNCTXT-ICON_TEXT = 'Master PWD Shape'.
  SSCRFIELDS-FUNCTXT_03 = FUNCTXT.

  FUNCTXT-ICON_ID = ICON_SAP_LOGON_GROUP_SSO.
  FUNCTXT-QUICKINFO = 'ABAP PWD VC'.
  FUNCTXT-ICON_TEXT = 'ABAP PWD VC'.
  SSCRFIELDS-FUNCTXT_04 = FUNCTXT.

  FUNCTXT-ICON_ID = ICON_SAP.
  FUNCTXT-QUICKINFO = 'SAP SUSER'.
  FUNCTXT-ICON_TEXT = 'SAP SUSER'.
  SSCRFIELDS-FUNCTXT_05 = FUNCTXT.

ENDFORM.
*------------------------------------------------------------------*
* FORM SET_PF_STATUS
*------------------------------------------------------------------*
FORM SET_PF_STATUS  USING PI_EXTAB    TYPE SLIS_T_EXTAB.

  DATA: BEGIN OF LT_EXCL OCCURS 0,
          MENU(20)        TYPE C.
  DATA: END OF LT_EXCL.

  REFRESH: LT_EXCL. CLEAR: LT_EXCL.

  "### F8 기본 실행 시,
  IF SY-UCOMM IS INITIAL.

    IF R_ABAP = 'X'.

      LT_EXCL-MENU = 'REMOTE_JV'.  APPEND LT_EXCL.

      SET PF-STATUS 'S100' EXCLUDING LT_EXCL.

    ELSEIF R_JAVA = 'X'.

      LT_EXCL-MENU = 'REMOTE_C'.  APPEND LT_EXCL.

      SET PF-STATUS 'S100' EXCLUDING LT_EXCL.

    ELSEIF R_OS = 'X' OR R_DB = 'X'.

      LT_EXCL-MENU = 'REMOTE_JV'.  APPEND LT_EXCL.
      LT_EXCL-MENU = 'REMOTE_C'.  APPEND LT_EXCL.

      SET PF-STATUS 'S100' EXCLUDING LT_EXCL.

    ELSE.

      SET PF-STATUS 'S100' EXCLUDING LT_EXCL.

    ENDIF.


  ELSEIF SY-UCOMM = 'FC01'.

    LT_EXCL-MENU = 'CHG_PWD'.   APPEND LT_EXCL.

    SET PF-STATUS 'S100' EXCLUDING LT_EXCL.

  ELSEIF SY-UCOMM = 'FC05'.

    LT_EXCL-MENU = 'CHG_PWD'.   APPEND LT_EXCL.
    LT_EXCL-MENU = 'SEQ_UP'.    APPEND LT_EXCL.
    LT_EXCL-MENU = 'REMOTE_JV'. APPEND LT_EXCL.
    LT_EXCL-MENU = 'REMOTE_C'.  APPEND LT_EXCL.

    SET PF-STATUS 'S100' EXCLUDING LT_EXCL.

  ELSE.

  ENDIF.

*  IF SY-UCOMM = 'FC01'.
*    SET PF-STATUS 'S200' EXCLUDING PI_EXTAB.
*  ELSE.
*    SET PF-STATUS 'S100' EXCLUDING PI_EXTAB.
*  ENDIF.

ENDFORM.
*&---------------------------------------------------------------------*
*&      Form  MENU_SELECT
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM MENU_SELECT .

  "### DATA - FC02, FC03
  DATA: LT_FIELDCAT     TYPE SLIS_T_FIELDCAT_ALV WITH HEADER LINE.
  DATA: LT_EXCL         TYPE SLIS_T_EXTAB WITH HEADER LINE.

  "### DATA - FC04
  DATA: LT_SPOPLI       LIKE TABLE OF SPOPLI WITH HEADER LINE.
  DATA: LV_ANSWER(1)    TYPE C,
        VC_SYSTEM(80)   TYPE C.

  CASE SY-UCOMM.

    "### 메뉴_01 : 테이블 전체 리스트 조회
    WHEN 'FC01'.

      REFRESH: GT_DATA. CLEAR: GT_DATA, VIEW_ALL.

      VIEW_ALL = 'X'.

      "### 조건 없이 전체 데이터 셀렉트
      SELECT * INTO CORRESPONDING FIELDS OF TABLE GT_DATA
        FROM ZBC_MASTER_PW.

      SORT GT_DATA BY SYS SID ROLE TYPE ID.

      PERFORM RESULT_VIEW TABLES GT_DATA.

    "### 메뉴_02 : 패스워드 정책 조회 (Tcode-SECPOL 정책 설정 : ZSECPOL)
    WHEN 'FC02'.

      REFRESH: LT_FIELDCAT. CLEAR: LT_FIELDCAT.

      "### ALV Field Catalog 설정 (Table 에 맞게 순서와 너비 등등을 설정)
      LT_FIELDCAT-FIELDNAME   = 'PARAM'.
      LT_FIELDCAT-SELTEXT_M   = 'PARAM'.
      LT_FIELDCAT-KEY         = 'X'.
      LT_FIELDCAT-OUTPUTLEN   = 20.
      LT_FIELDCAT-COL_POS     = 0.
      APPEND LT_FIELDCAT. CLEAR  LT_FIELDCAT.

      LT_FIELDCAT-FIELDNAME   = 'VALUE'.
      LT_FIELDCAT-SELTEXT_M   = 'VALUE'.
      LT_FIELDCAT-OUTPUTLEN   = 10.
      LT_FIELDCAT-COL_POS     = 1.
      APPEND LT_FIELDCAT. CLEAR  LT_FIELDCAT.

      "### 팝업 ALV 에서 불필요한 펑션코드 제거
      LT_EXCL-FCODE = '&NT1'. APPEND LT_EXCL.
      LT_EXCL-FCODE = '&ETA'. APPEND LT_EXCL.
      LT_EXCL-FCODE = '&OUP'. APPEND LT_EXCL.
      LT_EXCL-FCODE = '&ODN'. APPEND LT_EXCL.
      LT_EXCL-FCODE = '&ILT'. APPEND LT_EXCL.
      LT_EXCL-FCODE = '&OL0'. APPEND LT_EXCL.
      LT_EXCL-FCODE = '%SC'.  APPEND LT_EXCL.
      LT_EXCL-FCODE = '%SC+'. APPEND LT_EXCL.

      CALL FUNCTION 'REUSE_ALV_POPUP_TO_SELECT'
        EXPORTING
          I_TITLE      = 'Password Policy'
          I_TABNAME    = 'PWD_POLICY'
          I_LINEMARK_FIELDNAME = 'LINECOLOR'
          IT_FIELDCAT  = LT_FIELDCAT[]
          IT_EXCLUDING = LT_EXCL[]
        TABLES
          T_OUTTAB    = PWD_POLICY.

    "### 메뉴_03 : 마스터 패스워드 형태 확인
    WHEN 'FC03'.

      REFRESH: LT_FIELDCAT. CLEAR: LT_FIELDCAT.

      APPEND MASTER_PASSWORD_SHAPE.

      "### ALV Field Catalog 설정 (Table 에 맞게 순서와 너비 등등을 설정)
      LT_FIELDCAT-FIELDNAME   = 'PWD_SHAPE'.
      LT_FIELDCAT-SELTEXT_M   = 'Master Password Shape'.
      LT_FIELDCAT-OUTPUTLEN   = 30.
      LT_FIELDCAT-COL_POS     = 0.
      APPEND LT_FIELDCAT. CLEAR  LT_FIELDCAT.

      "### 팝업 ALV 에서 불필요한 펑션코드 제거
      LT_EXCL-FCODE = '&NT1'. APPEND LT_EXCL.
      LT_EXCL-FCODE = '&ETA'. APPEND LT_EXCL.
      LT_EXCL-FCODE = '&OUP'. APPEND LT_EXCL.
      LT_EXCL-FCODE = '&ODN'. APPEND LT_EXCL.
      LT_EXCL-FCODE = '&ILT'. APPEND LT_EXCL.
      LT_EXCL-FCODE = '&OL0'. APPEND LT_EXCL.
      LT_EXCL-FCODE = '%SC'.  APPEND LT_EXCL.
      LT_EXCL-FCODE = '%SC+'. APPEND LT_EXCL.

      CALL FUNCTION 'REUSE_ALV_POPUP_TO_SELECT'
        EXPORTING
          I_TITLE      = 'Master Password SHAPE'
          I_TABNAME    = 'MASTER_PASSWORD_SHAPE'
          IT_FIELDCAT  = LT_FIELDCAT[]
          IT_EXCLUDING = LT_EXCL[]
        TABLES
          T_OUTTAB    = MASTER_PASSWORD_SHAPE.

    "### 메뉴_04 : ABAP서버 패스워드 유효성 검사(VC)
    WHEN 'FC04'.

      REFRESH: LT_SPOPLI. CLEAR: LT_SPOPLI.

      "### 시스템 역할이 전체 선택이라면, 에러 메세지 출력 후 액션 롤백.
      IF C2_ALL = 'X'.
        MESSAGE '패스워드 유효성 검사는 전체 역할에 대해 사용 불가능합니다. 역할을 지정해주세요.' TYPE 'S'.
        REJECT.
      ENDIF.

      PERFORM SET_CONDITION.

      "### SYSTEM 이 ABAP 일 경우에만 진행 가능.
      IF R_ABAP = 'X'.

        CONCATENATE ' => Select : ' GV_ALV_HEADER INTO VC_SYSTEM SEPARATED BY SPACE.

        LT_SPOPLI-VAROPTION = '<< 패스워드 유효성 검사 진행 >>'. "# ALL
        APPEND LT_SPOPLI. CLEAR LT_SPOPLI.

        LT_SPOPLI-VAROPTION = '작업 취소'. "# DEV/QAS/PRD
        APPEND LT_SPOPLI. CLEAR LT_SPOPLI.

        CALL FUNCTION 'POPUP_TO_DECIDE_LIST'
          EXPORTING
            TITEL     = 'Password VC Check - Server Select'
            TEXTLINE1 = '해당 기능 사용 시, 유효성 검사(VC) 실패 시스템에 대해서 계정이 잠길수 있습니다.'
            TEXTLINE2 = '필요한 경우에만 사용하시고, VC 실패 시스템에 대해서 즉시 패스워드를 업데이트 해주세요.'
            TEXTLINE3 = VC_SYSTEM
          IMPORTING
            ANSWER    = LV_ANSWER
          TABLES
            T_SPOPLI  = LT_SPOPLI.

        IF SY-SUBRC = 0.

          CASE LV_ANSWER.

            WHEN '1'. PERFORM ABAP_VC_CHECK.
            WHEN '2'. REJECT.
            WHEN 'A'. REJECT.

          ENDCASE.

        ENDIF.

      ELSE.
        MESSAGE 'ABAP 시스템에 대해서만 패스워드 유효성 검사(VC)가 가능합니다.' TYPE 'S'.
        REJECT.

      ENDIF.

    "### 메뉴_05 : SAP SUSER 조회
    "### (이전 기타시스템 조회기능은 간편검색으로 변경)
    WHEN 'FC05'.

      REFRESH: GT_DATA. CLEAR: GT_DATA, VIEW_ALL.

      VIEW_ALL = 'X'.

      "### 조건 없이 전체 데이터 셀렉트
      SELECT * INTO CORRESPONDING FIELDS OF TABLE GT_DATA
        FROM ZBC_MASTER_PW
        WHERE SYS = 'SAP'.

      SORT GT_DATA BY SYS SID ROLE TYPE ID.

      PERFORM RESULT_VIEW TABLES GT_DATA.


  ENDCASE.

ENDFORM.

*------------------------------------------------------------------*
* FORM USER_COMMAND
*------------------------------------------------------------------*
FORM USER_COMMAND  USING PI_UCOMM    LIKE SY-UCOMM
                          PI_SELFIELD TYPE SLIS_SELFIELD.

  "### DATA - &1C1
  TYPES: TXT(2000)    TYPE C,
         TEMP_TXT     TYPE TABLE OF TXT.

  DATA: LT_TXT        TYPE TEMP_TXT WITH HEADER LINE.
  DATA: LV_RC         TYPE I.

  "### DATA - SAVE
  DATA: P_REF         TYPE REF TO CL_GUI_ALV_GRID.
  DATA: P_EDITED(1)   TYPE C.

  DATA: CPASS         TYPE BAPIPWD,
        LV_SUBRC      LIKE SY-SUBRC,
        LV_MSGTXT     TYPE STRING.

  DATA: RC_SUM(4)     TYPE N.

  "### DATA - S_CHG_PWD
  DATA: LT_FIELDS     LIKE SVAL OCCURS 0 WITH HEADER LINE.
  DATA: TEMP_COUNT(5) TYPE N.

  "### DATA - REMOTE_C
  DATA: RFC_ERR_TXT   LIKE RFCDES-RFCOPTIONS.

  "### DATA - REMOTE_JV
  DATA: URL_GET_PARAM TYPE STRING.

  "### DATA - SEQ_UP
  DATA: SEQ_POS(2)    TYPE N,
        SEQ_VAL(1)    TYPE N,
        TMP_POS(2)    TYPE N,
        TMP_LEN(2)    TYPE N,
        NUM_CHK(4)    TYPE C,
        SEQ_PASS(20)  TYPE C,
        TMP_PASS1(20) TYPE C,
        TMP_PASS2(20) TYPE C.

  "### DATA - ADD_SYSTEM
  DATA: IT_FIELDS LIKE SVAL OCCURS 0 WITH HEADER LINE.

  "### ALV 전체 행에 대해서 라인컬러 초기화
*  LOOP AT GT_DATA.
*    GT_DATA-LINECOLOR = ''. MODIFY GT_DATA.
*  ENDLOOP.

  CASE PI_UCOMM.

    "### UserCommand_Double Click
    WHEN '&IC1'.        " SAP standard code for double-clicking

      REFRESH: LT_TXT. CLEAR: LT_TXT, LV_RC.

      "### 유저가 더블클릭한 필드가 ID 또는 PASSWORD 라면, 해당 값을 사용자 클립보드로 복사
      IF PI_SELFIELD-FIELDNAME = 'ID' OR PI_SELFIELD-FIELDNAME = 'PASSWORD'.

        READ TABLE GT_DATA  INDEX PI_SELFIELD-TABINDEX.
        LT_TXT = GT_DATA-PASSWORD. APPEND LT_TXT.

        CALL METHOD CL_GUI_FRONTEND_SERVICES=>CLIPBOARD_EXPORT
          IMPORTING
            DATA = LT_TXT[]
          CHANGING
            RC   = LV_RC
          EXCEPTIONS
            CNTL_ERROR           = 1
            ERROR_NO_GUI         = 2
            NOT_SUPPORTED_BY_GUI = 3
            OTHERS               = 4.

        MESSAGE 'Copy' TYPE 'S'.

      ENDIF.

    "### UserCommand_BACK/EXIT/CANC
    WHEN 'BACK1' OR 'EXIT' OR 'CANC'.

      "### 수정 모드에서 화면을 빠져 나갈시,
      IF GV_FLAG = 'E'.

        "### 락 오브젝트 강제 해제
        PERFORM DEQUEUE_OBJECT.

        "### 세이브가 안된 데이터에 대해서, 기존 데이터(TEMP_DATA)로 롤백
        GT_DATA[] = TEMP_DATA[].

      ENDIF.

      "### BACK, EXIT, CANC 를 할때, 저장 여부 확인.
      IF SAVE_CHECK IS INITIAL.

        CLEAR: POPUP_RET.

        PERFORM ASK_SAVE_CHECK.
        IF SY-SUBRC = 0 AND POPUP_RET = 2.
          REJECT.
        ENDIF.

      ENDIF.

      CLEAR: SAVE_CHECK.
      LEAVE TO SCREEN 0.

    "### UserCommand_SAVE
    WHEN 'SAVE'.

      CLEAR: P_REF, CPASS, LV_SUBRC, LV_MSGTXT.

      "### ALV 상에서 변경된 값을 확인하여 리프레시
      CALL FUNCTION 'GET_GLOBALS_FROM_SLVC_FULLSCR'
        IMPORTING
          E_GRID = P_REF.

      CALL METHOD P_REF->CHECK_CHANGED_DATA
        IMPORTING
          E_VALID = P_EDITED.

      "### 현재 조회모드(GV_FLAG)
      "### = E : 패스워드 대량수정모드
      "### = S : 패스워드 싱글수정모드
      "### = U : 패스워드 시퀸셜업모드
      IF GV_FLAG = 'E' OR GV_FLAG = 'S' OR GV_FLAG = 'U'.

        "### ALV 전체 행에 대해서 라인컬러 초기화
        LOOP AT GT_DATA.
          GT_DATA-LINECOLOR = ''. MODIFY GT_DATA.
        ENDLOOP.

        "### 조회 리스트 전체 값에 대해서, Password 정책 검사
        LOOP AT GT_DATA.


          "### 패스워드가 변경된 행을 찾는 로직
          "### 변경 전, 원본 데이터인 TEMP_DATA 와, 변경된 현재 테이블 GT_DATA 의 같은 인덱스를 읽어와서 PASSWORD 가 불일치 할 경우, 변경된 행.
          READ TABLE TEMP_DATA INDEX SY-TABIX.
          IF SY-SUBRC = 0 AND ( TEMP_DATA-PASSWORD NE GT_DATA-PASSWORD ).

            "### 변경된 패스워드에 대해서, Password 정책 검사
            "### => 시스템 TAG1 이  ETC 인 기타 시스템에 대해서는 패스워드 정책 검사를 적용하지 않고, 패스 처리.
            IF GT_DATA-TAG1 = 'ETC'.
              LV_SUBRC = 0.

            ELSE.
              CPASS = GT_DATA-PASSWORD.
              CALL FUNCTION 'PASSWORD_FORMAL_CHECK'
                EXPORTING
                  PASSWORD = CPASS
                  SECURITY_POLICY = 'BC_MASTER'
                IMPORTING
                  RC       = LV_SUBRC
                  MSGTEXT  = LV_MSGTXT.

            ENDIF.

            RC_SUM = RC_SUM + LV_SUBRC.

            "### Password 정책 검사 성공 시,
            IF LV_SUBRC = 0.

              GT_DATA-AENAM = SY-UNAME.
              GT_DATA-AEDAT = SY-DATUM.
              GT_DATA-AEZET = SY-UZEIT.
              MODIFY GT_DATA.

            "### Password 정책 검사 실패 시,
            ELSE.
              CLEAR: CPASS.
              "### 패스워드 정책 검사 실패 항목에 대해서, 빨간색 하이라이트 표시
              GT_DATA-LINECOLOR = 'C600'. MODIFY GT_DATA.
              "### 패스워드 정책 검사 실패 사유 메세지 표시
              MESSAGE LV_MSGTXT TYPE 'S'.
*              REJECT.
            ENDIF.

          ENDIF.

        ENDLOOP.

        "### Password 정책 검사를 통과 했다면, 변경된 데이터를 데이블로 저장
        IF RC_SUM = 0.

          SAVE_CHECK = 'X'.

          "### 데이터 저장 완료 후, 원본 임시 보관 테이블 TEMP_DATA 를 저장된 데이터로 업데이트
          TEMP_DATA[] = GT_DATA[].

          "### 데이터 저장 완료 후, 조회 오브젝트 락 해제
          PERFORM DEQUEUE_OBJECT.

          PERFORM SAVE_DATA.

          CLEAR: GV_FLAG.

        ENDIF.

      ENDIF.

    "### UserCommand_CHG_PWD : 패스워드 대량수정모드
    WHEN 'CHG_PWD'.

      "### 전체리스트 조회에서는 대량수정모드를 사용할수 없도록 제한
      IF VIEW_ALL = 'X'.
        CLEAR: VIEW_ALL.
        MESSAGE '전체 리스트 조회모드의 대량 패스워드 변경은 SM30 티코드를 사용해주세요.' TYPE 'S'.
        REJECT.
      ENDIF.

      "### 해당 버튼 토글 설정, 현재 대량수정모드가 아니라면 대량수정모드로 변경.
      IF GV_FLAG IS INITIAL.

        REFRESH: TEMP_DATA. CLEAR: TEMP_DATA.

        "### 대량수정모드 시, 수정 롤백을 위한 임시 테이블. GT_DATA 그대로 TEMP_DATA로 카피.
        TEMP_DATA[] = GT_DATA[].

        "### 조회 오브젝트 중복 수정방지를 위한 락 설정
        PERFORM ENQUEUE_OBJECT.

        GV_FLAG = 'E'.

        "### 대량수정모드로 GV_FLAG 값 전달 후, ALV 재출력
        PERFORM RESULT_VIEW TABLES GT_DATA.

      "### 대량수정모드라면, 일반조회모드로 변경
      ELSE.

        "### 일반조회모드 변경 시, 데이터 변경 여부와 관계없이 저장 여부 확인
        CLEAR: POPUP_RET.

        PERFORM ASK_SAVE_CHECK.
        IF SY-SUBRC = 0 AND POPUP_RET = 2.
          REJECT.
        ENDIF.

        CLEAR: GV_FLAG.
        SAVE_CHECK = 'X'.

        "### 수정->조회 모드 변경 시, 락 오브젝트 해제
        PERFORM DEQUEUE_OBJECT.

        "### 세이브가 안된 데이터에 대해서, 기존 데이터(TEMP_DATA)로 롤백
        GT_DATA[] = TEMP_DATA[].

        "### 일반조회모드로 GV_FLAG 값 초기화 후, ALV 재출력
        LEAVE TO SCREEN 0.
        PERFORM RESULT_VIEW TABLES GT_DATA.

      ENDIF.

    "### userCommand_S_CHG_PWD : 패스워드 단일수정기능
    WHEN 'S_CHG_PWD'.

      REFRESH: LT_FIELDS. CLEAR: LT_FIELDS, TEMP_COUNT.

      "### 선택한 행이 몇 개인지 확인하는 로직. 싱글수정기능은 행을 한 개만 선택해야 함.
      LOOP AT GT_DATA WHERE SEL = 'X'.
        TEMP_COUNT = TEMP_COUNT + 1. ENDLOOP.

      "### 선택한 행이 한개가 맞다면,
      IF TEMP_COUNT = 1.
        IF GV_FLAG <> 'E'.

          LT_FIELDS-TABNAME   = 'BAPIPWD'.
          LT_FIELDS-FIELDNAME = 'BAPIPWD'.
          LT_FIELDS-FIELDTEXT = 'Password'.
          APPEND LT_FIELDS.

          "### 팝업을 통해서, 변경할 패스워드를 입력받는다.
          CALL FUNCTION 'POPUP_GET_VALUES'
            EXPORTING
              POPUP_TITLE       = 'Change Password'
            TABLES
              FIELDS            = LT_FIELDS
            EXCEPTIONS
              ERROR_IN_FIELDS   = 1
              OTHERS            = 2.

          "### 변경할 패스워드 값을 제대로 입력받았다면,
          IF SY-SUBRC = 0 AND LT_FIELDS-VALUE IS NOT INITIAL.

            "### 단일수정모드 시, 수정 롤백을 위한 임시 테이블. GT_DATA 그대로 TEMP_DATA로 카피.
            TEMP_DATA[] = GT_DATA[].

            GV_FLAG = 'S'.
            CLEAR: SAVE_CHECK.

            "### 선택한 행에 대해서, GT_DATA-PASSWORD 값을 변경할 패스워드로 수정한 다음, MODIRY 한다.
            LOOP AT GT_DATA WHERE SEL = 'X'.

              GT_DATA-PASSWORD = LT_FIELDS-VALUE.
              GT_DATA-LINECOLOR = 'C300'.
              MODIFY GT_DATA.

            ENDLOOP.

          ENDIF.

        ELSE.
          MESSAGE '대량수정모드 사용 중에는, 해당 기능을 사용할 수 없습니다. 대량수정모드 종료 후 다시 시도해주세요.' TYPE 'S'.

        ENDIF.

      ELSE.
        MESSAGE '한 개의 행을 선택해주세요.' TYPE 'S'.
      ENDIF.

    "### UserCommnad_REMOTE_C : ABAP 시스템 원격로그인기능
    WHEN 'REMOTE_C'.

      CLEAR: RFC_ERR_TXT, TEMP_COUNT.

      "### 선택한 행이 몇 개인지 확인하는 로직. 싱글수정기능은 행을 한 개만 선택해야 함.
      LOOP AT GT_DATA WHERE SEL = 'X'.
        TEMP_COUNT = TEMP_COUNT + 1. ENDLOOP.

      "### 선택한 행이 한개가 맞다면,
      IF TEMP_COUNT = 1.

        IF GV_FLAG <> 'E'.

          "### 선택한 행의 데이터를 인터널 테이블 헤더로 읽어온다.
          READ TABLE GT_DATA  INDEX PI_SELFIELD-TABINDEX.

          "### 선택한 행의 SYSTEM 이 ABAP 이라면,
          IF GT_DATA-SYS = 'ABAP'.

            "### 원격로그인을 위한 임시 RFC 목적지(ZBC_TEMP_RFC_DEST)를 생성
            PERFORM CREATE_RFC_DEST USING 'ZBC_TEMP_RFC_DEST'
                                          GT_DATA-SID GT_DATA-TYPE GT_DATA-ID GT_DATA-PASSWORD.

            "### 임시 RFC 목적지를 사용하여, 시스템 원격로그인
            CALL FUNCTION 'SYSTEM_REMOTE_LOGIN'
              EXPORTING
                DESTINATION = 'ZBC_TEMP_RFC_DEST'
              IMPORTING
                ERROR_MESSAGE = RFC_ERR_TXT.

            "### 원격로그인 실패로 인해, ERROR 메세지가 리턴되었다면, ERROR 메세지 출력
            IF RFC_ERR_TXT IS NOT INITIAL.
              MESSAGE RFC_ERR_TXT TYPE 'S'.
            ENDIF.

            "### 원격로그인 완료 후, 임시 RFC 목적지는 삭제
            PERFORM DELETE_RFC_DEST USING 'ZBC_TEMP_RFC_DEST'.

          ELSE.
            MESSAGE 'Remote Login 기능은 ABAP 시스템만 지원됩니다.' TYPE 'S'.
          ENDIF.

        ELSE.
          MESSAGE '대량수정모드 사용 중에는, 해당 기능을 사용할 수 없습니다. 대량수정모드 종료 후 다시 시도해주세요.' TYPE 'S'.

        ENDIF.

      ELSE.
        MESSAGE '한 개의 행을 선택해주세요.' TYPE 'S'.
      ENDIF.

    "### UserCommnad_REMOTE_JV : JAVA 시스템 URL 접속기능
    WHEN 'REMOTE_JV'.

      CLEAR: URL_GET_PARAM.

      "### 선택한 행이 몇 개인지 확인하는 로직. 행을 한 개만 선택해야 함.
      LOOP AT GT_DATA WHERE SEL = 'X'.
        TEMP_COUNT = TEMP_COUNT + 1. ENDLOOP.

      "### 선택한 행이 한개가 맞다면,
      IF TEMP_COUNT = 1.

        CONCATENATE GT_DATA-URL
                    '/webdynpro/resources/sap.com/tc~lm~itsam~ui~mainframe~wd/FloorPlanApp?home=true&j_username='
                    GT_DATA-ID
                    '&j_password='
                    GT_DATA-PASSWORD INTO URL_GET_PARAM.

        CALL METHOD CL_GUI_FRONTEND_SERVICES=>EXECUTE
          EXPORTING
            APPLICATION = 'chrome.exe'
            PARAMETER  = URL_GET_PARAM.

      ELSE.

        MESSAGE '한 개의 행을 선택해주세요.' TYPE 'S'.

      ENDIF.

    "### UserCommnad_SEQ_UP : 패스워드 시퀸셜 업 모드
    WHEN 'SEQ_UP'.

      CLEAR: SEQ_POS, TMP_POS, SEQ_VAL, NUM_CHK, TMP_PASS1, TMP_PASS2.

      "### 선택한 행이 몇 개인지 확인하는 로직. 싱글수정기능은 행을 한 개만 선택해야 함.
      LOOP AT GT_DATA WHERE SEL = 'X'.
        TEMP_COUNT = TEMP_COUNT + 1. ENDLOOP.

      "### 선택한 행이 한개가 맞다면,
      IF TEMP_COUNT = 1.

        "### 대량수정모드 시에는 시퀸셜업모드 사용 불가.
        IF GV_FLAG <> 'E'.

          "### 선택한 행의 데이터를 인터널 테이블 헤더로 읽어온다.
          READ TABLE GT_DATA  INDEX PI_SELFIELD-TABINDEX.

          "### 마스터 패스워드 형태에서 시퀸셜 위치를 찾음
          SEARCH MASTER_PASSWORD_SHAPE-PWD_SHAPE FOR '_'.
          IF SY-SUBRC = 0. SEQ_POS = SY-FDPOS. ENDIF.

          "### 선택된 행의 패스워드에서 마스터패스워드 시퀸셜 위치를 찾아, 숫자가 맞는지 확인
          CALL FUNCTION 'NUMERIC_CHECK'
            EXPORTING
              STRING_IN = GT_DATA-PASSWORD+SEQ_POS(1)
            IMPORTING
              HTYPE = NUM_CHK.

          "### 시퀸셜 위치의 값이 숫자가 맞다면, 해당 위치가 시퀸셜 위치라고 인식.
          IF NUM_CHK = 'NUMC'.

            "### 해당 패스워드의 시퀸셜 위치의 시퀸셜 값을 찾는다.
            SEQ_VAL = GT_DATA-PASSWORD+SEQ_POS(1).

            "### 다만, 현재 시퀸셜 값이 9 미만 일때만, 시퀸셜 값을 증가시킨다.
            IF SEQ_VAL < 9.

              SEQ_VAL = SEQ_VAL + 1.

              "### 시퀸셜 위치 기준 마스터 패스워드 앞부분 슬라이싱
              CLEAR: TMP_POS. TMP_POS = SEQ_POS.
              TMP_PASS1 = MASTER_PASSWORD_SHAPE-PWD_SHAPE(TMP_POS).

              "### 시퀸셜 위치 기준 마스터 패스워드 뒷부분 슬라이싱
              CLEAR: TMP_POS, TMP_LEN. TMP_POS = SEQ_POS + 1.
              TMP_LEN = STRLEN( MASTER_PASSWORD_SHAPE-PWD_SHAPE ) - TMP_POS.
              TMP_PASS2 = MASTER_PASSWORD_SHAPE-PWD_SHAPE+TMP_POS(TMP_LEN).

              "### 마스터 패스워드의 스퀸셜 위치 기준 ,
              "### 앞부분 + 스퀸셜 값 + 뒷부분 조합하여, 다음 스퀸셜 값 패스워드 생성.
              CONCATENATE TMP_PASS1 SEQ_VAL TMP_PASS2 INTO SEQ_PASS.


              "### 시퀸셜업모드 시, 수정 롤백을 위한 임시 테이블. GT_DATA 그대로 TEMP_DATA로 카피.
              TEMP_DATA[] = GT_DATA[].

              GV_FLAG = 'U'.
              CLEAR: SAVE_CHECK.

              LOOP AT GT_DATA WHERE SEL = 'X'.
                GT_DATA-PASSWORD = SEQ_PASS.
                GT_DATA-LINECOLOR = 'C500'.
                MODIFY GT_DATA.
              ENDLOOP.

            "### 시퀸셜 값이 9라면, 해당 요청을 REJECT 하고, 오류 메세지를 출력
             ELSE.
               MESSAGE '시퀸셜 값이 9이므로, 더 이상 올릴수 없습니다.' TYPE 'S'.
               REJECT.
             ENDIF.

           "### 숫자가 아니라면, 해당 요청을 REJECT 하고, 오류 메세지 출력
           ELSE.
             MESSAGE '마스터 패스워드 형태의 시퀸셜 위치가 다릅니다.' TYPE 'S'.
             REJECT.
           ENDIF.

         ELSE.
           MESSAGE '대량수정모드 사용 중에는, 해당 기능을 사용할 수 없습니다. 대량수정모드 종료 후 다시 시도해주세요.' TYPE 'S'.

         ENDIF.

      ELSE.
        MESSAGE '한 개의 행을 선택해주세요.' TYPE 'S'.

      ENDIF.

    "### UserCommnad_VC_MCHG : VC 값 수동 변경
    WHEN 'VC_MCHG'.

      "### VC 값 수동 변경을 위해, 선택한 행에 대해서 변경 처리
      LOOP AT GT_DATA WHERE SEL = 'X'.

        GV_FLAG = 'V'.

        "### 만약 VC 값이 없다면 디폴트로 X 처리.
        IF GT_DATA-PW_VC IS INITIAL.
          GT_DATA-PW_VC = 'X'.

        ELSEIF GT_DATA-PW_VC = 'O'.
          GT_DATA-PW_VC = 'X'.

        ELSEIF GT_DATA-PW_VC = 'X'.
          GT_DATA-PW_VC = 'O'.

        ENDIF.

        MODIFY GT_DATA.
        PERFORM SAVE_DATA.

        CLEAR: GV_FLAG.

      ENDLOOP.

    WHEN 'ADD_SYSTEM'.

      DATA: ADD_DATA LIKE TABLE OF ZBC_MASTER_PW WITH HEADER LINE.
      DATA: LOC_DATA LIKE TABLE OF ZBC_MASTER_PW WITH HEADER LINE.
      DATA: LT_SUBRC TYPE C.

      CLEAR:   IT_FIELDS, ADD_DATA.
      REFRESH: IT_FIELDS, ADD_DATA.

      "### 신규 시스템 정보를 받아올 팝업 임시 테이블
      IT_FIELDS-TABNAME   = 'ZBC_MASTER_PW'.
      IT_FIELDS-FIELDNAME = 'SYS'.
      IT_FIELDS-FIELDTEXT = 'SYS'.
      IT_FIELDS-FIELD_OBL = 'X'.
      APPEND IT_FIELDS. CLEAR IT_FIELDS.
      IT_FIELDS-TABNAME   = 'ZBC_MASTER_PW'.
      IT_FIELDS-FIELDNAME = 'SID'.
      IT_FIELDS-FIELDTEXT = 'SID'.
      IT_FIELDS-FIELD_OBL = 'X'.
      APPEND IT_FIELDS. CLEAR IT_FIELDS.
      IT_FIELDS-TABNAME   = 'ZBC_MASTER_PW'.
      IT_FIELDS-FIELDNAME = 'ROLE'.
      IT_FIELDS-FIELDTEXT = 'ROLE'.
      IT_FIELDS-FIELD_OBL = 'X'.
      APPEND IT_FIELDS. CLEAR IT_FIELDS.
      IT_FIELDS-TABNAME   = 'ZBC_MASTER_PW'.
      IT_FIELDS-FIELDNAME = 'TYPE'.
      IT_FIELDS-FIELDTEXT = 'TYPE'.
      IT_FIELDS-FIELD_OBL = 'X'.
      APPEND IT_FIELDS. CLEAR IT_FIELDS.
      IT_FIELDS-TABNAME   = 'ZBC_MASTER_PW'.
      IT_FIELDS-FIELDNAME = 'ID'.
      IT_FIELDS-FIELDTEXT = 'ID'.
      IT_FIELDS-FIELD_OBL = 'X'.
      APPEND IT_FIELDS. CLEAR IT_FIELDS.
      IT_FIELDS-TABNAME   = 'ZBC_MASTER_PW'.
      IT_FIELDS-FIELDNAME = 'PASSWORD'.
      IT_FIELDS-FIELDTEXT = '#PASSWORD'.
      APPEND IT_FIELDS. CLEAR IT_FIELDS.
      IT_FIELDS-TABNAME   = 'ZBC_MASTER_PW'.
      IT_FIELDS-FIELDNAME = 'IP'.
      IT_FIELDS-FIELDTEXT = '#IP'.
      APPEND IT_FIELDS. CLEAR IT_FIELDS.
      IT_FIELDS-TABNAME   = 'ZBC_MASTER_PW'.
      IT_FIELDS-FIELDNAME = 'HOSTNAME'.
      IT_FIELDS-FIELDTEXT = '#HOSTNAME'.
      APPEND IT_FIELDS. CLEAR IT_FIELDS.
      IT_FIELDS-TABNAME   = 'ZBC_MASTER_PW'.
      IT_FIELDS-FIELDNAME = 'DESC_LOG'.
      IT_FIELDS-FIELDTEXT = '#DESC_LOG'.
      APPEND IT_FIELDS. CLEAR IT_FIELDS.
*      IT_FIELDS-TABNAME   = 'ZBC_MASTER_PW'.
*      IT_FIELDS-FIELDNAME = 'TAG1'.
*      IT_FIELDS-FIELDTEXT = 'TAG1'.
*      IT_FIELDS-FIELD_OBL = 'X'.
*      APPEND IT_FIELDS. CLEAR IT_FIELDS.
*      IT_FIELDS-TABNAME   = 'ZBC_MASTER_PW'.
*      IT_FIELDS-FIELDNAME = 'TAG2'.
*      IT_FIELDS-FIELDTEXT = '#TAG2'.
*      APPEND IT_FIELDS.

      CALL FUNCTION 'POPUP_GET_VALUES_USER_HELP'
        EXPORTING
          POPUP_TITLE       = 'ADD SYSTEM'
        IMPORTING
          RETURNCODE        = LT_SUBRC
        TABLES
          FIELDS            = IT_FIELDS
        EXCEPTIONS
          ERROR_IN_FIELDS   = 1
          OTHERS            = 2.

      IF LT_SUBRC IS INITIAL.

        "### 팝업으로 입력된 데이터를 필드에 맞게 정리
        READ TABLE IT_FIELDS WITH KEY FIELDNAME = 'SYS'.      ADD_DATA-SYS      = IT_FIELDS-VALUE.
        READ TABLE IT_FIELDS WITH KEY FIELDNAME = 'SID'.      ADD_DATA-SID      = IT_FIELDS-VALUE.
        READ TABLE IT_FIELDS WITH KEY FIELDNAME = 'ROLE'.     ADD_DATA-ROLE     = IT_FIELDS-VALUE.
        READ TABLE IT_FIELDS WITH KEY FIELDNAME = 'TYPE'.     ADD_DATA-TYPE     = IT_FIELDS-VALUE.
        READ TABLE IT_FIELDS WITH KEY FIELDNAME = 'ID'.       ADD_DATA-ID       = IT_FIELDS-VALUE.
        READ TABLE IT_FIELDS WITH KEY FIELDNAME = 'PASSWORD'. ADD_DATA-PASSWORD = IT_FIELDS-VALUE.
        READ TABLE IT_FIELDS WITH KEY FIELDNAME = 'IP'.       ADD_DATA-IP       = IT_FIELDS-VALUE.
        READ TABLE IT_FIELDS WITH KEY FIELDNAME = 'HOSTNAME'. ADD_DATA-HOSTNAME = IT_FIELDS-VALUE.
        READ TABLE IT_FIELDS WITH KEY FIELDNAME = 'DESC_LOG'. ADD_DATA-DESC_LOG = IT_FIELDS-VALUE.
*        READ TABLE IT_FIELDS WITH KEY FIELDNAME = 'TAG1'.     ADD_DATA-TAG1     = IT_FIELDS-VALUE.
*        READ TABLE IT_FIELDS WITH KEY FIELDNAME = 'TAG2'.     ADD_DATA-TAG2     = IT_FIELDS-VALUE.
        ADD_DATA-PW_VC = 'O'.
        ADD_DATA-AENAM = SY-UNAME.
        ADD_DATA-AEDAT = SY-DATUM.
        ADD_DATA-AEZET = SY-UZEIT.

        "### 자동 태깅 기능 추가
        PERFORM AUTO_TAGGING TABLES ADD_DATA.

        APPEND ADD_DATA.

        "### 기존 데이터와 중복값 체크를 위한, 기존 테이블 데이터 셀렉트.
        SELECT * INTO CORRESPONDING FIELDS OF TABLE LOC_DATA
          FROM ZBC_MASTER_PW
          WHERE SYS  = ADD_DATA-SYS
            AND SID  = ADD_DATA-SID
            AND ROLE = ADD_DATA-ROLE
            AND TYPE = ADD_DATA-TYPE
            AND ID   = ADD_DATA-ID.

        "### 키값으로 조회를 하는데, 셀렉트된 데이터가 없다면, 신규값이므로 데이터 모디파이
        IF SY-SUBRC <> 0.
          MODIFY ZBC_MASTER_PW FROM TABLE ADD_DATA.
          MESSAGE '입력한 시스템/유저가 정상적으로 등록되었습니다.' TYPE 'S'.
        ELSE.
          MESSAGE '입력한 시스템/유저은 기등록된 시스템/유저입니다.' TYPE 'E'.
        ENDIF.

      ENDIF.

  ENDCASE.

  "### ALV 리프레시 설정
  PI_SELFIELD-REFRESH = 'X'.
  PI_SELFIELD-COL_STABLE = 'X'.
  PI_SELFIELD-ROW_STABLE = 'X'.
*  LEAVE TO SCREEN 0.

ENDFORM.

*&---------------------------------------------------------------------*
*&      Form  SAVE_DATA
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM SAVE_DATA.

  "### 인터널 테이블의 KEY가 중복되는지 체크할 것
  "### 중복이 없다면 테이블에 KEY를 단위로 UPDATE할 것
  DATA: LT_DATA   LIKE TABLE OF  ZBC_MASTER_PW   WITH HEADER LINE.

  "### GT_DATA 를 로컬 인터널 테이블 LT_DATA 로 복사
  LOOP AT GT_DATA.
    MOVE-CORRESPONDING GT_DATA  TO  LT_DATA .
    APPEND LT_DATA.
  ENDLOOP.

  "### 중복값 제거 작업을 위한 SORT 실시
  SORT LT_DATA  BY SYS SID ROLE TYPE ID.

  "### 키값을 기준으로 중복값 제거
  DELETE ADJACENT DUPLICATES FROM LT_DATA COMPARING SYS SID ROLE TYPE ID.

  IF LINES( LT_DATA ) NE LINES( GT_DATA ) .
    MESSAGE '중복값 에러 발생' TYPE 'S'.  EXIT.
  ENDIF.

  "### 중복값이 없다면, 인터널 테이블 데이터를 테이블로 저장
  MODIFY ZBC_MASTER_PW  FROM TABLE  LT_DATA .

  IF SY-SUBRC = 0 .

    IF GV_FLAG NE 'V'.
      MESSAGE '저장 완료' TYPE 'S'.
    ENDIF.

    IF GV_FLAG = 'E'. LEAVE TO SCREEN 0. ENDIF.
  ENDIF.

ENDFORM.                    " SAVE_DATA
*&---------------------------------------------------------------------*
*&      Form  ENQUEUE_OBJECT
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM ENQUEUE_OBJECT .

  LOOP AT GT_DATA.

    CALL FUNCTION 'ENQUEUE_EZBC_MASTER_PW'
      EXPORTING
        MODE_ZBC_MASTER_PW  = 'E'
        SYS            = GV_SET_SYS
        SID            = GV_SET_SID
      EXCEPTIONS
        FOREIGN_LOCK   = 1
        SYSTEM_FAILURE = 2.

    IF SY-SUBRC <> 0.
      MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
            WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
    ENDIF.

  ENDLOOP.

ENDFORM.
*&---------------------------------------------------------------------*
*&      Form  DEQUEUE_OBJECT
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM DEQUEUE_OBJECT .

  LOOP AT GT_DATA.

    CALL FUNCTION 'DEQUEUE_EZBC_MASTER_PW'
      EXPORTING
        MODE_ZBC_MASTER_PW  = 'E'
        SYS            = GV_SET_SYS
        SID            = GV_SET_SID.

  ENDLOOP.

ENDFORM.
*&---------------------------------------------------------------------*
*&      Form  CREATE_RFC_DEST
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM CREATE_RFC_DEST  USING F_RFC_DEST_NAME
                             F_SET_SID
                             F_SET_TYPE
                             F_SET_ID
                             F_SET_PASSWORD.

  DATA: LT_DATA LIKE TABLE OF ZBC_MASTER_PW WITH HEADER LINE.

  DATA: F_SYSTEMID  LIKE RFCOPT-RFCSYSID,
        F_SERVER    LIKE RFCDISPLAY-RFCHOST,
        F_CLIENT    LIKE RFCDISPLAY-RFCCLIENT,
        F_USER      LIKE RFCDISPLAY-RFCUSER,
        F_PASSWORD  LIKE RFCDISPLAY-RFCAUTH,
        F_ACTION    LIKE RFCDISPLAY-RFCTRACE.

  "### Remote Login 서버 IP주소 검색
  SELECT * INTO CORRESPONDING FIELDS OF TABLE LT_DATA
    FROM ZBC_MASTER_PW
    WHERE SYS = 'OS'
      AND SID = F_SET_SID.

  READ TABLE LT_DATA  INDEX 1.

  F_SYSTEMID = F_SET_SID.
  F_SERVER   = LT_DATA-IP.
  F_CLIENT   = F_SET_TYPE.
  F_USER     = F_SET_ID.
  F_PASSWORD = F_SET_PASSWORD.
  F_ACTION   = 'I'.

  CALL FUNCTION 'RFC_MODIFY_R3_DESTINATION'
    EXPORTING
      DESTINATION     = F_RFC_DEST_NAME
      ACTION          = F_ACTION
      AUTHORITY_CHECK = 'X'
      SYSTEMID        = F_SYSTEMID
      SYSTEMNR        = '00'
      SERVER          = F_SERVER
      CLIENT          = F_CLIENT
      USER            = F_USER
      PASSWORD        = F_PASSWORD
      DESCRIPTION     = 'TEMP RFC Destination By.ZBC_MASTER_PASSWORD'
    EXCEPTIONS
      AUTHORITY_NOT_AVAILABLE = 1
      DESTINATION_ALREADY_EXIST = 2
      DESTINATION_NOT_EXIST = 3
      DESTINATION_ENQUEUE_REJECT = 4
      INFORMATION_FAILURE = 5
      TRFC_ENTRY_INVALID = 6
      INTERNAL_FAILURE = 7
      SNC_INFORMATION_FAILURE = 8
      SNC_INTERNAL_FAILURE = 9
      DESTINATION_IS_LOCKED = 10
      OTHERS = 11.

  IF SY-SUBRC <> 0.

    IF SY-SUBRC = 2.

      PERFORM DELETE_RFC_DEST USING F_RFC_DEST_NAME.
      MESSAGE 'RFC Destinaion 중복 오류. 기존 RFC Dest 를 삭제하였으니 재시도 해주세요.' TYPE 'S'.

    ELSE.

      MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
            WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.

    ENDIF.
  ENDIF.

ENDFORM.
*&---------------------------------------------------------------------*
*&      Form  DELETE_RFC_DEST
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM DELETE_RFC_DEST  USING F_RFC_DEST_NAME.

  CALL FUNCTION 'RFC_MODIFY_R3_DESTINATION'
    EXPORTING
      DESTINATION     = F_RFC_DEST_NAME
      ACTION          = 'D'
    EXCEPTIONS
      AUTHORITY_NOT_AVAILABLE = 1
      DESTINATION_ALREADY_EXIST = 2
      DESTINATION_NOT_EXIST = 3
      DESTINATION_ENQUEUE_REJECT = 4
      INFORMATION_FAILURE = 5
      TRFC_ENTRY_INVALID = 6
      INTERNAL_FAILURE = 7
      SNC_INFORMATION_FAILURE = 8
      SNC_INTERNAL_FAILURE = 9
      DESTINATION_IS_LOCKED = 10
      OTHERS = 11.

  IF SY-SUBRC <> 0.
    MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
          WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
  ENDIF.

ENDFORM.
*&---------------------------------------------------------------------*
*&      Form  SET_PWD_POLICY
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM SET_PWD_POLICY .

  DATA: LT_SECPOL_DATA LIKE TABLE OF SEC_POLICY_RT WITH HEADER LINE.

  SELECT * INTO CORRESPONDING FIELDS OF TABLE LT_SECPOL_DATA
    FROM SEC_POLICY_RT
    WHERE NAME = 'ZSECPOL'.

  PWD_POLICY-PARAM = 'Security Policy'.
  PWD_POLICY-VALUE = 'ZSECPOL'.
  PWD_POLICY-LINECOLOR = 'C510'.
  APPEND PWD_POLICY.
  CLEAR PWD_POLICY.

  READ TABLE LT_SECPOL_DATA WITH KEY ATTRIB_KEY = 'MIN_PASSWORD_UPPERCASE'.
  PWD_POLICY-PARAM = 'UPPER_CASE'.
  PWD_POLICY-VALUE = LT_SECPOL_DATA-ATTRIB_VALUE.
  APPEND PWD_POLICY. CLEAR: PWD_POLICY.

  READ TABLE LT_SECPOL_DATA WITH KEY ATTRIB_KEY = 'MIN_PASSWORD_LOWERCASE'.
  PWD_POLICY-PARAM = 'LOWER_CASE'.
  PWD_POLICY-VALUE = LT_SECPOL_DATA-ATTRIB_VALUE.
  APPEND PWD_POLICY. CLEAR PWD_POLICY.

  READ TABLE LT_SECPOL_DATA WITH KEY ATTRIB_KEY = 'MIN_PASSWORD_SPECIALS'.
  PWD_POLICY-PARAM = 'SPECIALS'.
  PWD_POLICY-VALUE = LT_SECPOL_DATA-ATTRIB_VALUE.
  APPEND PWD_POLICY. CLEAR PWD_POLICY.

  READ TABLE LT_SECPOL_DATA WITH KEY ATTRIB_KEY = 'MIN_PASSWORD_DIGITS'.
  PWD_POLICY-PARAM = 'DIGITS'.
  PWD_POLICY-VALUE = LT_SECPOL_DATA-ATTRIB_VALUE.
  APPEND PWD_POLICY. CLEAR PWD_POLICY.

  READ TABLE LT_SECPOL_DATA WITH KEY ATTRIB_KEY = 'MIN_PASSWORD_LENGTH'.
  PWD_POLICY-PARAM = 'LENGTH'.
  PWD_POLICY-VALUE = LT_SECPOL_DATA-ATTRIB_VALUE.
  APPEND PWD_POLICY. CLEAR PWD_POLICY.

ENDFORM.

*&---------------------------------------------------------------------*
*&      Form  ABAP_VC_CHECK
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM ABAP_VC_CHECK .

  DATA: LV_SUBRC      TYPE SY-SUBRC,
        LV_COUNT1(2)  TYPE N,
        LV_COUNT2(2)  TYPE N,
        LV_TEMP_DEST  LIKE RFCDISPLAY-RFCDEST.

  PERFORM SELECT_DATA.

  LV_COUNT1 = 1.
  LV_COUNT2 = 1.

  LOOP AT GT_DATA.

    CLEAR: LV_SUBRC, LV_TEMP_DEST.

    CONCATENATE 'ZBC_VC_RFC_DEST_' LV_COUNT1 INTO LV_TEMP_DEST.

    "### 패스워드 유효성 검사 전용 RFC Destination 생성
    PERFORM CREATE_RFC_DEST USING LV_TEMP_DEST
                                  GT_DATA-SID GT_DATA-TYPE GT_DATA-ID GT_DATA-PASSWORD.

    "### 생성된 패스워드 유효성 검사 전용 RFC Desination 을 사용하여, 패스워드 유효 여부 확인
    "### 만약 해당 ID/Password 로 로그인 되지 않는 다면, LV_SUBRC 값은 2를 리턴한다.
    PERFORM RFC_SYNC_AUTH USING LV_TEMP_DEST
                          CHANGING LV_SUBRC.

    "### 패스워드 유효성 검사 결과에 따라 PW_VC 값 설정
    IF LV_SUBRC = 0.  GT_DATA-PW_VC = 'O'.
    ELSE.             GT_DATA-PW_VC = 'X'.
    ENDIF.

    MODIFY GT_DATA.

    "### LOOP 마지막이라면 LV_COUNT1 를 더 증가시키지 않고, LOOP 를 탈출
    AT LAST. EXIT. ENDAT.
    LV_COUNT1 = LV_COUNT1 + 1.

  ENDLOOP.

  "### LOOP 카운트(GT_DATA 행 갯수) 만큼 생성된 ZBC_VC_RFC_DEST_$$ 를 다시 삭제
  DO LV_COUNT1 TIMES.

    CONCATENATE 'ZBC_VC_RFC_DEST_' LV_COUNT2 INTO LV_TEMP_DEST.
    PERFORM DELETE_RFC_DEST USING LV_TEMP_DEST.

    LV_COUNT2 = LV_COUNT2 + 1.

  ENDDO.

  PERFORM SAVE_DATA.

  MESSAGE '패스워드 유효성 검사 완료' TYPE 'S'.


ENDFORM.
*&---------------------------------------------------------------------*
*&      Form  ASK_SAVE_CHECK
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM ASK_SAVE_CHECK.

  CALL FUNCTION 'POPUP_TO_CONFIRM'
    EXPORTING
      TITLEBAR                = 'Save Check'
      TEXT_QUESTION           = 'Task was not Saved. Do you want to Exit?'
      TEXT_BUTTON_1           = 'Yes'
      TEXT_BUTTON_2           = 'No'
      DEFAULT_BUTTON          = '2'
      DISPLAY_CANCEL_BUTTON   = ''
    IMPORTING
      ANSWER                  = POPUP_RET.

ENDFORM.
*&---------------------------------------------------------------------*
*&      Form  RFC_SYNC_AUTH
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM RFC_SYNC_AUTH  USING F_DEST CHANGING F_SUBRC.

  CALL FUNCTION 'RFC_PING'
    DESTINATION F_DEST
    EXCEPTIONS
      COMMUNICATION_FAILURE = 1
      SYSTEM_FAILURE        = 2.

  CALL FUNCTION 'RFCPING'
    DESTINATION F_DEST
    EXCEPTIONS
      COMMUNICATION_FAILURE = 1
      SYSTEM_FAILURE        = 2.

  F_SUBRC = SY-SUBRC.

ENDFORM.
*&---------------------------------------------------------------------*
*&      Form  DATA_CLEANING
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM DATA_CLEANING .

  DATA:LT_DATA LIKE TABLE OF GT_DATA WITH HEADER LINE.

  SELECT * INTO CORRESPONDING FIELDS OF TABLE LT_DATA
    FROM ZBC_MASTER_PW.

  "### 데이터 전체 정렬
  SORT LT_DATA BY SYS SID ROLE TYPE ID.

  "### 아래 GV_FLAG 값 V는 원래 해당 용도의 FLAG 값이 아니지만, SAVE_DATA 폼 내 동작이 필요해 차용.
  GV_FLAG ='V'.

  PERFORM SAVE_DATA.

  CLEAR: GV_FLAG.

ENDFORM.
*&---------------------------------------------------------------------*
*&      Form  AUTO_TAGGING
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*      -->P_ADD_DATA  text
*----------------------------------------------------------------------*
FORM AUTO_TAGGING  TABLES   T_DATA STRUCTURE ZBC_MASTER_PW.

  "### 1. 기본 태깅 설정
  "### SUSER TAG
  IF T_DATA-SYS = 'SAP'. T_DATA-TAG1 = 'SUSER'. ENDIF.

  "### G01 SYS1 TAG
  IF T_DATA-SID = 'SD1' OR T_DATA-SID = 'SQ1' OR T_DATA-SID = 'SP1'. T_DATA-TAG1 = 'G01'. T_DATA-TAG2 = 'SYS1'. ENDIF.
  "### G01 SYS2 TAG
  IF T_DATA-SID = 'SD2' OR T_DATA-SID = 'SQ2' OR T_DATA-SID = 'SP2'. T_DATA-TAG1 = 'G01'. T_DATA-TAG2 = 'SYS2'. ENDIF.
  "### G01 SYS3 TAG
  IF T_DATA-SID = 'SD3' OR T_DATA-SID = 'SQ3' OR T_DATA-SID = 'SP3'. T_DATA-TAG1 = 'G01'. T_DATA-TAG2 = 'SYS3'. ENDIF.
  "### G01 SYS4 TAG
  IF T_DATA-SID = 'SD4' OR T_DATA-SID = 'SP4'. T_DATA-TAG1 = 'G01'. T_DATA-TAG2 = 'SYS4'. ENDIF.
  "### G01 SYS5 TAG
  IF T_DATA-SID = 'SD5' OR T_DATA-SID = 'SP5'. T_DATA-TAG1 = 'G01'. T_DATA-TAG2 = 'SYS5'. ENDIF.
  "### G01 SYS6 TAG
  IF T_DATA-SID = 'SD6' OR T_DATA-SID = 'SP6'. T_DATA-TAG1 = 'G01'. T_DATA-TAG2 = 'SYS6'. ENDIF.

  "### SYS7 TAG
  IF T_DATA-SID CP 'S*7'. T_DATA-TAG1 = 'SYS7'. ENDIF.

  "### SYS8  TAG
  IF T_DATA-SID CP 'A*8' OR T_DATA-SID CP 'B*8' OR T_DATA-SID CP 'C*8'. T_DATA-TAG1 = 'SYS8'. ENDIF.

  "### SYS9  TAG
  IF T_DATA-SID CP 'A*9' OR T_DATA-SID CP 'B*9' OR T_DATA-SID CP 'C*9'. T_DATA-TAG1 = 'SYS9'. ENDIF.

  "### SYS10  TAG
  IF T_DATA-SID CP 'X*0' OR T_DATA-SID CP 'Y*0' OR T_DATA-SID CP 'Z*0'. T_DATA-TAG1 = 'SYS10'. ENDIF.

  "### SYS11  TAG
  IF T_DATA-SID CP 'Z*1'. T_DATA-TAG1 = 'SYS11'. ENDIF.


  "### 2. 기본 태깅 이후, ETC 추가 태깅 설정
  "### TYPE 이 TST(TEST) 인 경우 ETC
  IF T_DATA-TYPE = 'TST'. T_DATA-TAG1 = 'ETC'. CLEAR T_DATA-TAG2. ENDIF.
  "### SYS 이 WEB, WIN(Window) 인 경우 ETC
  IF T_DATA-SYS = 'WEB' OR T_DATA-SYS = 'WIN'. T_DATA-TAG1 = 'ETC'. CLEAR T_DATA-TAG2. ENDIF.


  "### 위 조건을 거쳤는데도 TAG1 값이 없을 경우, ETC 태킹
  IF T_DATA-TAG1 IS INITIAL. T_DATA-TAG1 = 'ETC'. ENDIF.

ENDFORM.




2. ABAP DIctionary

2-1. Table ZBC_MASTER_PW

필드 PASSWORD 를 제외한 나머지 필드는 전부 BuiltIn Type

필드 PASSWORD 는 Case Seneitive 설정을 위해 Data element 설정

FieldKeyInitVDTypeLenDesc

SYS X X CHAR 5 System
SID X X CHAR 3 SID
ROLE X X CHAR 3 Role
TYPE X X CHAR 10 System Type
ID X X CHAR 20 ID
PASSWORD     CHAR 20 Password (Data Element ZPASSWORD)
IP     CHAR 16 System IP
HOSTNAME     CHAR 20 System Hostname
DESC_LOG     CHAR 200 Description
PW_VC     CHAR 1 Password Vaild Check
TAG1     CHAR 20 Tag 1
TAG2     CHAR 20 Tag 2
URL     CHAR 200 JAVA URL
AENAM     CHAR 12 Change User
AEDAT     DATS 8 Change Date
AEZET     TIMS 6 Change Time

 


2-2. Field ZPASSWORD

2-2-1. Domain ZPASSWORD

Data Type : CHAR
No. Characters : 20
Output Length : 20
Lower Case : V

2-2-2. Data Element ZPASSWORD

Domain : ZPASSWORD

 


2-3. Lock Object EZBC_MASTER_PW

  • Primary Table
    -> Name : ZBC_MASTER_PW
    -> Lock Mode : Write Lock
  • Lock parameterLock paramTableField
    SYS ZBC_MASTER_PW SYS
    SID ZBC_MASTER_PW SID
    ROLE ZBC_MASTER_PW ROLE
    TYPE ZBC_MASTER_PW TYPE
    ID ZBC_MASTER_PW ID

 


2-4. GUI Status

GUI Status Name : S100

2-4-1. Application Toolbar

  • S_CHG_PWD
    -> Function Text : S_CHG_PWD
    -> Icon Name : ICON_ANNOTATION
    -> Icon Text / Info. Text : Password Change
  • CHG_PWD
    -> Function Text : CHG_PWD
    -> Icon Name : ICON_CHANGE_TEXT
    -> Icon Text / Info. Text : MASS PWD Change
  • REMOTE_C
    -> Function Text : REMOTE_C
    -> Icon Name : ICON_CONNECT
    -> Icon Text / Info. Text : Remote Login (ABAP)
  • REMOTE_JV
    -> Function Text : REMOTE_JV
    -> Icon Name : ICON_CONNECT
    -> Icon Text / Info. Text : Remote Login (JAVA)
  • SEQ_UP
    -> Function Text : SEQ_UP
    -> Icon Name : ICON_UNASSIGN
    -> Icon Text / Info. Text : Sequential UP
  • VC_MCHG
    -> Function Text : VC_MCHG
    -> Icon Name : ICON_ACTIVE_INACTIVE
    -> Icon Text / Info. Text : VC Manual Change
  • ADD_SYSTEM
    -> Function Text : ADD_SYSTEM
    -> Icon Name : ICON_INSERT_MULTIPLE_LINES
    -> Icon Text / Info. Text : ADD SYSTEM

2-4-2. Function Keys

SAVE - BACK1 - EXIT - CANC