This project does not seem to handle request data directly as such no vulnerable execution paths were found.
include
, or for example
via PHP's auto-loading mechanism.
These results are based on our legacy PHP analysis, consider migrating to our new PHP analysis engine instead. Learn more
1 | <?php |
||
2 | /** |
||
3 | * Definition of OOjs UI ResourceLoader modules. |
||
4 | * |
||
5 | * This program is free software; you can redistribute it and/or modify |
||
6 | * it under the terms of the GNU General Public License as published by |
||
7 | * the Free Software Foundation; either version 2 of the License, or |
||
8 | * (at your option) any later version. |
||
9 | * |
||
10 | * This program is distributed in the hope that it will be useful, |
||
11 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
||
12 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||
13 | * GNU General Public License for more details. |
||
14 | * |
||
15 | * You should have received a copy of the GNU General Public License along |
||
16 | * with this program; if not, write to the Free Software Foundation, Inc., |
||
17 | * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. |
||
18 | * http://www.gnu.org/copyleft/gpl.html |
||
19 | * |
||
20 | * @file |
||
21 | */ |
||
22 | |||
23 | if ( !defined( 'MEDIAWIKI' ) ) { |
||
24 | die( 'Not an entry point.' ); |
||
25 | } |
||
26 | |||
27 | // WARNING: OOjs-UI is NOT TESTED with older browsers and is likely to break |
||
28 | // if loaded in browsers that don't support ES5 |
||
29 | return call_user_func( function () { |
||
30 | $themes = ExtensionRegistry::getInstance()->getAttribute( 'SkinOOUIThemes' ); |
||
31 | // We only use the theme names for file names, and they are lowercase |
||
32 | $themes = array_map( 'strtolower', $themes ); |
||
33 | $themes['default'] = 'mediawiki'; |
||
34 | |||
35 | // Helper function to generate paths to files used in 'skinStyles' and 'skinScripts'. |
||
36 | $getSkinSpecific = function ( $module, $ext = 'css' ) use ( $themes ) { |
||
37 | return array_combine( |
||
38 | array_keys( $themes ), |
||
39 | array_map( function ( $theme ) use ( $module, $ext ) { |
||
40 | $module = $module ? "$module-" : ''; |
||
0 ignored issues
–
show
|
|||
41 | // TODO Allow extensions to specify this path somehow |
||
42 | return "resources/lib/oojs-ui/oojs-ui-$module$theme.$ext"; |
||
43 | }, array_values( $themes ) ) |
||
44 | ); |
||
45 | }; |
||
46 | |||
47 | $modules = []; |
||
48 | |||
49 | // Omnibus module. |
||
50 | $modules['oojs-ui'] = [ |
||
51 | 'dependencies' => [ |
||
52 | 'oojs-ui-core', |
||
53 | 'oojs-ui-widgets', |
||
54 | 'oojs-ui-toolbars', |
||
55 | 'oojs-ui-windows', |
||
56 | ], |
||
57 | 'targets' => [ 'desktop', 'mobile' ], |
||
58 | ]; |
||
59 | |||
60 | // The core JavaScript library. |
||
61 | $modules['oojs-ui-core'] = [ |
||
62 | 'scripts' => [ |
||
63 | 'resources/lib/oojs-ui/oojs-ui-core.js', |
||
64 | 'resources/src/oojs-ui-local.js', |
||
65 | ], |
||
66 | 'skinScripts' => $getSkinSpecific( null, 'js' ), |
||
67 | 'dependencies' => [ |
||
68 | 'es5-shim', |
||
69 | 'oojs', |
||
70 | 'oojs-ui-core.styles', |
||
71 | 'oojs-ui.styles.icons', |
||
72 | 'oojs-ui.styles.indicators', |
||
73 | 'oojs-ui.styles.textures', |
||
74 | 'mediawiki.language', |
||
75 | ], |
||
76 | 'targets' => [ 'desktop', 'mobile' ], |
||
77 | ]; |
||
78 | // This contains only the styles required by core widgets. |
||
79 | $modules['oojs-ui-core.styles'] = [ |
||
80 | 'position' => 'top', |
||
81 | 'styles' => 'resources/src/oojs-ui-local.css', // HACK, see inside the file |
||
82 | 'skinStyles' => $getSkinSpecific( 'core' ), |
||
83 | 'targets' => [ 'desktop', 'mobile' ], |
||
84 | ]; |
||
85 | |||
86 | // Additional widgets and layouts module. |
||
87 | $modules['oojs-ui-widgets'] = [ |
||
88 | 'scripts' => 'resources/lib/oojs-ui/oojs-ui-widgets.js', |
||
89 | 'skinStyles' => $getSkinSpecific( 'widgets' ), |
||
90 | 'dependencies' => 'oojs-ui-core', |
||
91 | 'messages' => [ |
||
92 | 'ooui-outline-control-move-down', |
||
93 | 'ooui-outline-control-move-up', |
||
94 | 'ooui-outline-control-remove', |
||
95 | 'ooui-selectfile-button-select', |
||
96 | 'ooui-selectfile-dragdrop-placeholder', |
||
97 | 'ooui-selectfile-not-supported', |
||
98 | 'ooui-selectfile-placeholder', |
||
99 | ], |
||
100 | 'targets' => [ 'desktop', 'mobile' ], |
||
101 | ]; |
||
102 | // Toolbar and tools module. |
||
103 | $modules['oojs-ui-toolbars'] = [ |
||
104 | 'scripts' => 'resources/lib/oojs-ui/oojs-ui-toolbars.js', |
||
105 | 'skinStyles' => $getSkinSpecific( 'toolbars' ), |
||
106 | 'dependencies' => 'oojs-ui-core', |
||
107 | 'messages' => [ |
||
108 | 'ooui-toolbar-more', |
||
109 | 'ooui-toolgroup-collapse', |
||
110 | 'ooui-toolgroup-expand', |
||
111 | ], |
||
112 | 'targets' => [ 'desktop', 'mobile' ], |
||
113 | ]; |
||
114 | // Windows and dialogs module. |
||
115 | $modules['oojs-ui-windows'] = [ |
||
116 | 'scripts' => 'resources/lib/oojs-ui/oojs-ui-windows.js', |
||
117 | 'skinStyles' => $getSkinSpecific( 'windows' ), |
||
118 | 'dependencies' => 'oojs-ui-core', |
||
119 | 'messages' => [ |
||
120 | 'ooui-dialog-message-accept', |
||
121 | 'ooui-dialog-message-reject', |
||
122 | 'ooui-dialog-process-continue', |
||
123 | 'ooui-dialog-process-dismiss', |
||
124 | 'ooui-dialog-process-error', |
||
125 | 'ooui-dialog-process-retry', |
||
126 | ], |
||
127 | 'targets' => [ 'desktop', 'mobile' ], |
||
128 | ]; |
||
129 | |||
130 | $imageSets = [ |
||
131 | // Comments for greppability |
||
132 | 'icons', // oojs-ui.styles.icons |
||
133 | 'indicators', // oojs-ui.styles.indicators |
||
134 | 'textures', // oojs-ui.styles.textures |
||
135 | 'icons-accessibility', // oojs-ui.styles.icons-accessibility |
||
136 | 'icons-alerts', // oojs-ui.styles.icons-alerts |
||
137 | 'icons-content', // oojs-ui.styles.icons-content |
||
138 | 'icons-editing-advanced', // oojs-ui.styles.icons-editing-advanced |
||
139 | 'icons-editing-core', // oojs-ui.styles.icons-editing-core |
||
140 | 'icons-editing-list', // oojs-ui.styles.icons-editing-list |
||
141 | 'icons-editing-styling', // oojs-ui.styles.icons-editing-styling |
||
142 | 'icons-interactions', // oojs-ui.styles.icons-interactions |
||
143 | 'icons-layout', // oojs-ui.styles.icons-layout |
||
144 | 'icons-location', // oojs-ui.styles.icons-location |
||
145 | 'icons-media', // oojs-ui.styles.icons-media |
||
146 | 'icons-moderation', // oojs-ui.styles.icons-moderation |
||
147 | 'icons-movement', // oojs-ui.styles.icons-movement |
||
148 | 'icons-user', // oojs-ui.styles.icons-user |
||
149 | 'icons-wikimedia', // oojs-ui.styles.icons-wikimedia |
||
150 | ]; |
||
151 | $rootPath = 'resources/lib/oojs-ui/themes'; |
||
152 | |||
153 | foreach ( $imageSets as $name ) { |
||
154 | $module = [ |
||
155 | 'position' => 'top', |
||
156 | 'class' => 'ResourceLoaderOOUIImageModule', |
||
157 | 'name' => $name, |
||
158 | 'rootPath' => $rootPath, |
||
159 | ]; |
||
160 | |||
161 | if ( substr( $name, 0, 5 ) === 'icons' ) { |
||
162 | $module['selectorWithoutVariant'] = '.oo-ui-icon-{name}, .mw-ui-icon-{name}:before'; |
||
163 | $module['selectorWithVariant'] = ' |
||
164 | .oo-ui-image-{variant}.oo-ui-icon-{name}, .mw-ui-icon-{name}-{variant}:before, |
||
165 | /* Hack for Flow, see T110051 */ |
||
166 | .mw-ui-hovericon:hover .mw-ui-icon-{name}-{variant}-hover:before, |
||
167 | .mw-ui-hovericon.mw-ui-icon-{name}-{variant}-hover:hover:before'; |
||
168 | } |
||
169 | |||
170 | $modules["oojs-ui.styles.$name"] = $module; |
||
171 | } |
||
172 | |||
173 | return $modules; |
||
174 | } ); |
||
175 |
It seems like you are assigning to a variable which was imported through a
use
statement which was not imported by reference.For clarity, we suggest to use a different name or import by reference depending on whether you would like to have the change visibile in outer-scope.
Change not visible in outer-scope
Change visible in outer-scope