1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
|
<?php /* vim: set expandtab sw=4 ts=4 sts=4: */ /** * Handles the IPv4/IPv6 to binary transformation for text plain * * @package PhpMyAdmin-Transformations * @subpackage IPToBinary */ namespace PhpMyAdmin\Plugins\Transformations\Input;
use PhpMyAdmin\Plugins\IOTransformationsPlugin;
/** * Handles the IPv4/IPv6 to binary transformation for text plain * * @package PhpMyAdmin-Transformations * @subpackage IPToBinary */ // @codingStandardsIgnoreLine class Text_Plain_Iptobinary extends IOTransformationsPlugin { /** * Gets the transformation description of the plugin * * @return string */ public static function getInfo() { return __( 'Converts an Internet network address in (IPv4/IPv6) format to binary' ); }
/** * Does the actual work of each specific transformations plugin. * * @param string $buffer text to be transformed. a binary string containing * an IP address, as returned from MySQL's INET6_ATON * function * @param array $options transformation options * @param string $meta meta information * * @return string IP address */ public function applyTransformation($buffer, array $options = array(), $meta = '') { $val = @inet_pton($buffer); if ($val !== false) { return '0x' . bin2hex($val); }
return $buffer; }
/** * Returns the html for input field to override default textarea. * Note: Return empty string if default textarea is required. * * @param array $column column details * @param int $row_id row number * @param string $column_name_appendix the name attribute * @param array $options transformation options * @param string $value Current field value * @param string $text_dir text direction * @param int $tabindex tab index * @param int $tabindex_for_value offset for the values tabindex * @param int $idindex id index * * @return string the html for input field */ public function getInputHtml( array $column, $row_id, $column_name_appendix, array $options, $value, $text_dir, $tabindex, $tabindex_for_value, $idindex ) { $html = ''; $val = ''; if (!empty($value)) { $length = strlen($value); if ($length == 4 || $length == 16) { $ip = @inet_ntop(pack('A' . $length, $value)); if ($ip !== false) { $val = $ip; } } $html = '<input type="hidden" name="fields_prev' . $column_name_appendix . '" value="' . htmlspecialchars($val) . '"/>'; } $class = 'transform_IPToBin'; $html .= '<input type="text" name="fields' . $column_name_appendix . '"' . ' value="' . htmlspecialchars($val) . '"' . ' size="40"' . ' dir="' . $text_dir . '"' . ' class="' . $class . '"' . ' id="field_' . ($idindex) . '_3"' . ' tabindex="' . ($tabindex + $tabindex_for_value) . '" />';
return $html; }
/* ~~~~~~~~~~~~~~~~~~~~ Getters and Setters ~~~~~~~~~~~~~~~~~~~~ */
/** * Gets the transformation name of the plugin * * @return string */ public static function getName() { return "IPv4/IPv6 To Binary"; }
/** * Gets the plugin`s MIME type * * @return string */ public static function getMIMEType() { return "Text"; }
/** * Gets the plugin`s MIME subtype * * @return string */ public static function getMIMESubtype() { return "Plain"; } }
|