├── .gitignore
├── tests
├── code
│ ├── testcode
│ │ ├── emptyFile
│ │ ├── short1
│ │ ├── short2
│ │ ├── short3
│ │ ├── dbal
│ │ │ ├── db2
│ │ │ ├── oci
│ │ │ ├── pg
│ │ │ ├── ibase
│ │ │ ├── mssql
│ │ │ ├── mysql
│ │ │ ├── mysqli
│ │ │ ├── odbc
│ │ │ ├── sqlite
│ │ │ └── sqlsrv
│ │ ├── functions
│ │ │ ├── die
│ │ │ ├── eval
│ │ │ ├── exec
│ │ │ ├── md5
│ │ │ ├── sha1
│ │ │ ├── backticks
│ │ │ ├── getenv
│ │ │ ├── system
│ │ │ ├── addslashes
│ │ │ ├── passthru
│ │ │ ├── include_once
│ │ │ ├── require_once
│ │ │ ├── stripslashes
│ │ │ ├── include_once2
│ │ │ ├── require_once2
│ │ │ ├── htmlspecialchars
│ │ │ ├── md52
│ │ │ └── umilfile.php
│ │ ├── short4
│ │ ├── noShort
│ │ ├── noBinary
│ │ ├── noinphpbb.php
│ │ ├── noExtension
│ │ ├── include
│ │ │ ├── include6
│ │ │ ├── include1
│ │ │ ├── require1
│ │ │ ├── include7
│ │ │ ├── includeonce1
│ │ │ ├── requireonce1
│ │ │ ├── include2
│ │ │ ├── require2
│ │ │ ├── include3
│ │ │ ├── includeonce2
│ │ │ ├── requireonce2
│ │ │ ├── include4
│ │ │ └── include5
│ │ ├── inphpbb.php
│ │ ├── inphpbb3.php
│ │ ├── phpbb.php
│ │ ├── requestVar1
│ │ ├── requestVar2
│ │ ├── requestVar3
│ │ ├── unixFile
│ │ └── windowsFile
│ ├── empty_test.php
│ ├── unix_test.php
│ ├── binary_test.php
│ ├── request_var_test.php
│ ├── short_test.php
│ ├── in_phpbb_test.php
│ ├── db_test.php
│ ├── include_test.php
│ ├── function_test.php
│ ├── print_test.php
│ ├── modx_test.php
│ └── globals_test.php
├── mock
│ ├── modx_license.php
│ ├── modx_version.php
│ └── modx_object.php
├── bootstrap.php
└── test_framework
│ ├── phpbb_test_case_helpers.php
│ ├── mpv_mock.php
│ └── phpbb_test_case.php
├── mpv
├── docs
├── AUTHORS
└── COPYING
├── test-file.zip
├── includes
├── functions_compress.php
├── lib
│ ├── cortex_base.php
│ └── cortex_xml.php
├── tests
│ ├── tests_lang.php
│ ├── tests_html.php
│ ├── tests_execution.php
│ ├── test_base.php
│ ├── tests_packaging.php
│ ├── tests_modx.php
│ └── tests_code.php
├── languages
│ ├── en
│ │ └── lang.php
│ └── fr
│ │ └── lang.php
└── functions_mpv.php
├── .travis.yml
├── phpunit.xml.all
├── README.md
├── phpunit.xml.dist
├── cli.php
├── test.php
├── mpv_config.php
├── stats.php
├── style.css
└── store
└── data
└── modx-1.2.6.xsd
/.gitignore:
--------------------------------------------------------------------------------
1 | store/*
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/emptyFile:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/tests/code/testcode/short1:
--------------------------------------------------------------------------------
1 |
2 | ?>
3 |
--------------------------------------------------------------------------------
/tests/code/testcode/short2:
--------------------------------------------------------------------------------
1 |
2 | ?>
3 |
--------------------------------------------------------------------------------
/tests/code/testcode/short3:
--------------------------------------------------------------------------------
1 |
2 | ?>
3 |
--------------------------------------------------------------------------------
/tests/code/testcode/dbal/db2:
--------------------------------------------------------------------------------
1 | db2_connect();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/dbal/oci:
--------------------------------------------------------------------------------
1 | oci_connect();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/dbal/pg:
--------------------------------------------------------------------------------
1 | pg_connect();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/functions/die:
--------------------------------------------------------------------------------
1 | die();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/functions/eval:
--------------------------------------------------------------------------------
1 | eval();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/functions/exec:
--------------------------------------------------------------------------------
1 | exec();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/functions/md5:
--------------------------------------------------------------------------------
1 | md5();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/functions/sha1:
--------------------------------------------------------------------------------
1 | sha1();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/short4:
--------------------------------------------------------------------------------
1 | =
2 |
3 | ?>
4 |
--------------------------------------------------------------------------------
/tests/code/testcode/dbal/ibase:
--------------------------------------------------------------------------------
1 | ibase_connect();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/dbal/mssql:
--------------------------------------------------------------------------------
1 | mssql_connect();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/dbal/mysql:
--------------------------------------------------------------------------------
1 | mysql_connect();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/dbal/mysqli:
--------------------------------------------------------------------------------
1 | mysqli_connect();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/dbal/odbc:
--------------------------------------------------------------------------------
1 | odbc_connect();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/dbal/sqlite:
--------------------------------------------------------------------------------
1 | sqlite_connect();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/dbal/sqlsrv:
--------------------------------------------------------------------------------
1 | sqlsrv_connect();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/functions/backticks:
--------------------------------------------------------------------------------
1 | `test`
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/functions/getenv:
--------------------------------------------------------------------------------
1 | getenv();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/functions/system:
--------------------------------------------------------------------------------
1 | system();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/noShort:
--------------------------------------------------------------------------------
1 |
4 |
--------------------------------------------------------------------------------
/mpv:
--------------------------------------------------------------------------------
1 | #!/bin/bash
2 |
3 | php "$(dirname $0)/cli.php" "$@"
--------------------------------------------------------------------------------
/tests/code/testcode/functions/addslashes:
--------------------------------------------------------------------------------
1 | addslashes();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/functions/passthru:
--------------------------------------------------------------------------------
1 | passthru();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/noBinary:
--------------------------------------------------------------------------------
1 | This is only a textfile
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/noinphpbb.php:
--------------------------------------------------------------------------------
1 |
4 |
--------------------------------------------------------------------------------
/tests/code/testcode/functions/include_once:
--------------------------------------------------------------------------------
1 | include_once();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/functions/require_once:
--------------------------------------------------------------------------------
1 | require_once();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/functions/stripslashes:
--------------------------------------------------------------------------------
1 | stripslashes();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/functions/include_once2:
--------------------------------------------------------------------------------
1 | include_once '';
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/functions/require_once2:
--------------------------------------------------------------------------------
1 | require_once 'file';
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/noExtension:
--------------------------------------------------------------------------------
1 | This is a binary file.
2 | �
3 |
--------------------------------------------------------------------------------
/docs/AUTHORS:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/phpBB/mpv/master/docs/AUTHORS
--------------------------------------------------------------------------------
/test-file.zip:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/phpBB/mpv/master/test-file.zip
--------------------------------------------------------------------------------
/tests/code/testcode/functions/htmlspecialchars:
--------------------------------------------------------------------------------
1 | htmlspecialchars();
2 |
--------------------------------------------------------------------------------
/tests/code/testcode/include/include6:
--------------------------------------------------------------------------------
1 |
4 |
--------------------------------------------------------------------------------
/tests/code/testcode/inphpbb.php:
--------------------------------------------------------------------------------
1 |
4 |
--------------------------------------------------------------------------------
/tests/code/testcode/inphpbb3.php:
--------------------------------------------------------------------------------
1 |
4 |
--------------------------------------------------------------------------------
/tests/code/testcode/include/include1:
--------------------------------------------------------------------------------
1 |
4 |
--------------------------------------------------------------------------------
/tests/code/testcode/include/require1:
--------------------------------------------------------------------------------
1 |
4 |
--------------------------------------------------------------------------------
/tests/code/testcode/include/include7:
--------------------------------------------------------------------------------
1 |
4 |
--------------------------------------------------------------------------------
/tests/code/testcode/include/includeonce1:
--------------------------------------------------------------------------------
1 |
4 |
--------------------------------------------------------------------------------
/tests/code/testcode/include/requireonce1:
--------------------------------------------------------------------------------
1 |
4 |
--------------------------------------------------------------------------------
/tests/code/testcode/phpbb.php:
--------------------------------------------------------------------------------
1 |
7 |
--------------------------------------------------------------------------------
/tests/code/testcode/include/include2:
--------------------------------------------------------------------------------
1 |
4 |
--------------------------------------------------------------------------------
/tests/code/testcode/include/require2:
--------------------------------------------------------------------------------
1 |
4 |
--------------------------------------------------------------------------------
/tests/code/testcode/requestVar1:
--------------------------------------------------------------------------------
1 |
6 |
--------------------------------------------------------------------------------
/tests/code/testcode/requestVar2:
--------------------------------------------------------------------------------
1 |
6 |
--------------------------------------------------------------------------------
/tests/code/testcode/requestVar3:
--------------------------------------------------------------------------------
1 |
6 |
--------------------------------------------------------------------------------
/tests/code/testcode/include/include3:
--------------------------------------------------------------------------------
1 |
4 |
--------------------------------------------------------------------------------
/tests/code/testcode/include/includeonce2:
--------------------------------------------------------------------------------
1 |
4 |
--------------------------------------------------------------------------------
/tests/code/testcode/include/requireonce2:
--------------------------------------------------------------------------------
1 |
4 |
--------------------------------------------------------------------------------
/includes/functions_compress.php:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/phpBB/mpv/master/includes/functions_compress.php
--------------------------------------------------------------------------------
/tests/code/testcode/include/include4:
--------------------------------------------------------------------------------
1 |
7 |
--------------------------------------------------------------------------------
/tests/code/testcode/include/include5:
--------------------------------------------------------------------------------
1 |
7 |
--------------------------------------------------------------------------------
/tests/code/testcode/unixFile:
--------------------------------------------------------------------------------
1 | This is a file with UNIX line ends
2 | This is a file with UNIX line ends
3 | This is a file with UNIX line ends
4 | This is a file with UNIX line ends
5 | This is a file with UNIX line ends
6 |
--------------------------------------------------------------------------------
/tests/code/testcode/windowsFile:
--------------------------------------------------------------------------------
1 | This is a file with windows line ends
2 | This is a file with windows line ends
3 | This is a file with windows line ends
4 | This is a file with windows line ends
5 | This is a file with windows line ends
6 |
--------------------------------------------------------------------------------
/tests/mock/modx_license.php:
--------------------------------------------------------------------------------
1 | test_case = $test_case;
19 | }
20 |
21 | public function setExpectedTriggerError($errno, $message = '')
22 | {
23 | phpbb_test_case::$expected_error = $message;
24 | }
25 | }
26 |
--------------------------------------------------------------------------------
/tests/test_framework/mpv_mock.php:
--------------------------------------------------------------------------------
1 | assertEquals(phpbb_test_case::$expected_error, $message);
35 | }
36 | }
37 |
--------------------------------------------------------------------------------
/tests/mock/modx_object.php:
--------------------------------------------------------------------------------
1 | xpath;
19 | }
20 |
21 | public function set_xpath($foo)
22 | {
23 | $this->xpath = $foo;
24 | }
25 |
26 | public function get_by_name($name, $return = true)
27 | {
28 | return (isset($this->data_ary[$name])) ? $this->data_ary[$name] : false;
29 | }
30 |
31 | public function set_by_name($name, $value)
32 | {
33 | $this->data_ary[$name] = $value;
34 | }
35 | }
36 |
--------------------------------------------------------------------------------
/phpunit.xml.all:
--------------------------------------------------------------------------------
1 |
2 |
3 |
14 |
15 |
16 | ./tests/
17 |
18 |
19 |
20 |
21 |
22 | ./tests/
23 |
24 |
25 |
26 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # MOD Pre-Validator
2 |
3 | MPV is a tool that performs basic checks on phpBB MODs. It gives hints about things that could be wrong, and rates them as NOTICE, WARNING or FAIL.
4 |
5 | It is written and maintained by the phpBB Modifications Team.
6 |
7 | http://www.phpbb.com/mods/mpv/
8 |
9 | [](http://travis-ci.org/phpbb/mpv)
10 |
11 | ## Contributions
12 |
13 | Do you have an improvement? Did you made a translation? Did you fix a bug? Fork our GitHub repo, make your changes in a separate branch, and send a pull request.
14 | Please read our guidelines first [here](http://wiki.phpbb.com/display/DEV/Sub-Project+Contribution+Guidelines)
15 |
16 | ## Bug Tracker
17 |
18 | If you find a bug, and you are unable to fix it yourself, please submit it to the [MOD Team Tools](http://www.phpbb.com/bugs/modteamtools/) bug tracker on phpBB.com.
19 |
--------------------------------------------------------------------------------
/phpunit.xml.dist:
--------------------------------------------------------------------------------
1 |
2 |
3 |
14 |
15 |
16 | ./tests/
17 |
18 |
19 |
20 |
21 |
22 | slow
23 |
24 |
25 |
26 |
27 |
28 | ./tests/
29 |
30 |
31 |
32 |
--------------------------------------------------------------------------------
/cli.php:
--------------------------------------------------------------------------------
1 | #!/usr/bin/php
2 | output_type = (mpv::OUTPUT_TEXT);
47 | mpv::$exec_php = mpv::EXEC_PHP;
48 | $mpv->validate($argv[1]);
49 |
50 | print $lang['VALIDATION_RESULTS'] . "\n\n" . $mpv;
51 |
--------------------------------------------------------------------------------
/tests/code/empty_test.php:
--------------------------------------------------------------------------------
1 | redirect(), expected triggered error (else false), expected returned result url (else false))
18 | return array(
19 | array('testcode/emptyFile', 'FILE_EMPTY', false),
20 | array('testcode/noExtension', false, true),
21 | );
22 | }
23 |
24 | protected function setUp()
25 | {
26 | parent::setUp();
27 |
28 | $this->test = new mpv_tests_code(new mpv);
29 | }
30 |
31 | /**
32 | * @dataProvider provider
33 | */
34 | public function test_empty($test, $expected_error, $expected_result)
35 | {
36 | global $user;
37 | $this->test->setFilename('tests/code/' . $test);
38 |
39 | if ($expected_error !== false)
40 | {
41 | $this->setExpectedTriggerError(E_USER_ERROR, $expected_error);
42 | }
43 |
44 | $result = $this->test->unittest('test_empty', array());
45 |
46 | $this->assertEquals($expected_result, $result);
47 | }
48 | }
49 |
50 |
--------------------------------------------------------------------------------
/tests/code/unix_test.php:
--------------------------------------------------------------------------------
1 | redirect(), expected triggered error (else false), expected returned result url (else false))
18 | return array(
19 | array('testcode/windowsFile', 'NO_UNIX_ENDINGS', false),
20 | array('testcode/unixFile', false, true),
21 | );
22 | }
23 |
24 | protected function setUp()
25 | {
26 | parent::setUp();
27 |
28 | $this->test = new mpv_tests_code(new mpv);
29 | }
30 |
31 | /**
32 | * @dataProvider provider
33 | */
34 | public function test_unix($test, $expected_error, $expected_result)
35 | {
36 | global $user;
37 | $this->test->setFilename('tests/code/' . $test);
38 |
39 | if ($expected_error !== false)
40 | {
41 | $this->setExpectedTriggerError(E_USER_ERROR, $expected_error);
42 | }
43 |
44 | $result = $this->test->unittest('test_unix_endings', array());
45 |
46 | $this->assertEquals($expected_result, $result);
47 | }
48 | }
49 |
50 |
--------------------------------------------------------------------------------
/tests/code/binary_test.php:
--------------------------------------------------------------------------------
1 | redirect(), expected triggered error (else false), expected returned result url (else false))
18 | return array(
19 | array('testcode/noExtension', false, true),
20 | array('testcode/ignoreFile.php', false, false),
21 | array('testcode/noBinary', 'FILE_NON_BINARY', false),
22 | );
23 | }
24 |
25 | protected function setUp()
26 | {
27 | parent::setUp();
28 |
29 | $this->test = new mpv_tests_code(new mpv);
30 | }
31 |
32 | /**
33 | * @dataProvider provider
34 | */
35 | public function test_binary($test, $expected_error, $expected_result)
36 | {
37 | global $user;
38 |
39 | if ($expected_error !== false)
40 | {
41 | $this->setExpectedTriggerError(E_USER_ERROR, $expected_error);
42 | }
43 |
44 | $result = $this->test->unittest('check_binary', array(('tests/code/' . $test)));
45 |
46 | $this->assertEquals($expected_result, $result);
47 |
48 | }
49 | }
50 |
51 |
--------------------------------------------------------------------------------
/tests/test_framework/phpbb_test_case.php:
--------------------------------------------------------------------------------
1 | backupStaticAttributesBlacklist += array(
20 | 'PHP_CodeCoverage' => array('instance'),
21 | 'PHP_CodeCoverage_Filter' => array('instance'),
22 | 'PHP_CodeCoverage_Util' => array('ignoredLines', 'templateMethods'),
23 | 'PHP_Timer' => array('startTimes',),
24 | 'PHP_Token_Stream' => array('customTokens'),
25 | 'PHP_Token_Stream_CachingFactory' => array('cache'),
26 |
27 | 'phpbb_database_test_case' => array('already_connected'),
28 | );
29 | }
30 |
31 | public function get_test_case_helpers()
32 | {
33 | if (!$this->test_case_helpers)
34 | {
35 | $this->test_case_helpers = new phpbb_test_case_helpers($this);
36 | }
37 |
38 | return $this->test_case_helpers;
39 | }
40 |
41 | public function setExpectedTriggerError($errno, $message = '')
42 | {
43 | self::$expected_error = $message;
44 | }
45 | }
46 |
--------------------------------------------------------------------------------
/tests/code/request_var_test.php:
--------------------------------------------------------------------------------
1 | redirect(), expected triggered error (else false), expected returned result url (else false))
18 | return array(
19 | array('testcode/requestVar1', false, true),
20 | array('testcode/requestVar2', 'USAGE_REQUEST_VAR_INT', false),
21 | array('testcode/requestVar3', false, true),
22 | array('testcode/short2', false, true),
23 | );
24 | }
25 |
26 | protected function setUp()
27 | {
28 | parent::setUp();
29 |
30 | $this->test = new mpv_tests_code(new mpv);
31 | }
32 |
33 | /**
34 | * @dataProvider provider
35 | */
36 | public function test_request_var($test, $expected_error, $expected_result)
37 | {
38 | global $user;
39 | $this->test->setFilename('tests/code/' . $test);
40 |
41 | if ($expected_error !== false)
42 | {
43 | $this->setExpectedTriggerError(E_USER_ERROR, $expected_error);
44 | }
45 |
46 | $result = $this->test->unittest('test_request_var', array());
47 |
48 | $this->assertEquals($expected_result, $result);
49 | }
50 | }
51 |
52 |
--------------------------------------------------------------------------------
/tests/code/short_test.php:
--------------------------------------------------------------------------------
1 | redirect(), expected triggered error (else false), expected returned result url (else false))
18 | return array(
19 | array('testcode/short1', 'SHORT_TAGS', true),
20 | array('testcode/short2', 'SHORT_TAGS', true),
21 | array('testcode/short3', 'SHORT_TAGS', true),
22 | array('testcode/short4', 'SHORT_TAGS', true),
23 | array('testcode/noShort', false, true),
24 | );
25 | }
26 |
27 | protected function setUp()
28 | {
29 | parent::setUp();
30 |
31 | $this->test = new mpv_tests_code(new mpv);
32 | }
33 |
34 | /**
35 | * @dataProvider provider
36 | */
37 | public function test_short($test, $expected_error, $expected_result)
38 | {
39 | global $user;
40 | $this->test->setFilename('tests/code/' . $test);
41 |
42 | if ($expected_error !== false)
43 | {
44 | $this->setExpectedTriggerError(E_USER_ERROR, $expected_error);
45 | }
46 |
47 | $result = $this->test->unittest('test_short_tags', array());
48 |
49 | $this->assertEquals($expected_result, $result);
50 | }
51 | }
52 |
53 |
--------------------------------------------------------------------------------
/test.php:
--------------------------------------------------------------------------------
1 | output_type = ((HTML_FORMAT) ? mpv::OUTPUT_HTML : mpv::OUTPUT_BBCODE);
34 | mpv::$exec_php = mpv::EXEC_PHP;
35 | $mpv->validate('./test-file.zip');
36 |
37 | if (HTML_HEADERS)
38 | {
39 | print '';
40 | print '
41 |
42 | ' . $lang['TITLE'] . '
43 |
44 |
45 | ';
46 | }
47 | print '';
48 | print '';
49 | print '' . $lang['VALIDATION_RESULTS'] . "
";
50 | print '';
51 | print ((HTML_FORMAT) ? nl2br($mpv) : $mpv);
52 | print '';
53 | print '
';
54 | print ' ';
55 |
56 |
57 | ?>
58 |
--------------------------------------------------------------------------------
/includes/lib/cortex_base.php:
--------------------------------------------------------------------------------
1 | __get_()
30 | *
31 | * @access public
32 | * @param string Property name
33 | * @return mixed Property value
34 | */
35 | public function __get($property_name)
36 | {
37 | $method_name = '__get_' . $property_name;
38 | if (method_exists($this, $method_name))
39 | {
40 | return $this->$method_name();
41 | }
42 |
43 | if (!property_exists($this, $property_name))
44 | {
45 | throw new exception('Trying to get non-existing property ' . htmlspecialchar(get_class($this)) . '->' . htmlspecialchar($property_name));
46 | }
47 |
48 | return $this->$property_name;
49 | }
50 |
51 | /**
52 | * Setter, will attempt to call $this->__set_()
53 | *
54 | * @access public
55 | * @param string Property name
56 | * @param mixed Property value
57 | * @return void
58 | */
59 | public function __set($property_name, $property_value)
60 | {
61 | $method_name = '__set_' . $property_name;
62 | if (method_exists($this, $method_name))
63 | {
64 | $this->$method_name($property_value);
65 | }
66 | else
67 | {
68 | $this->$property_name = $property_value;
69 | }
70 | }
71 | }
72 | ?>
73 |
--------------------------------------------------------------------------------
/tests/code/in_phpbb_test.php:
--------------------------------------------------------------------------------
1 | redirect(), expected triggered error (else false), expected returned result url (else false))
18 | return array(/*
19 | array('testcode/short1', 'SHORT_TAGS', false),
20 | array('testcode/short2', 'SHORT_TAGS', false),
21 | array('testcode/short3', 'SHORT_TAGS', false),
22 | array('testcode/short4', 'SHORT_TAGS', false),*/
23 | array('mcp/info/mcp_test.php', false, true),
24 | array('acp/info/acp_test.php', false, true),
25 | array('ucp/info/ucp_test.php', false, true),
26 | array('testcode/inphpbb.php', false, true),
27 | array('testcode/inphpbb3.php', false, true),
28 | array('testcode/phpbb.php', false, true),
29 | array('testcode/noinphpbb.php', 'NO_IN_PHPBB', false),
30 | );
31 | }
32 |
33 | protected function setUp()
34 | {
35 | parent::setUp();
36 |
37 | $this->test = new mpv_tests_code(new mpv);
38 | }
39 |
40 | /**
41 | * @dataProvider provider
42 | */
43 | public function test_in_phpbb($test, $expected_error, $expected_result)
44 | {
45 | global $user;
46 | $this->test->setFilename('tests/code/' . $test);
47 |
48 | if ($expected_error !== false)
49 | {
50 | $this->setExpectedTriggerError(E_USER_ERROR, $expected_error);
51 | }
52 |
53 | $result = $this->test->unittest('test_in_phpbb', array());
54 |
55 | $this->assertEquals($expected_result, $result);
56 | }
57 | }
58 |
59 |
--------------------------------------------------------------------------------
/tests/code/db_test.php:
--------------------------------------------------------------------------------
1 | redirect(), expected triggered error (else false), expected returned result url (else false))
18 | return array(
19 | array('testcode/dbal/mysql', 'USAGE_MYSQL', false),
20 | array('testcode/dbal/mysqli', 'USAGE_MYSQLI', false),
21 | array('testcode/dbal/oci', 'USAGE_OCI', false),
22 | array('testcode/dbal/sqlite', 'USAGE_SQLITE', false),
23 | array('testcode/dbal/pg', 'USAGE_PG', false),
24 | array('testcode/dbal/mssql', 'USAGE_MSSQL', false),
25 | array('testcode/dbal/odbc', 'USAGE_ODBC', false),
26 | array('testcode/dbal/sqlsrv', 'USAGE_SQLSRV', false),
27 | array('testcode/dbal/ibase', 'USAGE_IBASE', false),
28 | array('testcode/dbal/db2', 'USAGE_DB2', false),
29 | array('testcode/short2', false, true),
30 | );
31 | }
32 |
33 | protected function setUp()
34 | {
35 | parent::setUp();
36 |
37 | $this->test = new mpv_tests_code(new mpv);
38 | }
39 |
40 | /**
41 | * @dataProvider provider
42 | */
43 | public function test_mysql($test, $expected_error, $expected_result)
44 | {
45 | global $user;
46 | $this->test->setFilename('tests/code/' . $test);
47 |
48 | if ($expected_error !== false)
49 | {
50 | $this->setExpectedTriggerError(E_USER_ERROR, $expected_error);
51 | }
52 |
53 | $result = $this->test->unittest('test_dbal', array());
54 |
55 | $this->assertEquals($expected_result, $result);
56 |
57 | }
58 | }
59 |
60 |
--------------------------------------------------------------------------------
/mpv_config.php:
--------------------------------------------------------------------------------
1 | array('properties')
53 | $statistics = array(
54 | 'meta' => array('name', 'content'),
55 | );
56 |
57 | ?>
58 |
--------------------------------------------------------------------------------
/tests/code/testcode/functions/umilfile.php:
--------------------------------------------------------------------------------
1 | session_begin();
23 | $auth->acl($user->data);
24 | $user->setup('viewtopic');
25 |
26 | $file = request_var('file', '');
27 | $filename = $phpbb_root_path . 'umil/error_files/' . $file . '.txt';
28 |
29 | if ($user->data['user_type'] != USER_FOUNDER || // Only founders can access this.
30 | !$file || // Do we have a file name?
31 | strpos($file, '/') || strpos($file, '.')) // Make sure they are not attempting to grab files outside of the umil/error_files/ directory
32 | {
33 | header('HTTP/1.0 403 Forbidden');
34 | trigger_error($user->lang['LINKAGE_FORBIDDEN']);
35 | }
36 |
37 | // Check if headers already sent or not able to get the file contents.
38 | if (headers_sent() || !@file_exists($filename) || !@is_readable($filename))
39 | {
40 | // PHP track_errors setting On?
41 | if (!empty($php_errormsg))
42 | {
43 | trigger_error($user->lang['UNABLE_TO_DELIVER_FILE'] . '
' . sprintf($user->lang['TRACKED_PHP_ERROR'], $php_errormsg));
44 | }
45 |
46 | trigger_error('UNABLE_TO_DELIVER_FILE');
47 | }
48 |
49 | header('Content-type: text/plain');
50 | header('Content-Disposition: filename="' . $file . '.txt"');
51 |
52 | $size = @filesize($filename);
53 | if ($size)
54 | {
55 | header("Content-Length: $size");
56 | }
57 |
58 | $fp = @fopen($filename, 'rb');
59 | if ($fp !== false)
60 | {
61 | while (!feof($fp))
62 | {
63 | echo fread($fp, 8192);
64 | }
65 | fclose($fp);
66 | }
67 |
68 | garbage_collection();
69 | exit_handler();
70 | ?>
71 |
--------------------------------------------------------------------------------
/tests/code/include_test.php:
--------------------------------------------------------------------------------
1 | redirect(), expected triggered error (else false), expected returned result url (else false))
18 | return array(
19 | array('testcode/include/include1', 'INCLUDE_NO_ROOT', false),
20 | array('testcode/include/includeonce1', 'INCLUDE_NO_ROOT', false),
21 | array('testcode/include/require1', 'INCLUDE_NO_ROOT', false),
22 | array('testcode/include/requireonce1', 'INCLUDE_NO_ROOT', false),
23 |
24 | array('testcode/include/include2', 'INCLUDE_NO_PHP', false),
25 | array('testcode/include/includeonce2', 'INCLUDE_NO_PHP', false),
26 | array('testcode/include/require2', 'INCLUDE_NO_PHP', false),
27 | array('testcode/include/requireonce2', 'INCLUDE_NO_PHP', false),
28 |
29 | array('testcode/include/include3', false, true),
30 | array('testcode/include/include4', 'INCLUDE_NO_ROOT', false),
31 | array('testcode/include/include5', 'INCLUDE_NO_PHP', false),
32 | array('testcode/include/include6', false, true),
33 | array('testcode/include/include7', false, true),
34 |
35 | array('testcode/short2', false, true),
36 | );
37 | }
38 |
39 | protected function setUp()
40 | {
41 | parent::setUp();
42 |
43 | $this->test = new mpv_tests_code(new mpv);
44 | }
45 |
46 | /**
47 | * @dataProvider provider
48 | */
49 | public function test_include($test, $expected_error, $expected_result)
50 | {
51 | global $user;
52 | $this->test->setFilename('tests/code/' . $test);
53 |
54 | if ($expected_error !== false)
55 | {
56 | $this->setExpectedTriggerError(E_USER_ERROR, $expected_error);
57 | }
58 |
59 | $result = $this->test->unittest('test_include', array());
60 |
61 | $this->assertEquals($expected_result, $result);
62 | }
63 | }
64 |
65 |
--------------------------------------------------------------------------------
/tests/code/function_test.php:
--------------------------------------------------------------------------------
1 | redirect(), expected triggered error (else false), expected returned result url (else false))
18 | return array(
19 | array('testcode/dbal/mysql', false, true),
20 | array('testcode/functions/eval', 'USAGE_EVAL', false),
21 | array('testcode/functions/exec', 'USAGE_EXEC', false),
22 | array('testcode/functions/system', 'USAGE_SYSTEM', false),
23 | array('testcode/functions/passthru', 'USAGE_PASSTHRU', false),
24 | array('testcode/functions/getenv', 'USAGE_GETENV', false),
25 | array('testcode/functions/die', 'USAGE_DIE', false),
26 | array('testcode/functions/sha1', 'USAGE_SHA1', false),
27 | array('testcode/functions/addslashes', 'USAGE_ADDSLASHES', false),
28 | array('testcode/functions/htmlspecialchars', 'USAGE_HTMLSPECIALCHARS', false),
29 | array('testcode/functions/stripslashes', 'USAGE_STRIPSLASHES', false),
30 |
31 | array('testcode/functions/backticks', 'USAGE_`', false),
32 |
33 | array('testcode/functions/include_once', 'USAGE_INCLUDEONCE', false),
34 | array('testcode/functions/include_once2', 'USAGE_INCLUDEONCE', false),
35 | array('testcode/functions/require_once', 'USAGE_REQUIREONCE', false),
36 | array('testcode/functions/require_once2', 'USAGE_REQUIREONCE', false),
37 | array('testcode/functions/md5', 'USAGE_MD5', false),
38 | array('testcode/functions/md52', false, true),
39 | array('testcode/short2', false, true),
40 | );
41 | }
42 |
43 | protected function setUp()
44 | {
45 | parent::setUp();
46 |
47 | $this->test = new mpv_tests_code(new mpv);
48 | }
49 |
50 | /**
51 | * @dataProvider provider
52 | */
53 | public function test_function($test, $expected_error, $expected_result)
54 | {
55 | global $user;
56 | $this->test->setFilename('tests/code/' . $test);
57 |
58 | if ($expected_error !== false)
59 | {
60 | $this->setExpectedTriggerError(E_USER_ERROR, $expected_error);
61 | }
62 |
63 | $result = $this->test->unittest('test_code', array());
64 |
65 | if ($expected_error === false)
66 | $this->assertEquals($expected_result, $result);
67 | }
68 | }
69 |
70 |
--------------------------------------------------------------------------------
/includes/tests/tests_lang.php:
--------------------------------------------------------------------------------
1 | validator->package_files) || !sizeof($this->validator->package_files))
39 | {
40 | return;
41 | }
42 |
43 | foreach ($this->validator->package_files as $package_file)
44 | {
45 | // only test language files
46 | /*if (!preg_match($package_file, '#language/.+\.php#'))
47 | {
48 | continue;
49 | }*/
50 |
51 | if (mpv::check_unwanted($package_file))
52 | {
53 | continue;
54 | }
55 |
56 | $this->failed_tests = array();
57 |
58 | $this->file_name = $package_file;
59 | $this->file_contents = file_get_contents($this->validator->temp_dir . $package_file);
60 | $this->file_contents_file = file($this->validator->temp_dir . $package_file);
61 |
62 | foreach ($test_methods as $method)
63 | {
64 | if (substr($method, 0, 5) == 'test_')
65 | {
66 | if (!$this->$method() || $this->terminate)
67 | {
68 | $this->failed_tests[] = substr($method, 5);
69 | }
70 |
71 | if ($this->terminate)
72 | {
73 | unset($this->file_contents, $this->file_contents_file);
74 |
75 | return;
76 | }
77 | }
78 | }
79 |
80 | unset($this->file_contents, $this->file_contents_file);
81 | }
82 | }
83 |
84 | /**
85 | * Test for the use of an UTF-8 byte-order-mark (BOM)
86 | *
87 | * @access private
88 | * @return bool
89 | */
90 | protected function test_bom()
91 | {
92 | if (substr($this->file_contents, 0, 3) === $this->bom_char)
93 | {
94 | $this->push_error(mpv::ERROR_WARNING, 'USAGE_BOM');
95 | return false;
96 | }
97 |
98 | return true;
99 | }
100 | }
101 |
--------------------------------------------------------------------------------
/tests/code/print_test.php:
--------------------------------------------------------------------------------
1 | redirect(), expected triggered error (else false), expected returned result url (else false))
18 | return array(
19 |
20 |
21 | array("", 'USAGE_PRINTR', false),
22 | array("", false, true),
23 | array("", false, true),
24 |
25 | array("", 'USAGE_VARDUMP', false),
26 | array("", 'USAGE_VARDUMP', false),
27 | array("", false, true),
28 | array("", false, true),
29 |
30 | array("", 'USAGE_PRINTF', false),
31 | array("", false, true),
32 | array("", false, true),
33 |
34 |
35 | array("", 'USAGE_ECHO', false),
36 | array("", false, true),
37 | array("", false, true),
38 | array("", 'USAGE_ECHO', false),
39 | array("", false, true),
40 | array("", false, true),
41 |
42 | array("", 'USAGE_PRINT', false),
43 | array("", false, true),
44 | array("", false, true),
45 | array("", 'USAGE_PRINT', false),
46 | array("", false, true),
47 | array("", false, true),
48 | );
49 | }
50 |
51 | protected function setUp()
52 | {
53 | parent::setUp();
54 |
55 | $this->test = new mpv_tests_code(new mpv);
56 | }
57 |
58 | /**
59 | * @dataProvider provider
60 | */
61 | public function test_global($test, $expected_error, $expected_result)
62 | {
63 | global $user;
64 | $this->test->setCode('tests/code/' . $test);
65 |
66 | if ($expected_error !== false)
67 | {
68 | $this->setExpectedTriggerError(E_USER_ERROR, $expected_error);
69 | }
70 |
71 | $result = $this->test->unittest('test_echo', array());
72 |
73 | if ($expected_error === false)
74 | $this->assertEquals($expected_result, $result);
75 | }
76 | }
77 |
78 |
79 |
--------------------------------------------------------------------------------
/includes/tests/tests_html.php:
--------------------------------------------------------------------------------
1 | validator->package_files))
33 | {
34 | $files = array_merge($files, $this->validator->package_files);
35 | }
36 |
37 | if (is_array($this->validator->modx_files))
38 | {
39 | $files = array_merge($files, $this->validator->modx_files);
40 | }
41 |
42 | foreach ($files as $package_file)
43 | {
44 | if (mpv::check_unwanted($package_file))
45 | {
46 | continue;
47 | }
48 |
49 | // Only test html, php, xml files
50 | if (!in_array(strrchr($package_file, '.'), array('.php', '.xml', '.html')))
51 | {
52 | continue;
53 | }
54 |
55 | $this->failed_tests = array();
56 |
57 | $this->file_name = $package_file;
58 | $this->file_contents = file_get_contents($this->validator->temp_dir . $package_file);
59 |
60 | $this->file_contents_file = file($this->validator->temp_dir . $package_file);
61 |
62 | foreach ($test_methods as $method)
63 | {
64 | if (substr($method, 0, 5) == 'test_')
65 | {
66 | if (!$this->$method() || $this->terminate)
67 | {
68 | $this->failed_tests[] = substr($method, 5);
69 | }
70 |
71 | if ($this->terminate)
72 | {
73 | unset($this->file_contents, $this->file_contents_file);
74 |
75 | return;
76 | }
77 | }
78 | }
79 |
80 | unset($this->file_contents, $this->file_contents_file);
81 | }
82 | }
83 |
84 | /**
85 | * Test for non closed BR tags
86 | *
87 | * @return bool
88 | */
89 | protected function test_br()
90 | {
91 | $return = true;
92 |
93 | if (preg_match('#
#', $this->file_contents))
94 | {
95 | $return = $this->display_line_code(mpv::ERROR_FAIL, 'USAGE_BR_NON_CLOSED', false, '#
#');
96 | }
97 |
98 | return $return;
99 | }
100 | /**
101 | * Test for non closed IMG tags
102 | *
103 | * @return bool
104 | */
105 | protected function test_img()
106 | {
107 | $return = true;
108 | /*
109 | * Disable this check for now, it doesnt detect it correctly atm.
110 | if (preg_match('#
#', $this->file_contents))
111 | {
112 | $return = $this->display_line_code(mpv::ERROR_FAIL, 'USAGE_IMG_NON_CLOSED', false, '#
#');
113 | }
114 | */
115 |
116 | return $return;
117 | }
118 | }
119 |
--------------------------------------------------------------------------------
/tests/code/modx_test.php:
--------------------------------------------------------------------------------
1 | test = new mpv_tests_modx(new mpv());
41 | $this->test->modx_object = new phpbb_mock_modx_object();
42 | $this->version = new phpbb_mock_modx_version();
43 | }
44 |
45 | /**
46 | * @dataProvider provider
47 | */
48 | public function test_version($test, $expected_error, $expected_result)
49 | {
50 | global $user;
51 |
52 | if ($expected_error !== false)
53 | {
54 | $this->setExpectedTriggerError(E_USER_ERROR, $expected_error);
55 | }
56 |
57 | $this->version->value = $test;
58 | $this->test->modx_object->set_xpath($this->version);
59 | $result = $this->test->unittest('test_version', array());
60 |
61 | $this->assertEquals($expected_result, $result);
62 | }
63 |
64 | public function test_version_no_object()
65 | {
66 | $this->setExpectedTriggerError(E_USER_ERROR, 'VERSION_FIELD_MISSING');
67 | $this->version = '1.0.0';
68 | $this->test->modx_object->set_xpath($this->version);
69 | $result = $this->test->unittest('test_version', array());
70 | $this->assertEquals(false, $result);
71 | }
72 |
73 | public static function data_modx_license()
74 | {
75 | return array(
76 | array('http://opensource.org/licenses/gpl-license.php GNU General Public License v2', false, true),
77 | array('http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2', false, true),
78 | array('http://opensource.org/licenses/MIT', 'LICENSE_NOT_GPL2', false),
79 | array(null, 'LICENSE_FIELD_MISSING', false),
80 | );
81 | }
82 |
83 | /**
84 | * @dataProvider data_modx_license
85 | */
86 | public function test_modx_license($test, $expected_error, $expected_result)
87 | {
88 | global $user;
89 |
90 | if ($expected_error !== false)
91 | {
92 | $this->setExpectedTriggerError(E_USER_ERROR, $expected_error);
93 | }
94 |
95 | if (isset($test))
96 | {
97 | $this->license = new phpbb_mock_modx_license();
98 | $this->license->value = $test;
99 | }
100 | else
101 | {
102 | $this->license = $test;
103 | }
104 | $this->test->modx_object->set_by_name('license', $this->license);
105 | $result = $this->test->unittest('test_license', array());
106 |
107 | $this->assertEquals($expected_result, $result);
108 | }
109 | }
110 |
--------------------------------------------------------------------------------
/includes/tests/tests_execution.php:
--------------------------------------------------------------------------------
1 | validator->package_files) || !sizeof($this->validator->package_files))
45 | {
46 | return;
47 | }
48 |
49 | foreach ($this->validator->package_files as $package_file)
50 | {
51 | if (mpv::check_unwanted($package_file))
52 | {
53 | continue;
54 | }
55 |
56 | $this->file_name = $package_file;
57 |
58 | // Only test PHP files
59 | if (substr($package_file, -3) !== 'php')
60 |
61 | {
62 | continue;
63 | }
64 |
65 | $this->failed_tests = array();
66 |
67 | $this->file_contents = file_get_contents($this->validator->temp_dir . $package_file);
68 |
69 | $this->file_contents_file = file($this->validator->temp_dir . $package_file);
70 |
71 | unset($content);
72 |
73 | foreach ($test_methods as $method)
74 | {
75 | if (substr($method, 0, 5) == 'test_')
76 | {
77 | if (!$this->$method() || $this->terminate)
78 | {
79 | $this->failed_tests[] = substr($method, 5);
80 | }
81 |
82 | if ($this->terminate)
83 | {
84 | unset($this->file_contents, $this->file_contents_file);
85 |
86 | return;
87 | }
88 | }
89 | }
90 |
91 | unset($this->file_contents, $this->file_contents_file);
92 | }
93 | }
94 |
95 | /**
96 | * Tests if there are any syntax errors by default.
97 | */
98 | protected function test_php()
99 | {
100 |
101 | $file = tempnam(sys_get_temp_dir(), 'mpv');
102 | $file2 = tempnam(sys_get_temp_dir(), 'mpv');
103 | $open = @fopen($file, 'wb');
104 |
105 | if (!$open)
106 | {
107 | $this->push_error(mpv::ERROR_NOTICE, 'UNABLE_OPEN', $file);
108 | return false;
109 | }
110 | foreach(file($this->validator->temp_dir . $this->file_name) as $line)
111 | {
112 | $result = @fwrite($open, "$line\n");
113 |
114 | if (!$result)
115 | {
116 | fclose($open);
117 | $this->push_error(mpv::ERROR_NOTICE, 'UNABLE_WRITE', $file);
118 |
119 | return;
120 | }
121 | }
122 | @fclose($file);
123 | $result = array();
124 | $data = @exec('php -l ' . escapeshellarg($file) . " 2>&1 >/dev/null", $result);
125 | @unlink($file);
126 |
127 | if (sizeof($result))
128 | {
129 | // looks like we have a problem.
130 | $ct = sizeof($result) ;
131 | for ($i = 0; $i < $ct; $i++)
132 | {
133 | $error = str_replace($file, $this->file_name, $result[$i]);
134 | $this->push_error(mpv::ERROR_WARNING, 'PHP_ERROR', htmlspecialchars($error));
135 | }
136 | }
137 |
138 | return true;
139 | }
140 | }
141 |
--------------------------------------------------------------------------------
/stats.php:
--------------------------------------------------------------------------------
1 |
24 |
25 |
26 |
27 |
52 |
53 |
54 |
55 |
56 |
57 | $properties)
64 | {
65 | $data_file = './store/data/' . $tag . '_data.txt';
66 |
67 | if (file_exists($data_file))
68 | {
69 | $contents = file_get_contents($data_file);
70 | $entries = explode("\r\n", $contents);
71 |
72 | foreach ($entries as $entry)
73 | {
74 | $mod_name = '';
75 | $split_entry = explode("||", $entry);
76 |
77 | foreach ($split_entry as $entry_value)
78 | {
79 | //Check for the MOD name and assign counts as needed
80 | if (empty($mod_name))
81 | {
82 | $mod_name = $entry_value;
83 | $mod_name_id = str_replace(' ', '_', $mod_name);
84 | if (isset($mod_count[$mod_name_id]))
85 | {
86 | $mod_count[$mod_name_id] += 1;
87 | }
88 | else
89 | {
90 | $mod_count = array_merge($mod_count, array($mod_name_id => 1));
91 | }
92 | $entries_values[] = $entry_value;
93 | continue;
94 | }
95 | $entries_values[] = $entry_value;
96 | $entry_value_id = str_replace(' ', '_', $entry_value);
97 | if (isset($property_count[$entry_value_id]))
98 | {
99 | $property_count[$entry_value_id] += 1;
100 | }
101 | else
102 | {
103 | $property_count = array_merge($property_count, array($entry_value_id => 1));
104 | }
105 | }
106 | }
107 | }
108 | }
109 |
110 | //Remove the duplicates
111 | $entries_values = array_unique($entries_values);
112 | sort($entries_values);
113 | $row = " | %s | %s |
\n";
114 |
115 | print '
116 |
117 | | ' . $lang['TAG_DATA'] . ' | ' . $lang['DATA_COUNT'] . " |
118 |
\n";
119 |
120 | //Print out each row for the properties
121 | foreach ($entries_values as $entry)
122 | {
123 | $entry_id = str_replace(' ', '_', $entry);
124 |
125 | if (isset($property_count[$entry_id]))
126 | {
127 | print sprintf($row, $entry, $property_count[$entry_id]);
128 | }
129 | }
130 | print '
131 |
132 |
133 |
134 | | ' . $lang['MOD_NAME'] . ' | ' . $lang['SUBMIT_COUNT'] . " |
135 |
\n";
136 |
137 | //Print out each row for the MOD names
138 | foreach ($entries_values as $entry)
139 | {
140 | if (!empty($entry))
141 | {
142 | $entry_id = str_replace(' ', '_', $entry);
143 |
144 | if (isset($mod_count[$entry_id]))
145 | {
146 | print sprintf($row, $entry, $mod_count[$entry_id]);
147 | }
148 | }
149 | }
150 | print '
';
151 | }
152 |
153 | ?>
154 |
155 |
156 |
--------------------------------------------------------------------------------
/tests/code/globals_test.php:
--------------------------------------------------------------------------------
1 | redirect(), expected triggered error (else false), expected returned result url (else false))
18 | return array(
19 | array("", 'USAGE_GLOBALS', false),
20 | array("", 'USAGE_HTTPPOSTVARS', false),
21 | array("", 'USAGE_HTTPPOSTVARS', false),
22 |
23 | array("", 'USAGE_HTTPGETVARS', false),
24 | array("", 'USAGE_HTTPGETVARS', false),
25 |
26 | array("", 'USAGE_HTTPSERVERVARS', false),
27 | array("", 'USAGE_HTTPSERVERVARS', false),
28 |
29 | array("", 'USAGE_HTTPENVVARS', false),
30 | array("", 'USAGE_HTTPENVVARS', false),
31 |
32 | array("", 'USAGE_HTTPCOOKIEVARS', false),
33 | array("", 'USAGE_HTTPCOOKIEVARS', false),
34 |
35 | array("", 'USAGE_HTTPPOSTFILES', false),
36 | array("", 'USAGE_HTTPPOSTFILES', false),
37 |
38 | array("", 'USAGE_HTTPSESSIONVARS', false),
39 | array("", 'USAGE_HTTPSESSIONVARS', false),
40 |
41 | array("", 'USAGE_FILES', false),
42 | array("", 'USAGE_FILES', false),
43 |
44 | array("", 'USAGE_SESSION', false),
45 | array("", false, true),
46 |
47 | array("", 'USAGE_SERVER', false),
48 | array("", false, true),
49 |
50 | array("", 'USAGE_ENV', false),
51 | array("", false, true),
52 |
53 | array("", 'USAGE_REQUEST', false),
54 | array("", false, true),
55 |
56 | array("", 'USAGE_POST', false),
57 | array("", false, true),
58 |
59 | array("", 'USAGE_GET', false),
60 | array("", false, true),
61 |
62 | array("", 'USAGE_COOKIE', false),
63 | array("", false, true),
64 | array("", false, true),
65 |
66 | array("", false, true),
67 | array("", false, true),
68 |
69 | );
70 | }
71 |
72 | protected function setUp()
73 | {
74 | parent::setUp();
75 |
76 | $this->test = new mpv_tests_code(new mpv);
77 | }
78 |
79 | /**
80 | * @dataProvider provider
81 | */
82 | public function test_global($test, $expected_error, $expected_result)
83 | {
84 | global $user;
85 | $this->test->setCode('tests/code/' . $test);
86 |
87 | if ($expected_error !== false)
88 | {
89 | $this->setExpectedTriggerError(E_USER_ERROR, $expected_error);
90 | }
91 |
92 | $result = $this->test->unittest('test_globals', array());
93 |
94 | if ($expected_error === false)
95 | $this->assertEquals($expected_result, $result);
96 | }
97 | }
98 |
99 |
--------------------------------------------------------------------------------
/includes/tests/test_base.php:
--------------------------------------------------------------------------------
1 | validator = $validator;
79 | $this->terminate = false;
80 | $this->failed_tests = array();
81 | }
82 | public abstract function run();
83 |
84 | /**
85 | * Wrapper around $this->validator->push_error
86 | *
87 | * @access protected
88 | * @param int Error type
89 | * @param string Message
90 | * @param mixed Optional array of sprintf() values, or a non-array for passing one single value
91 | * @return void
92 | */
93 | protected function push_error($type, $message, $sprintf_args = null)
94 | {
95 | $this->validator->push_error($type, $message, $this->file_name, $sprintf_args);
96 | }
97 |
98 | /**
99 | * Displays a inline code block with the line of wrong code.
100 | *
101 | * @access protected
102 | * @param int Error type
103 | * @param string Message
104 | * @param string String to use in strpos
105 | * @param string String to use in preg_match
106 | * @param array array that contains words that should not be in the line
107 | * @return bool
108 | */
109 | protected function display_line_code($type, $message, $strpos, $preg_match = false, $ignore_in_line = array())
110 | {
111 | $found = false;
112 |
113 | $in_comment = false;
114 |
115 | if (!is_array($ignore_in_line))
116 | {
117 | if (is_string($ignore_in_line))
118 | {
119 | $ignore_in_line = array(0 => $ignore_in_line);
120 | }
121 | else
122 | {
123 | $ignore_in_line = array();
124 | }
125 | }
126 |
127 | foreach ($this->file_contents_file as $line => $content)
128 | {
129 | $content_new = $content;
130 | $loc = strpos($content, '*/');
131 |
132 | if ($in_comment && $loc === false)
133 | {
134 | $content_new = '';
135 | }
136 | else if ($in_comment && $loc !== false)
137 | {
138 | // Need to replace everything till */
139 | $total = strlen($content_new);
140 | $negative = $total - $loc;
141 | $total = $total - $negative;
142 |
143 | $content_new = substr($content_new, ($loc + 2));
144 | $in_comment = false;
145 | }
146 | else if(!$in_comment && strpos($content, '/*') !== false)
147 | {
148 | if ($loc !== false) // Used as inline
149 | {
150 | $content_new = preg_replace('#/\*(.*)\*/#si', '', $content_new);
151 | }
152 | else
153 | {
154 | $in_comment = true;
155 |
156 | $content_new = substr($content_new, 0, strpos($content, '/*'));
157 | }
158 | }
159 | $loc = strpos($content_new, '//');
160 |
161 | if ($loc !== false)
162 | {
163 | $content_new = substr($content_new, 0, $loc + 2);
164 | }
165 |
166 | foreach ($ignore_in_line as $value)
167 | {
168 | if (strpos($content_new, $value) !== false)
169 | {
170 | $content_new = '';
171 | }
172 | }
173 |
174 |
175 | if (empty($content_new))
176 | {
177 | continue;
178 | }
179 |
180 | // Yes, $content_new in if, and $content in code.
181 | // This is because we want comments still being displayed ;)
182 | if (!$preg_match && strpos($content_new, $strpos) !== false)
183 | {
184 | $this->push_error($type, $message, array((string) ($line + 1) , '[code]' . trim($content) . '[/code]'));
185 | $found = true;
186 | }
187 | else if ($preg_match && preg_match($preg_match, $content_new))
188 | {
189 | $this->push_error($type, $message, array((string) ($line + 1) , '[code]' . trim($content) . '[/code]'));
190 | $found = true;
191 | }
192 | }
193 |
194 | return $found;
195 | }
196 |
197 | /**
198 | * Terminate all further testing; used if failing one test could result in other tests malfunctioning
199 | *
200 | * @access protected
201 | * @return bool
202 | */
203 | protected function terminate()
204 | {
205 | $this->terminate = true;
206 | $this->push_error(mpv::ERROR_WARNING, 'TESTING_TERMINATED');
207 |
208 | return false;
209 | }
210 |
211 | /**
212 | * Check whether a given test failed
213 | *
214 | * @access protected
215 | * @param string Test name
216 | * @return bool
217 | */
218 | protected function failed_test($test_name)
219 | {
220 | return in_array($test_name, $this->failed_tests);
221 | }
222 |
223 | /**
224 | * Returns a array with failed tests
225 | *
226 | * @access public
227 | * @return array
228 | */
229 | public function return_failed_tests()
230 | {
231 | return $this->failed_tests;
232 | }
233 |
234 | /**
235 | * Extracs a dir from a filename
236 | *
237 | * @param string $file Filename
238 | * @return string
239 | */
240 | protected function extract_dir($file)
241 | {
242 | return substr($file, 0, -strlen(basename($file)));
243 | }
244 |
245 | /**
246 | * Test a function from phpunit that is private.
247 | * @param string $function Functioname
248 | * @param array $parameters Function parameters
249 | **/
250 | public function unittest($function, $parameters)
251 | {
252 | return call_user_func_array(array($this, $function), $parameters);
253 | }
254 |
255 | public function setFilename($file)
256 | {
257 | $this->file_name = $file;
258 | $this->file_contents = @file_get_contents($file);
259 | $this->file_contents_file = @file($file);
260 | }
261 |
262 | public function setCode($file)
263 | {
264 | $this->file_name = "";
265 | $this->file_contents = $file;
266 | $this->file_contents_file = explode("\n", $file);
267 | }
268 | }
269 | ?>
270 |
--------------------------------------------------------------------------------
/includes/tests/tests_packaging.php:
--------------------------------------------------------------------------------
1 | 'db40dbe549fcbbb5a790f7e81ce8e4db',
48 | '1.0.3' => 'e0999771662ee6eada0425ff076c3062',
49 | '1.0.4' => 'ada48057d56ebd22298648a8130fe573',
50 | '1.0.5' => '29c5b8a1c881b0b5b249dbfd29bb6f29',
51 | );
52 |
53 | /**
54 | * Run the tests in this collection
55 | *
56 | * @access public
57 | * @return void
58 | */
59 | public function run()
60 | {
61 | $test_methods = get_class_methods($this);
62 | foreach ($test_methods as $method)
63 | {
64 | if (substr($method, 0, 5) == 'test_')
65 | {
66 | if (!$this->$method() || $this->terminate)
67 | {
68 | $this->failed_tests[] = substr($method, 5);
69 | }
70 |
71 | if ($this->terminate)
72 | {
73 | return;
74 | }
75 | }
76 | }
77 | }
78 |
79 | /**
80 | * Test if the there is more as 1 xsl file
81 | *
82 | * @access private
83 | * @return bool
84 | */
85 | protected function test_xsl()
86 | {
87 | if (sizeof($this->validator->xsl_files) == 0)
88 | {
89 | $this->push_error(mpv::ERROR_FAIL, 'NO_XSL_FILE');
90 | return false;
91 | }
92 |
93 | return true;
94 | }
95 |
96 |
97 | /**
98 | * Test the MD5 for certian files like UMIL and xsl
99 | *
100 | * @access private
101 | * @return bool
102 | */
103 | protected function test_files()
104 | {
105 | $error = false;
106 | $found_umil = false;
107 | if (sizeof($this->validator->xsl_files) > 0)
108 | {
109 | foreach ($this->validator->xsl_files as $file)
110 | {
111 | $md5 = md5_file($this->validator->temp_dir . $file);
112 |
113 | if (!in_array($md5, $this->valid_md5_xsl))
114 | {
115 | $error = true;
116 | $this->push_error(mpv::ERROR_WARNING, 'MODIFIED_XSL', $file, array($md5, $this->valid_md5_xsl[0]));
117 | }
118 | else if ($md5 != $this->valid_md5_xsl[0]) // Note, newest MD5 for xsl should be the first!
119 | {
120 | $error = true;
121 | $this->push_error(mpv::ERROR_FAIL, 'OLD_XSL', $file, array($md5));
122 | }
123 | }
124 |
125 | foreach ($this->validator->package_files as $file)
126 | {
127 | if (strpos($file, 'license.txt') !== false)
128 | {
129 | $md5 = md5_file($this->validator->temp_dir . $file);
130 |
131 | if (!in_array($md5, $this->license_md5))
132 | {
133 | $this->push_error(mpv::ERROR_FAIL, 'LICENSE_MD5', $file, array($md5, implode(', ',$this->license_md5)));
134 | }
135 | }
136 |
137 | $tmp = explode('/', $file);
138 |
139 | if (isset($tmp[sizeof($tmp) - 2]) && isset($tmp[sizeof($tmp) - 1]) && $tmp[sizeof($tmp) - 2] == 'umil' && $tmp[sizeof($tmp) - 1] == 'umil.php')
140 | {
141 | $md5 = md5_file($this->validator->temp_dir . $file);
142 |
143 | if ($found_umil)
144 | {
145 | $this->push_error(mpv::ERROR_WARNING, 'POSSIBLE_TWO_UMIL', null, array($file, $found_umil));
146 | continue;
147 | }
148 |
149 | if (!defined('IN_PHPBB'))
150 | {
151 | define('IN_PHPBB', true);
152 | }
153 | include ($this->validator->temp_dir . $file);
154 |
155 | if (!defined('UMIL_VERSION'))
156 | {
157 | $this->push_error(mpv::ERROR_FAIL, 'NO_UMIL_VERSION', $file);
158 |
159 | continue;
160 | }
161 | else if (version_compare(UMIL_VERSION, mpv::get_current_version('umil'), '<'))
162 | {
163 | $this->push_error(mpv::ERROR_FAIL, 'UMIL_OUTDATED', $file);
164 |
165 | // Check to see if the md5 still exists
166 | if (isset($this->valid_md5_umil[UMIL_VERSION]) && $this->valid_md5_umil[UMIL_VERSION] != $md5)
167 | {
168 | // Invalid MD5 for version as well :)
169 | $this->push_error(mpv::ERROR_WARNING, 'INCORRECT_UMIL_MD5', $file);
170 | }
171 | }
172 | else if (!isset($this->valid_md5_umil[UMIL_VERSION]))
173 | {
174 | $this->push_error(mpv::ERROR_FAIL, 'UNKNOWN_VERSION_UMIL', $file);
175 | }
176 | else if ($this->valid_md5_umil[UMIL_VERSION] != $md5)
177 | {
178 | $this->push_error(mpv::ERROR_WARNING, 'INCORRECT_UMIL_MD5', $file);
179 | }
180 | $found_umil = $file;
181 | }
182 | }
183 | }
184 | }
185 |
186 | /**
187 | * Checks to see if the required license.txt exists
188 | *
189 | * @access private
190 | * @return bool
191 | */
192 | protected function test_license()
193 | {
194 | foreach ($this->validator->package_files as $filename)
195 | {
196 | if (mpv::check_unwanted($filename))
197 | {
198 | continue;
199 | }
200 |
201 | if (strtolower(basename($filename)) == 'license.txt')
202 | {
203 | return true;
204 | }
205 | }
206 | $this->push_error(mpv::ERROR_FAIL, 'NO_LICENSE');
207 | return false;
208 | }
209 |
210 | /**
211 | * Test to see if prosilver.xml or english.xml exisits.
212 | *
213 | * @return bool
214 | * @access private
215 | */
216 | protected function test_prosilver_english()
217 | {
218 | $return = true;
219 | foreach ($this->validator->package_files as $filename)
220 | {
221 | if (mpv::check_unwanted($filename))
222 | {
223 | continue;
224 | }
225 |
226 | $file = strtolower(basename($filename));
227 |
228 | if ($file == 'prosilver.xml' || (strpos($file, 'prosilver') !== false && strpos($file, '.xml') !== false))
229 | {
230 | $this->push_error(mpv::ERROR_FAIL, 'PROSILVER_NO_MAIN_MODX', null, array($filename));
231 | $return = false;
232 | }
233 |
234 | if ($file == 'en.xml' || (strpos($file, 'english') !== false && strpos($file, '.xml') !== false))
235 | {
236 | $this->push_error(mpv::ERROR_FAIL, 'ENGLISH_NO_MAIN_MODX', null, array($filename));
237 | $return = false;
238 | }
239 | }
240 |
241 | return $return;
242 | }
243 |
244 | /**
245 | * Checks to see if there are bad files from svn or the OS
246 | *
247 | * @access private
248 | * @return bool
249 | */
250 | protected function test_unwanted()
251 | {
252 | // precache regexp for efficiency
253 | $regexp = '#(^|.*/)(' . implode('|', array_map('preg_quote', mpv::$unwanted_files)) . ')(?:/|$)#i';
254 |
255 | $unwanted_files = array();
256 | foreach (mpv::$package_directories as $filename)
257 | {
258 | if (preg_match($regexp, $filename, $matches))
259 | {
260 | // don't add files multiple times
261 | if (isset($unwanted_files[$matches[1] . $matches[2]]))
262 | {
263 | continue;
264 | }
265 |
266 | // add unwanted file, use array keys for efficiency
267 | $unwanted_files[$matches[1] . $matches[2]] = true;
268 |
269 | // if there is no dir, it's the root
270 | if ($matches[1] === '')
271 | {
272 | $matches[1] = './';
273 | }
274 |
275 | // push notice
276 | $this->push_error(mpv::ERROR_FAIL, 'UNWANTED_FILE', null, array($matches[1], $matches[2]));
277 | }
278 | }
279 |
280 | return sizeof($unwanted_files);
281 | }
282 |
283 | /**
284 | * Wrapper around $this->validator->push_error
285 | *
286 | * @access private
287 | * @param int Error type
288 | * @param string Message
289 | * @param string Filename of the file causing the error
290 | * @param mixed Optional array of sprintf() values, or a non-array for passing one single value
291 | * @return void
292 | */
293 | protected function push_error($type, $message, $filename = null, $sprintf_args = null)
294 | {
295 | $this->validator->push_error($type, $message, $filename, $sprintf_args);
296 | }
297 | }
298 |
--------------------------------------------------------------------------------
/style.css:
--------------------------------------------------------------------------------
1 |
2 | html {
3 | background: #6C7989;
4 | background: #6c7989 -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #6c7989), color-stop(100%, #434b55)) fixed;
5 | background: #6c7989 -webkit-linear-gradient(#6c7989, #434b55) fixed;
6 | background: #6c7989 -moz-linear-gradient(#6c7989, #434b55) fixed;
7 | background: #6c7989 -o-linear-gradient(#6c7989, #434b55) fixed;
8 | background: #6c7989 -ms-linear-gradient(#6c7989, #434b55) fixed;
9 | background: #6c7989 linear-gradient(#6c7989, #434b55) fixed;
10 | }
11 |
12 | body {
13 | padding: 50px 0;
14 | margin: 0;
15 | font: 14px/1.5 "Helvetica Neue", Helvetica, Arial, sans-serif;
16 | color: #555;
17 | font-weight: 300;
18 | background: url("") repeat fixed 0 0 transparent;
19 | }
20 |
21 | .wrapper {
22 | width: 640px;
23 | margin: 0 auto;
24 | background: #DEDEDE;
25 | -webkit-border-radius: 8px;
26 | -moz-border-radius: 8px;
27 | -ms-border-radius: 8px;
28 | -o-border-radius: 8px;
29 | border-radius: 8px;
30 | -webkit-box-shadow: rgba(0, 0, 0, 0.2) 0 0 0 1px, rgba(0, 0, 0, 0.45) 0 3px 10px;
31 | -moz-box-shadow: rgba(0, 0, 0, 0.2) 0 0 0 1px, rgba(0, 0, 0, 0.45) 0 3px 10px;
32 | box-shadow: rgba(0, 0, 0, 0.2) 0 0 0 1px, rgba(0, 0, 0, 0.45) 0 3px 10px;
33 | }
34 |
35 | header, section, footer {
36 | display: block;
37 | }
38 |
39 | header {
40 | -webkit-border-radius: 8px 8px 0 0;
41 | -moz-border-radius: 8px 8px 0 0;
42 | -ms-border-radius: 8px 8px 0 0;
43 | -o-border-radius: 8px 8px 0 0;
44 | border-radius: 8px 8px 0 0;
45 | background: #C6EAFA;
46 | background: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #ddfbfc), color-stop(100%, #c6eafa));
47 | background: -webkit-linear-gradient(#ddfbfc, #c6eafa);
48 | background: -moz-linear-gradient(#ddfbfc, #c6eafa);
49 | background: -o-linear-gradient(#ddfbfc, #c6eafa);
50 | background: -ms-linear-gradient(#ddfbfc, #c6eafa);
51 | background: linear-gradient(#ddfbfc, #c6eafa);
52 | position: relative;
53 | padding: 15px 20px;
54 | border-bottom: 1px solid #B2D2E1;
55 | }
56 |
57 |
58 | a {
59 | color: #069;
60 | text-decoration: none;
61 | }
62 |
63 | p {
64 | margin: 0 0 20px;
65 | padding: 0;
66 | }
67 |
68 | strong {
69 | color: #222;
70 | font-weight: 700;
71 | }
72 |
73 | header h1 {
74 | margin: 0;
75 | padding: 0;
76 | font-size: 24px;
77 | line-height: 1.2;
78 | color: #069;
79 | text-shadow: rgba(255, 255, 255, 0.9) 0 1px 0;
80 | }
81 | header.without-description h1 {
82 | margin: 10px 0;
83 | }
84 | header p {
85 | margin: 0;
86 | color: #61778B;
87 | width: 300px;
88 | font-size: 13px;
89 | }
90 | header p.view {
91 | display: none;
92 | font-weight: 700;
93 | text-shadow: rgba(255, 255, 255, 0.9) 0 1px 0;
94 | -webkit-font-smoothing: antialiased;
95 | }
96 | header p.view a {
97 | color: #06c;
98 | }
99 | header p.view small {
100 | font-weight: 400;
101 | }
102 | header ul {
103 | margin: 0;
104 | padding: 0;
105 | list-style: none;
106 | position: absolute;
107 | z-index: 1;
108 | right: 20px;
109 | top: 20px;
110 | height: 38px;
111 | padding: 1px 0;
112 | background: #5198DF;
113 | background: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #77b9fb), color-stop(100%, #3782cd));
114 | background: -webkit-linear-gradient(#77b9fb, #3782cd);
115 | background: -moz-linear-gradient(#77b9fb, #3782cd);
116 | background: -o-linear-gradient(#77b9fb, #3782cd);
117 | background: -ms-linear-gradient(#77b9fb, #3782cd);
118 | background: linear-gradient(#77b9fb, #3782cd);
119 | border-radius: 5px;
120 | -webkit-box-shadow: inset rgba(255, 255, 255, 0.45) 0 1px 0, inset rgba(0, 0, 0, 0.2) 0 -1px 0;
121 | -moz-box-shadow: inset rgba(255, 255, 255, 0.45) 0 1px 0, inset rgba(0, 0, 0, 0.2) 0 -1px 0;
122 | box-shadow: inset rgba(255, 255, 255, 0.45) 0 1px 0, inset rgba(0, 0, 0, 0.2) 0 -1px 0;
123 | width: auto;
124 | }
125 | header ul:before {
126 | content: '';
127 | position: absolute;
128 | z-index: -1;
129 | left: -5px;
130 | top: -4px;
131 | right: -5px;
132 | bottom: -6px;
133 | background: rgba(0, 0, 0, 0.1);
134 | -webkit-border-radius: 8px;
135 | -moz-border-radius: 8px;
136 | -ms-border-radius: 8px;
137 | -o-border-radius: 8px;
138 | border-radius: 8px;
139 | -webkit-box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 0, inset rgba(255, 255, 255, 0.7) 0 -1px 0;
140 | -moz-box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 0, inset rgba(255, 255, 255, 0.7) 0 -1px 0;
141 | box-shadow: rgba(0, 0, 0, 0.2) 0 -1px 0, inset rgba(255, 255, 255, 0.7) 0 -1px 0;
142 | }
143 | header ul li {
144 | width: 79px;
145 | float: left;
146 | border-right: 1px solid #3A7CBE;
147 | height: 38px;
148 | }
149 | header ul li.single {
150 | border: none;
151 | }
152 | header ul li + li {
153 | width: 78px;
154 | border-left: 1px solid #8BBEF3;
155 | }
156 | header ul li + li + li {
157 | border-right: none;
158 | width: 79px;
159 | }
160 | header ul a {
161 | line-height: 1;
162 | font-size: 11px;
163 | color: #fff;
164 | color: rgba(255, 255, 255, 0.8);
165 | display: block;
166 | text-align: center;
167 | font-weight: 400;
168 | padding-top: 6px;
169 | height: 40px;
170 | text-shadow: rgba(0, 0, 0, 0.4) 0 -1px 0;
171 | }
172 | header ul a strong {
173 | font-size: 14px;
174 | display: block;
175 | color: #fff;
176 | -webkit-font-smoothing: antialiased;
177 | }
178 |
179 | section {
180 | padding: 15px 20px;
181 | font-size: 15px;
182 | border-top: 1px solid #fff;
183 | background: -webkit-gradient(linear, 50% 0%, 50% 700, color-stop(0%, #fafafa), color-stop(100%, #dedede));
184 | background: -webkit-linear-gradient(#fafafa, #dedede 700px);
185 | background: -moz-linear-gradient(#fafafa, #dedede 700px);
186 | background: -o-linear-gradient(#fafafa, #dedede 700px);
187 | background: -ms-linear-gradient(#fafafa, #dedede 700px);
188 | background: linear-gradient(#fafafa, #dedede 700px);
189 | -webkit-border-radius: 0 0 8px 8px;
190 | -moz-border-radius: 0 0 8px 8px;
191 | -ms-border-radius: 0 0 8px 8px;
192 | -o-border-radius: 0 0 8px 8px;
193 | border-radius: 0 0 8px 8px;
194 | position: relative;
195 | }
196 |
197 | h1, h2, h3, h4, h5, h6 {
198 | color: #222;
199 | padding: 0;
200 | margin: 0 0 20px;
201 | line-height: 1.2;
202 | }
203 |
204 | p, ul, ol, table, pre, dl {
205 | margin: 0 0 20px;
206 | }
207 |
208 | h1, h2, h3 {
209 | line-height: 1.1;
210 | }
211 |
212 | h1 {
213 | font-size: 28px;
214 | }
215 |
216 | h2 {
217 | color: #393939;
218 | }
219 |
220 | h3, h4, h5, h6 {
221 | color: #494949;
222 | }
223 |
224 | blockquote {
225 | margin: 0 -20px 20px;
226 | padding: 15px 20px 1px 40px;
227 | font-style: italic;
228 | background: #ccc;
229 | background: rgba(0, 0, 0, 0.06);
230 | color: #222;
231 | }
232 |
233 | img {
234 | max-width: 100%;
235 | }
236 |
237 | code, pre {
238 | font-family: Monaco, Bitstream Vera Sans Mono, Lucida Console, Terminal;
239 | color: #333;
240 | font-size: 12px;
241 | overflow-x: auto;
242 | }
243 |
244 | pre {
245 | padding: 20px;
246 | background: #6C7989;
247 | color: #f8f8f2;
248 | margin: 0 -20px 20px;
249 | }
250 | pre code {
251 | color: #6C7989;
252 | }
253 | li pre {
254 | margin-left: -60px;
255 | padding-left: 60px;
256 | }
257 |
258 | table {
259 | width: 100%;
260 | border-collapse: collapse;
261 | }
262 |
263 | th, td {
264 | text-align: left;
265 | padding: 5px 10px;
266 | border-bottom: 1px solid #aaa;
267 | }
268 |
269 | dt {
270 | color: #222;
271 | font-weight: 700;
272 | }
273 |
274 | th {
275 | color: #222;
276 | }
277 |
278 | small {
279 | font-size: 11px;
280 | }
281 |
282 | hr {
283 | border: 0;
284 | background: #aaa;
285 | height: 1px;
286 | margin: 0 0 20px;
287 | }
288 |
289 | footer {
290 | width: 640px;
291 | margin: 0 auto;
292 | padding: 20px 0 0;
293 | color: #ccc;
294 | overflow: hidden;
295 | }
296 | footer a {
297 | color: #fff;
298 | font-weight: bold;
299 | }
300 | footer p {
301 | float: left;
302 | }
303 | footer p + p {
304 | float: right;
305 | }
306 |
307 | @media print, screen and (max-width: 740px) {
308 | body {
309 | padding: 0;
310 | }
311 |
312 | .wrapper {
313 | -webkit-border-radius: 0;
314 | -moz-border-radius: 0;
315 | -ms-border-radius: 0;
316 | -o-border-radius: 0;
317 | border-radius: 0;
318 | -webkit-box-shadow: none;
319 | -moz-box-shadow: none;
320 | box-shadow: none;
321 | width: 100%;
322 | }
323 |
324 | footer {
325 | -webkit-border-radius: 0;
326 | -moz-border-radius: 0;
327 | -ms-border-radius: 0;
328 | -o-border-radius: 0;
329 | border-radius: 0;
330 | padding: 20px;
331 | width: auto;
332 | }
333 | footer p {
334 | float: none;
335 | margin: 0;
336 | }
337 | footer p + p {
338 | float: none;
339 | }
340 | }
341 | @media print, screen and (max-width:580px) {
342 | header ul {
343 | display: none;
344 | }
345 |
346 | header p.view {
347 | display: block;
348 | }
349 |
350 | header p {
351 | width: 100%;
352 | }
353 | }
354 |
355 | @media print {
356 | header p.view a small:before {
357 | content: 'at http://github.com/';
358 | }
359 | }
360 |
361 |
--------------------------------------------------------------------------------
/includes/languages/en/lang.php:
--------------------------------------------------------------------------------
1 | 'Using %s as zip method',
33 | 'TYPE_PHP' => 'php',
34 | 'TYPE_PHPBB' => 'phpBB',
35 | 'TYPE_EXEC' => 'exec',
36 | 'INVALID_ZIP_METHOD' => 'Invalid zip method %s',
37 |
38 | 'TITLE' => 'phpBB MOD Pre-Validator Results',
39 | 'TITLE_STATS' => 'MPV Stats',
40 | 'MIN_PHP' => 'PHP 5.2.0 is required',
41 | 'INVALID_ID' => 'Invalid ID',
42 | 'NO_DATA' => 'No data found',
43 | 'INVALID_MODE' => 'Invalid server mode',
44 | 'VALIDATION_RESULTS' => 'Validation results:',
45 | 'MEM_USE' => 'Memory Usage:',
46 | 'TOTAL_TIME' => 'Time : %.3fs',
47 | 'GB' => 'GB',
48 | 'GIB' => 'GiB',
49 | 'MB' => 'MB',
50 | 'MIB' => 'MiB',
51 | 'BYTES' => 'Bytes',
52 | 'KB' => 'KB',
53 | 'KIB' => 'KiB',
54 | 'NO_MODX_FILES' => 'No MODX files found in package',
55 | 'MODX_SCHEMA_INVALID' => 'Invalid XML/MODX [code]%s[/code]',
56 |
57 | 'FSOCK_DISABLED' => 'The operation could not be completed because the fsockopen function has been disabled or the server being queried could not be found.',
58 | 'FILE_NOT_FOUND' => 'The requested file could not be found',
59 | 'VERSION_FIELD_MISSING' => 'The version element is missing from the MODX file.',
60 | 'LICENSE_FIELD_MISSING' => 'The license element is missing from the MODX file.',
61 | 'TARGET_VERSION_NOT_FOUND' => 'The target-version element is missing from the MODX file',
62 | 'INVALID_VERSION_FORMAT' => 'The supplied version (%s) is invalid. The format should be: 1.0.0.',
63 |
64 | 'VALIDATING_ZIP' => '(Validating %s)',
65 | 'MAJOR_VERSION_UNSTABLE' => 'Your MOD version (%s) is unstable. It should be higher starting at 1.0.0.
66 | Example:
67 | [b]0.0.1[/b] is unstable
68 | [b]0.1.0[/b] is unstable
69 | [b]1.0.1[/b] is stable',
70 | 'VERSION_SHOULD_BE_VERSION' => 'The supplied version (%s) should just be a version like 1.0.0, and not be %s.',
71 |
72 | 'NOT_LATEST_PHPBB' => 'Target revision in the MODX file says the MOD is for %s while the latest phpBB version is %s',
73 |
74 | 'INVALID_INLINE_ACTION' => 'An inline action contains new lines [code]%s[/code]',
75 | 'INVALID_INLINE_FIND' => 'An inline find contains new lines [code]%s[/code]',
76 | 'SHORT_TAGS' => 'This file is using short open tags ( instead of 'The license specified in the MODX file may not be the GPLv2.',
79 |
80 | 'MODIFIED_XSL' => 'The MD5 signature of the XSL file is unknown, file might be modified. Found signature %s, expected newest %s',
81 | 'OLD_XSL' => 'You are using a old version of the MODX xsl. You should update the XSL prior to submitting',
82 | 'LICENSE_MD5' => 'Found a wrong md5 signature. Found %s while expected %s',
83 |
84 | 'MANY_EDIT_CHILDREN' => 'The MOD uses many edit children. This could indicate incorrect usage of the edit tag.',
85 | 'MULTIPLE_XSL' => 'You have multiple XSL files. It is preferred to have only one XSL file so as to not confuse the user.',
86 |
87 | 'NO_XSL_FOUND_IN_DIR' => 'There is no XSL found in directory %s. Starting from July 27, 2008 it is required/preferred to have an XSL file in all directories where a MODX file is located at due to a FireFox 3 limitation.',
88 | 'NO_XSL_FOUND_IN_DIR2' => 'IMPORTANT: MPV cannot detect if there is an XSL at a higher directory. Please test with FireFox 3 to verify it displays correctly. If the MOD displays correctly you can ignore above warning! See our policy for more information.',
89 |
90 | 'NO_LICENSE' => 'You are missing the required license.txt file.',
91 | 'NO_UNIX_ENDINGS' => 'This file doesn\'t use UNIX line endings.',
92 | 'NO_XSL_FILE' => 'You are missing the required XSL file for displaying the XML file in the browser.',
93 |
94 | 'USAGE_MYSQL' => 'You are using a hardcoded MySQL function at line %s: %sphpBB MODs are required to use the Database Abstraction Layer (DBAL).',
95 | 'USAGE_MYSQLI' => 'You are using a hardcoded MySQLi function at line %s: %sphpBB MODs are required to use the Database Abstraction Layer (DBAL).',
96 | 'USAGE_OCI' => 'You are using a hardcoded oci (oracle) function at line %s: %sphpBB MODs are required to use the Database Abstraction Layer (DBAL).',
97 | 'USAGE_SQLITE' => 'You are using a hardcoded SQLite function at line %s: %sphpBB MODs are required to use the Database Abstraction Layer (DBAL).',
98 | 'USAGE_PG' => 'You are using a hardcoded PostgreSQL function at line %s: %sphpBB MODs are required to use the Database Abstraction Layer (DBAL).',
99 | 'USAGE_MSSQL' => 'You are using a hardcoded MSSQL function at line %s: %sphpBB MODs are required to use the Database Abstraction Layer (DBAL).',
100 | 'USAGE_ODBC' => 'You are using a hardcoded ODBC function at line %s: %sphpBB MODs are required to use the Database Abstraction Layer (DBAL).',
101 | 'USAGE_SQLSRV' => 'You are using a hardcoded SQLSRV (MSSQL) function at line %s: %sphpBB MODs are required to use the Database Abstraction Layer (DBAL).',
102 | 'USAGE_IBASE' => 'You are using a hardcoded ibase (Interbase/Firebird) function at line %s: %sphpBB MODs are required to use the Database Abstraction Layer (DBAL).',
103 | 'USAGE_DB2' => 'You are using a hardcoded DB2 function at line %s: %sphpBB MODs are required to use the Database Abstraction Layer (DBAL).',
104 |
105 | 'USAGE_GET' => 'Using $_GET at line %s: %srequest_var() should be used instead.',
106 | 'USAGE_POST' => 'Using $_POST at line %s: %srequest_var() should be used instead.',
107 | 'USAGE_COOKIE' => 'Using $_COOKIE at line %s: %srequest_var() should be used with the fourth parameter.',
108 | 'USAGE_SERVER' => 'Using $_SERVER at line %s: %s[b]$_SERVER [u]IS[/u] user input![/b]',
109 | 'USAGE_SESSION' => 'Using $_SESSION at line %s: %sThe phpBB session system should be used instead.',
110 | 'USAGE_REQUEST' => 'Using $_REQUEST at line %s: %srequest_var should be used instead.',
111 | 'USAGE_ENV' => 'Using $_ENV at line %s: %s',
112 | 'USAGE_FILES' => 'Using $_FILES at line %s: %sThe upload functions included in phpBB should be used instead.',
113 | 'USAGE_GLOBALS' => 'Using $GLOBALS at line %s: %s',
114 |
115 | 'USAGE_PRINT' => 'Using print() at line %s: %s The phpBB template system should be used instead.',
116 | 'USAGE_PRINTF' => 'Using printf() at line %s: %s The phpBB template system should be used instead.',
117 | 'USAGE_ECHO' => 'Using echo() at line %s: %s The phpBB template system should be used instead.',
118 | 'USAGE_PRINTR' => 'Using printr() at line %s: %s The phpBB template system should be used instead.',
119 |
120 | 'USAGE_`' => 'Using backticks at line %s: %s',
121 | 'USAGE_EVAL' => 'Using eval() at line %s: %s',
122 | 'USAGE_EXEC' => 'Using exec() at line %s: %s',
123 | 'USAGE_SYSTEM' => 'Using system() at line %s: %s',
124 | 'USAGE_PASSTHRU' => 'Using passthru() at line %s: %s',
125 | 'USAGE_GETENV' => 'Using getenv() at line %s: %s',
126 | 'USAGE_DIE' => 'Using die() at line %s: %s',
127 | 'USAGE_MD5' => 'Using md5() at line %s: %sMD5 should not be used for anything related to passwords. Other usage of MD5 is probably valid.',
128 | 'USAGE_SHA1' => 'Using sha1() at line %s: %s',
129 | 'USAGE_ADDSLASHES' => 'Using addslashes() at line %s: %s',
130 | 'USAGE_STRIPSLASHES' => 'Using stripslashes() at line %s: %s',
131 | 'USAGE_HTMLSPECIALCHARS'=> 'Using htmlspecialchars() at line %s: %s',
132 | 'USAGE_INCLUDEONCE' => 'Using include_once() at line %s: %sUsing include with a function/class_exists check is preferred over include/require _once',
133 | 'USAGE_REQUIREONCE' => 'Using require_once() at line %s: %sUsing include with a function/class_exists check is preferred over include/require _once',
134 | 'USAGE_VARDUMP' => 'Using var_dump at line %s: %s',
135 |
136 | 'USAGE_BOM' => 'Your file is using a UTF-8 byte-order-mark (BOM)',
137 |
138 | 'USAGE_REQUEST_VAR_INT' => 'A call to request_var() is casting an integer to a string at line %s: %s',
139 |
140 | 'UNWANTED_FILE' => 'Your package contains an unwanted file "%2$s" in %1$s',
141 |
142 | 'INCLUDE_NO_ROOT' => 'A call to include or require is missing $phpbb_root_path in call at line %s: %s',
143 | 'INCLUDE_NO_PHP' => 'A call to include or require is missing $phpEx in call at line %s: %s',
144 |
145 | 'PACKAGE_NOT_EXISTS' => 'Choosen file (%s) does not exist',
146 | 'UNABLE_EXTRACT_PHP' => 'Unable to extract %s using php.',
147 | 'UNABLE_OPEN_PHP' => 'Unable to open %s using php.',
148 |
149 | 'LINK_NOT_EXISTS' => 'The file for link %s does not exist in the zip file.',
150 |
151 | 'NO_IN_PHPBB' => 'A define for IN_PHPBB is missing or there is no check for if IN_PHPBB is set.',
152 | 'FILE_EMPTY' => 'This PHP file has been detected as being empty.',
153 |
154 | 'COPY_BASENAME_DIFFER' => 'Basenames of the copy command differ: From %s to %s. Both should be the same',
155 |
156 | 'USING_MODX_OUTDATED' => 'You are using MODX version %s while the latest release of MODX is %s. Please update your MODX file to the latest version.',
157 | 'USING_MODX_UNKNOWN' => 'Found a invalid MODX version for XML file. Cannot continue pre-validating this file.',
158 |
159 | 'PROSILVER_NO_MAIN_MODX' => 'ProSilver style changes should be placed in the main MODX file and not in %s.',
160 | 'ENGLISH_NO_MAIN_MODX' => 'English language changes should be placed in the main MODX file and not in %s.',
161 |
162 | 'MPV_XML_ERROR' => 'XML error in MODX file %s',
163 |
164 | 'USAGE_BR_NON_CLOSED' => 'A BR is not closed correctly which causes invalid XHTML at line %s: %s',
165 | 'USAGE_IMG_NON_CLOSED' => 'An IMG is not closed correctly which causes invalid XHTML at line %s: %s',
166 |
167 | 'FILE_NON_BINARY' => 'File has been detected as non-binary while the extension IS binary. Checking for PHP code for security reasons. ',
168 |
169 | 'GENERAL_NOTICE' => 'Please note that all checks are done by an automated tool. In [u]some[/u] cases a FAIL/WARNING can be valid/allowed usage of a function.',
170 |
171 | 'UNABLE_OPEN' => 'Unable to open %s.',
172 | 'UNABLE_WRITE'=> 'Unable to write to %s.',
173 | 'PHP_ERROR' => 'A PHP error was found: [code]%s[/code]',
174 | 'NO_PRE_VAL_ERRORS' => 'No pre-validation problems found',
175 | 'REPORT_BY' => 'Report made by MPV',
176 | 'MPV_SERVER' => 'MPV server',
177 | 'UNKNOWN_OUTPUT' => 'Unknown output type',
178 | 'MPV_NOTICE' => 'MPV notice found at %1$s line %2$s: %3$s',
179 | 'MPV_WARNING' => 'MPV warning found at %1$s line %2$s: %3$s',
180 | 'MPV_NOTICE' => 'MPV notice found at %1$s line %2$s: %3$s',
181 | 'MPV_USER_NOTICE' => 'MPV user notice found at %1$s line %2$s: %3$s',
182 | 'MPV_GENERAL_ERROR' => 'MPV encountered an error at %1$s line %2$s: %3$s',
183 | 'MPV_FAIL_RESULT' => 'FAIL',
184 | 'MPV_NOTICE_RESULT' => 'NOTICE',
185 | 'MPV_WARNING_RESULT' => 'WARNING',
186 | 'MPV_INFO_RESULT' => 'INFO',
187 | 'INVALID_TYPE' => 'Invalid $type for this function!',
188 | 'MOD_NAME' => 'MOD Name',
189 | 'SUBMIT_COUNT' => 'Submission Count',
190 | 'TAG_DATA' => 'Tag Data',
191 | 'DATA_COUNT' => 'Data Count',
192 |
193 | 'NO_UMIL_VERSION' => 'Could not find UMIL_VERSION in umil.php',
194 | 'UMIL_OUTDATED' => 'The included UMIL is outdated.',
195 | 'INCORRECT_UMIL_MD5' => 'The included UMIL is modified.',
196 | 'UNKNOWN_VERSION_UMIL' => 'The included UMIL version is unknown. The can mean the version is outdated.',
197 | 'POSSIBLE_TWO_UMIL' => 'Possible 2 UMIL files included: %s and %s.',
198 |
199 | ));
200 |
--------------------------------------------------------------------------------
/includes/tests/tests_modx.php:
--------------------------------------------------------------------------------
1 | validator->modx_files) || !sizeof($this->validator->modx_files))
57 | {
58 | $this->validator->push_error(mpv::ERROR_FAIL, 'NO_MODX_FILES');
59 | return;
60 | }
61 |
62 | foreach ($this->validator->modx_files as $modx_filename => $modx_object)
63 | {
64 | $this->modx_filename = $this->file_name = $modx_filename;
65 |
66 | if (mpv::check_unwanted($modx_filename))
67 | {
68 | continue;
69 | }
70 |
71 | if (preg_match('#modx-(.*?)\.xsd#s', (string) $modx_object, $matches))
72 | {
73 | $current_modx_version = mpv::get_current_version('modx');
74 | if ($matches[1] != $current_modx_version)
75 | {
76 | $this->push_error(mpv::ERROR_FAIL, 'USING_MODX_OUTDATED', array($matches[1], $current_modx_version));
77 | //continue;
78 | }
79 | //Let's see if we can download the file from phpbb.compact
80 | if (!LOCAL_ONLY && !@file_exists($this->validator->dir . 'store/data/' . $matches[0]))
81 | {
82 | $data = @file_get_contents("http://www.phpbb.com/mods/xml/{$matches[0]}");
83 |
84 | //Now we write out the .xsd
85 | if (isset($data) && $data !== false)
86 | {
87 | $cache = @fopen($this->validator->dir . 'store/data/' . $matches[0], 'wb');
88 | @fwrite($cache, $data);
89 | @fclose($cache);
90 | }
91 | else
92 | {
93 | $this->push_error(mpv::ERROR_FAIL, sprintf('UNABLE_OPEN', "http://www.phpbb.com/mods/xml/{$matches[0]}"));
94 | continue;
95 | }
96 | }
97 | $errors = $modx_object->validate($this->validator->dir . 'store/data/' . $matches[0]);
98 | }
99 | else
100 | {
101 | $this->push_error(mpv::ERROR_FAIL, 'USING_MODX_UNKNOWN');
102 | continue;
103 | }
104 |
105 | if ($errors !== true)
106 | {
107 | foreach ($errors as $error)
108 | {
109 | $this->push_error(mpv::ERROR_FAIL, 'MODX_SCHEMA_INVALID', $error);
110 | }
111 | continue;
112 | }
113 |
114 | $this->failed_tests = array();
115 |
116 | $this->modx_object = $modx_object;
117 | $this->modx_dir = $this->extract_dir($modx_filename);
118 | $mod_title = $this->modx_object->get_xpath('//header/title', true);
119 |
120 | //Do we need to store some statistics?
121 | if (sizeof($statistics))
122 | {
123 | foreach ($statistics as $tag => $properties)
124 | {
125 | $line_to_write = '';
126 |
127 | //First we need to get the tag's existing nodes
128 | $tag_node = $this->modx_object->get_by_name($tag, false);
129 | //Now we go through each node to get the properties
130 | foreach ($tag_node as $node)
131 | {
132 | foreach ($properties as $property)
133 | {
134 | if (empty($line_to_write))
135 | {
136 | //Let's start with the MOD's title
137 | $line_to_write = $mod_title->value;
138 | }
139 | //Let's build the string we're going to save
140 | $line_to_write .= "||" . $property . ": " . $node->attributes[$property];
141 | }
142 | }
143 | if (!empty($line_to_write))
144 | {
145 | //Open text file and write to it
146 | $file_handle = @fopen($this->validator->dir . 'store/data/' . $tag . '_data.txt', 'a');
147 | if ($file_handle !== false)
148 | {
149 | @fwrite($file_handle, $line_to_write . "\r\n");
150 | @fclose($fh);
151 | }
152 | }
153 | }
154 |
155 | }
156 |
157 | foreach ($test_methods as $method)
158 | {
159 | if (substr($method, 0, 5) == 'test_')
160 | {
161 | if (!$this->$method() || $this->terminate)
162 | {
163 | $this->failed_tests[] = substr($method, 5);
164 | }
165 |
166 | if ($this->terminate)
167 | {
168 | return;
169 | }
170 | }
171 | }
172 | }
173 | }
174 |
175 | /**
176 | * Test the MOD's version
177 | *
178 | * @access public
179 | * @return bool
180 | */
181 | protected function test_version()
182 | {
183 | $version = $this->modx_object->get_xpath('//header/mod-version', true);
184 |
185 | if (!is_object($version))
186 | {
187 | $this->push_error(mpv::ERROR_FAIL, 'VERSION_FIELD_MISSING');
188 |
189 | return false;
190 | }
191 | $version = strtolower($version->value);
192 |
193 | $unstable = array(
194 | 'rc',
195 | 'alpha',
196 | 'beta',
197 | 'dev',
198 | 'a',
199 | 'b',
200 | );
201 |
202 | $option = implode('|', $unstable);
203 |
204 | // Check the version format and numbering
205 | if (preg_match('#((\d+)\.)+(\d+)[a-z]?#', $version, $matches))
206 | {
207 | if (preg_match('#((\d+)\.)+(\d+)-(' . $option . '+)(\d+{0,)?#i', $version, $matches))
208 | {
209 | $this->push_error(mpv::ERROR_FAIL, 'MAJOR_VERSION_UNSTABLE', array($version));
210 | return false;
211 | }
212 |
213 | if (version_compare('1.0.0', $version) > 0)
214 | {
215 | $this->push_error(mpv::ERROR_FAIL, 'MAJOR_VERSION_UNSTABLE', array($version));
216 | return false;
217 | }
218 | }
219 | else
220 | {
221 | // Not a valid version
222 | $this->push_error(mpv::ERROR_FAIL, 'INVALID_VERSION_FORMAT', array($version));
223 | return false;
224 | }
225 |
226 | return true;
227 | }
228 |
229 | protected function test_xsl_exists()
230 | {
231 | $found = false;
232 | foreach ($this->validator->xsl_files as $xsl_file)
233 | {
234 | if ($this->modx_dir == $this->extract_dir($xsl_file))
235 | {
236 | $found = true;
237 |
238 | break;
239 | }
240 | }
241 |
242 | if (!$found)
243 | {
244 | $this->push_error(mpv::ERROR_NOTICE, 'NO_XSL_FOUND_IN_DIR', $this->modx_dir);
245 | $this->push_error(mpv::ERROR_NOTICE, 'NO_XSL_FOUND_IN_DIR2', $this->modx_dir);
246 | }
247 | return $found;
248 | }
249 |
250 | /**
251 | * Check whether files to open exist in the phpBB package
252 | * @return bool
253 | * @access private
254 | */
255 | protected function test_open()
256 | {
257 | $return = true;
258 | $open_ary = $this->modx_object->get_by_name('open', false);
259 |
260 | foreach ($open_ary as $open_src)
261 | {
262 | $filename_ary[] = $open_src->attributes['src'];
263 | }
264 | unset($open_ary);
265 |
266 | $files_array = file($this->validator->dir . 'includes/tests/filelist.txt');
267 |
268 | // Simulation of in_array. Might be able to switch back to the actual
269 | // function.
270 | /**
271 | * @TODO: Does this actually work?
272 | */
273 | foreach ($files_array as $filename)
274 | {
275 | $match = false;
276 | foreach ($files_array as $test_filename)
277 | {
278 | if (trim($filename) == trim($test_filename))
279 | {
280 | $match = true;
281 | break;
282 | }
283 | }
284 |
285 | if (!$match)
286 | {
287 | $return = false;
288 |
289 | if (strpos($filename, '/') === 0)
290 | {
291 | $this->push_error(mpv::ERROR_FAIL, 'OPEN_FAIL_LEADING_SLASH');
292 | }
293 | else if (strpos($filename, '\\') !== false)
294 | {
295 | $this->push_error(mpv::ERROR_FAIL, 'OPEN_FAIL_BACKSLASH');
296 | }
297 | else if (preg_match('#language/[a-z_.]+/(.*)\.php#', $filename))
298 | {
299 | $this->push_error(mpv::ERROR_NOTICE, 'OPEN_FAIL_TRANSLATION');
300 | }
301 | else if (preg_match('#styles/[a-z_.]+/(.*)/#', $filename))
302 | {
303 | $this->push_error(mpv::ERROR_NOTICE, 'OPEN_FAIL_STYLE');
304 | }
305 | else
306 | {
307 | $this->push_error(mpv::ERROR_FAIL, 'OPEN_FAIL_NOT_EXISTS');
308 | }
309 | }
310 | }
311 |
312 | return $return;
313 | }
314 |
315 | /**
316 | * Check if the opens are the same.
317 | *
318 | * @access private
319 | * @return bool
320 | */
321 | protected function test_copy()
322 | {
323 | $copy_ary = $this->modx_object->get_by_name('//action-group/copy/file', false);
324 |
325 | $return = true;
326 |
327 | foreach ($copy_ary as $copy_tag)
328 | {
329 | $from = str_replace('\\', '/', $copy_tag->attributes['from']);
330 | $to = str_replace('\\', '/', $copy_tag->attributes['to']);
331 | if (isset ($from) && isset($to) && trim(basename($from)) != trim(basename($to)))
332 | {
333 | $this->push_error(mpv::ERROR_FAIL, 'COPY_BASENAME_DIFFER', array(basename($from), basename($to)));
334 |
335 | $return = false;
336 | }
337 | }
338 |
339 | return $return;
340 | }
341 |
342 | /**
343 | * Attempt to detect whether edit tags are well-formed
344 | * @access private
345 | * @return bool
346 | */
347 | protected function test_edit()
348 | {
349 | // First, grab all of the edit tags
350 | $edit_ary = $this->modx_object->get_by_name('edit', false);
351 |
352 | $return = true;
353 |
354 | // Then grab the children of each edit tag
355 | foreach ($edit_ary as $edit_tag)
356 | {
357 | // This is pretty darn simplistic, but it stands to reason.
358 | // Two children is normal, three will happen occasionally
359 | // Four is very rare unless the author did something wrong :)
360 | // And at five we give a fail by default.
361 | // PAUL: changed from 2 3/5 to 5/7.
362 | if (isset($edit_tag->children[5]))
363 | {
364 | $this->push_error(mpv::ERROR_NOTICE, 'MANY_EDIT_CHILDREN');
365 |
366 | $return = false;
367 | }
368 | else if (isset($edit_tag->children[7])) // Changed from 3 to 5, no idea why this one was the same as above?
369 | {
370 | $this->push_error(mpv::ERROR_FAIL, 'MANY_EDIT_CHILDREN');
371 |
372 | $return = false;
373 | }
374 | }
375 | return $return;
376 | }
377 |
378 | /**
379 | * Check if license matches "boilerplate" GPLv2 notice
380 | * @access private
381 | * @return bool
382 | */
383 | protected function test_license()
384 | {
385 | $license = $this->modx_object->get_by_name('license', true);
386 |
387 | if (!is_object($license))
388 | {
389 | $this->push_error(mpv::ERROR_FAIL, 'LICENSE_FIELD_MISSING');
390 |
391 | return false;
392 | }
393 | $license = $license->value;
394 |
395 | $allowed_licenses = array(
396 | 'http://opensource.org/licenses/gpl-license.php GNU General Public License v2',
397 | 'http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2',
398 | );
399 |
400 | if (!in_array($license, $allowed_licenses))
401 | {
402 | $this->push_error(mpv::ERROR_WARNING, 'LICENSE_NOT_GPL2');
403 |
404 | return false;
405 | }
406 |
407 | return true;
408 | }
409 |
410 | /**
411 | * Test whether in-line find tags contain new lines
412 | * @access private
413 | * @return bool
414 | */
415 | protected function test_inline_find()
416 | {
417 | $return = true;
418 | $inline_find_ary = $this->modx_object->get_by_name('inline-find', false);
419 |
420 | foreach ($inline_find_ary as $inline_find_tag)
421 | {
422 | $contents = $inline_find_tag->value;
423 | if (strpos($contents, "\n") !== false)
424 | {
425 | $return = false;
426 | $this->push_error(mpv::ERROR_FAIL, 'INVALID_INLINE_FIND', $contents);
427 | }
428 | }
429 |
430 | return $return;
431 | }
432 |
433 | /**
434 | * Test whether in-line action tags contain new lines
435 | * @access private
436 | * @return bool
437 | */
438 | protected function test_inline_action()
439 | {
440 | $return = true;
441 | $inline_action_ary = $this->modx_object->get_by_name('inline-action', false);
442 |
443 | foreach ($inline_action_ary as $inline_action_tag)
444 | {
445 | $contents = $inline_action_tag->value;
446 | if (strpos($contents, "\n") !== false)
447 | {
448 | $return = false;
449 | $this->push_error(mpv::ERROR_FAIL, 'INVALID_INLINE_ACTION', $contents);
450 | }
451 | }
452 |
453 | return $return;
454 | }
455 |
456 | /**
457 | * Test whether links exist
458 | * Note: links can be external, and we can't very well check those. They are
459 | * exempt from the check
460 | * @return bool
461 | * @access private
462 | */
463 | protected function test_links()
464 | {
465 | $return = true;
466 | $link_ary = $this->modx_object->get_by_name('link', false);
467 |
468 | foreach ($link_ary as $link_tag)
469 | {
470 | $link_href = $link_tag->attributes['href'];
471 |
472 | if (!file_exists($this->validator->temp_dir . $this->modx_dir . $link_href) && strpos($link_href, '://') === false)
473 | {
474 | $return = false;
475 | $this->push_error(mpv::ERROR_FAIL, 'LINK_NOT_EXISTS', $link_href);
476 | }
477 | }
478 |
479 | return $return;
480 | }
481 |
482 | /**
483 | * Test the phpBB version
484 | */
485 | protected function test_phpbb_version()
486 | {
487 | $return = true;
488 |
489 | $phpbb_version = $this->modx_object->get_by_name('target-version', true);
490 | //If we're only going to be local then we get the version from the config file
491 | $current_phpbb_version = mpv::get_current_version('phpbb');
492 |
493 | if (!is_object($phpbb_version))
494 | {
495 | $this->push_error(mpv::ERROR_FAIL, 'TARGET_VERSION_NOT_FOUND');
496 |
497 | $return = false;
498 | }
499 | else if (version_compare(strtolower(trim($phpbb_version->value)), strtolower($current_phpbb_version), '<'))
500 | {
501 | if (mpv::$mod_dir . '/' . basename($this->modx_filename) == $this->modx_filename)
502 | {
503 | $this->push_error(mpv::ERROR_FAIL , 'NOT_LATEST_PHPBB', array($phpbb_version->value, $current_phpbb_version));
504 | }
505 | else
506 | {
507 | $this->push_error(mpv::ERROR_WARNING , 'NOT_LATEST_PHPBB', array($phpbb_version->value, $current_phpbb_version));
508 | }
509 |
510 | $return = false;
511 | }
512 |
513 | return $return;
514 | }
515 | }
516 |
--------------------------------------------------------------------------------
/includes/tests/tests_code.php:
--------------------------------------------------------------------------------
1 | validator->package_files) || !sizeof($this->validator->package_files))
31 | {
32 | return;
33 | }
34 |
35 | foreach ($this->validator->package_files as $package_file)
36 | {
37 | $this->file_name = $package_file;
38 |
39 | if (mpv::check_unwanted($package_file))
40 | {
41 | continue;
42 | }
43 |
44 | // Only test PHP files
45 | // We also check files that should be binary, but arent.
46 | // Maybe there is php in that?
47 | if (in_array(substr($package_file, -3), array('.md', 'txt', 'tml', 'htm', 'tpl', 'xsl', 'xml', 'css', '.js', 'sql', 'ess')) || $this->check_binary($this->validator->temp_dir . $package_file))
48 |
49 | {
50 | continue;
51 | }
52 |
53 | $this->failed_tests = array();
54 |
55 | $this->file_contents = file_get_contents($this->validator->temp_dir . $package_file);
56 |
57 | $this->file_contents_file = file($this->validator->temp_dir . $package_file);
58 |
59 | unset($content);
60 |
61 | foreach ($test_methods as $method)
62 | {
63 | if (substr($method, 0, 5) == 'test_')
64 | {
65 | if (!$this->$method() || $this->terminate)
66 | {
67 | $this->failed_tests[] = substr($method, 5);
68 | }
69 |
70 | if ($this->terminate)
71 | {
72 | unset($this->file_contents, $this->file_contents_file);
73 |
74 | return;
75 | }
76 | }
77 | }
78 |
79 | unset($this->file_contents, $this->file_contents_file);
80 | }
81 | }
82 |
83 | /**
84 | * Add a note if a file isnt a binary, but extension is binary.
85 | * Allowed non binary extension:
86 | * txt, php, html, htm, tpl, xml, xsl, css
87 | */
88 | protected function check_binary($filename)
89 | {
90 | $base = basename($filename);
91 | $ext = substr($base, -3);
92 |
93 | if (in_array($ext, array('.md', 'txt', 'php', 'tml', 'htm', 'tpl', 'xsl', 'xml', 'css', '.js', 'sql', 'ess')))
94 | {
95 | return false;
96 | }
97 | /**
98 | * Perl version:
99 | *
100 | # Is this a binary file? Let's look at the first few
101 | # lines to figure it out:
102 | for line in lines[:5]:
103 | for c in line.rstrip():
104 | if c.isspace():
105 | continue
106 | if c < ' ' or c > chr(127):
107 | lines = BINARY_EXPLANATION_LINES[:]
108 | break
109 | *
110 | */
111 | $file = file($filename);
112 |
113 | for ($i = 0, $count = sizeof($file); $i < $count; $i++)
114 | {
115 | if ($i > 5)
116 | {
117 | break;
118 | }
119 | for ($j = 0, $count2 = strlen($file[$i]); $j < $count2; $j++)
120 | {
121 | if ($file[$i][$j] > chr(127))
122 | {
123 | unset($file);
124 | return true;
125 | }
126 | }
127 | }
128 | unset($file);
129 |
130 | $this->push_error(MPV::ERROR_FAIL, 'FILE_NON_BINARY');
131 |
132 | return false;
133 |
134 | }
135 |
136 | /**
137 | * Enter description here...
138 | *
139 | * @access private
140 | * @return bool
141 | */
142 | protected function test_empty()
143 | {
144 | if (strlen(trim($this->file_contents)) == 0)
145 | {
146 | $this->push_error(MPV::ERROR_WARNING, 'FILE_EMPTY');
147 |
148 | $this->terminate = true;
149 | return false;
150 | }
151 | return true;
152 | }
153 |
154 | /**
155 | * Test for the use of improper line endings
156 | *
157 | * @access private
158 | * @return bool
159 | */
160 | protected function test_unix_endings()
161 | {
162 | if (strpos($this->file_contents, "\r") !== false)
163 | {
164 | $this->push_error(mpv::ERROR_WARNING, 'NO_UNIX_ENDINGS');
165 | return false;
166 | }
167 |
168 | return true;
169 | }
170 |
171 | /**
172 | * Test for the use of short tags ()
173 | *
174 | * @access private
175 | * @return bool
176 | */
177 | protected function test_short_tags()
178 | {
179 | $strpos = '';
180 | if (strpos($this->file_contents, "=") !== false)
181 | {
182 | $strpos = '=';
183 | }
184 | else if (strpos($this->file_contents, ' ') !== false)
185 | {
186 | $strpos = ' ';
187 | }
188 | else if (strpos($this->file_contents, "\r") !== false)
189 | {
190 | $strpos = "\r";
191 | }
192 | else if (strpos($this->file_contents, "\n") !== false)
193 | {
194 | $strpos = "\n";
195 | }
196 |
197 | if ($strpos)
198 | {
199 | return $this->display_line_code(mpv::ERROR_FAIL, 'SHORT_TAGS', $strpos);
200 | }
201 |
202 | return true;
203 | }
204 | /**
205 | * Tests to see if IN_PHPBB is defined.
206 | *
207 | * @access private
208 | * @return bool
209 | */
210 | protected function test_in_phpbb()
211 | {
212 | if (preg_match("#(a|u|m)cp/info/(a|u|m)cp_(.?)#i", $this->file_name))
213 | {
214 | // Ignore info files
215 | return true;
216 | }
217 | if (preg_match("#define([ ]+){0,1}\(([ ]+){0,1}'IN_PHPBB'#", $this->file_contents))
218 | {
219 | return true;
220 | }
221 | else if (preg_match("#defined([ ]+){0,1}\(([ ]+){0,1}'IN_PHPBB'#", $this->file_contents))
222 | {
223 | return true;
224 | }
225 | $this->push_error(MPV::ERROR_FAIL, 'NO_IN_PHPBB');
226 | return false;
227 | }
228 |
229 | /**
230 | * Test for mysql_* (DBAL) functions
231 | *
232 | * @access private
233 | * @return bool
234 | */
235 | protected function test_dbal()
236 | {
237 | $return = true;
238 |
239 | $functions = array(
240 | 'mysql_',
241 | 'mysqli_',
242 | 'oci_',
243 | 'sqlite_',
244 | 'pg_',
245 | 'mssql_',
246 | 'odbc_',
247 | 'sqlsrv_',
248 | 'ibase_',
249 | 'db2_',
250 | );
251 |
252 | foreach ($functions as $function)
253 | {
254 |
255 | if (preg_match("#(^\s*|[^a-z0-9_])" . preg_quote($function, '#') . "{1}([a-zA-Z0-9_]+){1,}\s*\({1}#si", $this->file_contents))
256 | {
257 | if ($this->display_line_code(mpv::ERROR_FAIL, 'USAGE_' . strtoupper(str_replace(array('_', '$', '('), '', $function)), false, "#(^\s*|[^a-z0-9_])" . preg_quote($function, '#') . "{1}([a-zA-Z0-9_]+){1,}\s*\({1}#si", array('new', 'function')))
258 | {
259 | $return = false;
260 | }
261 | }
262 | }
263 | return $return;
264 | }
265 |
266 | /**
267 | * Test for some basic disallowed functions
268 | *
269 | * @access private
270 | * @return bool
271 | */
272 | protected function test_code()
273 | {
274 | $return = true;
275 |
276 | $functions = array(
277 | 'eval' => mpv::ERROR_FAIL,
278 | 'exec' => mpv::ERROR_FAIL,
279 | 'system' => mpv::ERROR_FAIL,
280 | 'passthru' => mpv::ERROR_FAIL,
281 | 'getenv' => mpv::ERROR_FAIL,
282 | 'die' => mpv::ERROR_FAIL,
283 | 'addslashes' => mpv::ERROR_FAIL,
284 | 'stripslashes' => mpv::ERROR_FAIL,
285 | 'htmlspecialchars' => mpv::ERROR_FAIL,
286 | 'include_once' => mpv::ERROR_NOTICE,
287 | 'require_once' => mpv::ERROR_NOTICE,
288 | 'md5' => mpv::ERROR_WARNING,
289 | 'sha1' => mpv::ERROR_WARNING,
290 | );
291 |
292 | $functions_none = array(
293 | '`'
294 | );
295 |
296 | $functions_without = array(
297 | 'include_once' => mpv::ERROR_NOTICE,
298 | 'require_once' => mpv::ERROR_NOTICE,
299 | );
300 |
301 | foreach ($functions as $function => $code)
302 | {
303 | if (preg_match("#(^\s*|[^a-z0-9_])" . preg_quote($function, '#') . "{1}\s*\({1}#si", $this->file_contents))
304 | {
305 | if ($this->display_line_code($code, 'USAGE_' . strtoupper(str_replace(array('_', '$', '('), '', $function)), false, "#(^\s*|[^a-z0-9_])" . preg_quote($function) . "([ \(|\(| ]+)#si"))
306 | {
307 | $return = false;
308 | }
309 | }
310 | }
311 |
312 | foreach ($functions_without as $function => $code)
313 | {
314 | if (preg_match("#(^\s*|[^a-z0-9_])" . preg_quote($function, '#') . "{1}\s*\({0}#si", $this->file_contents))
315 | {
316 | if ($this->display_line_code($code, 'USAGE_' . strtoupper(str_replace(array('_', '$', '('), '', $function)), false, "#(^\s*|[^a-z0-9_])" . preg_quote($function) . "([ \(|\(| ]+)#si"))
317 | {
318 | $return = false;
319 | }
320 | }
321 | }
322 |
323 | foreach ($functions_none as $function)
324 | {
325 | if (preg_match("#" . preg_quote($function, '#') . "#si", $this->file_contents) && strpos($this->file_name, '/language/') == 0)
326 | {
327 | if ($this->display_line_code(mpv::ERROR_FAIL, 'USAGE_' . strtoupper(str_replace(array('_', '$', '('), '', $function)), false, "#" . preg_quote($function) . "#si"))
328 | {
329 | $return = false;
330 | }
331 | }
332 | }
333 |
334 | return $return;
335 | }
336 |
337 | /**
338 | * Test for print/echo functions
339 | *
340 | * @access private
341 | * @return bool
342 | */
343 | protected function test_echo()
344 | {
345 | $return = true;
346 |
347 | $functions = array(
348 | 'print_r',
349 | 'var_dump',
350 | 'printf',
351 | );
352 |
353 | $functions_none = array(
354 | 'print',
355 | 'echo',
356 | );
357 |
358 | foreach ($functions as $function)
359 | {
360 | if (preg_match("#(^\s*|[^a-z0-9_])" . preg_quote($function, '#') . "{1}\s*\({1}#si", $this->file_contents))
361 | {
362 | if ($this->display_line_code(mpv::ERROR_FAIL, 'USAGE_' . strtoupper(str_replace(array('_', '$', '('), '', $function)), false, "#(^\s*|[^a-z0-9_])" . preg_quote($function) . "([ \(|\(| ]+)#si"))
363 | {
364 | $return = false;
365 | }
366 | }
367 | }
368 |
369 | foreach ($functions_none as $function)
370 | {
371 | if (preg_match("#(^\s*|[^a-z0-9_])" . preg_quote($function, '#') . "{1}\s*\({0,1}#si", $this->file_contents))
372 | {
373 | if ($this->display_line_code(mpv::ERROR_FAIL, 'USAGE_' . strtoupper(str_replace(array('_', '$', '('), '', $function)), false, "#(^\s*|[^a-z0-9_])" . preg_quote($function) . "([ \(|\(| ]+)#si", array('fread')))
374 | {
375 | $return = false;
376 | }
377 | }
378 | }
379 | return $return;
380 | }
381 |
382 | /**
383 | * Test for $_*[]
384 | *
385 | * @access private
386 | * @return bool
387 | */
388 | protected function test_globals()
389 | {
390 | $return = true;
391 |
392 | $fail_functions = array(
393 | '$GLOBALS',
394 | '$HTTP_POST_VARS',
395 | '$HTTP_GET_VARS',
396 | '$HTTP_SERVER_VARS',
397 | '$HTTP_ENV_VARS',
398 | '$HTTP_COOKIE_VARS',
399 | '$HTTP_POST_FILES',
400 | '$HTTP_SESSION_VARS',
401 | '$_FILES',
402 | );
403 |
404 | $warning_functions = array(
405 | '$_SESSION',
406 | '$_SERVER',
407 | '$_ENV',
408 | '$_REQUEST',
409 | );
410 |
411 | $isset_functions = array(
412 | '$_POST',
413 | '$_GET',
414 | '$_COOKIE',
415 | );
416 |
417 | foreach ($warning_functions as $function)
418 | {
419 | if (strpos($this->file_contents, $function) !== false)
420 | {
421 | if ($this->display_line_code(mpv::ERROR_WARNING, 'USAGE_' . strtoupper(str_replace(array('_' , '$'), '', $function)), $function, false, array('isset', 'empty')))
422 | {
423 | $return = false;
424 | }
425 | }
426 | }
427 |
428 | foreach ($fail_functions as $function)
429 | {
430 | if (strpos($this->file_contents, $function) !== false)
431 | {
432 | $lower = strtoupper(str_replace(array('_' , '$'), '', $function));
433 | if ($this->display_line_code(mpv::ERROR_FAIL, 'USAGE_' . $lower, $function, false))
434 | {
435 | $return = false;
436 | }
437 | }
438 | }
439 |
440 | foreach ($isset_functions as $function)
441 | {
442 | if (strpos($this->file_contents, $function) !== false)
443 | {
444 | $lower = strtoupper(str_replace(array('_' , '$'), '', $function));
445 | if ($this->display_line_code(mpv::ERROR_FAIL, 'USAGE_' . $lower, $function, false, array('isset', 'empty')))
446 | {
447 | $return = false;
448 | }
449 | }
450 | }
451 |
452 | return $return;
453 | }
454 |
455 | /**
456 | * Checks for the request_var usage with integers. Should match on "0" and '0'
457 | *
458 | * @access private
459 | * @return bool
460 | */
461 | protected function test_request_var()
462 | {
463 | //
464 | if (preg_match("#request_var\((['|\"]+)(.*)(['|\"]+), (['|\"]+)([0-9]+)(['|\"]+)#si", $this->file_contents))
465 | {
466 | $this->display_line_code(mpv::ERROR_FAIL, 'USAGE_REQUEST_VAR_INT', false, "#request_var\((['|\"]+)(.*)(['|\"]+), (['|\"]+)([0-9]+)(['|\"]+)#si");
467 | return false;
468 | }
469 |
470 | return true;
471 | }
472 |
473 | /**
474 | *
475 | */
476 | protected function test_include()
477 | {
478 | $return = true;
479 |
480 | $in_comment = false;
481 | foreach ($this->file_contents_file as $line => $content)
482 | {
483 | $content_new = $content;
484 | $loc = strpos($content, '*/');
485 |
486 | if ($in_comment && $loc === false)
487 | {
488 | $content_new = '';
489 | }
490 | else if ($in_comment && $loc !== false)
491 | {
492 | // Need to replace everything till */
493 | $total = strlen($content_new);
494 | $negative = $total - $loc;
495 | $total = $total - $negative;
496 |
497 | $content_new = substr($content_new, ($loc + 2));
498 | $in_comment = false;
499 | }
500 | else if(!$in_comment && strpos($content, '/*') !== false)
501 | {
502 | if ($loc !== false) // Used as inline
503 | {
504 | $content_new = preg_replace('#/\*(.*)\*/#si', '', $content_new);
505 | }
506 | else
507 | {
508 | $in_comment = true;
509 |
510 | $content_new = substr($content_new, 0, strpos($content, '/*'));
511 | }
512 | }
513 | $loc = strpos($content_new, '//');
514 | if ($loc !== false)
515 | {
516 | $content_new = substr($content_new, 0, $loc + 2);
517 | }
518 |
519 | if (preg_match("#^(include_once|require_once|include|require)(\s'|\s\"|\s\$|\s\(|\()#", trim($content_new)))
520 | {
521 | if (strpos($content_new, '$phpbb_root_path') === false && strpos($content_new, '$phpbb_admin_path') === false)
522 | {
523 | $return = false;
524 |
525 | $this->push_error(mpv::ERROR_WARNING, 'INCLUDE_NO_ROOT', array((string)($line + 1), '[code]' . trim($content) . '[/code]'));
526 | }
527 | if (strpos($content_new, '.php') !== false && strpos($content_new, '$phpEx') === false)
528 | {
529 | $return = false;
530 |
531 | $this->push_error(mpv::ERROR_WARNING, 'INCLUDE_NO_PHP', array((string)($line + 1), '[code]' . trim($content) . '[/code]'));
532 | }
533 | }
534 | }
535 | return $return;
536 | }
537 | }
538 |
--------------------------------------------------------------------------------
/includes/languages/fr/lang.php:
--------------------------------------------------------------------------------
1 | (Maël Soucaze) http://mael.soucaze.com/
24 | * @copyright (c) 2010 phpBB Group
25 | * @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License
26 | * @version $Id$
27 | *
28 | */
29 |
30 | if (empty($lang) || !is_array($lang))
31 | {
32 | $lang = array();
33 | }
34 |
35 | // DEVELOPERS PLEASE NOTE
36 | //
37 | // All language files should use UTF-8 as their encoding and the files must not contain a BOM.
38 | //
39 | // Placeholders can now contain order information, e.g. instead of
40 | // 'Page %s of %s' you can (and should) write 'Page %1$s of %2$s', this allows
41 | // translators to re-order the output of data while ensuring it remains correct
42 | //
43 | // You do not need this where single placeholders are used, e.g. 'Message %d' is fine
44 | // equally where a string contains only two placeholders which are used to wrap text
45 | // in a url you again do not need to specify an order e.g., 'Click %sHERE%s' is fine
46 |
47 | $lang = array_merge($lang, array(
48 | // Only used for debug purposes.
49 | 'ZIP_METHOD' => 'Utilisant %s comme une méthode ZIP',
50 | 'TYPE_PHP' => 'PHP',
51 | 'TYPE_PHPBB' => 'phpBB',
52 | 'TYPE_EXEC' => 'Exécutable',
53 | 'INVALID_ZIP_METHOD' => '%s est une méthode ZIP invalide',
54 |
55 | 'TITLE' => 'Résultats du MOD Pre-Validator de phpBB',
56 | 'TITLE_STATS' => 'Statistiques de MPV',
57 | 'MIN_PHP' => 'PHP 5.2.0 est obligatoire',
58 | 'INVALID_ID' => 'ID invalide',
59 | 'NO_DATA' => 'Aucune donnée n’a été trouvée',
60 | 'VALIDATION_RESULTS' => 'Résultats de la validation :',
61 | 'MEM_USE' => 'Utilisation de la mémoire :',
62 | 'TOTAL_TIME' => 'Durée : %.3fs',
63 | 'GB' => 'Go',
64 | 'GIB' => 'Gio',
65 | 'MB' => 'Mo',
66 | 'MIB' => 'Mio',
67 | 'BYTES' => 'Octets',
68 | 'KB' => 'Ko',
69 | 'KIB' => 'Kio',
70 | 'NO_MODX_FILES' => 'Aucun fichier MODX n’a été trouvé dans cette archive',
71 | 'MODX_SCHEMA_INVALID' => 'XML/MODX invalide [code]%s[/code]',
72 |
73 | 'FSOCK_DISABLED' => 'L’opération n’a pas pu se terminer car la fonction fsockopen a été désactivée ou le serveur demandé est introuvable.',
74 | 'FILE_NOT_FOUND' => 'Le fichier demandé est introuvable',
75 | 'VERSION_FIELD_MISSING' => 'L’élément “version” n’a pas été spécifié dans le fichier MODX.',
76 | 'LICENSE_FIELD_MISSING' => 'L’élément “license” n’a pas été spécifié dans le fichier MODX.',
77 | 'TARGET_VERSION_NOT_FOUND' => 'L’élément “target-version” n’a pas été spécifié dans le fichier MODX',
78 | 'INVALID_VERSION_FORMAT' => 'La version que vous avez fourni (%s) est invalide. Le format doit être : 1.0.0.',
79 |
80 | 'VALIDATING_ZIP' => '(En train de valider %s)',
81 | 'MAJOR_VERSION_UNSTABLE' => 'La version de votre MOD (%s) est instable. Elle doit être obligatoirement plus élevée que la version initiale 1.0.0.
82 | Par exemple :
83 | [b]0.0.1[/b] est instable
84 | [b]0.1.0[/b] est instable
85 | [b]1.0.1[/b] est stable',
86 |
87 | 'NOT_LATEST_PHPBB' => 'La révision cible, située dans le fichier MODX, indique que le MOD est compatible avec la version %s alors que la dernière version de phpBB est la %s',
88 |
89 | 'INVALID_INLINE_ACTION' => 'Une action “dans la ligne” contient de nouvelles lignes [code]%s[/code]',
90 | 'INVALID_INLINE_FIND' => 'Une action “dans la ligne, rechercher” contient de nouvelles lignes [code]%s[/code]',
91 | 'SHORT_TAGS' => 'Ce fichier utilise des balises d’ouvertures raccourcies ( à la place de 'La licence spécifiée dans le fichier MODX ne peut pas être la GPLv2.',
94 |
95 | 'MODIFIED_XSL' => 'La signature MD5 du fichier XSL est inconnue, le fichier doit être modifié. Signature trouvée : %s. Signature souhaitée : %s',
96 | 'OLD_XSL' => 'Vous utilisez une version obsolète du fichier XSL de MODX. Vous devriez mettre à jour le XSL avant tout transfert',
97 | 'LICENSE_MD5' => 'Une signature MD5 invalide a été trouvée. Signature trouvée : %s. Signature souhaitée : %s',
98 |
99 | 'MANY_EDIT_CHILDREN' => 'Le MOD utilise de nombreuses requêtes d’éditions. Cela peut indiquer un usage incorrect de la balise d’édition.',
100 | 'MULTIPLE_XSL' => 'Vous bénéficiez de nombreux fichiers XSL. Il est recommandé de n’avoir qu’un seul et unique fichier XSL afin de ne pas déstabiliser les utilisateurs.',
101 |
102 | 'NO_XSL_FOUND_IN_DIR' => 'Aucun fichier XSL n’a été trouvé dans le répertoire %s. Depuis le 27 juillet 2008, il est obligatoire d’avoir un fichier XSL dans tous les répertoires contenant un fichier MODX à cause d’une limitation du navigateur Mozilla Firefox 3.',
103 | 'NO_XSL_FOUND_IN_DIR2' => 'IMPORTANT : MPV ne peut pas détecter s’il y a bien un fichier XSL dans un répertoire supérieur. Veuillez tester l’affichage avec le navigateur Mozilla Firefox 3 afin de vous assurer que tout fonctionne correctement. Si le MOD s’affiche correctement, vous pouvez alors ignorer l’avertissement affiché ci-dessus ! Pour plus d’informations, veuillez consulter notre politique de fonctionnement.',
104 |
105 | 'NO_LICENSE' => 'Le fichier license.txt est introuvable alors que celui-ci est obligatoire.',
106 | 'NO_UNIX_ENDINGS' => 'Ce fichier n’utilise aucune ligne de fin UNIX.',
107 | 'NO_XSL_FILE' => 'Le fichier XSL est introuvable alors que celui-ci est obligatoire afin d’afficher le fichier XML dans un navigateur.',
108 |
109 | 'USAGE_MYSQL' => 'Vous utilisez une fonction MySQL modifiée à la ligne %s : %sLes MODs de phpBB sont obligatoires afin d’utiliser le “Database Abstraction Layer” (DBAL).',
110 | 'USAGE_MYSQLI' => 'Vous utilisez une fonction MySQLi modifiée à la ligne %s : %sLes MODs de phpBB sont obligatoires afin d’utiliser le “Database Abstraction Layer” (DBAL).',
111 | 'USAGE_OCI' => 'Vous utilisez une fonction OCI (Oracle) modifiée à la ligne %s : %sLes MODs de phpBB sont obligatoires afin d’utiliser le “Database Abstraction Layer” (DBAL).',
112 | 'USAGE_SQLITE' => 'Vous utilisez une fonction SQLite modifiée à la ligne %s : %sLes MODs de phpBB sont obligatoires afin d’utiliser le “Database Abstraction Layer” (DBAL).',
113 | 'USAGE_PG' => 'Vous utilisez une fonction PostgreSQL modifiée à la ligne %s : %sLes MODs de phpBB sont obligatoires afin d’utiliser le “Database Abstraction Layer” (DBAL).',
114 | 'USAGE_MSSQL' => 'Vous utilisez une fonction MSSQL modifiée à la ligne %s : %sLes MODs de phpBB sont obligatoires afin d’utiliser le “Database Abstraction Layer” (DBAL).',
115 | 'USAGE_ODBC' => 'Vous utilisez une fonction ODBC modifiée à la ligne %s : %sLes MODs de phpBB sont obligatoires afin d’utiliser le “Database Abstraction Layer” (DBAL).',
116 | 'USAGE_SQLSRV' => 'Vous utilisez une fonction SQLSRV (MSSQL) modifiée à la ligne %s : %sLes MODs de phpBB sont obligatoires afin d’utiliser le “Database Abstraction Layer” (DBAL).',
117 | 'USAGE_IBASE' => 'Vous utilisez une fonction iBase (Interbase/Firebird) modifiée à la ligne %s : %sLes MODs de phpBB sont obligatoires afin d’utiliser le “Database Abstraction Layer” (DBAL).',
118 | 'USAGE_DB2' => 'Vous utilisez une fonction DB2 modifiée à la ligne %s : %sLes MODs de phpBB sont obligatoires afin d’utiliser le “Database Abstraction Layer” (DBAL).',
119 |
120 | 'USAGE_GET' => 'Vous utilisez $_GET à la ligne %s : %srequest_var() devrait être utilisé à la place.',
121 | 'USAGE_POST' => 'Vous utilisez $_POST à la ligne %s : %srequest_var() devrait être utilisé à la place.',
122 | 'USAGE_COOKIE' => 'Vous utilisez $_COOKIE à la ligne %s : %srequest_var() devrait être utilisé en utilisant le quatrième paramètre.',
123 | 'USAGE_SERVER' => 'Vous utilisez $_SERVER à la ligne %s : %s[b]$_SERVER [u]EST[/u] une saisie qui doit être réalisée par l’utilisateur ![/b]',
124 | 'USAGE_SESSION' => 'Vous utilisez $_SESSION à la ligne %s : %sLe système de session de phpBB devrait être utilisé à la place.',
125 | 'USAGE_REQUEST' => 'Vous utilisez $_REQUEST à la ligne %s : %srequest_var devrait être utilisé à la place.',
126 | 'USAGE_ENV' => 'Vous utilisez $_ENV à la ligne %s : %s',
127 | 'USAGE_FILES' => 'Vous utilisez $_FILES à la ligne %s : %sLes fonctions de transfert inclues dans phpBB devraient être utilisées à la place.',
128 | 'USAGE_GLOBALS' => 'Vous utilisez $GLOBALS à la ligne %s : %s',
129 |
130 | 'USAGE_PRINT' => 'Vous utilisez print() à la ligne %s : %s Le système de template de phpBB devrait être utilisé à la place.',
131 | 'USAGE_PRINTF' => 'Vous utilisez printf() à la ligne %s : %s Le système de template de phpBB devrait être utilisé à la place.',
132 | 'USAGE_ECHO' => 'Vous utilisez echo() à la ligne %s : %s Le système de template de phpBB devrait être utilisé à la place.',
133 | 'USAGE_PRINTR' => 'Vous utilisez printr() à la ligne %s : %s Le système de template de phpBB devrait être utilisé à la place.',
134 |
135 | 'USAGE_`' => 'Vous utilisez backticks à la ligne %s : %s',
136 | 'USAGE_EVAL' => 'Vous utilisez eval() à la ligne %s : %s',
137 | 'USAGE_EXEC' => 'Vous utilisez exec() à la ligne %s : %s',
138 | 'USAGE_SYSTEM' => 'Vous utilisez system() à la ligne %s : %s',
139 | 'USAGE_PASSTHRU' => 'Vous utilisez passthru() à la ligne %s : %s',
140 | 'USAGE_GETENV' => 'Vous utilisez getenv() à la ligne %s : %s',
141 | 'USAGE_DIE' => 'Vous utilisez die() à la ligne %s : %s',
142 | 'USAGE_MD5' => 'Vous utilisez md5() à la ligne %s : %sMD5 ne devrait pas être utilisé pour tout ce qui concerne les mots de passe. Les autres utilisations de MD5 seront probablement valides.',
143 | 'USAGE_SHA1' => 'Vous utilisez sha1() à la ligne %s : %s',
144 | 'USAGE_ADDSLASHES' => 'Vous utilisez addslashes() à la ligne %s : %s',
145 | 'USAGE_STRIPSLASHES' => 'Vous utilisez stripslashes() à la ligne %s : %s',
146 | 'USAGE_INCLUDEONCE' => 'Vous utilisez include_once() à la ligne %s : %sIl est préférable que vous utilisiez include avec function/class_exists check plutôt qu’avec include/require _once',
147 | 'USAGE_REQUIREONCE' => 'Vous utilisez require_once() à la ligne %s : %sIl est préférable que vous utilisiez include avec function/class_exists check plutôt qu’avec include/require _once',
148 | 'USAGE_VARDUMP' => 'Vous utilisez var_dump à la ligne %s : %s',
149 |
150 | 'USAGE_BOM' => 'Votre fichier est encodé en UTF-8 avec BOM',
151 |
152 | 'USAGE_REQUEST_VAR_INT' => 'Une liaison à request_var() incante un entier à une chaîne à la ligne %s : %s',
153 |
154 | 'UNWANTED_FILE' => 'Votre archive contient un fichier indésirable nommé "%2$s" et situé dans %1$s',
155 |
156 | 'INCLUDE_NO_ROOT' => 'Une liaison à “include” ou à “require” est manquante à $phpbb_root_path à la ligne %s : %s',
157 | 'INCLUDE_NO_PHP' => 'Une liaison à “include” ou à “require” est manquante à $phpEx à la ligne %s : %s',
158 |
159 | 'PACKAGE_NOT_EXISTS' => 'Le fichier sélectionné (%s) n’existe pas',
160 | 'UNABLE_EXTRACT_PHP' => 'Impossible d’extraire %s en utilisant la méthode PHP.',
161 | 'UNABLE_OPEN_PHP' => 'Impossible d’ouvrir %s en utilisant la méthode PHP.',
162 |
163 | 'LINK_NOT_EXISTS' => 'Le(s) fichier(s) pour lier %s n’existe(nt) pas dans le fichier compressé.',
164 |
165 | 'NO_IN_PHPBB' => 'Une définition pour IN_PHPBB est manquante ou il n’y a aucune vérification pour savoir si IN_PHPBB est paramétré.',
166 | 'FILE_EMPTY' => 'Ce fichier PHP a été détecté comme étant vide.',
167 |
168 | 'COPY_BASENAME_DIFFER' => 'Les noms de base de la commande de copie diffèrent : de %s à %s. Les deux apparaissent comme étant identiques',
169 |
170 | 'USING_MODX_OUTDATED' => 'Vous utilisez la version %s de MODX alors que la dernière version de MODX est la %s. Veuillez mettre à jour votre fichier MODX vers la dernière version.',
171 | 'USING_MODX_UNKNOWN' => 'Une version incorrecte de MODX a été trouvée concernant le fichier XML. Il est impossible de continuer la prévalidation de ce fichier.',
172 |
173 | 'PROSILVER_NO_MAIN_MODX' => 'Les modifications du style prosilver devraient être inclues dans le fichier principal de MODX et non dans %s.',
174 | 'ENGLISH_NO_MAIN_MODX' => 'Les modifications des fichiers de langue anglais devraient être inclues dans le fichier principal de MODX et non dans %s.',
175 |
176 | 'MPV_XML_ERROR' => 'Une erreur XML est survenue dans le fichier MODX %s',
177 |
178 | 'USAGE_BR_NON_CLOSED' => 'Une balise BR n’a pas été fermée correctement et rend invalide le fichier au niveau XHTML. L’erreur est localisée à la ligne %s : %s',
179 | 'USAGE_IMG_NON_CLOSED' => 'Une balise IMG n’a pas été fermée correctement et rend invalide le fichier au niveau XHTML. L’erreur est localisée à la ligne %s : %s',
180 |
181 | 'FILE_NON_BINARY' => 'Le fichier a été détecté comme étant non binaire alors que l’extension est quant à elle binaire. Veuillez vérifier le code PHP par mesure de sécurité.',
182 |
183 | 'GENERAL_NOTICE' => 'Veuillez noter que toutes les vérifications ont été réalisées par un outil automatique. Dans [u]certains[/u] cas, un échec ou un avertissement peut être considéré comme étant correct et fonctionnel.',
184 |
185 | 'UNABLE_OPEN' => 'Impossible d’ouvrir %s.',
186 | 'UNABLE_WRITE'=> 'Impossible d’écrire sur %s.',
187 | 'PHP_ERROR' => 'Une erreur PHP a été trouvée : [code]%s[/code]',
188 | 'NO_PRE_VAL_ERRORS' => 'Aucun problème de prévalidation n’a été trouvé',
189 | 'REPORT_BY' => 'Rapport réalisé par MPV',
190 | 'MPV_SERVER' => 'Serveur MPV',
191 | 'UNKNOWN_OUTPUT' => 'Type de sortie inconnu',
192 | 'MPV_NOTICE' => 'Avis MPV trouvé sur %1$s à la ligne %2$s : %3$s',
193 | 'MPV_WARNING' => 'Avertissement MPV trouvé sur %1$s à la ligne %2$s : %3$s',
194 | 'MPV_NOTICE' => 'Avis MPV trouvé sur %1$s à la ligne %2$s : %3$s',
195 | 'MPV_USER_NOTICE' => 'Avis utilisateur MPV trouvé sur %1$s à la ligne %2$s : %3$s',
196 | 'MPV_GENERAL_ERROR' => 'MPV a rencontré une erreur sur %1$s à la ligne %2$s : %3$s',
197 | 'MPV_FAIL_RESULT' => 'ÉCHEC',
198 | 'MPV_NOTICE_RESULT' => 'AVIS',
199 | 'MPV_WARNING_RESULT' => 'AVERTISSEMENT',
200 | 'MPV_INFO_RESULT' => 'INFORMATION',
201 | 'INVALID_TYPE' => '$type invalide concernant cette fonction !',
202 | 'MOD_NAME' => 'Nom du MOD',
203 | 'SUBMIT_COUNT' => 'Compteur d’envois',
204 | 'TAG_DATA' => 'Tag de données',
205 | 'DATA_COUNT' => 'Compteur de données',
206 |
207 | 'NO_UMIL_VERSION' => 'Impossible de trouver UMIL_VERSION dans umil.php',
208 | 'UMIL_OUTDATED' => 'L’UMIL fourni est obsolète.',
209 | 'INCORRECT_UMIL_MD5' => 'L’UMIL fourni est modifié.',
210 | 'UNKNOWN_VERSION_UMIL' => 'La version d’UMIL que vous avez renseigné est inconnue. Cela peut signifier que la version est obsolète.',
211 |
212 | ));
--------------------------------------------------------------------------------
/docs/COPYING:
--------------------------------------------------------------------------------
1 | GNU GENERAL PUBLIC LICENSE
2 | Version 2, June 1991
3 |
4 | Copyright (C) 1989, 1991 Free Software Foundation, Inc.
5 | 675 Mass Ave, Cambridge, MA 02139, USA
6 | Everyone is permitted to copy and distribute verbatim copies
7 | of this license document, but changing it is not allowed.
8 |
9 | Preamble
10 |
11 | The licenses for most software are designed to take away your
12 | freedom to share and change it. By contrast, the GNU General Public
13 | License is intended to guarantee your freedom to share and change free
14 | software--to make sure the software is free for all its users. This
15 | General Public License applies to most of the Free Software
16 | Foundation's software and to any other program whose authors commit to
17 | using it. (Some other Free Software Foundation software is covered by
18 | the GNU Library General Public License instead.) You can apply it to
19 | your programs, too.
20 |
21 | When we speak of free software, we are referring to freedom, not
22 | price. Our General Public Licenses are designed to make sure that you
23 | have the freedom to distribute copies of free software (and charge for
24 | this service if you wish), that you receive source code or can get it
25 | if you want it, that you can change the software or use pieces of it
26 | in new free programs; and that you know you can do these things.
27 |
28 | To protect your rights, we need to make restrictions that forbid
29 | anyone to deny you these rights or to ask you to surrender the rights.
30 | These restrictions translate to certain responsibilities for you if you
31 | distribute copies of the software, or if you modify it.
32 |
33 | For example, if you distribute copies of such a program, whether
34 | gratis or for a fee, you must give the recipients all the rights that
35 | you have. You must make sure that they, too, receive or can get the
36 | source code. And you must show them these terms so they know their
37 | rights.
38 |
39 | We protect your rights with two steps: (1) copyright the software, and
40 | (2) offer you this license which gives you legal permission to copy,
41 | distribute and/or modify the software.
42 |
43 | Also, for each author's protection and ours, we want to make certain
44 | that everyone understands that there is no warranty for this free
45 | software. If the software is modified by someone else and passed on, we
46 | want its recipients to know that what they have is not the original, so
47 | that any problems introduced by others will not reflect on the original
48 | authors' reputations.
49 |
50 | Finally, any free program is threatened constantly by software
51 | patents. We wish to avoid the danger that redistributors of a free
52 | program will individually obtain patent licenses, in effect making the
53 | program proprietary. To prevent this, we have made it clear that any
54 | patent must be licensed for everyone's free use or not licensed at all.
55 |
56 | The precise terms and conditions for copying, distribution and
57 | modification follow.
58 |
59 | GNU GENERAL PUBLIC LICENSE
60 | TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
61 |
62 | 0. This License applies to any program or other work which contains
63 | a notice placed by the copyright holder saying it may be distributed
64 | under the terms of this General Public License. The "Program", below,
65 | refers to any such program or work, and a "work based on the Program"
66 | means either the Program or any derivative work under copyright law:
67 | that is to say, a work containing the Program or a portion of it,
68 | either verbatim or with modifications and/or translated into another
69 | language. (Hereinafter, translation is included without limitation in
70 | the term "modification".) Each licensee is addressed as "you".
71 |
72 | Activities other than copying, distribution and modification are not
73 | covered by this License; they are outside its scope. The act of
74 | running the Program is not restricted, and the output from the Program
75 | is covered only if its contents constitute a work based on the
76 | Program (independent of having been made by running the Program).
77 | Whether that is true depends on what the Program does.
78 |
79 | 1. You may copy and distribute verbatim copies of the Program's
80 | source code as you receive it, in any medium, provided that you
81 | conspicuously and appropriately publish on each copy an appropriate
82 | copyright notice and disclaimer of warranty; keep intact all the
83 | notices that refer to this License and to the absence of any warranty;
84 | and give any other recipients of the Program a copy of this License
85 | along with the Program.
86 |
87 | You may charge a fee for the physical act of transferring a copy, and
88 | you may at your option offer warranty protection in exchange for a fee.
89 |
90 | 2. You may modify your copy or copies of the Program or any portion
91 | of it, thus forming a work based on the Program, and copy and
92 | distribute such modifications or work under the terms of Section 1
93 | above, provided that you also meet all of these conditions:
94 |
95 | a) You must cause the modified files to carry prominent notices
96 | stating that you changed the files and the date of any change.
97 |
98 | b) You must cause any work that you distribute or publish, that in
99 | whole or in part contains or is derived from the Program or any
100 | part thereof, to be licensed as a whole at no charge to all third
101 | parties under the terms of this License.
102 |
103 | c) If the modified program normally reads commands interactively
104 | when run, you must cause it, when started running for such
105 | interactive use in the most ordinary way, to print or display an
106 | announcement including an appropriate copyright notice and a
107 | notice that there is no warranty (or else, saying that you provide
108 | a warranty) and that users may redistribute the program under
109 | these conditions, and telling the user how to view a copy of this
110 | License. (Exception: if the Program itself is interactive but
111 | does not normally print such an announcement, your work based on
112 | the Program is not required to print an announcement.)
113 |
114 | These requirements apply to the modified work as a whole. If
115 | identifiable sections of that work are not derived from the Program,
116 | and can be reasonably considered independent and separate works in
117 | themselves, then this License, and its terms, do not apply to those
118 | sections when you distribute them as separate works. But when you
119 | distribute the same sections as part of a whole which is a work based
120 | on the Program, the distribution of the whole must be on the terms of
121 | this License, whose permissions for other licensees extend to the
122 | entire whole, and thus to each and every part regardless of who wrote it.
123 |
124 | Thus, it is not the intent of this section to claim rights or contest
125 | your rights to work written entirely by you; rather, the intent is to
126 | exercise the right to control the distribution of derivative or
127 | collective works based on the Program.
128 |
129 | In addition, mere aggregation of another work not based on the Program
130 | with the Program (or with a work based on the Program) on a volume of
131 | a storage or distribution medium does not bring the other work under
132 | the scope of this License.
133 |
134 | 3. You may copy and distribute the Program (or a work based on it,
135 | under Section 2) in object code or executable form under the terms of
136 | Sections 1 and 2 above provided that you also do one of the following:
137 |
138 | a) Accompany it with the complete corresponding machine-readable
139 | source code, which must be distributed under the terms of Sections
140 | 1 and 2 above on a medium customarily used for software interchange; or,
141 |
142 | b) Accompany it with a written offer, valid for at least three
143 | years, to give any third party, for a charge no more than your
144 | cost of physically performing source distribution, a complete
145 | machine-readable copy of the corresponding source code, to be
146 | distributed under the terms of Sections 1 and 2 above on a medium
147 | customarily used for software interchange; or,
148 |
149 | c) Accompany it with the information you received as to the offer
150 | to distribute corresponding source code. (This alternative is
151 | allowed only for noncommercial distribution and only if you
152 | received the program in object code or executable form with such
153 | an offer, in accord with Subsection b above.)
154 |
155 | The source code for a work means the preferred form of the work for
156 | making modifications to it. For an executable work, complete source
157 | code means all the source code for all modules it contains, plus any
158 | associated interface definition files, plus the scripts used to
159 | control compilation and installation of the executable. However, as a
160 | special exception, the source code distributed need not include
161 | anything that is normally distributed (in either source or binary
162 | form) with the major components (compiler, kernel, and so on) of the
163 | operating system on which the executable runs, unless that component
164 | itself accompanies the executable.
165 |
166 | If distribution of executable or object code is made by offering
167 | access to copy from a designated place, then offering equivalent
168 | access to copy the source code from the same place counts as
169 | distribution of the source code, even though third parties are not
170 | compelled to copy the source along with the object code.
171 |
172 | 4. You may not copy, modify, sublicense, or distribute the Program
173 | except as expressly provided under this License. Any attempt
174 | otherwise to copy, modify, sublicense or distribute the Program is
175 | void, and will automatically terminate your rights under this License.
176 | However, parties who have received copies, or rights, from you under
177 | this License will not have their licenses terminated so long as such
178 | parties remain in full compliance.
179 |
180 | 5. You are not required to accept this License, since you have not
181 | signed it. However, nothing else grants you permission to modify or
182 | distribute the Program or its derivative works. These actions are
183 | prohibited by law if you do not accept this License. Therefore, by
184 | modifying or distributing the Program (or any work based on the
185 | Program), you indicate your acceptance of this License to do so, and
186 | all its terms and conditions for copying, distributing or modifying
187 | the Program or works based on it.
188 |
189 | 6. Each time you redistribute the Program (or any work based on the
190 | Program), the recipient automatically receives a license from the
191 | original licensor to copy, distribute or modify the Program subject to
192 | these terms and conditions. You may not impose any further
193 | restrictions on the recipients' exercise of the rights granted herein.
194 | You are not responsible for enforcing compliance by third parties to
195 | this License.
196 |
197 | 7. If, as a consequence of a court judgment or allegation of patent
198 | infringement or for any other reason (not limited to patent issues),
199 | conditions are imposed on you (whether by court order, agreement or
200 | otherwise) that contradict the conditions of this License, they do not
201 | excuse you from the conditions of this License. If you cannot
202 | distribute so as to satisfy simultaneously your obligations under this
203 | License and any other pertinent obligations, then as a consequence you
204 | may not distribute the Program at all. For example, if a patent
205 | license would not permit royalty-free redistribution of the Program by
206 | all those who receive copies directly or indirectly through you, then
207 | the only way you could satisfy both it and this License would be to
208 | refrain entirely from distribution of the Program.
209 |
210 | If any portion of this section is held invalid or unenforceable under
211 | any particular circumstance, the balance of the section is intended to
212 | apply and the section as a whole is intended to apply in other
213 | circumstances.
214 |
215 | It is not the purpose of this section to induce you to infringe any
216 | patents or other property right claims or to contest validity of any
217 | such claims; this section has the sole purpose of protecting the
218 | integrity of the free software distribution system, which is
219 | implemented by public license practices. Many people have made
220 | generous contributions to the wide range of software distributed
221 | through that system in reliance on consistent application of that
222 | system; it is up to the author/donor to decide if he or she is willing
223 | to distribute software through any other system and a licensee cannot
224 | impose that choice.
225 |
226 | This section is intended to make thoroughly clear what is believed to
227 | be a consequence of the rest of this License.
228 |
229 | 8. If the distribution and/or use of the Program is restricted in
230 | certain countries either by patents or by copyrighted interfaces, the
231 | original copyright holder who places the Program under this License
232 | may add an explicit geographical distribution limitation excluding
233 | those countries, so that distribution is permitted only in or among
234 | countries not thus excluded. In such case, this License incorporates
235 | the limitation as if written in the body of this License.
236 |
237 | 9. The Free Software Foundation may publish revised and/or new versions
238 | of the General Public License from time to time. Such new versions will
239 | be similar in spirit to the present version, but may differ in detail to
240 | address new problems or concerns.
241 |
242 | Each version is given a distinguishing version number. If the Program
243 | specifies a version number of this License which applies to it and "any
244 | later version", you have the option of following the terms and conditions
245 | either of that version or of any later version published by the Free
246 | Software Foundation. If the Program does not specify a version number of
247 | this License, you may choose any version ever published by the Free Software
248 | Foundation.
249 |
250 | 10. If you wish to incorporate parts of the Program into other free
251 | programs whose distribution conditions are different, write to the author
252 | to ask for permission. For software which is copyrighted by the Free
253 | Software Foundation, write to the Free Software Foundation; we sometimes
254 | make exceptions for this. Our decision will be guided by the two goals
255 | of preserving the free status of all derivatives of our free software and
256 | of promoting the sharing and reuse of software generally.
257 |
258 | NO WARRANTY
259 |
260 | 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
261 | FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
262 | OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
263 | PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
264 | OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
265 | MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
266 | TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
267 | PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
268 | REPAIR OR CORRECTION.
269 |
270 | 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
271 | WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
272 | REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
273 | INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
274 | OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
275 | TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
276 | YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
277 | PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
278 | POSSIBILITY OF SUCH DAMAGES.
279 |
280 | END OF TERMS AND CONDITIONS
281 |
282 |
--------------------------------------------------------------------------------
/includes/lib/cortex_xml.php:
--------------------------------------------------------------------------------
1 | formatOutput = true;
55 | $document->preserveWhiteSpace = false;
56 |
57 | // Attempt to load the document
58 | if (!$document->load($filename))
59 | {
60 | return false;
61 | }
62 |
63 | return self::load_element($document->documentElement);
64 | }
65 |
66 | /**
67 | * Create a cortex_xml object based on a given DOMElement
68 | *
69 | * @access public
70 | * @param object DOMElement
71 | * @return object
72 | */
73 | private static function load_element(DOMElement $element)
74 | {
75 | $object = new cortex_xml();
76 | $object->element = $element;
77 |
78 | return $object;
79 | }
80 |
81 | /**
82 | * Constructor
83 | *
84 | * @access public
85 | * @param string Name
86 | * @param string Namespace URI
87 | * @param mixed Initial value
88 | * @return void
89 | */
90 | public function __construct($name = null, $namespace_uri = null, $value = null)
91 | {
92 | if (is_null($name))
93 | {
94 | return;
95 | }
96 |
97 | $document = new DOMDocument('1.0', 'utf-8');
98 | $document->formatOutput = true;
99 | $document->preserveWhiteSpace = false;
100 |
101 | $this->element = (!is_null($namespace_uri)) ? $document->createElementNS($namespace_uri, $name) : $document->createElement($name);
102 |
103 | if (!is_null($namespace_uri))
104 | {
105 | $this->element->setAttribute('xmlns:xsi', 'http://www.w3.org/2001/XMLSchema-instance');
106 | }
107 |
108 | if (!is_null($value))
109 | {
110 | $this->element->value = $value;
111 | }
112 |
113 | $document->appendChild($this->element);
114 | }
115 |
116 | /**
117 | * Add an attribute to this node
118 | *
119 | * @access public
120 | * @param string Name
121 | * @param mixed Value
122 | * @return bool True on success, otherwise false
123 | */
124 | public function add_attribute($name, $value)
125 | {
126 | return $this->set_attribute($name, $value);
127 | }
128 |
129 | /**
130 | * Set the value of an existing attribute of this node
131 | *
132 | * @access public
133 | * @param string Name
134 | * @param mixed Value
135 | * @return bool True on success, otherwise false
136 | */
137 | public function set_attribute($name, $value)
138 | {
139 | return $this->element->setAttribute($name, $value);
140 | }
141 |
142 | /**
143 | * Remove an attribute from this node
144 | *
145 | * @access public
146 | * @param string Name
147 | * @return bool True on success, otherwise false
148 | */
149 | public function remove_attribute($name)
150 | {
151 | return $this->element->removeAttribute($name);
152 | }
153 |
154 | /**
155 | * Add a child node to the current node
156 | *
157 | * @access public
158 | * @param string Name
159 | * @param mixed Initial value
160 | * @return object cortex_xml object
161 | */
162 | public function add_node($name, $value = null)
163 | {
164 | $node = new cortex_xml();
165 | $node->element = $this->document->createElement($name);
166 |
167 | if (!is_null($value))
168 | {
169 | $node->value = $value;
170 | }
171 |
172 | $this->element->appendChild($node->element);
173 | return $node;
174 | }
175 |
176 | /**
177 | * Append a child to the current document/node
178 | *
179 | * @access public
180 | * @param object cortex_xml object
181 | * @return void
182 | */
183 | public function append_child(cortex_xml $node)
184 | {
185 | $child = $this->document->importNode($node->element, true);
186 | $this->element->appendChild($child);
187 | }
188 |
189 | /**
190 | * Remove this node from the document
191 | *
192 | * @access public
193 | * @return void
194 | */
195 | public function remove()
196 | {
197 | $this->element->parentNode->removeChild($this->element);
198 | }
199 |
200 | /**
201 | * Execute an XPath query and return the resulting elements
202 | *
203 | * @access public
204 | * @param string XPath
205 | * @param bool Return only the first result
206 | * @return mixed Array if !$return_first, cortex_xml object or null
207 | */
208 | public function get_xpath($path, $return_first = false)
209 | {
210 | $xpath = new DOMXpath($this->document);
211 |
212 | // Take care of the default namespace, DOMXpath doesn't support this
213 | if (!is_null($this->default_ns))
214 | {
215 | $path = preg_replace('#/([^:/]+?)#', '/doc-ns:$1', $path);
216 | $xpath->registerNameSpace('doc-ns', $this->default_ns);
217 | }
218 |
219 | $nodes = $this->parse_children($xpath->query($path));
220 | if ($return_first)
221 | {
222 | return (sizeof($nodes) > 0) ? $nodes[0] : null;
223 | }
224 |
225 | return $nodes;
226 | }
227 |
228 | /**
229 | * Get all child nodes with a given name
230 | *
231 | * @access public
232 | * @param string Name
233 | * @param bool Return only the first node
234 | * @return mixed Array if !$return_first, cortex_xml object or null
235 | */
236 | public function get_by_name($name, $return_first = true)
237 | {
238 | return $this->get_xpath('//' . $name, $return_first);
239 | }
240 |
241 | /**
242 | * Get all child nodes of which a given attribute has a certain value
243 | *
244 | * @access public
245 | * @param string Name
246 | * @param mixed Value
247 | * @return mixed Array if !$return_first, cortex_xml object or null
248 | */
249 | public function get_by_attribute($name, $value, $return_first = true)
250 | {
251 | return $this->get_xpath('//*[attribute::' . $name . '=\'' . $value . '\']', $return_first);
252 | }
253 |
254 | /**
255 | * Validate the document against its schema. Will attempt to download the schema using its URI
256 | * if $schema == null
257 | *
258 | * @access public
259 | * @param string Path to XSD, XSD data or null to automatically download the XSD
260 | * @return mixed TRUE or an array describing the errors
261 | */
262 | public function validate($schema = null)
263 | {
264 | if ((is_null($schema) && !is_null($this->schema_location)) || strpos($schema, 'http://') !== false)
265 | {
266 | $schema = @file_get_contents((strpos($schema, 'http://') !== false) ? $schema : $this->schema_location);
267 | if ($schema === false)
268 | {
269 | return true;
270 | }
271 | }
272 | else if (@file_exists($schema))
273 | {
274 | set_error_handler(array($this, 'error_handler'));
275 |
276 | $valid = $this->document->schemaValidate($schema);
277 | restore_error_handler();
278 |
279 | return ($valid === false) ? $this->error_stack : true;
280 | }
281 |
282 | set_error_handler(array($this, 'error_handler'));
283 |
284 | $valid = $this->document->schemaValidateSource($schema);
285 | restore_error_handler();
286 |
287 | return ($valid === false) ? $this->error_stack : true;
288 | }
289 |
290 | /**
291 | * Internal error handler for filling the error stack. Should not be called
292 | * from outside of this class.
293 | *
294 | * @access public
295 | * @return void
296 | */
297 | public function error_handler($error_no, $msg_text, $error_file, $error_line)
298 | {
299 | $this->error_stack[] = substr($msg_text, strpos($msg_text, ']: Element') + 3);
300 | }
301 |
302 | /**
303 | * Directly output the data to the client
304 | *
305 | * @access public
306 | * @param bool Set to TRUE to send the 'no-cache' header. Should be done in order
307 | * to prevent headaches and other mental disorders when using AJAX
308 | * @param bool exit() after having sent the data
309 | * @return void
310 | */
311 | public function output_xml($no_cache = false, $exit = false)
312 | {
313 | $ob_contents = ob_get_contents();
314 | if ($ob_contents !== false)
315 | {
316 | ob_clean();
317 | }
318 |
319 | header('Content-type: application/xml');
320 |
321 | if ($no_cache)
322 | {
323 | header('Pragma: no-cache');
324 | header('Cache-Control: no-cache');
325 | header('Expires: ' . date('r', 0));
326 | }
327 |
328 | print $this;
329 |
330 | if ($exit)
331 | {
332 | exit();
333 | }
334 | }
335 |
336 | /**
337 | * Write XML to a file
338 | *
339 | * @access public
340 | * @param string Filename to write to
341 | * @return void
342 | */
343 | public function save_file($filename)
344 | {
345 | if (!@file_put_contents($filename, (string) $this))
346 | {
347 | throw new cortex_exception('cortex_xml: Could not store XML data', 'Could not write to "' . $filename . '"');
348 | }
349 | }
350 |
351 | #region // Getters
352 |
353 | /**
354 | * Getter for this element's DOMDocument
355 | *
356 | * @access protected
357 | * @return object
358 | */
359 | protected function __get_document()
360 | {
361 | return $this->element->ownerDocument;
362 | }
363 |
364 | /**
365 | * Getter for the default namespace URI
366 | *
367 | * @access protected
368 | * @return mixed String or null
369 | */
370 | protected function __get_default_ns()
371 | {
372 | return $this->document->documentElement->namespaceURI;
373 | }
374 |
375 | /**
376 | * Getter for the default namespace's prefix
377 | *
378 | * @access protected
379 | * @return mixed String or null
380 | */
381 | protected function __get_default_ns_prefix()
382 | {
383 | return $this->document->documentElement->lookupPrefix($this->default_ns);
384 | }
385 |
386 | /**
387 | * Getter for the URI from which we should be able to get this document's schema
388 | *
389 | * @access protected
390 | * @return mixed String or null
391 | */
392 | protected function __get_schema_location()
393 | {
394 | if (is_null($this->default_ns) && isset($this->attributes['noNamespaceSchemaLocation']))
395 | {
396 | return $this->attributes['noNamespaceSchemaLocation'];
397 | }
398 | else if (is_null($this->default_ns) || !isset($this->attributes['schemaLocation']))
399 | {
400 | return null;
401 | }
402 |
403 | $url_start = strpos($this->attributes['schemaLocation'], $this->default_ns . ' ');
404 | if ($url_start === false)
405 | {
406 | return null;
407 | }
408 |
409 | $schema_url = substr($this->attributes['schemaLocation'], $url_start + strlen($this->default_ns . ' '));
410 | if (strpos($schema_url, ' ') !== false)
411 | {
412 | $schema_url = substr($schema_url, 0, strpos($schema_url, ' '));
413 | }
414 |
415 | return $schema_url;
416 | }
417 |
418 | /**
419 | * Getter for the name of this node
420 | *
421 | * @access protected
422 | * @return string
423 | */
424 | protected function __get_name()
425 | {
426 | return $this->element->tagName;
427 | }
428 |
429 | /**
430 | * Getter for this node's children
431 | *
432 | * @access protected
433 | * @return array
434 | */
435 | protected function __get_children()
436 | {
437 | return $this->parse_children($this->element->childNodes);
438 | }
439 |
440 | /**
441 | * Getter for this node's attributes
442 | *
443 | * @access protected
444 | * @return array
445 | */
446 | protected function __get_attributes()
447 | {
448 | $attributes = array();
449 | $dom_attributes = $this->element->attributes;
450 |
451 | $i = 0;
452 | while ($dom_attribute = $dom_attributes->item($i))
453 | {
454 | $attributes[$dom_attribute->name] = $dom_attribute->value;
455 | $i++;
456 | }
457 |
458 | return $attributes;
459 | }
460 |
461 | /**
462 | * Getter vor this node's value
463 | *
464 | * @access protected
465 | * @return string
466 | */
467 | protected function __get_value()
468 | {
469 | return $this->element->nodeValue;
470 | }
471 |
472 | /**
473 | * Getter for the document's raw XML (without the XML declaration)
474 | *
475 | * @access public
476 | * @return void
477 | */
478 | protected function __get_raw_xml()
479 | {
480 | $raw_xml = (string) $this;
481 | $raw_xml = trim(substr($raw_xml, strpos($raw_xml, "\n")));
482 |
483 | return $raw_xml;
484 | }
485 |
486 | /**
487 | * Getter for this node's *inner* XML
488 | *
489 | * @access public
490 | * @return string
491 | */
492 | protected function __get_inner_xml()
493 | {
494 | $raw_xml = $this->raw_xml;
495 | $raw_xml = substr($raw_xml, strpos($raw_xml, '<' . $this->name) + 1);
496 | $raw_xml = substr($raw_xml, strpos($raw_xml, '>') + 1);
497 | $raw_xml = substr($raw_xml, 0, strrpos($raw_xml, '' . $this->name . '>'));
498 |
499 | return trim($raw_xml);
500 | }
501 |
502 | #endregion
503 |
504 | #region // Setters
505 |
506 | /**
507 | * Setter for the document's schema location
508 | *
509 | * @access protected
510 | * @param string URI
511 | * @return void
512 | */
513 | protected function __set_schema_location($value)
514 | {
515 | if (is_null($this->default_ns))
516 | {
517 | $this->set_attribute('xsi:noNamespaceSchemaLocation', $value);
518 | }
519 | else
520 | {
521 | $this->set_attribute('xsi:schemaLocation', $this->default_ns . ' ' . $value);
522 | }
523 | }
524 |
525 | /**
526 | * Setter for the node's value. Automatically uses CDATA when needed
527 | *
528 | * @access protected
529 | * @param mixed Value
530 | * @return void
531 | */
532 | protected function __set_value($value)
533 | {
534 | foreach ($this->element->childNodes as $child)
535 | {
536 | $this->element->removeChild($child);
537 | }
538 |
539 | // It could be that the passed value is an array
540 | if (is_array($value))
541 | {
542 | foreach ($value as $node_name => $node_value)
543 | {
544 | $this->add_node($node_name, $node_value);
545 | }
546 |
547 | return;
548 | }
549 |
550 | // Figure out whether to use CDATA or not
551 | if (strpos($value, '<') !== false || strpos($value, '>') !== false || strpos($value, '&') !== false)
552 | {
553 | $text_node = $this->document->createCDATASection($value);
554 | }
555 | else
556 | {
557 | $text_node = $this->document->createTextNode($value);
558 | }
559 |
560 | $this->element->appendChild($text_node);
561 | }
562 |
563 | /**
564 | * Setter for the node's attributes
565 | *
566 | * @access public
567 | * @param array Value
568 | * @return void
569 | */
570 | protected function __set_attributes($value)
571 | {
572 | while (list($attribute, ) = each($value))
573 | {
574 | $this->remove_attribute($attribute);
575 | }
576 |
577 | foreach ($value as $attr_name => $attr_value)
578 | {
579 | $this->add_attribute($attr_name, $attr_value);
580 | }
581 | }
582 |
583 | #endregion
584 |
585 | /**
586 | * Return the document's raw XML
587 | *
588 | * @access public
589 | * @return string
590 | */
591 | public function __toString()
592 | {
593 | $this->document->normalizeDocument();
594 |
595 | $raw_xml = explode("\n", $this->document->saveXML());
596 | for ($i = 0, $_i = sizeof($raw_xml); $i < $_i; $i++)
597 | {
598 | $raw_xml[$i] = str_repeat("\t", strspn($raw_xml[$i], ' ') / 2) . trim($raw_xml[$i]);
599 | }
600 |
601 | return implode("\n", $raw_xml);
602 | }
603 |
604 | /**
605 | * Get an array of cortex_xml objects based on an array of DOM* objects
606 | *
607 | * @access private
608 | * @param array DOM* objects
609 | * @return array
610 | */
611 | private function parse_children($elements)
612 | {
613 | $children = array();
614 | foreach ($elements as $element)
615 | {
616 | if (get_class($element) == 'DOMElement')
617 | {
618 | $children[] = self::load_element($element);
619 | }
620 | }
621 |
622 | return $children;
623 | }
624 | }
625 | ?>
626 |
--------------------------------------------------------------------------------
/store/data/modx-1.2.6.xsd:
--------------------------------------------------------------------------------
1 |
2 |
4 |
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 |
139 |
140 |
141 |
142 |
143 |
144 |
145 |
146 |
147 |
148 |
149 |
150 |
151 |
152 |
153 |
154 |
155 |
156 |
157 |
158 |
159 |
160 |
161 |
162 |
163 |
164 |
165 |
166 |
167 |
168 |
169 |
170 |
171 |
172 |
173 |
174 |
175 |
176 |
177 |
178 |
179 |
180 |
181 |
182 |
183 |
184 |
185 |
186 |
187 |
188 |
189 |
190 |
191 |
192 |
193 |
194 |
195 |
196 |
197 |
198 |
199 |
200 |
201 |
202 |
203 |
204 |
205 |
206 |
207 |
208 |
209 |
210 |
211 |
212 |
213 |
214 |
215 |
216 |
217 |
218 |
219 |
220 |
221 |
222 |
223 |
224 |
225 |
226 |
227 |
228 |
229 |
230 |
231 |
232 |
233 |
234 |
235 |
236 |
237 |
238 |
239 |
240 |
241 |
242 |
243 |
244 |
245 |
246 |
247 |
248 |
249 |
250 |
251 |
252 |
253 |
254 |
255 |
256 |
257 |
258 |
259 |
260 |
261 |
262 |
263 |
264 |
265 |
266 |
267 |
268 |
269 |
270 |
271 |
272 |
273 |
274 |
275 |
276 |
277 |
278 |
279 |
280 |
281 |
282 |
283 |
284 |
285 |
286 |
287 |
288 |
289 |
290 |
291 |
292 |
293 |
294 |
295 |
296 |
297 |
298 |
299 |
300 |
301 |
302 |
303 |
304 |
305 |
306 |
307 |
308 |
309 |
310 |
311 |
312 |
313 |
314 |
315 |
316 |
317 |
318 |
319 |
320 |
321 |
322 |
323 |
324 |
325 |
326 |
327 |
328 |
329 |
330 |
331 |
332 |
333 |
334 |
335 |
336 |
337 |
338 |
339 |
340 |
341 |
342 |
343 |
344 |
345 |
346 |
347 |
348 |
349 |
350 |
351 |
352 |
353 |
354 |
355 |
356 |
357 |
358 |
359 |
360 |
361 |
362 |
363 |
364 |
365 |
366 |
367 |
368 |
369 |
370 |
371 |
372 |
373 |
374 |
375 |
--------------------------------------------------------------------------------
/includes/functions_mpv.php:
--------------------------------------------------------------------------------
1 |