СБИС Сапер - Алгоритм работы — различия между версиями

Материал из razgovorov.ru
Перейти к: навигация, поиск
(Алгоритм проверки прав на Сбытовую организацию)
(Состав ини-файла)
Строка 105: Строка 105:
 
Элемент Проверка содержит:
 
Элемент Проверка содержит:
 
# "Название" - название проверки, например SALES_ORG;
 
# "Название" - название проверки, например SALES_ORG;
# "Тип" - содержит название проверки, например VKORG;  
+
# "Тип" - техническое имя проверки, например VKORG;  
 
# "Значение" - массив параметров для запуска проверки полномочий SAP. Каждый параметр имеет структуру:
 
# "Значение" - массив параметров для запуска проверки полномочий SAP. Каждый параметр имеет структуру:
 
## "Название" - название параметра, например ACTVT;
 
## "Название" - название параметра, например ACTVT;

Версия 08:54, 11 декабря 2017

Алгоритм проверки прав на балансовую единицу

Словарь данных

  1. /SBIS/S_AUTHORITY - структура данных о правах. Содержит таблицы:
    1. BUKRS_RE_01 - range по БЕ, для которых есть права на объект полномочий 'F_BKPF_BUK' ACTVT 01 (бухгалтерский документ: полномочия на балансовые единицы, создать).
    2. BUKRS_RE_03 - range по БЕ, для которых есть права на объект полномочий 'F_BKPF_BUK' ACTVT 03 (бухгалтерский документ: полномочия на балансовые единицы, просмотреть).
    3. VKORG_RE_01
    4. и другие
  2. /SBIS/S_FILTER_LIST_DOC - структура фильтра. Содержит поля и таблицы:
    1. GJAHR
    2. BELNR
    3. DATE_FROM
    4. DATE_TO
    5. TIME_FROM
    6. TIME_TO
    7. PAGE
    8. PAGE_SIZE
    9. RET_LIST_SIZE
    10. PARTNER_ID
    11. PARTNER_INN
    12. PARTNER_KPP
    13. ORG_ID
    14. ORG_INN
    15. ORG_KPP
    16. STATUS_NAME
    17. IS_RANGE - индикатор range/параметр
    18. BLDAT_RE
    19. KUNNR_RE
    20. BUKRS_RE
    21. STATU_RE
    22. BELNR_RE
    23. OPBEL_RE
    24. PARTN_RE
    25. VKORG_RE
    26. VTWEG_RE
    27. FKART_RE


Проверка прав на БЕ при запуске Сапера

  1. При запуске конкретного реестра Сапера выполняется метод /SBIS/CL_TREE_ACCORDION->SET_CONTENT_FILTER. Читается сохраненный фильтр, проверяются права, запускается просмотр списка.
    1. Сохраняем последний используемый реестр.
    2. /SBIS/CL_CORE->GET_AUTHORITY (es_authority). Получаем список БЕ на которые есть права.
    3. /SBIS/CL_CORE->GET_PARAM (iv_ini_name, iv_user_settings, et_settings). Получаем пользовательские настройки из БД.
    4. /SBIS/CL_TREE_ACCORDION->READ_CONTENT_FILTER (iv_parent_name, it_user_settings, is_authority, es_filter). Чтение фильтра из сохраненных настроек. Изменение фильтра, если он не заполнен, или изменились права.
    5. /SBIS/CL_CORE->CHECK_AUTHORITY (is_authority, is_filter). Проверка прав на получение данных, запрашиваемых в фильтре.
    6. /SBIS/CL_TREE_ACCORDION->VIEW_CONTENT. Вывод списка на экран в соответствии с заданным фильтром.

Проверка прав на БЕ при запуске фильтра

  1. /SBIS/CL_TREE->HANDLE_TOOLBAR_FILTER. Запускается метод-обработчик при нажатии кнопки Фильтр.
    1. Получаем из настроек реестра название ФМ для окна фильтра в переменную LV_FILTER_FM_NAME и настройки фильтра.
    2. Запуск ФМ из переменной LV_FILTER_FM_NAME для вывода окна фильтра, например /SBIS/FM_FILTER_SCREEN_302 (is_authority, ev_fcode, cs_filter). Запуск экрана, например 0302.
      1. PBO_0302. Вывод данных старого фильтра на экран.
      2. Ввод пользователем новых данных фильтра.
      3. PAI_0302. Проверка при нажатии ОК или Enter, введенных значений, в т.ч. прав на БЕ в соответствии со списком разрешенных. Вывод ошибок при их возникновении.
        1. PAI_0302_CHECK.
          1. /SBIS/CL_CORE->CHECK_AUTHORITY (is_authority, is_filter). Проверка прав на получение данных, запрашиваемых в фильтре.
    3. При нажатии ОК и отсутствии ошибок:
      1. /SBIS/CL_TREE_ACCORDION->HANDLE_SET_CONTENT_FILTER. Генерируем событие для сохранения фильтра в настройках пользователя.
      2. /SBIS/CL_TREE_ACCORDION->HANDLE_UPDATE_CONTENT. Генерируем событие для получения списка и обновления экрана в соответствии с новыми данными фильтра.


Алгоритм проверки прав на Сбытовую организацию

Словарь данных

  1. /SBIS/S_AUTHORITY - структура данных о правах. Содержит данные:
    1. BUKRS_RE - range по Балансовым единицам, для которых есть права на объект полномочий 'F_BKPF_BUK' (бухгалтерский документ: полномочия на балансовые единицы) с заданными значениями параметров;
    2. BUKRS_RE_X - индикатор, что данные в BUKRS_RE получены;
    3. VKORG_RE - range по Сбытовым организациям, для которых есть права на объект полномочий 'F_VBAK_VKO' (Торговый документ: полномочия на сбытовые организации) с заданными значениями параметров;
    4. VKORG_RE_X - индикатор, что данные в VKORG_RE получены;
    5. и т.д.
  2. /SBIS/S_FILTER_LIST_DOC - структура фильтра. Содержит данные:
    1. GJAHR
    2. BELNR
    3. DATE_FROM
    4. DATE_TO
    5. TIME_FROM
    6. TIME_TO
    7. PAGE
    8. PAGE_SIZE
    9. RET_LIST_SIZE
    10. PARTNER_ID
    11. PARTNER_INN
    12. PARTNER_KPP
    13. ORG_ID
    14. ORG_INN
    15. ORG_KPP
    16. STATUS_NAME
    17. IS_RANGE - индикатор range/параметр
    18. BLDAT_RE
    19. KUNNR_RE
    20. BUKRS_RE
    21. STATU_RE
    22. BELNR_RE
    23. OPBEL_RE
    24. PARTN_RE
    25. VKORG_RE
    26. VTWEG_RE
    27. FKART_RE


Состав ини-файла

На уровне аккордеона для требуемого реестра опционально добавляем элемент CHECK_AUTHORITY, который содержит массив элементов - требуемых проверок.

Элемент Проверка содержит:

  1. "Название" - название проверки, например SALES_ORG;
  2. "Тип" - техническое имя проверки, например VKORG;
  3. "Значение" - массив параметров для запуска проверки полномочий SAP. Каждый параметр имеет структуру:
    1. "Название" - название параметра, например ACTVT;
    2. "Значение" - значение параметра, например 03;
    3. "Версия" - комментарий, например "Операция";
  4. "Версия" - комментарий, например "Сбытовая организация";

Проверка прав на Сбытовую организацию при запуске Сапера

  1. При запуске конкретного реестра Сапера выполняется метод /SBIS/CL_TREE_ACCORDION->SET_CONTENT_FILTER. Читается сохраненный фильтр, проверяются права, запускается просмотр списка.
    1. Сохраняем последний используемый реестр.
    2. /SBIS/CL_CORE->GET_PARAM (iv_ini_name, iv_user_settings, et_settings). Получаем пользовательские настройки из БД.
    3. /SBIS/CL_TREE_ACCORDION->READ_CONTENT_FILTER (iv_parent_name, it_user_settings, is_authority, es_filter). Чтение фильтра из сохраненных настроек.
    4. /SBIS/CL_AUTHORITY->CHECK_AUTHORITY (is_authority, is_filter, iv_ini_name). Проверка прав на получение данных, запрашиваемых в фильтре.
      1. Если права некорректные - вызываем окно фильтра.
        1. Заполняем фильтр, при нажатии ОК или Enter происходит проверка прав CHECK_AUTHORITY класса CL_AUTHORITY.
        2. Если отменили фильтр, то выводим пустой список документов.
    5. /SBIS/CL_TREE_ACCORDION->VIEW_CONTENT. Вывод списка на экран в соответствии с заданным фильтром.

Проверка прав на Сбытовую организацию при запуске фильтра

  1. /SBIS/CL_TREE->HANDLE_TOOLBAR_FILTER. Запускается метод-обработчик при нажатии кнопки Фильтр.
    1. Получаем из настроек реестра название ФМ для окна фильтра в переменную LV_FILTER_FM_NAME и настройки фильтра.
    2. Запуск ФМ из переменной LV_FILTER_FM_NAME для вывода окна фильтра, например /SBIS/FM_FILTER_SCREEN_302 (is_authority, ev_fcode, cs_filter). Запуск экрана, например 0302.
      1. PBO_0302. Вывод данных старого фильтра на экран.
      2. Ввод пользователем новых данных фильтра.
      3. PAI_0302. Проверка при нажатии ОК или Enter, введенных значений, в т.ч. прав на СбОрг в соответствии со списком разрешенных. Вывод ошибок при их возникновении.
        1. PAI_0302_CHECK.
          1. /SBIS/CL_AUTHORITY->CHECK_AUTHORITY (is_authority, is_filter, iv_ini_name). Проверка прав на получение данных, запрашиваемых в фильтре.
    3. При нажатии ОК и отсутствии ошибок:
      1. /SBIS/CL_TREE_ACCORDION->HANDLE_SET_CONTENT_FILTER. Генерируем событие для сохранения фильтра в настройках пользователя.
      2. /SBIS/CL_TREE_ACCORDION->HANDLE_UPDATE_CONTENT. Генерируем событие для получения списка и обновления экрана в соответствии с новыми данными фильтра.

Алгоритм метода GET_AUTHORITY класса /SBIS/CL_AUTHORITY

Осуществляет получение списка объектов, на которые есть права у пользователя, в структуру /SBIS/S_AUTHORITY.

На входе - название проверки, которую выполняем, например VKORG.

На выходе - заполненный range с разрешенными объектами, например VKORG_RE, и заполненный индикатор, например VKORG_RE_X.

Алгоритм:

  1. Осуществляем чтение настроек по имени проверки. Получаем внутр. таблицу с параметрами для запуска проверки полномочий.
  2. Цикл по внутр. таблице параметров, заполнение временных переменных для выполнения проверки.
  3. Получаем полный список сбытовых организаций в системе во внутр. таблицу. Цикл по внутр. таблице.
  4. Для каждой сбытовой организации выполняем проверку полномочий с заданными в настройках параметрами, например V_VBAK_VKO с параметрами ACTVT=03, SPART=01, VKORG=ZUCH, VTWEG=Z1.
    1. Если проверка прошла, то добавляем запись в таблицу разрешенных объектов структуры /SBIS/S_AUTHORITY, например в VKORG_RE.
    2. Если проверка не прошла - не добавляем.
  5. Устанавливаем индикатор что данные получены, например в поле VKORG_RE_X структуры /SBIS/S_AUTHORITY.

Алгоритм метода CHECK_AUTHORITY класса /SBIS/CL_AUTHORITY

Осуществляет проверку прав на объекты из фильтра. Например на БЕ, Сбытовую организацию.

На входе - данные фильтра в виде структуры /SBIS/S_FILTER_LIST_DOC; список разрешенных объектов в виде структуры /SBIS/S_AUTHORITY; название узла настроек реестра iv_ini_name.

На выходе - исключительная ситуация с текстом ошибки, либо ее отсутствие.

Алгоритм

  1. Для заданного реестра читаем настройки по iv_ini_name и получаем внутр. таблицу LT_SETTINGS со списком активных проверок, которые необходимо выполнить, а также параметров проверки.
  2. Идем по списку проверок. Если активна конкретная проверка - выполняем метод проверки из класса /SBIS/CL_AUTHORITY, например CHECK_AUTH_VKORG. Имя запускаемого метода формируется динамически и ему передается список параметров.
    1. В случае если данные S_AUTHORITY еще не получены, запускаем метод GET_AUTHORITY и получаем данные.
    2. Выполняем проверку для конкретного объекта полномочий, например V_VBAK_VKO. Параметры проверки берем из внутр. таблицы настроек LT_SETTINGS.