Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
0.00% covered (danger)
0.00%
0 / 267
0.00% covered (danger)
0.00%
0 / 13
CRAP
0.00% covered (danger)
0.00%
0 / 4
phpbb_questionnaire_data_collector
0.00% covered (danger)
0.00%
0 / 11
0.00% covered (danger)
0.00%
0 / 5
56
0.00% covered (danger)
0.00%
0 / 1
 __construct
0.00% covered (danger)
0.00%
0 / 2
0.00% covered (danger)
0.00%
0 / 1
2
 add_data_provider
0.00% covered (danger)
0.00%
0 / 1
0.00% covered (danger)
0.00%
0 / 1
2
 get_data_raw
0.00% covered (danger)
0.00%
0 / 3
0.00% covered (danger)
0.00%
0 / 1
6
 get_data_for_form
0.00% covered (danger)
0.00%
0 / 1
0.00% covered (danger)
0.00%
0 / 1
2
 collect
0.00% covered (danger)
0.00%
0 / 4
0.00% covered (danger)
0.00%
0 / 1
6
phpbb_questionnaire_php_data_provider
0.00% covered (danger)
0.00%
0 / 21
0.00% covered (danger)
0.00%
0 / 2
12
0.00% covered (danger)
0.00%
0 / 1
 get_identifier
0.00% covered (danger)
0.00%
0 / 1
0.00% covered (danger)
0.00%
0 / 1
2
 get_data
0.00% covered (danger)
0.00%
0 / 20
0.00% covered (danger)
0.00%
0 / 1
6
phpbb_questionnaire_system_data_provider
0.00% covered (danger)
0.00%
0 / 21
0.00% covered (danger)
0.00%
0 / 3
210
0.00% covered (danger)
0.00%
0 / 1
 get_identifier
0.00% covered (danger)
0.00%
0 / 1
0.00% covered (danger)
0.00%
0 / 1
2
 get_data
0.00% covered (danger)
0.00%
0 / 8
0.00% covered (danger)
0.00%
0 / 1
2
 is_private_ip
0.00% covered (danger)
0.00%
0 / 12
0.00% covered (danger)
0.00%
0 / 1
156
phpbb_questionnaire_phpbb_data_provider
0.00% covered (danger)
0.00%
0 / 212
0.00% covered (danger)
0.00%
0 / 3
72
0.00% covered (danger)
0.00%
0 / 1
 __construct
0.00% covered (danger)
0.00%
0 / 5
0.00% covered (danger)
0.00%
0 / 1
6
 get_identifier
0.00% covered (danger)
0.00%
0 / 1
0.00% covered (danger)
0.00%
0 / 1
2
 get_data
0.00% covered (danger)
0.00%
0 / 206
0.00% covered (danger)
0.00%
0 / 1
30
1<?php
2/**
3*
4* This file is part of the phpBB Forum Software package.
5*
6* @copyright (c) phpBB Limited <https://www.phpbb.com>
7* @license GNU General Public License, version 2 (GPL-2.0)
8*
9* For full copyright and license information, please see
10* the docs/CREDITS.txt file.
11*
12*/
13
14/**
15* @ignore
16*/
17if (!defined('IN_PHPBB'))
18{
19    exit;
20}
21
22/**
23* This class collects data which is used to create some usage statistics.
24*
25* The collected data is - after authorization of the administrator - submitted
26* to a central server. For privacy reasons we try to collect only data which aren't private
27* or don't give any information which might help to identify the user.
28*
29* @author        Johannes Schlueter <johannes@php.net>
30* @copyright    (c) 2007-2008 Johannes Schlueter
31*/
32class phpbb_questionnaire_data_collector
33{
34    var $providers;
35    var $data = null;
36    var $install_id = '';
37
38    /**
39    * Constructor.
40    *
41    * @param    string $install_id
42    */
43    function __construct($install_id)
44    {
45        $this->install_id = $install_id;
46        $this->providers = array();
47    }
48
49    function add_data_provider($provider)
50    {
51        $this->providers[] = $provider;
52    }
53
54    /**
55    * Get data as an array.
56    *
57    * @return    array    All Data
58    */
59    function get_data_raw()
60    {
61        if (!$this->data)
62        {
63            $this->collect();
64        }
65
66        return $this->data;
67    }
68
69    function get_data_for_form()
70    {
71        return base64_encode(json_encode($this->get_data_raw()));
72    }
73
74    /**
75    * Collect info into the data property.
76    *
77    * @return    void
78    */
79    function collect()
80    {
81        foreach (array_keys($this->providers) as $key)
82        {
83            $provider = $this->providers[$key];
84            $this->data[$provider->get_identifier()] = $provider->get_data();
85        }
86        $this->data['install_id'] = $this->install_id;
87    }
88}
89
90/** interface: get_indentifier(), get_data() */
91
92/**
93* Questionnaire PHP data provider
94*/
95class phpbb_questionnaire_php_data_provider
96{
97    function get_identifier()
98    {
99        return 'PHP';
100    }
101
102    /**
103    * Get data about the PHP runtime setup.
104    *
105    * @return    array
106    */
107    function get_data()
108    {
109        return array(
110            'version'                        => PHP_VERSION,
111            'sapi'                            => PHP_SAPI,
112            'int_size'                        => defined('PHP_INT_SIZE') ? PHP_INT_SIZE : '',
113            'open_basedir'                    => (int) @ini_get('open_basedir'),
114            'memory_limit'                    => @ini_get('memory_limit'),
115            'allow_url_fopen'                => (int) @ini_get('allow_url_fopen'),
116            'allow_url_include'                => (int) @ini_get('allow_url_include'),
117            'file_uploads'                    => (int) @ini_get('file_uploads'),
118            'upload_max_filesize'            => @ini_get('upload_max_filesize'),
119            'post_max_size'                    => @ini_get('post_max_size'),
120            'disable_functions'                => @ini_get('disable_functions'),
121            'disable_classes'                => @ini_get('disable_classes'),
122            'enable_dl'                        => (int) @ini_get('enable_dl'),
123            'filter.default'                => @ini_get('filter.default'),
124            'zend.ze1_compatibility_mode'    => (int) @ini_get('zend.ze1_compatibility_mode'),
125            'unicode.semantics'                => (int) @ini_get('unicode.semantics'),
126            'zend_thread_safty'                => (int) function_exists('zend_thread_id'),
127            'extensions'                    => implode(',', get_loaded_extensions()),
128        );
129    }
130}
131
132/**
133* Questionnaire System data provider
134*/
135class phpbb_questionnaire_system_data_provider
136{
137    function get_identifier()
138    {
139        return 'System';
140    }
141
142    /**
143    * Get data about the general system information, like OS or IP (shortened).
144    *
145    * @return    array
146    */
147    function get_data()
148    {
149        global $request;
150
151        // Start discovering the IPV4 server address, if available
152        // Try apache, IIS, fall back to 0.0.0.0
153        $server_address = html_entity_decode($request->server('SERVER_ADDR', $request->server('LOCAL_ADDR', '0.0.0.0')), ENT_COMPAT);
154
155        return array(
156            'os'    => PHP_OS,
157            'httpd'    => html_entity_decode($request->server('SERVER_SOFTWARE'), ENT_COMPAT),
158            // we don't want the real IP address (for privacy policy reasons) but only
159            // a network address to see whether your installation is running on a private or public network.
160            'private_ip'    => $this->is_private_ip($server_address),
161            'ipv6'            => strpos($server_address, ':') !== false,
162        );
163    }
164
165    /**
166    * Checks whether the given IP is in a private network.
167    *
168    * @param    string    $ip    IP in v4 dot-decimal or v6 hex format
169    * @return    bool        true if the IP is from a private network, else false
170    */
171    function is_private_ip($ip)
172    {
173        // IPv4
174        if (strpos($ip, ':') === false)
175        {
176            $ip_address_ary = explode('.', $ip);
177
178            // build ip
179            if (!isset($ip_address_ary[0]) || !isset($ip_address_ary[1]))
180            {
181                $ip_address_ary = explode('.', '0.0.0.0');
182            }
183
184            // IANA reserved addresses for private networks (RFC 1918) are:
185            // - 10.0.0.0/8
186            // - 172.16.0.0/12
187            // - 192.168.0.0/16
188            if ($ip_address_ary[0] == '10' ||
189                ($ip_address_ary[0] == '172' && intval($ip_address_ary[1]) > 15 && intval($ip_address_ary[1]) < 32) ||
190                ($ip_address_ary[0] == '192' && $ip_address_ary[1] == '168'))
191            {
192                return true;
193            }
194        }
195        // IPv6
196        else
197        {
198            // unique local unicast
199            $prefix = substr($ip, 0, 2);
200            if ($prefix == 'fc' || $prefix == 'fd')
201            {
202                return true;
203            }
204        }
205
206        return false;
207    }
208}
209
210/**
211* Questionnaire phpBB data provider
212*/
213class phpbb_questionnaire_phpbb_data_provider
214{
215    var $config;
216    var $unique_id;
217
218    /**
219    * Constructor.
220    *
221    * @param    array    $config
222    */
223    function __construct($config)
224    {
225        // generate a unique id if necessary
226        if (empty($config['questionnaire_unique_id']))
227        {
228            $this->unique_id = unique_id();
229            $config->set('questionnaire_unique_id', $this->unique_id);
230        }
231        else
232        {
233            $this->unique_id = $config['questionnaire_unique_id'];
234        }
235
236        $this->config = $config;
237    }
238
239    /**
240    * Returns a string identifier for this data provider
241    *
242    * @return    string    "phpBB"
243    */
244    function get_identifier()
245    {
246        return 'phpBB';
247    }
248
249    /**
250    * Get data about this phpBB installation.
251    *
252    * @return    array    Relevant anonymous config options
253    */
254    function get_data()
255    {
256        global $phpbb_config_php_file;
257
258        extract($phpbb_config_php_file->get_all());
259        unset($dbhost, $dbport, $dbname, $dbuser, $dbpasswd); // Just a precaution
260
261        $dbms = \phpbb\config_php_file::convert_30_dbms_to_31($dbms);
262
263        // Only send certain config vars
264        $config_vars = array(
265            'active_sessions' => true,
266            'allow_attachments' => true,
267            'allow_autologin' => true,
268            'allow_avatar' => true,
269            'allow_avatar_local' => true,
270            'allow_avatar_upload' => true,
271            'allow_bbcode' => true,
272            'allow_birthdays' => true,
273            'allow_bookmarks' => true,
274            'allow_emailreuse' => true,
275            'allow_forum_notify' => true,
276            'allow_mass_pm' => true,
277            'allow_name_chars' => true,
278            'allow_namechange' => true,
279            'allow_nocensors' => true,
280            'allow_pm_attach' => true,
281            'allow_pm_report' => true,
282            'allow_post_links' => true,
283            'allow_privmsg' => true,
284            'allow_quick_reply' => true,
285            'allow_sig' => true,
286            'allow_sig_bbcode' => true,
287            'allow_sig_img' => true,
288            'allow_sig_links' => true,
289            'allow_sig_pm' => true,
290            'allow_sig_smilies' => true,
291            'allow_smilies' => true,
292            'allow_topic_notify' => true,
293            'attachment_quota' => true,
294            'auth_bbcode_pm' => true,
295            'auth_img_pm' => true,
296            'auth_method' => true,
297            'auth_smilies_pm' => true,
298            'avatar_filesize' => true,
299            'avatar_max_height' => true,
300            'avatar_max_width' => true,
301            'avatar_min_height' => true,
302            'avatar_min_width' => true,
303            'board_email_form' => true,
304            'board_hide_emails' => true,
305            'board_timezone' => true,
306            'browser_check' => true,
307            'bump_interval' => true,
308            'bump_type' => true,
309            'cache_gc' => true,
310            'captcha_plugin' => true,
311            'captcha_gd' => true,
312            'captcha_gd_foreground_noise' => true,
313            'captcha_gd_x_grid' => true,
314            'captcha_gd_y_grid' => true,
315            'captcha_gd_wave' => true,
316            'captcha_gd_3d_noise' => true,
317            'captcha_gd_fonts' => true,
318            'confirm_refresh' => true,
319            'check_attachment_content' => true,
320            'check_dnsbl' => true,
321            'chg_passforce' => true,
322            'cookie_secure' => true,
323            'coppa_enable' => true,
324            'database_gc' => true,
325            'default_dateformat' => true,
326            'default_lang' => true,
327            'display_last_edited' => true,
328            'display_order' => true,
329            'edit_time' => true,
330            'email_check_mx' => true,
331            'email_enable' => true,
332            'email_force_sender' => true,
333            'email_package_size' => true,
334            'enable_confirm' => true,
335            'enable_pm_icons' => true,
336            'enable_post_confirm' => true,
337            'feed_enable' => true,
338            'feed_http_auth' => true,
339            'feed_limit_post' => true,
340            'feed_limit_topic' => true,
341            'feed_overall' => true,
342            'feed_overall_forums' => true,
343            'feed_forum' => true,
344            'feed_topic' => true,
345            'feed_topics_new' => true,
346            'feed_topics_active' => true,
347            'feed_item_statistics' => true,
348            'flood_interval' => true,
349            'force_server_vars' => true,
350            'form_token_lifetime' => true,
351            'form_token_mintime' => true,
352            'form_token_sid_guests' => true,
353            'forward_pm' => true,
354            'forwarded_for_check' => true,
355            'full_folder_action' => true,
356            'fulltext_native_common_thres' => true,
357            'fulltext_native_load_upd' => true,
358            'fulltext_native_max_chars' => true,
359            'fulltext_native_min_chars' => true,
360            'gzip_compress' => true,
361            'hot_threshold' => true,
362            'img_create_thumbnail' => true,
363            'img_display_inlined' => true,
364            'img_max_height' => true,
365            'img_max_thumb_width' => true,
366            'img_max_width' => true,
367            'img_min_thumb_filesize' => true,
368            'ip_check' => true,
369            'jab_enable' => true,
370            'jab_package_size' => true,
371            'jab_use_ssl' => true,
372            'limit_load' => true,
373            'limit_search_load' => true,
374            'load_anon_lastread' => true,
375            'load_birthdays' => true,
376            'load_cpf_memberlist' => true,
377            'load_cpf_viewprofile' => true,
378            'load_cpf_viewtopic' => true,
379            'load_db_lastread' => true,
380            'load_db_track' => true,
381            'load_jumpbox' => true,
382            'load_moderators' => true,
383            'load_online' => true,
384            'load_online_guests' => true,
385            'load_online_time' => true,
386            'load_onlinetrack' => true,
387            'load_search' => true,
388            'load_tplcompile' => true,
389            'load_user_activity' => true,
390            'max_attachments' => true,
391            'max_attachments_pm' => true,
392            'max_autologin_time' => true,
393            'max_filesize' => true,
394            'max_filesize_pm' => true,
395            'max_login_attempts' => true,
396            'max_name_chars' => true,
397            'max_num_search_keywords' => true,
398            'max_poll_options' => true,
399            'max_post_chars' => true,
400            'max_post_font_size' => true,
401            'max_post_smilies' => true,
402            'max_post_urls' => true,
403            'max_quote_depth' => true,
404            'max_reg_attempts' => true,
405            'max_sig_chars' => true,
406            'max_sig_font_size' => true,
407            'max_sig_smilies' => true,
408            'max_sig_urls' => true,
409            'min_name_chars' => true,
410            'min_pass_chars' => true,
411            'min_post_chars' => true,
412            'min_search_author_chars' => true,
413            'mime_triggers' => true,
414            'new_member_post_limit' => true,
415            'new_member_group_default' => true,
416            'override_user_style' => true,
417            'pass_complex' => true,
418            'pm_edit_time' => true,
419            'pm_max_boxes' => true,
420            'pm_max_msgs' => true,
421            'pm_max_recipients' => true,
422            'posts_per_page' => true,
423            'print_pm' => true,
424            'queue_interval' => true,
425            'require_activation' => true,
426            'referer_validation' => true,
427            'search_block_size' => true,
428            'search_gc' => true,
429            'search_interval' => true,
430            'search_anonymous_interval' => true,
431            'search_type' => true,
432            'search_store_results' => true,
433            'secure_allow_deny' => true,
434            'secure_allow_empty_referer' => true,
435            'secure_downloads' => true,
436            'session_gc' => true,
437            'session_length' => true,
438            'smtp_delivery' => true,
439            'topics_per_page' => true,
440            'version' => true,
441            'warnings_expire_days' => true,
442            'warnings_gc' => true,
443
444            'num_files' => true,
445            'num_posts' => true,
446            'num_topics' => true,
447            'num_users' => true,
448            'record_online_users' => true,
449        );
450
451        $result = array();
452        foreach ($config_vars as $name => $void)
453        {
454            if (isset($this->config[$name]))
455            {
456                $result['config_' . $name] = $this->config[$name];
457            }
458        }
459
460        global $db, $request;
461
462        $result['dbms'] = $dbms;
463        $result['acm_type'] = $acm_type;
464        $result['user_agent'] = 'Unknown';
465        $result['dbms_version'] = $db->sql_server_info(true);
466
467        // Try to get user agent vendor and version
468        $match = array();
469        $user_agent = $request->header('User-Agent');
470        $agents = array('firefox', 'msie', 'opera', 'chrome', 'safari', 'mozilla', 'seamonkey', 'konqueror', 'netscape', 'gecko', 'navigator', 'mosaic', 'lynx', 'amaya', 'omniweb', 'avant', 'camino', 'flock', 'aol');
471
472        // We check here 1 by 1 because some strings occur after others (for example Mozilla [...] Firefox/)
473        foreach ($agents as $agent)
474        {
475            if (preg_match('#(' . $agent . ')[/ ]?([0-9.]*)#i', $user_agent, $match))
476            {
477                $result['user_agent'] = $match[1] . ' ' . $match[2];
478                break;
479            }
480        }
481
482        return $result;
483    }
484}