ajaxController = $ajax_page; $this->offset = ''; $this->baseUrl = ui_get_full_url( 'index.php?sec=configuration_wizard_setup&sec2=godmode/modules/private_enterprise_numbers' ); } /** * Returns an array with all the credentials matching filter and ACL. * * @param array $fields Fields array or 'count' keyword to retrieve count. * @param array $filter Filters to be applied. * @param integer $offset Offset (pagination). * @param integer $limit Limit (pagination). * @param string $order Sort order. * @param string $sort_field Sort field. * * @return array With all results or false if error. * @throws Exception On error. */ public static function getAll( $fields, $filter=null, $offset=null, $limit=null, $order=null, $sort_field=null ) { $sql_filters = []; $order_by = ''; $pagination = ''; $count = false; if (!is_array($fields) && $fields == 'count') { $fields = ['*']; $count = true; } else if (!is_array($fields)) { error_log('[configPEN.getAll] Fields must be an array or "count".'); throw new Exception('[configPEN.getAll] Fields must be an array or "count".'); } if (is_array($filter)) { if (!empty($filter['free_search'])) { $sql_filters[] = vsprintf( ' AND (lower(`manufacturer`) like lower("%%%s%%") OR pen = "%s") ', array_fill(0, 2, $filter['free_search']) ); } if (!empty($filter['pen'])) { $sql_filters[] = sprintf( ' AND `pen` = %d', $filter['pen'] ); } } if (isset($order)) { $dir = 'asc'; if ($order == 'desc') { $dir = 'desc'; }; if (in_array( $sort_field, [ 'pen', 'manufacturer', 'description', ] ) ) { $order_by = sprintf( 'ORDER BY `%s` %s', $sort_field, $dir ); } } if (isset($limit) && $limit > 0 && isset($offset) && $offset >= 0 ) { $pagination = sprintf( ' LIMIT %d OFFSET %d ', $limit, $offset ); } $sql = sprintf( 'SELECT %s FROM `tpen` WHERE 1=1 %s %s %s', join(',', $fields), join(' ', $sql_filters), $order_by, $pagination ); if ($count) { $sql = sprintf('SELECT count(*) as n FROM ( %s ) tt', $sql); return db_get_value_sql($sql); } return db_get_all_rows_sql($sql); } /** * AJAX: Return JSON content for datatable. * * @return void */ function draw() { global $config; // Datatables offset, limit and order. $filter = get_parameter('filter', []); $start = get_parameter('start', 0); $length = get_parameter('length', $config['block_size']); $order = get_datatable_order(true); try { ob_start(); $fields = ['*']; // Retrieve data. $data = $this->getAll( // Fields. $fields, // Filter. $filter, // Offset. $start, // Limit. $length, // Order. $order['direction'], // Sort field. $order['field'] ); // Retrieve counter. $count = $this->getAll( 'count', $filter ); if ($data) { $data = array_reduce( $data, function ($carry, $item) { // Transforms array of arrays $data into an array // of objects, making a post-process of certain fields. $tmp = (object) $item; $tmp->description = io_safe_output($tmp->description); $tmp->manufacturer = io_safe_output($tmp->manufacturer); $tmp->options = ''; $tmp->options = ''; $tmp->options .= html_print_image( 'images/operation.png', true, [ 'title' => __('Show'), 'class' => 'invert_filter', ] ); $tmp->options .= ''; $tmp->options .= ''; $tmp->options .= html_print_image( 'images/cross.png', true, [ 'title' => __('Delete'), 'class' => 'invert_filter', ] ); $tmp->options .= ''; $carry[] = $tmp; return $carry; } ); } // Datatables format: RecordsTotal && recordsfiltered. echo json_encode( [ 'data' => $data, 'recordsTotal' => $count, 'recordsFiltered' => $count, ] ); // Capture output. $response = ob_get_clean(); } catch (Exception $e) { echo json_encode(['error' => $e->getMessage()]); exit; } // If not valid, show error with issue. json_decode($response); if (json_last_error() == JSON_ERROR_NONE) { // If valid dump. echo $response; } else { echo json_encode( ['error' => $response] ); } exit; } /** * Run main page. * * @return void */ public function run() { // Require specific CSS and JS. ui_require_css_file('wizard'); ui_require_css_file('discovery'); ui_require_css_file('pen'); // Header section. // Breadcrums. $this->setBreadcrum([]); $this->prepareBreadcrum( [ [ 'link' => '', 'label' => __('Configuration'), 'selected' => false, ], [ 'link' => '', 'label' => __('Templates'), 'selected' => false, ], [ 'link' => $this->baseUrl, 'label' => __('Private Enterprise Numbers'), 'selected' => true, ], ], true ); ui_print_page_header( __('Private Enterprise Numbers'), '', false, '', true, '', false, '', GENERIC_SIZE_TEXT, '', $this->printHeader(true) ); // Definition for AJAX. html_print_input_hidden( 'ajax_file', ui_get_full_url('ajax.php', false, false, false) ); // Ajax page (hidden). html_print_input_hidden( 'ajax_page', $this->ajaxController ); // Allow message area. html_print_div(['id' => 'message_show_area']); // Prints the main table. html_print_div( [ 'id' => 'main_table_area', 'content' => $this->createMainTable(), ] ); } /** * Load modal information for PEN management. * * Ajax. Direct HTML. * * @return void */ public function loadModal() { $values = []; $id = (int) get_parameter('pen', 0); if ($id > 0) { $values = $this->getAll( // Fields. ['*'], // Filter. ['pen' => $id] ); if (is_array($values)) { $values = $values[0]; } } $form = [ 'action' => '#', 'id' => 'modal_form', 'onsubmit' => 'return false;', 'class' => '', ]; $inputs = []; $arguments = [ 'name' => 'pen', 'type' => 'number', 'value' => $values['pen'], 'required' => true, 'return' => true, 'size' => 50, ]; if ((bool) $values['pen']) { $arguments['disabled'] = true; } $inputs[] = [ 'label' => __('PEN'), 'class' => 'flex-row', 'id' => 'div-pen', 'arguments' => $arguments, ]; $inputs[] = [ 'label' => __('Manufacturer'), 'class' => 'flex-row', 'arguments' => [ 'name' => 'manufacturer', 'id' => 'manufacturer', 'type' => 'text', 'required' => true, 'value' => io_safe_output($values['manufacturer']), 'return' => true, ], ]; $inputs[] = [ 'label' => __('Description'), 'class' => 'flex-row', 'arguments' => [ 'name' => 'description', 'id' => 'description', 'type' => 'textarea', 'value' => io_safe_output($values['description']), 'return' => true, 'rows' => 50, 'columns' => 30, ], ]; echo '
'; echo parent::printForm( [ 'form' => $form, 'inputs' => $inputs, ], true ); echo '
'; } /** * Delete a manufacturer register from db. * * @return void */ public function delete() { $pen = get_parameter('pen', 0); if (empty($pen)) { echo json_encode(['error' => __('PEN is required')]); } else { if (db_process_sql_delete('tpen', ['pen' => $pen]) !== false) { echo json_encode(['result' => __('Successfully deleted')]); } else { global $config; echo json_encode(['error' => $config['dbconnection']->error]); } } } /** * Add or update a manufacturer to private enterprise numbers. * * @return void */ public function add() { $pen = get_parameter('pen', 0); $manufacturer = io_safe_input(strip_tags(io_safe_output((string) get_parameter('manufacturer')))); $description = io_safe_input(strip_tags(io_safe_output((string) get_parameter('description')))); $is_new = (bool) get_parameter('is_new', false); if (empty($pen)) { $error = __('PEN is required.'); } if (empty($manufacturer)) { $error = __('Manufacturer is required'); } if (!empty($error)) { echo json_encode( ['error' => $error] ); } // Add if not exists. $current = $this->getAll(['pen'], ['pen' => $pen]); if ($current === false) { // New. if ($is_new === false) { echo json_encode( [ 'error' => __('This PEN definition does not exist'), ] ); exit; } $rs = db_process_sql_insert( 'tpen', [ 'pen' => $pen, 'manufacturer' => $manufacturer, 'description' => $description, ] ); $str = __('created'); } else { // Update. if ($is_new === true) { echo json_encode( [ 'error' => __('This PEN definition already exists'), ] ); exit; } $rs = db_process_sql_update( 'tpen', [ 'manufacturer' => $manufacturer, 'description' => $description, ], ['pen' => $pen] ); $str = __('updated'); } if ($rs === false) { global $config; echo json_encode(['error' => $config['dbconnection']->error]); } else { echo json_encode(['result' => __('Succesfully %s', $str)]); } } /** * Create the main table with the PENs info * * @return string Return entire the table */ public function createMainTable() { global $config; $output = ''; // Datatables list. try { $columns = [ 'pen', 'manufacturer', 'description', 'options', ]; $column_names = [ __('PEN'), __('Manufacturer'), __('Description'), [ 'text' => __('Options'), 'class' => 'table_action_buttons', ], ]; $this->tableId = 'keystore'; // Load datatables user interface. $output .= ui_print_datatable( [ 'id' => $this->tableId, 'return' => true, 'class' => 'info_table', 'style' => 'width: 100%', 'columns' => $columns, 'column_names' => $column_names, 'ajax_url' => $this->ajaxController, 'ajax_data' => ['method' => 'draw'], 'no_sortable_columns' => [-1], 'order' => [ 'field' => 'pen', 'direction' => 'asc', ], 'search_button_class' => 'sub filter float-right', 'form' => [ 'inputs' => [ [ 'label' => __('Free search'), 'type' => 'text', 'class' => 'mw250px', 'id' => 'free_search', 'name' => 'free_search', ], ], ], ] ); } catch (Exception $e) { echo $e->getMessage(); } // Auxiliar div. $output .= ''; $output .= ''; $output .= ''; // Create button. $output .= parent::printInput( [ 'type' => 'submit', 'name' => 'create', 'label' => __('Register manufacturer'), 'attributes' => 'class="sub next"', 'return' => true, ] ); ob_start(); ?>