Linux webserver 6.8.0-49-generic #49~22.04.1-Ubuntu SMP PREEMPT_DYNAMIC Wed Nov 6 17:42:15 UTC 2 x86_64
Apache/2.4.52 (Ubuntu)
Server IP : 192.168.1.1 & Your IP : 3.148.202.164
Domains :
Cant Read [ /etc/named.conf ]
User : www-data
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
usr /
share /
phpmyadmin /
templates /
table /
structure /
Delete
Unzip
Name
Size
Permission
Date
Action
display_partitions.twig
9.95
KB
-rw-r--r--
2021-06-04 04:20
display_structure.twig
27.03
KB
-rw-r--r--
2021-06-04 04:20
display_table_stats.twig
7.41
KB
-rw-r--r--
2021-06-04 04:20
drop_confirm.twig
780
B
-rw-r--r--
2021-06-04 04:20
partition_definition_form.twig
542
B
-rw-r--r--
2021-06-04 04:20
primary.twig
905
B
-rw-r--r--
2021-06-04 04:20
Save
Rename
{% extends 'table/page_with_secondary_tabs.twig' %} {% block content %} <h1 class="d-none d-print-block">{{table}}</h1> <form method="post" action="{{ url('/table/structure') }}" name="fieldsForm" id="fieldsForm" class="ajax{{ hide_structure_actions ? ' HideStructureActions' }}"> {{ get_hidden_inputs(db, table) }} <input type="hidden" name="table_type" value= {%- if db_is_system_schema -%} "information_schema" {%- elseif tbl_is_view -%} "view" {%- else -%} "table" {%- endif %}> <div class="table-responsive-md"> <table id="tablestructure" class="table table-light table-striped table-hover w-auto"> {# Table header #} <thead class="thead-light"> <tr> <th class="print_ignore"></th> <th>#</th> <th>{% trans 'Name' %}</th> <th>{% trans 'Type' %}</th> <th>{% trans 'Collation' %}</th> <th>{% trans 'Attributes' %}</th> <th>{% trans 'Null' %}</th> <th>{% trans 'Default' %}</th> {% if show_column_comments -%} <th>{% trans 'Comments' %}</th> {%- endif %} <th>{% trans 'Extra' %}</th> {# @see table/structure.js, function moreOptsMenuResize() #} {% if not db_is_system_schema and not tbl_is_view %} <th colspan="{{ show_icons('ActionLinksMode') ? '8' : '9' -}} " class="action print_ignore">{% trans 'Action' %}</th> {% endif %} </tr> </thead> <tbody> {# Table body #} {% set rownum = 0 %} {% for row in fields %} {% set rownum = rownum + 1 %} {% set extracted_columnspec = extracted_columnspecs[rownum] %} {% set field_name = row['Field']|e %} {# For column comments #} {% set comments = row_comments[rownum] %} {# Underline commented fields and display a hover-title (CSS only) #} <tr> <td class="text-center print_ignore"> <input type="checkbox" class="checkall" name="selected_fld[]" value="{{ row['Field'] }}" id="checkbox_row_{{ rownum }}"> </td> <td class="right">{{ rownum }}</td> <th class="nowrap"> <label for="checkbox_row_{{ rownum }}"> {% if displayed_fields[rownum].comment is defined %} <span class="commented_column" title="{{ displayed_fields[rownum].comment }}">{{ displayed_fields[rownum].text }}</span> {% else %} {{ displayed_fields[rownum].text }} {% endif %} {{ displayed_fields[rownum].icon|raw }} </label> </th> <td{{ 'set' != extracted_columnspec['type'] and 'enum' != extracted_columnspec['type'] ? ' class="nowrap"' }}> <bdo dir="ltr" lang="en"> {{ extracted_columnspec['displayed_type']|raw }} {% if relation_commwork and relation_mimework and browse_mime and mime_map[row['Field']]['mimetype'] is defined %} <br>{% trans 'Media type:' %} {{ mime_map[row['Field']]['mimetype']|replace({'_': '/'})|lower }} {% endif %} </bdo> </td> <td> {% if row['Collation'] is not empty %} <dfn title="{{ collations[row['Collation']].description }}">{{ collations[row['Collation']].name }}</dfn> {% endif %} </td> <td class="column_attribute nowrap">{{ attributes[rownum] }}</td> <td>{{ row['Null'] == 'YES' ? 'Yes'|trans : 'No'|trans }}</td> <td class="nowrap"> {% if row['Default'] is not null %} {% if extracted_columnspec['type'] == 'bit' %} {{ row['Default']|convert_bit_default_value }} {% else %} {{ row['Default'] }} {% endif %} {% elseif row['Null'] == 'YES' %} <em>NULL</em> {% else %} <em>{% trans %}None{% context %}None for default{% endtrans %}</em> {% endif %} </td> {% if show_column_comments %} <td> {{ comments }} </td> {% endif %} <td class="nowrap">{{ row['Extra']|upper }}</td> {% if not tbl_is_view and not db_is_system_schema %} <td class="edit text-center print_ignore"> <a class="change_column_anchor ajax" href="{{ url('/table/structure/change', { 'db': db, 'table': table, 'field': row['Field'], 'change_column': 1 }) }}"> {{ get_icon('b_edit', 'Change'|trans) }} </a> </td> <td class="drop text-center print_ignore"> <a class="drop_column_anchor ajax" href="{{ url('/sql') }}" data-post="{{ get_common({ 'db': db, 'table': table, 'sql_query': 'ALTER TABLE ' ~ backquote(table) ~ ' DROP ' ~ backquote(row['Field']) ~ ';', 'dropped_column': row['Field'], 'purge': true, 'message_to_show': 'Column %s has been dropped.'|trans|format(row['Field']|e) }) }}"> {{ get_icon('b_drop', 'Drop'|trans) }} </a> </td> {% endif %} {% if not tbl_is_view and not db_is_system_schema %} {% set type = extracted_columnspec['print_type'] is not empty ? extracted_columnspec['print_type'] %} <td class="print_ignore"> <ul class="table-structure-actions resizable-menu"> {% if hide_structure_actions %} <li class="submenu shown"> <a href="#" class="tab nowrap">{{ get_icon('b_more', 'More'|trans) }}</a> <ul> {% endif %} <li class="primary nowrap"> {% if type == 'text' or type == 'blob' or tbl_storage_engine == 'ARCHIVE' or (primary and primary.hasColumn(field_name)) %} {{ get_icon('bd_primary', 'Primary'|trans) }} {% else %} <a rel="samepage" class="ajax add_key print_ignore add_primary_key_anchor" href="{{ url('/table/structure/add-key') }}" data-post="{{ get_common({ 'db': db, 'table': table, 'sql_query': 'ALTER TABLE ' ~ backquote(table) ~ (primary ? ' DROP PRIMARY KEY,') ~ ' ADD PRIMARY KEY(' ~ backquote(row['Field']) ~ ');', 'message_to_show': 'A primary key has been added on %s.'|trans|format(row['Field']|e) }) }}"> {{ get_icon('b_primary', 'Primary'|trans) }} </a> {% endif %} </li> <li class="add_unique unique nowrap"> {% if type == 'text' or type == 'blob' or tbl_storage_engine == 'ARCHIVE' or field_name in columns_with_unique_index %} {{ get_icon('bd_unique', 'Unique'|trans) }} {% else %} <a rel="samepage" class="ajax add_key print_ignore add_unique_anchor" href="{{ url('/table/structure/add-key') }}" data-post="{{ get_common({ 'db': db, 'table': table, 'sql_query': 'ALTER TABLE ' ~ backquote(table) ~ ' ADD UNIQUE(' ~ backquote(row['Field']) ~ ');', 'message_to_show': 'An index has been added on %s.'|trans|format(row['Field']|e) }) }}"> {{ get_icon('b_unique', 'Unique'|trans) }} </a> {% endif %} </li> <li class="add_index nowrap"> {% if type == 'text' or type == 'blob' or tbl_storage_engine == 'ARCHIVE' %} {{ get_icon('bd_index', 'Index'|trans) }} {% else %} <a rel="samepage" class="ajax add_key print_ignore add_index_anchor" href="{{ url('/table/structure/add-key') }}" data-post="{{ get_common({ 'db': db, 'table': table, 'sql_query': 'ALTER TABLE ' ~ backquote(table) ~ ' ADD INDEX(' ~ backquote(row['Field']) ~ ');', 'message_to_show': 'An index has been added on %s.'|trans|format(row['Field']|e) }) }}"> {{ get_icon('b_index', 'Index'|trans) }} </a> {% endif %} </li> {% set spatial_types = [ 'geometry', 'point', 'linestring', 'polygon', 'multipoint', 'multilinestring', 'multipolygon', 'geomtrycollection' ] %} <li class="spatial nowrap"> {% if type == 'text' or type == 'blob' or tbl_storage_engine == 'ARCHIVE' or (type not in spatial_types and (tbl_storage_engine == 'MYISAM' or mysql_int_version >= 50705)) %} {{ get_icon('bd_spatial', 'Spatial'|trans) }} {% else %} <a rel="samepage" class="ajax add_key print_ignore add_spatial_anchor" href="{{ url('/table/structure/add-key') }}" data-post="{{ get_common({ 'db': db, 'table': table, 'sql_query': 'ALTER TABLE ' ~ backquote(table) ~ ' ADD SPATIAL(' ~ backquote(row['Field']) ~ ');', 'message_to_show': 'An index has been added on %s.'|trans|format(row['Field']|e) }) }}"> {{ get_icon('b_spatial', 'Spatial'|trans) }} </a> {% endif %} </li> {# FULLTEXT is possible on TEXT, CHAR and VARCHAR #} <li class="fulltext nowrap"> {% if tbl_storage_engine is not empty and ( tbl_storage_engine == 'MYISAM' or tbl_storage_engine == 'ARIA' or tbl_storage_engine == 'MARIA' or (tbl_storage_engine == 'INNODB' and mysql_int_version >= 50604) ) and ('text' in type or 'char' in type) %} <a rel="samepage" class="ajax add_key add_fulltext_anchor" href="{{ url('/table/structure/add-key') }}" data-post="{{ get_common({ 'db': db, 'table': table, 'sql_query': 'ALTER TABLE ' ~ backquote(table) ~ ' ADD FULLTEXT(' ~ backquote(row['Field']) ~ ');', 'message_to_show': 'An index has been added on %s.'|trans|format(row['Field']|e) }) }}"> {{ get_icon('b_ftext', 'Fulltext'|trans) }} </a> {% else %} {{ get_icon('bd_ftext', 'Fulltext'|trans) }} {% endif %} </li> {# Distinct value action #} <li class="browse nowrap"> <a href="{{ url('/sql') }}" data-post="{{ get_common({ 'db': db, 'table': table, 'sql_query': 'SELECT COUNT(*) AS ' ~ backquote('Rows'|trans) ~ ', ' ~ backquote(row['Field']) ~ ' FROM ' ~ backquote(table) ~ ' GROUP BY ' ~ backquote(row['Field']) ~ ' ORDER BY ' ~ backquote(row['Field']), 'is_browse_distinct': true }) }}"> {{ get_icon('b_browse', 'Distinct values'|trans) }} </a> </li> {% if central_columns_work %} <li class="browse nowrap"> {% if row['Field'] in central_list %} <a href="#" class="central_columns remove_button"> {{ get_icon('centralColumns_delete', 'Remove from central columns'|trans) }} </a> {% else %} <a href="#" class="central_columns add_button"> {{ get_icon('centralColumns_add', 'Add to central columns'|trans) }} </a> {% endif %} </li> {% endif %} {% if hide_structure_actions %} </ul> </li> {% endif %} </ul> </td> {% endif %} </tr> {% endfor %} </tbody> </table> </div> <div class="print_ignore"> {% include 'select_all.twig' with { 'theme_image_path': theme_image_path, 'text_dir': text_dir, 'form_name': 'fieldsForm' } only %} <button class="btn btn-link mult_submit" type="submit" formaction="{{ url('/table/structure/browse') }}"> {{ get_icon('b_browse', 'Browse'|trans) }} </button> {% if not tbl_is_view and not db_is_system_schema %} <button class="btn btn-link mult_submit" type="submit" formaction="{{ url('/table/structure/change') }}"> {{ get_icon('b_edit', 'Change'|trans) }} </button> <button class="btn btn-link mult_submit" type="submit" formaction="{{ url('/table/structure/drop-confirm') }}"> {{ get_icon('b_drop', 'Drop'|trans) }} </button> {% if tbl_storage_engine != 'ARCHIVE' %} <button class="btn btn-link mult_submit" type="submit" formaction="{{ url('/table/structure/primary') }}"> {{ get_icon('b_primary', 'Primary'|trans) }} </button> <button class="btn btn-link mult_submit" type="submit" formaction="{{ url('/table/structure/unique') }}"> {{ get_icon('b_unique', 'Unique'|trans) }} </button> <button class="btn btn-link mult_submit" type="submit" formaction="{{ url('/table/structure/index') }}"> {{ get_icon('b_index', 'Index'|trans) }} </button> <button class="btn btn-link mult_submit" type="submit" formaction="{{ url('/table/structure/spatial') }}"> {{ get_icon('b_spatial', 'Spatial'|trans) }} </button> <button class="btn btn-link mult_submit" type="submit" formaction="{{ url('/table/structure/fulltext') }}"> {{ get_icon('b_ftext', 'Fulltext'|trans) }} </button> {% if central_columns_work %} <button class="btn btn-link mult_submit" type="submit" formaction="{{ url('/table/structure/central-columns-add') }}"> {{ get_icon('centralColumns_add', 'Add to central columns'|trans) }} </button> <button class="btn btn-link mult_submit" type="submit" formaction="{{ url('/table/structure/central-columns-remove') }}"> {{ get_icon('centralColumns_delete', 'Remove from central columns'|trans) }} </button> {% endif %} {% endif %} {% endif %} </div> </form> <hr class="print_ignore"> <div id="move_columns_dialog" class="hide" title="{% trans 'Move columns' %}"> <p>{% trans 'Move the columns by dragging them up and down.' %}</p> <form action="{{ url('/table/structure/move-columns') }}" name="move_column_form" id="move_column_form"> <div> {{ get_hidden_inputs(db, table) }} <ul></ul> </div> </form> </div> {# Work on the table #} <div id="structure-action-links"> {% if tbl_is_view and not db_is_system_schema %} {{ link_or_button( url('/view/create', {'db': db, 'table': table}), get_icon('b_edit', 'Edit view'|trans, true) ) }} {% endif %} <a href="#" id="printView">{{ get_icon('b_print', 'Print'|trans, true) }}</a> {% if not tbl_is_view and not db_is_system_schema %} {# Only display propose table structure for MySQL < 8.0 #} {% if mysql_int_version < 80000 or is_mariadb %} <a class="mr-0" href="{{ url('/sql') }}" data-post="{{ get_common({ 'db': db, 'table': table, 'sql_query': 'SELECT * FROM ' ~ backquote(table) ~ ' PROCEDURE ANALYSE()', 'session_max_rows': 'all' }) }}"> {{ get_icon( 'b_tblanalyse', 'Propose table structure'|trans, true ) }} </a> {{ show_mysql_docu('procedure_analyse') }} {% endif %} {% if is_active %} <a href="{{ url('/table/tracking', {'db': db, 'table': table}) }}"> {{ get_icon('eye', 'Track table'|trans, true) }} </a> {% endif %} <a href="#" id="move_columns_anchor"> {{ get_icon('b_move', 'Move columns'|trans, true) }} </a> <a href="{{ url('/normalization', {'db': db, 'table': table}) }}"> {{ get_icon('normalize', 'Normalize'|trans, true) }} </a> {% endif %} {% if tbl_is_view and not db_is_system_schema %} {% if is_active %} <a href="{{ url('/table/tracking', {'db': db, 'table': table}) }}"> {{ get_icon('eye', 'Track view'|trans, true) }} </a> {% endif %} {% endif %} </div> {% if not tbl_is_view and not db_is_system_schema %} <form method="post" action="{{ url('/table/add-field') }}" id="addColumns" name="addColumns"> {{ get_hidden_inputs(db, table) }} {% if show_icons('ActionLinksMode') %} {{ get_image('b_insrow', 'Add column'|trans) }} {% endif %} {% set num_fields -%} <input type="number" name="num_fields" value="1" onfocus="this.select()" min="1" required> {%- endset %} {{ 'Add %s column(s)'|trans|format(num_fields)|raw }} <input type="hidden" name="field_where" value="after"> {# I tried displaying the drop-down inside the label but with Firefox the drop-down was blinking #} <select name="after_field"> <option value="first" data-pos="first"> {% trans 'at beginning of table' %} </option> {% for one_column_name in columns_list %} <option value="{{ one_column_name }}" {{- loop.revindex0 == 0 ? ' selected="selected"' }}> {{ 'after %s'|trans|format(one_column_name) }} </option> {% endfor %} </select> <input class="btn btn-primary" type="submit" value="{% trans 'Go' %}"> </form> {% endif %} {% if not tbl_is_view and not db_is_system_schema and tbl_storage_engine != 'ARCHIVE' %} <div id="index_div" class="w-100 ajax"> <fieldset class="index_info"> <legend id="index_header"> {% trans 'Indexes' %} {{ show_mysql_docu('optimizing-database-structure') }} </legend> {% if indexes is not empty %} {{ indexes_duplicates|raw }} <div class="table-responsive jsresponsive"> <table class="table table-light table-striped table-hover table-sm w-auto" id="table_index"> <thead class="thead-light"> <tr> <th colspan="3" class="print_ignore">{% trans 'Action' %}</th> <th>{% trans 'Keyname' %}</th> <th>{% trans 'Type' %}</th> <th>{% trans 'Unique' %}</th> <th>{% trans 'Packed' %}</th> <th>{% trans 'Column' %}</th> <th>{% trans 'Cardinality' %}</th> <th>{% trans 'Collation' %}</th> <th>{% trans 'Null' %}</th> <th>{% trans 'Comment' %}</th> </tr> </thead> {% for index in indexes %} <tbody class="row_span"> {% set columns_count = index.getColumnCount() %} <tr class="noclick"> <td rowspan="{{ columns_count }}" class="edit_index print_ignore ajax"> <a class="ajax" href="{{ url('/table/indexes') }}" data-post="{{ get_common({ 'db': db, 'table': table, 'index': index.getName() }, '') }}"> {{ get_icon('b_edit', 'Edit'|trans) }} </a> </td> <td rowspan="{{ columns_count }}" class="rename_index print_ignore ajax" > <a class="ajax" href="{{ url('/table/indexes/rename') }}" data-post="{{ get_common({ 'db': db, 'table': table, 'index': index.getName() }, '') }}"> {{ get_icon('b_rename', 'Rename'|trans) }} </a> </td> <td rowspan="{{ columns_count }}" class="print_ignore"> {% if index.getName() == 'PRIMARY' %} {% set index_params = { 'sql_query': 'ALTER TABLE ' ~ backquote(table) ~ ' DROP PRIMARY KEY;', 'message_to_show': 'The primary key has been dropped.'|trans } %} {% else %} {% set index_params = { 'sql_query': 'ALTER TABLE ' ~ backquote(table) ~ ' DROP INDEX ' ~ backquote(index.getName()) ~ ';', 'message_to_show': 'Index %s has been dropped.'|trans|format(index.getName()) } %} {% endif %} <input type="hidden" class="drop_primary_key_index_msg" value="{{ index_params.sql_query|js_format(false) }}"> {{ link_or_button( url('/sql', index_params|merge({'db': db, 'table': table})), get_icon('b_drop', 'Drop'|trans), {'class': 'drop_primary_key_index_anchor ajax'} ) }} </td> <th rowspan="{{ columns_count }}">{{ index.getName() }}</th> <td rowspan="{{ columns_count }}">{{ index.getType()|default(index.getChoice()) }}</td> <td rowspan="{{ columns_count }}">{{ index.isUnique() ? 'Yes'|trans : 'No'|trans }}</td> <td rowspan="{{ columns_count }}">{{ index.isPacked()|raw }}</td> {% for column in index.getColumns() %} {% if column.getSeqInIndex() > 1 %} <tr class="noclick"> {% endif %} <td> {{ column.getName() }} {% if column.getSubPart() is not empty %} ({{ column.getSubPart() }}) {% endif %} </td> <td>{{ column.getCardinality() }}</td> <td>{{ column.getCollation() }}</td> <td>{{ column.getNull(true) }}</td> {% if column.getSeqInIndex() == 1 %} <td rowspan="{{ columns_count }}">{{ index.getComments() }}</td> {% endif %} </tr> {% endfor %} </tbody> {% endfor %} </table> </div> {% else %} <div class="no_indexes_defined">{{ 'No index defined!'|trans|notice }}</div> {% endif %} </fieldset> <fieldset class="tblFooters print_ignore text-left"> <form action="{{ url('/table/indexes') }}" method="post"> {{ get_hidden_inputs(db, table) }} <input type="hidden" name="create_index" value="1"> {% apply format('<input class="mx-2" type="number" name="added_fields" value="1" min="1" required>')|raw %} {% trans %}Create an index on %s columns{% endtrans %} {% endapply %} <input class="btn btn-primary add_index ajax" type="submit" value="{% trans 'Go' %}"> </form> </fieldset> </div> {% endif %} {# Display partition details #} {% if have_partitioning %} {# Detect partitioning #} {% if partition_names is not empty and partition_names[0] is not null %} {% set first_partition = partitions[0] %} {% set range_or_list = first_partition.getMethod() == 'RANGE' or first_partition.getMethod() == 'RANGE COLUMNS' or first_partition.getMethod() == 'LIST' or first_partition.getMethod() == 'LIST COLUMNS' %} {% set sub_partitions = first_partition.getSubPartitions() %} {% set has_sub_partitions = first_partition.hasSubPartitions() %} {% if has_sub_partitions %} {% set first_sub_partition = sub_partitions[0] %} {% endif %} <div id="partitions-2"{% if default_sliders_state != 'disabled' -%} {{- default_sliders_state == 'closed' ? ' style="display: none; overflow:auto;"' }} class="pma_auto_slider" title="{% trans 'Partitions' %}" {%- endif %}> {% include 'table/structure/display_partitions.twig' with { 'db': db, 'table': table, 'partitions': partitions, 'partition_method': first_partition.getMethod(), 'partition_expression': first_partition.getExpression(), 'has_description': first_partition.getDescription() is not empty, 'has_sub_partitions': has_sub_partitions, 'sub_partition_method': has_sub_partitions ? first_sub_partition.getMethod(), 'sub_partition_expression': has_sub_partitions ? first_sub_partition.getExpression(), 'range_or_list': range_or_list } only %} {% else %} {% include 'table/structure/display_partitions.twig' with { 'db': db, 'table': table } only %} {% endif %} </div> {% endif %} {# Displays Space usage and row statistics #} {% if show_stats %} {{ table_stats|raw }} {% endif %} <div class="clearfloat"></div> {% endblock %}