some fixes
This commit is contained in:
		
							
								
								
									
										281
									
								
								application/.idea/workspace.xml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										281
									
								
								application/.idea/workspace.xml
									
									
									
										generated
									
									
									
								
							| @@ -23,75 +23,10 @@ | ||||
|   </component> | ||||
|   <component name="FileEditorManager"> | ||||
|     <leaf> | ||||
|       <file leaf-file-name="plugin.php" pinned="false" current="false" current-in-tab="false"> | ||||
|         <entry file="file://$PROJECT_DIR$/core/plugin.php"> | ||||
|           <provider selected="true" editor-type-id="text-editor"> | ||||
|             <state line="21" column="20" selection-start="307" selection-end="307" vertical-scroll-proportion="-11.769231" vertical-offset="51" max-vertical-offset="2380"> | ||||
|               <folding /> | ||||
|             </state> | ||||
|           </provider> | ||||
|         </entry> | ||||
|       </file> | ||||
|       <file leaf-file-name="plugins.ManiaControl.xml" pinned="false" current="false" current-in-tab="false"> | ||||
|         <entry file="file://$PROJECT_DIR$/configs/plugins.ManiaControl.xml"> | ||||
|           <provider selected="true" editor-type-id="text-editor"> | ||||
|             <state line="11" column="0" selection-start="363" selection-end="363" vertical-scroll-proportion="0.0" vertical-offset="0" max-vertical-offset="323"> | ||||
|               <folding> | ||||
|                 <marker date="1384000064631" expanded="true" signature="111:311" placeholder="..." /> | ||||
|               </folding> | ||||
|             </state> | ||||
|           </provider> | ||||
|         </entry> | ||||
|       </file> | ||||
|       <file leaf-file-name="core.ManiaControl.xml" pinned="false" current="false" current-in-tab="false"> | ||||
|         <entry file="file://$PROJECT_DIR$/configs/core.ManiaControl.xml"> | ||||
|           <provider selected="true" editor-type-id="text-editor"> | ||||
|             <state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="0.0" vertical-offset="0" max-vertical-offset="357"> | ||||
|               <folding /> | ||||
|             </state> | ||||
|           </provider> | ||||
|         </entry> | ||||
|       </file> | ||||
|       <file leaf-file-name="database.ManiaControl.xml" pinned="false" current="false" current-in-tab="false"> | ||||
|         <entry file="file://$PROJECT_DIR$/configs/database.ManiaControl.xml"> | ||||
|           <provider selected="true" editor-type-id="text-editor"> | ||||
|             <state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="0.0" vertical-offset="0" max-vertical-offset="374"> | ||||
|               <folding /> | ||||
|             </state> | ||||
|           </provider> | ||||
|         </entry> | ||||
|       </file> | ||||
|       <file leaf-file-name="core.php" pinned="false" current="false" current-in-tab="false"> | ||||
|       <file leaf-file-name="core.php" pinned="false" current="true" current-in-tab="true"> | ||||
|         <entry file="file://$PROJECT_DIR$/core/core.php"> | ||||
|           <provider selected="true" editor-type-id="text-editor"> | ||||
|             <state line="168" column="13" selection-start="3581" selection-end="3581" vertical-scroll-proportion="-3.9605262" vertical-offset="2555" max-vertical-offset="6613"> | ||||
|               <folding /> | ||||
|             </state> | ||||
|           </provider> | ||||
|         </entry> | ||||
|       </file> | ||||
|       <file leaf-file-name="ManiaControl.php" pinned="false" current="false" current-in-tab="false"> | ||||
|         <entry file="file://$PROJECT_DIR$/ManiaControl.php"> | ||||
|           <provider selected="true" editor-type-id="text-editor"> | ||||
|             <state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="-0.0" vertical-offset="0" max-vertical-offset="544"> | ||||
|               <folding /> | ||||
|             </state> | ||||
|           </provider> | ||||
|         </entry> | ||||
|       </file> | ||||
|       <file leaf-file-name="pluginHandler.php" pinned="false" current="true" current-in-tab="true"> | ||||
|         <entry file="file://$PROJECT_DIR$/core/pluginHandler.php"> | ||||
|           <provider selected="true" editor-type-id="text-editor"> | ||||
|             <state line="32" column="2" selection-start="484" selection-end="484" vertical-scroll-proportion="0.7243675" vertical-offset="0" max-vertical-offset="751"> | ||||
|               <folding /> | ||||
|             </state> | ||||
|           </provider> | ||||
|         </entry> | ||||
|       </file> | ||||
|       <file leaf-file-name="manialinkIdHandler.php" pinned="false" current="false" current-in-tab="false"> | ||||
|         <entry file="file://$PROJECT_DIR$/core/manialinkIdHandler.php"> | ||||
|           <provider selected="true" editor-type-id="text-editor"> | ||||
|             <state line="19" column="5" selection-start="306" selection-end="306" vertical-scroll-proportion="-12.423077" vertical-offset="0" max-vertical-offset="748"> | ||||
|             <state line="117" column="33" selection-start="2501" selection-end="2501" vertical-scroll-proportion="0.6572104" vertical-offset="1433" max-vertical-offset="6647"> | ||||
|               <folding /> | ||||
|             </state> | ||||
|           </provider> | ||||
| @@ -111,17 +46,23 @@ | ||||
|         <option value="$PROJECT_DIR$/core/database.ManiaControl.php" /> | ||||
|         <option value="$PROJECT_DIR$/core/manialinkIdHandler.php" /> | ||||
|         <option value="$PROJECT_DIR$/core/core.ManiaControl.php" /> | ||||
|         <option value="$PROJECT_DIR$/core/plugin.php" /> | ||||
|         <option value="$PROJECT_DIR$/configs/plugins.ManiaControl.xml" /> | ||||
|         <option value="$PROJECT_DIR$/core/core.php" /> | ||||
|         <option value="$PROJECT_DIR$/core/pluginHandler.php" /> | ||||
|         <option value="$PROJECT_DIR$/core/plugin.php" /> | ||||
|         <option value="$PROJECT_DIR$/core/server.php" /> | ||||
|         <option value="$PROJECT_DIR$/ManiaControl.php" /> | ||||
|         <option value="$PROJECT_DIR$/core/commands.php" /> | ||||
|         <option value="$PROJECT_DIR$/core/stats.php" /> | ||||
|         <option value="$PROJECT_DIR$/core/chat.php" /> | ||||
|         <option value="$PROJECT_DIR$/core/callbacks.php" /> | ||||
|         <option value="$PROJECT_DIR$/core/core.php" /> | ||||
|       </list> | ||||
|     </option> | ||||
|   </component> | ||||
|   <component name="PhpWorkspaceProjectConfiguration" backward_compatibility_performed="true" /> | ||||
|   <component name="ProjectFrameBounds"> | ||||
|     <option name="x" value="-8" /> | ||||
|     <option name="y" value="-8" /> | ||||
|     <option name="x" value="618" /> | ||||
|     <option name="y" value="35" /> | ||||
|     <option name="width" value="1936" /> | ||||
|     <option name="height" value="1056" /> | ||||
|   </component> | ||||
| @@ -151,18 +92,6 @@ | ||||
|       <sortByType /> | ||||
|     </navigator> | ||||
|     <panes> | ||||
|       <pane id="Scope"> | ||||
|         <subPane subId="Problems" /> | ||||
|         <subPane subId="Tests" /> | ||||
|         <subPane subId="Project Files"> | ||||
|           <PATH> | ||||
|             <PATH_ELEMENT USER_OBJECT="Root"> | ||||
|               <option name="myItemId" value="" /> | ||||
|               <option name="myItemType" value="" /> | ||||
|             </PATH_ELEMENT> | ||||
|           </PATH> | ||||
|         </subPane> | ||||
|       </pane> | ||||
|       <pane id="ProjectPane"> | ||||
|         <subPane> | ||||
|           <PATH> | ||||
| @@ -211,6 +140,18 @@ | ||||
|           </PATH> | ||||
|         </subPane> | ||||
|       </pane> | ||||
|       <pane id="Scope"> | ||||
|         <subPane subId="Problems" /> | ||||
|         <subPane subId="Tests" /> | ||||
|         <subPane subId="Project Files"> | ||||
|           <PATH> | ||||
|             <PATH_ELEMENT USER_OBJECT="Root"> | ||||
|               <option name="myItemId" value="" /> | ||||
|               <option name="myItemType" value="" /> | ||||
|             </PATH_ELEMENT> | ||||
|           </PATH> | ||||
|         </subPane> | ||||
|       </pane> | ||||
|     </panes> | ||||
|   </component> | ||||
|   <component name="PropertiesComponent"> | ||||
| @@ -218,8 +159,8 @@ | ||||
|     <property name="WebServerToolWindowFactoryState" value="true" /> | ||||
|     <property name="options.lastSelected" value="reference.settings.ide.settings.uml" /> | ||||
|     <property name="last_opened_file_path" value="$PROJECT_DIR$/.." /> | ||||
|     <property name="options.searchVisible" value="true" /> | ||||
|     <property name="options.splitter.details.proportions" value="0.2" /> | ||||
|     <property name="options.searchVisible" value="true" /> | ||||
|   </component> | ||||
|   <component name="PublishConfig"> | ||||
|     <servers> | ||||
| @@ -283,29 +224,50 @@ | ||||
|     <servers /> | ||||
|   </component> | ||||
|   <component name="ToolWindowManager"> | ||||
|     <frame x="-8" y="-8" width="1936" height="1056" extended-state="7" /> | ||||
|     <frame x="618" y="35" width="1936" height="1056" extended-state="0" /> | ||||
|     <editor active="true" /> | ||||
|     <layout> | ||||
|       <window_info id="Changes" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Terminal" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Find" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Database" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Remote Host" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Debug" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.4" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Event Log" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="true" weight="0.105790645" sideWeight="0.5" order="-1" side_tool="true" content_ui="tabs" /> | ||||
|       <window_info id="Favorites" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="true" content_ui="tabs" /> | ||||
|       <window_info id="Version Control" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Changes" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="7" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Terminal" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="10" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="TODO" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="6" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Database" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Structure" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Project" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="true" weight="0.12540022" sideWeight="0.8942093" order="0" side_tool="false" content_ui="combo" /> | ||||
|       <window_info id="Remote Host" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="4" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Project" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="true" weight="0.12646745" sideWeight="0.8942093" order="0" side_tool="false" content_ui="combo" /> | ||||
|       <window_info id="Debug" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.4" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Favorites" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="2" side_tool="true" content_ui="tabs" /> | ||||
|       <window_info id="Event Log" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.105790645" sideWeight="0.5" order="8" side_tool="true" content_ui="tabs" /> | ||||
|       <window_info id="Run" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="2" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Version Control" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="9" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Cvs" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="4" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Message" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Ant Build" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Find" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Commander" active="false" anchor="right" auto_hide="false" internal_type="SLIDING" type="SLIDING" visible="false" weight="0.4" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Hierarchy" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="2" side_tool="false" content_ui="combo" /> | ||||
|       <window_info id="Inspection" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.4" sideWeight="0.5" order="5" side_tool="false" content_ui="tabs" /> | ||||
|     </layout> | ||||
|     <layout-to-restore> | ||||
|       <window_info id="Cvs" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="4" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Changes" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="7" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Message" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Terminal" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="10" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Find" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Ant Build" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Database" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Remote Host" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="4" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Debug" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.4" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Favorites" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="2" side_tool="true" content_ui="tabs" /> | ||||
|       <window_info id="Event Log" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="true" weight="0.105790645" sideWeight="0.5" order="8" side_tool="true" content_ui="tabs" /> | ||||
|       <window_info id="Version Control" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="9" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="TODO" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="6" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Structure" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Commander" active="false" anchor="right" auto_hide="false" internal_type="SLIDING" type="SLIDING" visible="false" weight="0.4" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Project" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="true" weight="0.12646745" sideWeight="0.8942093" order="0" side_tool="false" content_ui="combo" /> | ||||
|       <window_info id="Inspection" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.4" sideWeight="0.5" order="5" side_tool="false" content_ui="tabs" /> | ||||
|       <window_info id="Hierarchy" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="2" side_tool="false" content_ui="combo" /> | ||||
|     </layout> | ||||
|       <window_info id="Run" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="2" side_tool="false" content_ui="tabs" /> | ||||
|     </layout-to-restore> | ||||
|   </component> | ||||
|   <component name="VcsContentAnnotationSettings"> | ||||
|     <option name="myLimit" value="2678400000" /> | ||||
| @@ -316,63 +278,26 @@ | ||||
|     </option> | ||||
|   </component> | ||||
|   <component name="XDebuggerManager"> | ||||
|     <breakpoint-manager /> | ||||
|     <breakpoint-manager> | ||||
|       <option name="time" value="1" /> | ||||
|     </breakpoint-manager> | ||||
|   </component> | ||||
|   <component name="editorHistoryManager"> | ||||
|     <entry file="file://$PROJECT_DIR$/core/manialinkIdHandler.php"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="19" column="5" selection-start="306" selection-end="306" vertical-scroll-proportion="-12.423077" vertical-offset="0" max-vertical-offset="748"> | ||||
|           <folding /> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/core/authentication.php"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="0.0" vertical-offset="0" max-vertical-offset="1853"> | ||||
|           <folding /> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/ManiaControl.php"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="0.0" vertical-offset="0" max-vertical-offset="777"> | ||||
|           <folding /> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/ManiaControl.bat"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="0.0" vertical-offset="0" max-vertical-offset="777"> | ||||
|           <folding /> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/ManiaControl.sh"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="0.0" vertical-offset="0" max-vertical-offset="777"> | ||||
|           <folding /> | ||||
|         </state> | ||||
|         <state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="0.0" vertical-offset="0" max-vertical-offset="777" /> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/core/plugin.php"> | ||||
|     <entry file="file://$PROJECT_DIR$/configs/core.ManiaControl.xml"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="21" column="20" selection-start="307" selection-end="307" vertical-scroll-proportion="-11.769231" vertical-offset="51" max-vertical-offset="2380"> | ||||
|         <state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="0.0" vertical-offset="0" max-vertical-offset="777"> | ||||
|           <folding /> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/configs/plugins.ManiaControl.xml"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="11" column="0" selection-start="363" selection-end="363" vertical-scroll-proportion="0.0" vertical-offset="0" max-vertical-offset="323"> | ||||
|           <folding> | ||||
|             <marker date="1384000064631" expanded="true" signature="111:311" placeholder="..." /> | ||||
|           </folding> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/configs/core.ManiaControl.xml"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="0" column="0" selection-start="0" selection-end="0" vertical-scroll-proportion="0.0" vertical-offset="0" max-vertical-offset="777"> | ||||
|         <state line="11" column="0" selection-start="363" selection-end="363" vertical-scroll-proportion="0.24066924" vertical-offset="0" max-vertical-offset="777"> | ||||
|           <folding /> | ||||
|         </state> | ||||
|       </provider> | ||||
| @@ -384,16 +309,86 @@ | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/core/core.php"> | ||||
|     <entry file="file://$PROJECT_DIR$/core/authentication.php"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="168" column="13" selection-start="3581" selection-end="3581" vertical-scroll-proportion="-3.9605262" vertical-offset="2555" max-vertical-offset="6613"> | ||||
|         <state line="96" column="74" selection-start="2314" selection-end="2321" vertical-scroll-proportion="-6.3157897" vertical-offset="1152" max-vertical-offset="1853"> | ||||
|           <folding /> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/core/manialinkIdHandler.php"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="19" column="5" selection-start="306" selection-end="306" vertical-scroll-proportion="-12.423077" vertical-offset="0" max-vertical-offset="748"> | ||||
|           <folding /> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/core/database.php"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="68" column="14" selection-start="1719" selection-end="1721" vertical-scroll-proportion="1.4407989" vertical-offset="146" max-vertical-offset="6919"> | ||||
|           <folding /> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/core/commands.php"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="20" column="33" selection-start="0" selection-end="21192" vertical-scroll-proportion="0.4122682" vertical-offset="51" max-vertical-offset="11730"> | ||||
|           <folding /> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/core/stats.php"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="20" column="0" selection-start="268" selection-end="268" vertical-scroll-proportion="0.3566334" vertical-offset="90" max-vertical-offset="5151"> | ||||
|           <folding /> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/ManiaControl.php"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="26" column="0" selection-start="623" selection-end="623" vertical-scroll-proportion="0.5885486" vertical-offset="0" max-vertical-offset="751"> | ||||
|           <folding /> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/core/server.php"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="241" column="9" selection-start="5767" selection-end="5767" vertical-scroll-proportion="0.5021398" vertical-offset="3745" max-vertical-offset="6579"> | ||||
|           <folding /> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/core/plugin.php"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="11" column="15" selection-start="146" selection-end="146" vertical-scroll-proportion="-5.230769" vertical-offset="51" max-vertical-offset="2703"> | ||||
|           <folding /> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/core/chat.php"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="31" column="45" selection-start="452" selection-end="452" vertical-scroll-proportion="-15.5" vertical-offset="124" max-vertical-offset="1547"> | ||||
|           <folding /> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/core/callbacks.php"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="42" column="16" selection-start="0" selection-end="5670" vertical-scroll-proportion="0.24113475" vertical-offset="510" max-vertical-offset="3349"> | ||||
|           <folding /> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/core/pluginHandler.php"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="32" column="2" selection-start="484" selection-end="484" vertical-scroll-proportion="0.7243675" vertical-offset="0" max-vertical-offset="751"> | ||||
|         <state line="32" column="2" selection-start="478" selection-end="478" vertical-scroll-proportion="0.643026" vertical-offset="0" max-vertical-offset="846"> | ||||
|           <folding /> | ||||
|         </state> | ||||
|       </provider> | ||||
|     </entry> | ||||
|     <entry file="file://$PROJECT_DIR$/core/core.php"> | ||||
|       <provider selected="true" editor-type-id="text-editor"> | ||||
|         <state line="117" column="33" selection-start="2501" selection-end="2501" vertical-scroll-proportion="0.6572104" vertical-offset="1433" max-vertical-offset="6647"> | ||||
|           <folding /> | ||||
|         </state> | ||||
|       </provider> | ||||
|   | ||||
| @@ -4,7 +4,7 @@ namespace ManiaControl; | ||||
|  | ||||
| define('ManiaControlDir', __DIR__); | ||||
|  | ||||
| require_once __DIR__ . '/core/core.ManiaControl.php'; | ||||
| require_once __DIR__ . '/core/core.php'; | ||||
|  | ||||
| // Set process settings | ||||
| ini_set('memory_limit', '128M'); | ||||
|   | ||||
| @@ -17,15 +17,15 @@ class Authentication { | ||||
| 	/** | ||||
| 	 * Private properties | ||||
| 	 */ | ||||
| 	private $mControl = null; | ||||
| 	private $mc = null; | ||||
|  | ||||
| 	private $config = null; | ||||
|  | ||||
| 	/** | ||||
| 	 * Construct authentication manager | ||||
| 	 */ | ||||
| 	public function __construct($mControl) { | ||||
| 		$this->mControl = $mControl; | ||||
| 	public function __construct($mc) { | ||||
| 		$this->mc = $mc; | ||||
| 		 | ||||
| 		// Load config | ||||
| 		$this->config = Tools::loadConfig('authentication.ManiaControl.xml'); | ||||
| @@ -94,8 +94,8 @@ class Authentication { | ||||
| 	 * @param string $login        	 | ||||
| 	 */ | ||||
| 	public function sendNotAllowed($login) { | ||||
| 		if (!$this->iControl->chat->sendError('You do not have the required rights to perform this command!', $login)) { | ||||
| 			trigger_error("Couldn't send forbidden message to login '" . $login . "'. " . $this->iControl->getClientErrorText()); | ||||
| 		if (!$this->mc->chat->sendError('You do not have the required rights to perform this command!', $login)) { | ||||
| 			trigger_error("Couldn't send forbidden message to login '" . $login . "'. " . $this->mc->getClientErrorText()); | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|   | ||||
| @@ -49,7 +49,7 @@ class Callbacks { | ||||
| 	/** | ||||
| 	 * Private properties | ||||
| 	 */ | ||||
| 	private $mControl = null; | ||||
| 	private $mc = null; | ||||
|  | ||||
| 	private $callbackHandlers = array(); | ||||
|  | ||||
| @@ -64,8 +64,8 @@ class Callbacks { | ||||
| 	/** | ||||
| 	 * Construct callbacks handler | ||||
| 	 */ | ||||
| 	public function __construct($mControl) { | ||||
| 		$this->mControl = $mControl; | ||||
| 	public function __construct($mc) { | ||||
| 		$this->mc = $mc; | ||||
| 		 | ||||
| 		// Init values | ||||
| 		$this->last1Second = time(); | ||||
| @@ -82,7 +82,7 @@ class Callbacks { | ||||
| 		$this->triggerCallback(self::CB_IC_ONINIT, array(self::CB_IC_ONINIT)); | ||||
| 		 | ||||
| 		// Simulate begin map | ||||
| 		$map = $this->iControl->server->getMap(); | ||||
| 		$map = $this->mc->server->getMap(); | ||||
| 		if ($map) { | ||||
| 			$this->triggerCallback(self::CB_IC_BEGINMAP, array(self::CB_IC_BEGINMAP, array($map))); | ||||
| 		} | ||||
| @@ -122,12 +122,12 @@ class Callbacks { | ||||
| 		} | ||||
| 		 | ||||
| 		// Get server callbacks | ||||
| 		if (!$this->iControl->client) return; | ||||
| 		$this->iControl->client->resetError(); | ||||
| 		$this->iControl->client->readCB(); | ||||
| 		$callbacks = $this->iControl->client->getCBResponses(); | ||||
| 		if (!is_array($callbacks) || $this->iControl->client->isError()) { | ||||
| 			trigger_error("Error reading server callbacks. " . $this->iControl->getClientErrorText()); | ||||
| 		if (!$this->mc->client) return; | ||||
| 		$this->mc->client->resetError(); | ||||
| 		$this->mc->client->readCB(); | ||||
| 		$callbacks = $this->mc->client->getCBResponses(); | ||||
| 		if (!is_array($callbacks) || $this->mc->client->isError()) { | ||||
| 			trigger_error("Error reading server callbacks. " . $this->mc->getClientErrorText()); | ||||
| 			return; | ||||
| 		} | ||||
| 		 | ||||
|   | ||||
| @@ -12,7 +12,7 @@ class Chat { | ||||
| 	/** | ||||
| 	 * Private properties | ||||
| 	 */ | ||||
| 	private $mControl = null; | ||||
| 	private $mc = null; | ||||
|  | ||||
| 	private $config = null; | ||||
|  | ||||
| @@ -21,8 +21,8 @@ class Chat { | ||||
| 	/** | ||||
| 	 * Construct ManiaControl chat | ||||
| 	 */ | ||||
| 	public function __construct($mControl) { | ||||
| 		$this->mControl = $mControl; | ||||
| 	public function __construct($mc) { | ||||
| 		$this->mc = $mc; | ||||
| 		 | ||||
| 		// Load config | ||||
| 		$this->config = Tools::loadConfig('chat.ManiaControl.xml'); | ||||
| @@ -36,12 +36,12 @@ class Chat { | ||||
| 	 * @param bool $prefix        	 | ||||
| 	 */ | ||||
| 	public function sendChat($message, $login = null, $prefix = false) { | ||||
| 		if (!$this->iControl->client) return false; | ||||
| 		if (!$this->mc->client) return false; | ||||
| 		if ($login === null) { | ||||
| 			return $this->iControl->client->query('ChatSendServerMessage', ($prefix ? $this->prefix : '') . $message); | ||||
| 			return $this->mc->client->query('ChatSendServerMessage', ($prefix ? $this->prefix : '') . $message); | ||||
| 		} | ||||
| 		else { | ||||
| 			return $this->iControl->client->query('ChatSendServerMessageToLogin', ($prefix ? $this->prefix : '') . $message, $login); | ||||
| 			return $this->mc->client->query('ChatSendServerMessageToLogin', ($prefix ? $this->prefix : '') . $message, $login); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
|   | ||||
| @@ -12,7 +12,7 @@ class Commands { | ||||
| 	/** | ||||
| 	 * Private properties | ||||
| 	 */ | ||||
| 	private $mControl = null; | ||||
| 	private $mc = null; | ||||
|  | ||||
| 	private $config = null; | ||||
|  | ||||
| @@ -27,16 +27,16 @@ class Commands { | ||||
| 	/** | ||||
| 	 * Construct commands handler | ||||
| 	 */ | ||||
| 	public function __construct($mControl) { | ||||
| 		$this->mControl = $mControl; | ||||
| 	public function __construct($mc) { | ||||
| 		$this->mc = $mc; | ||||
| 		 | ||||
| 		// Load config | ||||
| 		$this->config = Tools::loadConfig('commands.ManiaControl.xml'); | ||||
| 		 | ||||
| 		// Register for callbacks | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_IC_5_SECOND, $this, 'each5Seconds'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_MP_BILLUPDATED, $this, 'handleBillUpdated'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERCHAT, $this, 'handleChatCallback'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_IC_5_SECOND, $this, 'each5Seconds'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_MP_BILLUPDATED, $this, 'handleBillUpdated'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERCHAT, $this, 'handleChatCallback'); | ||||
| 		 | ||||
| 		// Register basic commands | ||||
| 		$commands = array('help', 'version', 'shutdown', 'shutdownserver', 'networkstats', 'systeminfo', 'getservername',  | ||||
| @@ -102,7 +102,7 @@ class Commands { | ||||
| 				{ | ||||
| 					// Payed | ||||
| 					$message = 'Success! Thanks.'; | ||||
| 					$this->iControl->chat->sendSuccess($message, $login); | ||||
| 					$this->mc->chat->sendSuccess($message, $login); | ||||
| 					unset($this->openBills[$bill[0]]); | ||||
| 					break; | ||||
| 				} | ||||
| @@ -110,14 +110,14 @@ class Commands { | ||||
| 				{ | ||||
| 					// Refused | ||||
| 					$message = 'Transaction cancelled.'; | ||||
| 					$this->iControl->chat->sendError($message, $login); | ||||
| 					$this->mc->chat->sendError($message, $login); | ||||
| 					unset($this->openBills[$bill[0]]); | ||||
| 					break; | ||||
| 				} | ||||
| 			case 6: | ||||
| 				{ | ||||
| 					// Error | ||||
| 					$this->iControl->chat->sendError($bill[2], $login); | ||||
| 					$this->mc->chat->sendError($bill[2], $login); | ||||
| 					unset($this->openBills[$bill[0]]); | ||||
| 					break; | ||||
| 				} | ||||
| @@ -134,7 +134,7 @@ class Commands { | ||||
| 	private function getRightsLevel($commandName, $defaultLevel) { | ||||
| 		$command_rights = $this->config->xpath('//' . strtolower($commandName) . '/..'); | ||||
| 		if (empty($command_rights)) return $defaultLevel; | ||||
| 		$rights = $this->iControl->authentication->RIGHTS_LEVELS; | ||||
| 		$rights = $this->mc->authentication->RIGHTS_LEVELS; | ||||
| 		$highest_level = null; | ||||
| 		foreach ($command_rights as $right) { | ||||
| 			$levelName = $right->getName(); | ||||
| @@ -152,13 +152,13 @@ class Commands { | ||||
| 	 */ | ||||
| 	private function command_version($chat) { | ||||
| 		$login = $chat[1][1]; | ||||
| 		if (!$this->iControl->authentication->checkRight($login, $this->getRightsLevel('version', 'all'))) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, $this->getRightsLevel('version', 'all'))) { | ||||
| 			// Not allowed! | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 			return; | ||||
| 		} | ||||
| 		if (!$this->iControl->chat->sendInformation('This server is using ManiaControl v' . ManiaControl::VERSION . '!', $login)) { | ||||
| 			trigger_error("Couldn't send version to '" . $login . "'. " . $this->iControl->getClientErrorText()); | ||||
| 		if (!$this->mc->chat->sendInformation('This server is using ManiaControl v' . ManiaControl::VERSION . '!', $login)) { | ||||
| 			trigger_error("Couldn't send version to '" . $login . "'. " . $this->mc->getClientErrorText()); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @@ -167,9 +167,9 @@ class Commands { | ||||
| 	 */ | ||||
| 	private function command_help($chat) { | ||||
| 		$login = $chat[1][1]; | ||||
| 		if (!$this->iControl->authentication->checkRight($login, $this->getRightsLevel('help', 'all'))) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, $this->getRightsLevel('help', 'all'))) { | ||||
| 			// Not allowed! | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 			return; | ||||
| 		} | ||||
| 		// TODO: improve help command | ||||
| @@ -178,7 +178,7 @@ class Commands { | ||||
| 		$commands = array_keys($this->commandHandlers); | ||||
| 		$count = count($commands); | ||||
| 		for ($index = 0; $index < $count; $index++) { | ||||
| 			if (!$this->iControl->authentication->checkRight($login, $this->getRightsLevel($commands[$index], 'superadmin'))) { | ||||
| 			if (!$this->mc->authentication->checkRight($login, $this->getRightsLevel($commands[$index], 'superadmin'))) { | ||||
| 				unset($commands[$index]); | ||||
| 			} | ||||
| 		} | ||||
| @@ -191,8 +191,8 @@ class Commands { | ||||
| 			} | ||||
| 			$index++; | ||||
| 		} | ||||
| 		if (!$this->iControl->chat->sendInformation($list, $login)) { | ||||
| 			trigger_error("Couldn't send help list to '" . $login . "'. " . $this->iControl->getClientErrorText()); | ||||
| 		if (!$this->mc->chat->sendInformation($list, $login)) { | ||||
| 			trigger_error("Couldn't send help list to '" . $login . "'. " . $this->mc->getClientErrorText()); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @@ -201,18 +201,18 @@ class Commands { | ||||
| 	 */ | ||||
| 	private function command_getplanets($chat) { | ||||
| 		$login = $chat[1][1]; | ||||
| 		if (!$this->iControl->authentication->checkRight($login, $this->getRightsLevel('getplanets', 'admin'))) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, $this->getRightsLevel('getplanets', 'admin'))) { | ||||
| 			// Not allowed! | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 			return; | ||||
| 		} | ||||
| 		if (!$this->iControl->client->query('GetServerPlanets')) { | ||||
| 			trigger_error("Couldn't retrieve server planets. " . $this->iControl->getClientErrorText()); | ||||
| 		if (!$this->mc->client->query('GetServerPlanets')) { | ||||
| 			trigger_error("Couldn't retrieve server planets. " . $this->mc->getClientErrorText()); | ||||
| 		} | ||||
| 		else { | ||||
| 			$planets = $this->iControl->client->getResponse(); | ||||
| 			if (!$this->iControl->chat->sendInformation('This Server has ' . $planets . ' Planets!', $login)) { | ||||
| 				trigger_error("Couldn't send server planets to '" . $login . "'. " . $this->iControl->getClientErrorText()); | ||||
| 			$planets = $this->mc->client->getResponse(); | ||||
| 			if (!$this->mc->chat->sendInformation('This Server has ' . $planets . ' Planets!', $login)) { | ||||
| 				trigger_error("Couldn't send server planets to '" . $login . "'. " . $this->mc->getClientErrorText()); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| @@ -222,9 +222,9 @@ class Commands { | ||||
| 	 */ | ||||
| 	private function command_donate($chat) { | ||||
| 		$login = $chat[1][1]; | ||||
| 		if (!$this->iControl->authentication->checkRight($login, $this->getRightsLevel('donate', 'all'))) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, $this->getRightsLevel('donate', 'all'))) { | ||||
| 			// Not allowed! | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 			return; | ||||
| 		} | ||||
| 		$params = explode(' ', $chat[1][2]); | ||||
| @@ -239,22 +239,22 @@ class Commands { | ||||
| 		} | ||||
| 		if (count($params) >= 3) { | ||||
| 			$receiver = $params[2]; | ||||
| 			$receiverPlayer = $this->iControl->database->getPlayer($receiver); | ||||
| 			$receiverPlayer = $this->mc->database->getPlayer($receiver); | ||||
| 			$receiverName = ($receiverPlayer ? $receiverPlayer['NickName'] : $receiver); | ||||
| 		} | ||||
| 		else { | ||||
| 			$receiver = ''; | ||||
| 			$receiverName = $this->iControl->server->getName(); | ||||
| 			$receiverName = $this->mc->server->getName(); | ||||
| 		} | ||||
| 		$message = 'Donate ' . $amount . ' Planets to $<' . $receiverName . '$>?'; | ||||
| 		if (!$this->iControl->client->query('SendBill', $login, $amount, $message, $receiver)) { | ||||
| 		if (!$this->mc->client->query('SendBill', $login, $amount, $message, $receiver)) { | ||||
| 			trigger_error( | ||||
| 					"Couldn't create donation of " . $amount . " planets from '" . $login . "' for '" . $receiver . "'. " . | ||||
| 							 $this->iControl->getClientErrorText()); | ||||
| 			$this->iControl->chat->sendError("Creating donation failed.", $login); | ||||
| 							 $this->mc->getClientErrorText()); | ||||
| 			$this->mc->chat->sendError("Creating donation failed.", $login); | ||||
| 		} | ||||
| 		else { | ||||
| 			$bill = $this->iControl->client->getResponse(); | ||||
| 			$bill = $this->mc->client->getResponse(); | ||||
| 			$this->openBills[$bill] = $login; | ||||
| 		} | ||||
| 	} | ||||
| @@ -264,9 +264,9 @@ class Commands { | ||||
| 	 */ | ||||
| 	private function command_pay($chat) { | ||||
| 		$login = $chat[1][1]; | ||||
| 		if (!$this->iControl->authentication->checkRight($login, $this->getRightsLevel('pay', 'superadmin'))) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, $this->getRightsLevel('pay', 'superadmin'))) { | ||||
| 			// Not allowed! | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 			return; | ||||
| 		} | ||||
| 		$params = explode(' ', $chat[1][2]); | ||||
| @@ -285,15 +285,15 @@ class Commands { | ||||
| 		else { | ||||
| 			$receiver = $login; | ||||
| 		} | ||||
| 		$message = 'Payout from $<' . $this->iControl->server->getName() . '$>.'; | ||||
| 		if (!$this->iControl->client->query('Pay', $receiver, $amount, $message)) { | ||||
| 		$message = 'Payout from $<' . $this->mc->server->getName() . '$>.'; | ||||
| 		if (!$this->mc->client->query('Pay', $receiver, $amount, $message)) { | ||||
| 			trigger_error( | ||||
| 					"Couldn't create payout of" . $amount . " planets by '" . $login . "' for '" . $receiver . "'. " . | ||||
| 							 $this->iControl->getClientErrorText()); | ||||
| 			$this->iControl->chat->sendError("Creating payout failed.", $login); | ||||
| 							 $this->mc->getClientErrorText()); | ||||
| 			$this->mc->chat->sendError("Creating payout failed.", $login); | ||||
| 		} | ||||
| 		else { | ||||
| 			$bill = $this->iControl->client->getResponse(); | ||||
| 			$bill = $this->mc->client->getResponse(); | ||||
| 			$this->openBills[$bill] = $login; | ||||
| 		} | ||||
| 	} | ||||
| @@ -303,17 +303,17 @@ class Commands { | ||||
| 	 */ | ||||
| 	private function command_networkstats($chat) { | ||||
| 		$login = $chat[1][1]; | ||||
| 		if (!$this->iControl->authentication->checkRight($login, $this->getRightsLevel('networkstats', 'superadmin'))) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, $this->getRightsLevel('networkstats', 'superadmin'))) { | ||||
| 			// Not allowed! | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 			return; | ||||
| 		} | ||||
| 		$networkStats = $this->iControl->server->getNetworkStats(); | ||||
| 		$networkStats = $this->mc->server->getNetworkStats(); | ||||
| 		$message = 'NetworkStats: ' . 'uptime=' . $networkStats['Uptime'] . ', ' . 'nbConn=' . $networkStats['NbrConnection'] . ', ' . | ||||
| 				 'recvRate=' . $networkStats['RecvNetRate'] . ', ' . 'sendRate=' . $networkStats['SendNetRate'] . ', ' . 'recvTotal=' . | ||||
| 				 $networkStats['SendNetRate'] . ', ' . 'sentTotal=' . $networkStats['SendNetRate']; | ||||
| 		if (!$this->iControl->chat->sendInformation($message, $login)) { | ||||
| 			trigger_error("Couldn't send network stats to '" . $login . "'. " . $this->iControl->getClientErrorText()); | ||||
| 		if (!$this->mc->chat->sendInformation($message, $login)) { | ||||
| 			trigger_error("Couldn't send network stats to '" . $login . "'. " . $this->mc->getClientErrorText()); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @@ -322,16 +322,16 @@ class Commands { | ||||
| 	 */ | ||||
| 	private function command_systeminfo($chat) { | ||||
| 		$login = $chat[1][1]; | ||||
| 		if (!$this->iControl->authentication->checkRight($login, $this->getRightsLevel('systeminfo', 'superadmin'))) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, $this->getRightsLevel('systeminfo', 'superadmin'))) { | ||||
| 			// Not allowed! | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 			return; | ||||
| 		} | ||||
| 		$systemInfo = $this->iControl->server->getSystemInfo(); | ||||
| 		$systemInfo = $this->mc->server->getSystemInfo(); | ||||
| 		$message = 'SystemInfo: ' . 'ip=' . $systemInfo['PublishedIp'] . ', ' . 'port=' . $systemInfo['Port'] . ', ' . 'p2pPort=' . | ||||
| 				 $systemInfo['P2PPort'] . ', ' . 'title=' . $systemInfo['TitleId'] . ', ' . 'login=' . $systemInfo['ServerLogin'] . ', '; | ||||
| 		if (!$this->iControl->chat->sendInformation($message, $login)) { | ||||
| 			trigger_error("Couldn't send system info to '" . $login . "'. " . $this->iControl->getClientErrorText()); | ||||
| 		if (!$this->mc->chat->sendInformation($message, $login)) { | ||||
| 			trigger_error("Couldn't send system info to '" . $login . "'. " . $this->mc->getClientErrorText()); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @@ -340,12 +340,12 @@ class Commands { | ||||
| 	 */ | ||||
| 	private function command_shutdown($chat) { | ||||
| 		$login = $chat[1][1]; | ||||
| 		if (!$this->iControl->authentication->checkRight($login, $this->getRightsLevel('shutdown', 'superadmin'))) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, $this->getRightsLevel('shutdown', 'superadmin'))) { | ||||
| 			// Not allowed! | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 			return; | ||||
| 		} | ||||
| 		$this->iControl->quit("ManiaControl shutdown requested by '" . $login . "'"); | ||||
| 		$this->mc->quit("ManiaControl shutdown requested by '" . $login . "'"); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| @@ -353,15 +353,15 @@ class Commands { | ||||
| 	 */ | ||||
| 	private function command_startwarmup($chat) { | ||||
| 		$login = $chat[1][1]; | ||||
| 		if (!$this->iControl->authentication->checkRight($login, $this->getRightsLevel('startwarmup', 'operator'))) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, $this->getRightsLevel('startwarmup', 'operator'))) { | ||||
| 			// Not allowed! | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 			return; | ||||
| 		} | ||||
| 		if (!$this->iControl->client->query("SetWarmUp", true)) { | ||||
| 			trigger_error("Couldn't start warmup. " . $this->iControl->getClientErrorText()); | ||||
| 			$player = $this->iControl->database->getPlayer($login); | ||||
| 			$this->iControl->chat->sendInformation('$<' . ($player ? $player['NickName'] : $login) . '$> started WarmUp!'); | ||||
| 		if (!$this->mc->client->query("SetWarmUp", true)) { | ||||
| 			trigger_error("Couldn't start warmup. " . $this->mc->getClientErrorText()); | ||||
| 			$player = $this->mc->database->getPlayer($login); | ||||
| 			$this->mc->chat->sendInformation('$<' . ($player ? $player['NickName'] : $login) . '$> started WarmUp!'); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @@ -370,17 +370,17 @@ class Commands { | ||||
| 	 */ | ||||
| 	private function command_stopwarmup($chat) { | ||||
| 		$login = $chat[1][1]; | ||||
| 		if (!$this->iControl->authentication->checkRight($login, $this->getRightsLevel('stopwarmup', 'operator'))) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, $this->getRightsLevel('stopwarmup', 'operator'))) { | ||||
| 			// Not allowed! | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 			return; | ||||
| 		} | ||||
| 		if (!$this->iControl->client->query("SetWarmUp", false)) { | ||||
| 			trigger_error("Couldn't stop warmup. " . $this->iControl->getClientErrorText()); | ||||
| 		if (!$this->mc->client->query("SetWarmUp", false)) { | ||||
| 			trigger_error("Couldn't stop warmup. " . $this->mc->getClientErrorText()); | ||||
| 		} | ||||
| 		else { | ||||
| 			$player = $this->iControl->database->getPlayer($login); | ||||
| 			$this->iControl->chat->sendInformation('$<' . ($player ? $player['NickName'] : $login) . '$> stopped WarmUp!'); | ||||
| 			$player = $this->mc->database->getPlayer($login); | ||||
| 			$this->mc->chat->sendInformation('$<' . ($player ? $player['NickName'] : $login) . '$> stopped WarmUp!'); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @@ -389,9 +389,9 @@ class Commands { | ||||
| 	 */ | ||||
| 	private function command_shutdownserver($chat) { | ||||
| 		$login = $chat[1][1]; | ||||
| 		if (!$this->iControl->authentication->checkRight($login, $this->getRightsLevel('shutdownserver', 'superadmin'))) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, $this->getRightsLevel('shutdownserver', 'superadmin'))) { | ||||
| 			// Not allowed! | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 			return; | ||||
| 		} | ||||
| 		// Check for delayed shutdown | ||||
| @@ -401,10 +401,10 @@ class Commands { | ||||
| 			if ($param == 'empty') { | ||||
| 				$this->serverShutdownEmpty = !$this->serverShutdownEmpty; | ||||
| 				if ($this->serverShutdownEmpty) { | ||||
| 					$this->iControl->chat->sendInformation("The server will shutdown as soon as it's empty!", $login); | ||||
| 					$this->mc->chat->sendInformation("The server will shutdown as soon as it's empty!", $login); | ||||
| 				} | ||||
| 				else { | ||||
| 					$this->iControl->chat->sendInformation("Empty-shutdown cancelled!", $login); | ||||
| 					$this->mc->chat->sendInformation("Empty-shutdown cancelled!", $login); | ||||
| 				} | ||||
| 			} | ||||
| 			else { | ||||
| @@ -412,12 +412,12 @@ class Commands { | ||||
| 				if ($delay <= 0) { | ||||
| 					// Cancel shutdown | ||||
| 					$this->serverShutdownTime = -1; | ||||
| 					$this->iControl->chat->sendInformation("Delayed shutdown cancelled!", $login); | ||||
| 					$this->mc->chat->sendInformation("Delayed shutdown cancelled!", $login); | ||||
| 				} | ||||
| 				else { | ||||
| 					// Trigger delayed shutdown | ||||
| 					$this->serverShutdownTime = time() + $delay * 60.; | ||||
| 					$this->iControl->chat->sendInformation("The server will shut down in " . $delay . " minutes!", $login); | ||||
| 					$this->mc->chat->sendInformation("The server will shut down in " . $delay . " minutes!", $login); | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| @@ -431,9 +431,9 @@ class Commands { | ||||
| 	 */ | ||||
| 	private function command_kick($chat) { | ||||
| 		$login = $chat[1][1]; | ||||
| 		if (!$this->iControl->authentication->checkRight($login, $this->getRightsLevel('kick', 'operator'))) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, $this->getRightsLevel('kick', 'operator'))) { | ||||
| 			// Not allowed! | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 			return; | ||||
| 		} | ||||
| 		$params = explode(' ', $chat[1][2], 3); | ||||
| @@ -442,7 +442,7 @@ class Commands { | ||||
| 			return; | ||||
| 		} | ||||
| 		$target = $params[1]; | ||||
| 		$players = $this->iControl->server->getPlayers(); | ||||
| 		$players = $this->mc->server->getPlayers(); | ||||
| 		foreach ($players as $player) { | ||||
| 			if ($player['Login'] != $target) continue; | ||||
| 			// Kick player | ||||
| @@ -452,12 +452,12 @@ class Commands { | ||||
| 			else { | ||||
| 				$message = ""; | ||||
| 			} | ||||
| 			if (!$this->iControl->client->query('Kick', $target, $message)) { | ||||
| 				trigger_error("Couldn't kick player '" . $target . "'! " . $this->iControl->getClientErrorText()); | ||||
| 			if (!$this->mc->client->query('Kick', $target, $message)) { | ||||
| 				trigger_error("Couldn't kick player '" . $target . "'! " . $this->mc->getClientErrorText()); | ||||
| 			} | ||||
| 			return; | ||||
| 		} | ||||
| 		$this->iControl->chat->sendError("Invalid player login.", $login); | ||||
| 		$this->mc->chat->sendError("Invalid player login.", $login); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| @@ -465,26 +465,26 @@ class Commands { | ||||
| 	 */ | ||||
| 	private function command_removemap($chat) { | ||||
| 		$login = $chat[1][1]; | ||||
| 		if (!$this->iControl->authentication->checkRight($login, $this->getRightsLevel('kick', 'operator'))) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, $this->getRightsLevel('kick', 'operator'))) { | ||||
| 			// Not allowed! | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 			return; | ||||
| 		} | ||||
| 		// TODO: allow params | ||||
| 		// Get map name | ||||
| 		$map = $this->iControl->server->getMap(); | ||||
| 		$map = $this->mc->server->getMap(); | ||||
| 		if (!$map) { | ||||
| 			$this->iControl->chat->sendError("Couldn't remove map.", $login); | ||||
| 			$this->mc->chat->sendError("Couldn't remove map.", $login); | ||||
| 		} | ||||
| 		else { | ||||
| 			$mapName = $map['FileName']; | ||||
| 			 | ||||
| 			// Remove map | ||||
| 			if (!$this->iControl->client->query('RemoveMap', $mapName)) { | ||||
| 				trigger_error("Couldn't remove current map. " . $this->iControl->getClientErrorText()); | ||||
| 			if (!$this->mc->client->query('RemoveMap', $mapName)) { | ||||
| 				trigger_error("Couldn't remove current map. " . $this->mc->getClientErrorText()); | ||||
| 			} | ||||
| 			else { | ||||
| 				$this->iControl->chat->sendSuccess('Map removed.', $login); | ||||
| 				$this->mc->chat->sendSuccess('Map removed.', $login); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| @@ -494,9 +494,9 @@ class Commands { | ||||
| 	 */ | ||||
| 	private function command_addmap($chat) { | ||||
| 		$login = $chat[1][1]; | ||||
| 		if (!$this->iControl->authentication->checkRight($login, $this->getRightsLevel('addmap', 'operator'))) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, $this->getRightsLevel('addmap', 'operator'))) { | ||||
| 			// Not allowed! | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 			return; | ||||
| 		} | ||||
| 		$params = explode(' ', $chat[1][2], 2); | ||||
| @@ -505,36 +505,36 @@ class Commands { | ||||
| 			return; | ||||
| 		} | ||||
| 		// Check if ManiaControl can even write to the maps dir | ||||
| 		if (!$this->iControl->client->query('GetMapsDirectory')) { | ||||
| 			trigger_error("Couldn't get map directory. " . $this->iControl->getClientErrorText()); | ||||
| 			$this->iControl->chat->sendError("ManiaControl couldn't retrieve the maps directory.", $login); | ||||
| 		if (!$this->mc->client->query('GetMapsDirectory')) { | ||||
| 			trigger_error("Couldn't get map directory. " . $this->mc->getClientErrorText()); | ||||
| 			$this->mc->chat->sendError("ManiaControl couldn't retrieve the maps directory.", $login); | ||||
| 			return; | ||||
| 		} | ||||
| 		else { | ||||
| 			$mapDir = $this->iControl->client->getResponse(); | ||||
| 			$mapDir = $this->mc->client->getResponse(); | ||||
| 			if (!is_dir($mapDir)) { | ||||
| 				trigger_error("ManiaControl doesn't have have access to the maps directory in '" . $mapDir . "'."); | ||||
| 				$this->iControl->chat->sendError("ManiaControl doesn't have access to the maps directory.", $login); | ||||
| 				$this->mc->chat->sendError("ManiaControl doesn't have access to the maps directory.", $login); | ||||
| 				return; | ||||
| 			} | ||||
| 			$dlDir = (string) $this->iControl->config->maps_dir; | ||||
| 			$dlDir = (string) $this->mc->config->maps_dir; | ||||
| 			// Create mx directory if necessary | ||||
| 			if (!is_dir($mapDir . $dlDir) && !mkdir($mapDir . $dlDir)) { | ||||
| 				trigger_error("ManiaControl doesn't have to rights to save maps in'" . $mapDir . $dlDir, "'."); | ||||
| 				$this->iControl->chat->sendError("ManiaControl doesn't have to rights to save maps.", $login); | ||||
| 				$this->mc->chat->sendError("ManiaControl doesn't have to rights to save maps.", $login); | ||||
| 				return; | ||||
| 			} | ||||
| 			$mapDir .= $dlDir . '/'; | ||||
| 			// Download the map | ||||
| 			if (is_numeric($params[1])) { | ||||
| 				$serverInfo = $this->iControl->server->getSystemInfo(); | ||||
| 				$serverInfo = $this->mc->server->getSystemInfo(); | ||||
| 				$title = strtolower(substr($serverInfo['TitleId'], 0, 2)); | ||||
| 				// Check if map exists | ||||
| 				$url = 'http://' . $title . '.mania-exchange.com/api/tracks/get_track_info/id/' . $params[1] . '?format=json'; | ||||
| 				$mapInfo = Tools::loadFile($url); | ||||
| 				if (!$mapInfo || strlen($mapInfo) <= 0) { | ||||
| 					// Invalid id | ||||
| 					$this->iControl->chat->sendError('Invalid MX-Id!', $login); | ||||
| 					$this->mc->chat->sendError('Invalid MX-Id!', $login); | ||||
| 					return; | ||||
| 				} | ||||
| 				$mapInfo = json_decode($mapInfo, true); | ||||
| @@ -542,34 +542,34 @@ class Commands { | ||||
| 				$file = Tools::loadFile($url); | ||||
| 				if (!$file) { | ||||
| 					// Download error | ||||
| 					$this->iControl->chat->sendError('Download failed!', $login); | ||||
| 					$this->mc->chat->sendError('Download failed!', $login); | ||||
| 					return; | ||||
| 				} | ||||
| 				// Save map | ||||
| 				$fileName = $mapDir . $mapInfo['TrackID'] . '_' . $mapInfo['Name'] . '.Map.Gbx'; | ||||
| 				if (!file_put_contents($fileName, $file)) { | ||||
| 					// Save error | ||||
| 					$this->iControl->chat->sendError('Saving map failed!', $login); | ||||
| 					$this->mc->chat->sendError('Saving map failed!', $login); | ||||
| 					return; | ||||
| 				} | ||||
| 				// Check for valid map | ||||
| 				if (!$this->iControl->client->query('CheckMapForCurrentServerParams', $fileName)) { | ||||
| 					trigger_error("Couldn't check if map is valid. " . $this->iControl->getClientErrorText()); | ||||
| 				if (!$this->mc->client->query('CheckMapForCurrentServerParams', $fileName)) { | ||||
| 					trigger_error("Couldn't check if map is valid. " . $this->mc->getClientErrorText()); | ||||
| 				} | ||||
| 				else { | ||||
| 					$response = $this->iControl->client->getResponse(); | ||||
| 					$response = $this->mc->client->getResponse(); | ||||
| 					if (!$response) { | ||||
| 						// Inalid map type | ||||
| 						$this->iControl->chat->sendError("Invalid map type.", $login); | ||||
| 						$this->mc->chat->sendError("Invalid map type.", $login); | ||||
| 						return; | ||||
| 					} | ||||
| 				} | ||||
| 				// Add map to map list | ||||
| 				if (!$this->iControl->client->query('InsertMap', $fileName)) { | ||||
| 					$this->iControl->chat->sendError("Couldn't add map to match settings!", $login); | ||||
| 				if (!$this->mc->client->query('InsertMap', $fileName)) { | ||||
| 					$this->mc->chat->sendError("Couldn't add map to match settings!", $login); | ||||
| 					return; | ||||
| 				} | ||||
| 				$this->iControl->chat->sendSuccess('Map $<' . $mapInfo['Name'] . '$> successfully added!'); | ||||
| 				$this->mc->chat->sendSuccess('Map $<' . $mapInfo['Name'] . '$> successfully added!'); | ||||
| 			} | ||||
| 			else { | ||||
| 				// TODO: check if map exists locally | ||||
| @@ -583,13 +583,13 @@ class Commands { | ||||
| 	 */ | ||||
| 	private function command_nextmap($chat) { | ||||
| 		$login = $chat[1][1]; | ||||
| 		if (!$this->iControl->authentication->checkRight($login, $this->getRightsLevel('nextmap', 'operator'))) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, $this->getRightsLevel('nextmap', 'operator'))) { | ||||
| 			// Not allowed! | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 			return; | ||||
| 		} | ||||
| 		if (!$this->iControl->client->query('NextMap')) { | ||||
| 			trigger_error("Couldn't skip map. " . $this->iControl->getClientErrorText()); | ||||
| 		if (!$this->mc->client->query('NextMap')) { | ||||
| 			trigger_error("Couldn't skip map. " . $this->mc->getClientErrorText()); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @@ -598,13 +598,13 @@ class Commands { | ||||
| 	 */ | ||||
| 	private function command_restartmap($chat) { | ||||
| 		$login = $chat[1][1]; | ||||
| 		if (!$this->iControl->authentication->checkRight($login, $this->getRightsLevel('restartmap', 'operator'))) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, $this->getRightsLevel('restartmap', 'operator'))) { | ||||
| 			// Not allowed! | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 			return; | ||||
| 		} | ||||
| 		if (!$this->iControl->client->query('RestartMap')) { | ||||
| 			trigger_error("Couldn't restart map. " . $this->iControl->getClientErrorText()); | ||||
| 		if (!$this->mc->client->query('RestartMap')) { | ||||
| 			trigger_error("Couldn't restart map. " . $this->mc->getClientErrorText()); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @@ -613,13 +613,13 @@ class Commands { | ||||
| 	 */ | ||||
| 	private function command_getservername($chat) { | ||||
| 		$login = $chat[1][1]; | ||||
| 		if (!$this->iControl->authentication->checkRight($login, $this->getRightsLevel('getservername', 'operator'))) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, $this->getRightsLevel('getservername', 'operator'))) { | ||||
| 			// Not allowed! | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 			return; | ||||
| 		} | ||||
| 		$serverName = $this->iControl->server->getName(); | ||||
| 		$this->iControl->chat->sendInformation("Server Name: " . $serverName, $login); | ||||
| 		$serverName = $this->mc->server->getName(); | ||||
| 		$this->mc->chat->sendInformation("Server Name: " . $serverName, $login); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| @@ -627,9 +627,9 @@ class Commands { | ||||
| 	 */ | ||||
| 	private function command_setservername($chat) { | ||||
| 		$login = $chat[1][1]; | ||||
| 		if (!$this->iControl->authentication->checkRight($login, $this->getRightsLevel('setservername', 'admin'))) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, $this->getRightsLevel('setservername', 'admin'))) { | ||||
| 			// Not allowed! | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 			return; | ||||
| 		} | ||||
| 		$params = explode(' ', $chat[1][2], 2); | ||||
| @@ -638,13 +638,13 @@ class Commands { | ||||
| 			return; | ||||
| 		} | ||||
| 		$serverName = $params[1]; | ||||
| 		if (!$this->iControl->client->query('SetServerName', $serverName)) { | ||||
| 			trigger_error("Couldn't set server name. " . $this->iControl->getClientErrorText()); | ||||
| 			$this->iControl->chat->sendError("Error!"); | ||||
| 		if (!$this->mc->client->query('SetServerName', $serverName)) { | ||||
| 			trigger_error("Couldn't set server name. " . $this->mc->getClientErrorText()); | ||||
| 			$this->mc->chat->sendError("Error!"); | ||||
| 		} | ||||
| 		else { | ||||
| 			$serverName = $this->iControl->server->getName(); | ||||
| 			$this->iControl->chat->sendInformation("New Name: " . $serverName); | ||||
| 			$serverName = $this->mc->server->getName(); | ||||
| 			$this->mc->chat->sendInformation("New Name: " . $serverName); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @@ -654,7 +654,7 @@ class Commands { | ||||
| 	public function each5Seconds() { | ||||
| 		// Empty shutdown | ||||
| 		if ($this->serverShutdownEmpty) { | ||||
| 			$players = $this->iControl->server->getPlayers(); | ||||
| 			$players = $this->mc->server->getPlayers(); | ||||
| 			if (count($players) <= 0) { | ||||
| 				$this->shutdownServer('empty'); | ||||
| 			} | ||||
| @@ -672,12 +672,12 @@ class Commands { | ||||
| 	 * Perform server shutdown | ||||
| 	 */ | ||||
| 	private function shutdownServer($login = '#') { | ||||
| 		$this->iControl->client->resetError(); | ||||
| 		if (!$this->iControl->client->query('StopServer') || $this->iControl->client->isError()) { | ||||
| 			trigger_error("Server shutdown command from '" . $login . "' failed. " . $this->iControl->getClientErrorText()); | ||||
| 		$this->mc->client->resetError(); | ||||
| 		if (!$this->mc->client->query('StopServer') || $this->mc->client->isError()) { | ||||
| 			trigger_error("Server shutdown command from '" . $login . "' failed. " . $this->mc->getClientErrorText()); | ||||
| 			return; | ||||
| 		} | ||||
| 		$this->iControl->quit("Server shutdown requested by '" . $login . "'"); | ||||
| 		$this->mc->quit("Server shutdown requested by '" . $login . "'"); | ||||
| 	} | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -13,6 +13,8 @@ require_once __DIR__ . '/database.php'; | ||||
| require_once __DIR__ . '/server.php'; | ||||
| require_once __DIR__ . '/stats.php'; | ||||
| require_once __DIR__ . '/tools.php'; | ||||
| require_once __DIR__ . '/pluginHandler.php'; | ||||
| require_once __DIR__ . '/manialinkIdHandler.php'; | ||||
| list($endiantest) = array_values(unpack('L1L', pack('V', 1))); | ||||
| if ($endiantest == 1) { | ||||
| 	require_once __DIR__ . '/PhpRemote/GbxRemote.inc.php'; | ||||
| @@ -164,7 +166,7 @@ class ManiaControl { | ||||
| 		 | ||||
| 		// Load plugins | ||||
| 		//$this->loadPlugins(); | ||||
| 		$this->pluginhandler->loadPlugins(); | ||||
| 		$this->pluginHandler->loadPlugins(); | ||||
|  | ||||
| 		// Connect to server | ||||
| 		$this->connect(); | ||||
| @@ -191,12 +193,12 @@ class ManiaControl { | ||||
| 			$this->callbacks->handleCallbacks(); | ||||
| 			 | ||||
| 			// Loop plugins | ||||
| 			foreach ($this->plugins as $plugin) { | ||||
| 			/*foreach ($this->plugins as $plugin) { | ||||
| 				if (!method_exists($plugin, 'loop')) { | ||||
| 					continue; | ||||
| 				} | ||||
| 				$plugin->loop(); | ||||
| 			} | ||||
| 			}*/ | ||||
| 			 | ||||
| 			// Yield for next tick | ||||
| 			$loopEnd = microtime(true); | ||||
|   | ||||
| @@ -22,7 +22,7 @@ class Database { | ||||
| 	/** | ||||
| 	 * Private properties | ||||
| 	 */ | ||||
| 	private $mControl = null; | ||||
| 	private $mc = null; | ||||
|  | ||||
| 	private $config = null; | ||||
|  | ||||
| @@ -31,12 +31,12 @@ class Database { | ||||
| 	/** | ||||
| 	 * Construct database connection | ||||
| 	 */ | ||||
| 	public function __construct($mControl) { | ||||
| 		$this->mControl = $mControl; | ||||
| 	public function __construct($mc) { | ||||
| 		$this->mc = $mc; | ||||
| 		 | ||||
| 		// Load config | ||||
| 		$this->config = Tools::loadConfig('database.ManiaControl.xml'); | ||||
| 		$this->mControl->checkConfig($this->config, array("host", "user"), 'database.ManiaControl.xml'); | ||||
| 		$this->mc->checkConfig($this->config, array("host", "user"), 'database.ManiaControl.xml'); | ||||
| 		 | ||||
| 		// Get mysql server information | ||||
| 		$host = $this->config->xpath('host'); | ||||
| @@ -73,8 +73,8 @@ class Database { | ||||
| 		$this->initTables(); | ||||
| 		 | ||||
| 		// Register for callbacks | ||||
| 		$this->mControl->callbacks->registerCallbackHandler(Callbacks::CB_IC_5_SECOND, $this, 'handle5Second'); | ||||
| 		$this->mControl->callbacks->registerCallbackHandler(Callbacks::CB_IC_BEGINMAP, $this, 'handleBeginMap'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_IC_5_SECOND, $this, 'handle5Second'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_IC_BEGINMAP, $this, 'handleBeginMap'); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| @@ -227,7 +227,7 @@ class Database { | ||||
| 	 */ | ||||
| 	public function handle5Second($callback = null) { | ||||
| 		// Save current players in database | ||||
| 		$players = $this->mControl->server->getPlayers(); | ||||
| 		$players = $this->mc->server->getPlayers(); | ||||
| 		if ($players) { | ||||
| 			$query = ""; | ||||
| 			foreach ($players as $player) { | ||||
|   | ||||
| @@ -19,13 +19,15 @@ namespace ManiaControl; | ||||
|     private $author; | ||||
|     private $updateUrl; | ||||
|     private $name; | ||||
|     private $description; | ||||
|     private $active; | ||||
|  | ||||
|     public function __construct($mc, $name, $version = 0, $author = '', $updateUrl = ''){ | ||||
|     public function __construct($mc, $name, $version = 0, $author = '', $description = '', $updateUrl = ''){ | ||||
|        $this->mc = $mc; | ||||
|        $this->name = $name; | ||||
|        $this->version = $version; | ||||
|        $this->author = $author; | ||||
|        $this->description = $description; | ||||
|        $this->updateUrl = $updateUrl; | ||||
|  | ||||
|        $this->mc->pluginHandler->registerPlugin($this); | ||||
| @@ -131,5 +133,22 @@ namespace ManiaControl; | ||||
|      { | ||||
|          return $this->name; | ||||
|      } | ||||
|  | ||||
|      /** | ||||
|       * @param string $description | ||||
|       */ | ||||
|      public function setDescription($description) | ||||
|      { | ||||
|          $this->description = $description; | ||||
|      } | ||||
|  | ||||
|      /** | ||||
|       * @return string | ||||
|       */ | ||||
|      public function getDescription() | ||||
|      { | ||||
|          return $this->description; | ||||
|      } | ||||
|  | ||||
|  } | ||||
| ?> | ||||
| @@ -18,7 +18,7 @@ namespace ManiaControl; | ||||
|      private $plugins; | ||||
|  | ||||
|      public function __construct($mc){ | ||||
|          $this->mControl = $mc; | ||||
|          $this->mc = $mc; | ||||
|          $this->plugins = array(); | ||||
|      } | ||||
|  | ||||
|   | ||||
| @@ -22,20 +22,20 @@ class Server { | ||||
| 	/** | ||||
| 	 * Private properties | ||||
| 	 */ | ||||
| 	private $mControl = null; | ||||
| 	private $mc = null; | ||||
|  | ||||
| 	/** | ||||
| 	 * Construct server | ||||
| 	 */ | ||||
| 	public function __construct($mControl) { | ||||
| 		$this->mControl = $mControl; | ||||
| 	public function __construct($mc) { | ||||
| 		$this->mc = $mc; | ||||
| 		 | ||||
| 		// Load config | ||||
| 		$this->config = Tools::loadConfig('server.ManiaControl.xml'); | ||||
| 		$this->iControl->checkConfig($this->config, array('host', 'port', 'login', 'pass'), 'server'); | ||||
| 		$this->mc->checkConfig($this->config, array('host', 'port', 'login', 'pass'), 'server'); | ||||
| 		 | ||||
| 		// Register for callbacks | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_IC_1_SECOND, $this, 'eachSecond'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_IC_1_SECOND, $this, 'eachSecond'); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| @@ -52,11 +52,11 @@ class Server { | ||||
| 	 * @return string | ||||
| 	 */ | ||||
| 	public function getDataDirectory() { | ||||
| 		if (!$this->iControl->client->query('GameDataDirectory')) { | ||||
| 			trigger_error("Couldn't get data directory. " . $this->iControl->getClientErrorText()); | ||||
| 		if (!$this->mc->client->query('GameDataDirectory')) { | ||||
| 			trigger_error("Couldn't get data directory. " . $this->mc->getClientErrorText()); | ||||
| 			return null; | ||||
| 		} | ||||
| 		return $this->iControl->client->getResponse(); | ||||
| 		return $this->mc->client->getResponse(); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| @@ -87,54 +87,54 @@ class Server { | ||||
| 	public function getInfo($detailed = false) { | ||||
| 		if ($detailed) { | ||||
| 			$login = $this->getLogin(); | ||||
| 			if (!$this->iControl->client->query('GetDetailedPlayerInfo', $login)) { | ||||
| 				trigger_error("Couldn't fetch detailed server player info. " . $this->iControl->getClientErrorText()); | ||||
| 			if (!$this->mc->client->query('GetDetailedPlayerInfo', $login)) { | ||||
| 				trigger_error("Couldn't fetch detailed server player info. " . $this->mc->getClientErrorText()); | ||||
| 				return null; | ||||
| 			} | ||||
| 		} | ||||
| 		else { | ||||
| 			if (!$this->iControl->client->query('GetMainServerPlayerInfo')) { | ||||
| 				trigger_error("Couldn't fetch server player info. " . $this->iControl->getClientErrorText()); | ||||
| 			if (!$this->mc->client->query('GetMainServerPlayerInfo')) { | ||||
| 				trigger_error("Couldn't fetch server player info. " . $this->mc->getClientErrorText()); | ||||
| 				return null; | ||||
| 			} | ||||
| 		} | ||||
| 		return $this->iControl->client->getResponse(); | ||||
| 		return $this->mc->client->getResponse(); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get server options | ||||
| 	 */ | ||||
| 	public function getOptions() { | ||||
| 		if (!$this->iControl->client->query('GetServerOptions')) { | ||||
| 			trigger_error("Couldn't fetch server options. " . $this->iControl->getClientErrorText()); | ||||
| 		if (!$this->mc->client->query('GetServerOptions')) { | ||||
| 			trigger_error("Couldn't fetch server options. " . $this->mc->getClientErrorText()); | ||||
| 			return null; | ||||
| 		} | ||||
| 		return $this->iControl->client->getResponse(); | ||||
| 		return $this->mc->client->getResponse(); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Fetch server name | ||||
| 	 */ | ||||
| 	public function getName() { | ||||
| 		if (!$this->iControl->client->query('GetServerName')) { | ||||
| 			trigger_error("Couldn't fetch server name. " . $this->iControl->getClientErrorText()); | ||||
| 		if (!$this->mc->client->query('GetServerName')) { | ||||
| 			trigger_error("Couldn't fetch server name. " . $this->mc->getClientErrorText()); | ||||
| 			return null; | ||||
| 		} | ||||
| 		return $this->iControl->client->getResponse(); | ||||
| 		return $this->mc->client->getResponse(); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Fetch server version | ||||
| 	 */ | ||||
| 	public function getVersion($forceRefresh = false) { | ||||
| 		if (isset($this->iControl->client->version) && !$forceRefresh) return $this->iControl->client->version; | ||||
| 		if (!$this->iControl->client->query('GetVersion')) { | ||||
| 			trigger_error("Couldn't fetch server version. " . $this->iControl->getClientErrorText()); | ||||
| 		if (isset($this->mc->client->version) && !$forceRefresh) return $this->mc->client->version; | ||||
| 		if (!$this->mc->client->query('GetVersion')) { | ||||
| 			trigger_error("Couldn't fetch server version. " . $this->mc->getClientErrorText()); | ||||
| 			return null; | ||||
| 		} | ||||
| 		else { | ||||
| 			$this->iControl->client->version = $this->iControl->client->getResponse(); | ||||
| 			return $this->iControl->client->version; | ||||
| 			$this->mc->client->version = $this->mc->client->getResponse(); | ||||
| 			return $this->mc->client->version; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @@ -142,11 +142,11 @@ class Server { | ||||
| 	 * Fetch server system info | ||||
| 	 */ | ||||
| 	public function getSystemInfo($forceRefresh = false, &$client = null) { | ||||
| 		if (!$this->iControl->client && !$client) return null; | ||||
| 		if (!$client) $client = $this->iControl->client; | ||||
| 		if (!$this->mc->client && !$client) return null; | ||||
| 		if (!$client) $client = $this->mc->client; | ||||
| 		if (isset($client->systemInfo) && !$forceRefresh) return $client->systemInfo; | ||||
| 		if (!$client->query('GetSystemInfo')) { | ||||
| 			trigger_error("Couldn't fetch server system info. " . $this->iControl->getClientErrorText($client)); | ||||
| 			trigger_error("Couldn't fetch server system info. " . $this->mc->getClientErrorText($client)); | ||||
| 			return null; | ||||
| 		} | ||||
| 		else { | ||||
| @@ -159,14 +159,14 @@ class Server { | ||||
| 	 * Fetch network status | ||||
| 	 */ | ||||
| 	public function getNetworkStats($forceRefresh = false) { | ||||
| 		if (isset($this->iControl->client->networkStats) && !$forceRefresh) return $this->iControl->client->networkStats; | ||||
| 		if (!$this->iControl->client->query('GetNetworkStats')) { | ||||
| 			trigger_error("Couldn't fetch network stats. " . $this->iControl->getClientErrorText()); | ||||
| 		if (isset($this->mc->client->networkStats) && !$forceRefresh) return $this->mc->client->networkStats; | ||||
| 		if (!$this->mc->client->query('GetNetworkStats')) { | ||||
| 			trigger_error("Couldn't fetch network stats. " . $this->mc->getClientErrorText()); | ||||
| 			return null; | ||||
| 		} | ||||
| 		else { | ||||
| 			$this->iControl->client->networkStats = $this->iControl->client->getResponse(); | ||||
| 			return $this->iControl->client->networkStats; | ||||
| 			$this->mc->client->networkStats = $this->mc->client->getResponse(); | ||||
| 			return $this->mc->client->networkStats; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @@ -182,11 +182,11 @@ class Server { | ||||
| 			$gameMode = $parseValue; | ||||
| 		} | ||||
| 		else { | ||||
| 			if (!$this->iControl->client->query('GetGameMode')) { | ||||
| 				trigger_error("Couldn't fetch current game mode. " . $this->iControl->getClientErrorText()); | ||||
| 			if (!$this->mc->client->query('GetGameMode')) { | ||||
| 				trigger_error("Couldn't fetch current game mode. " . $this->mc->getClientErrorText()); | ||||
| 				return null; | ||||
| 			} | ||||
| 			$gameMode = $this->iControl->client->getResponse(); | ||||
| 			$gameMode = $this->mc->client->getResponse(); | ||||
| 		} | ||||
| 		if ($stringValue) { | ||||
| 			switch ($gameMode) { | ||||
| @@ -236,19 +236,19 @@ class Server { | ||||
| 	public function getPlayer($login, $detailed = false) { | ||||
| 		if (!$login) return null; | ||||
| 		$command = ($detailed ? 'GetDetailedPlayerInfo' : 'GetPlayerInfo'); | ||||
| 		if (!$this->iControl->client->query($command, $login)) { | ||||
| 			trigger_error("Couldn't player info for '" . $login . "'. " . $this->iControl->getClientErrorText()); | ||||
| 		if (!$this->mc->client->query($command, $login)) { | ||||
| 			trigger_error("Couldn't player info for '" . $login . "'. " . $this->mc->getClientErrorText()); | ||||
| 			return null; | ||||
| 		} | ||||
| 		return $this->iControl->client->getResponse(); | ||||
| 		return $this->mc->client->getResponse(); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Fetch all players | ||||
| 	 */ | ||||
| 	public function getPlayers(&$client = null, &$purePlayers = null, &$pureSpectators = null) { | ||||
| 		if (!$this->iControl->client && !$client) return null; | ||||
| 		if (!$client) $client = $this->iControl->client; | ||||
| 		if (!$this->mc->client && !$client) return null; | ||||
| 		if (!$client) $client = $this->mc->client; | ||||
| 		$fetchLength = 30; | ||||
| 		$offset = 0; | ||||
| 		$players = array(); | ||||
| @@ -257,7 +257,7 @@ class Server { | ||||
| 		$tries = 0; | ||||
| 		while ($tries < 10) { | ||||
| 			if (!$client->query('GetPlayerList', $fetchLength, $offset)) { | ||||
| 				trigger_error("Couldn't get player list. " . $this->iControl->getClientErrorText($client)); | ||||
| 				trigger_error("Couldn't get player list. " . $this->mc->getClientErrorText($client)); | ||||
| 				$tries++; | ||||
| 			} | ||||
| 			else { | ||||
| @@ -297,11 +297,11 @@ class Server { | ||||
| 	 */ | ||||
| 	public function getValidationReplay($login) { | ||||
| 		if (!$login) return null; | ||||
| 		if (!$this->iControl->client->query('GetValidationReplay', $login)) { | ||||
| 			trigger_error("Couldn't get validation replay of '" . $login . "'. " . $this->iControl->getClientErrorText()); | ||||
| 		if (!$this->mc->client->query('GetValidationReplay', $login)) { | ||||
| 			trigger_error("Couldn't get validation replay of '" . $login . "'. " . $this->mc->getClientErrorText()); | ||||
| 			return null; | ||||
| 		} | ||||
| 		return $this->iControl->client->getResponse(); | ||||
| 		return $this->mc->client->getResponse(); | ||||
| 	} | ||||
|  | ||||
| 	public function getGhostReplay($login) { | ||||
| @@ -317,8 +317,8 @@ class Server { | ||||
| 		$fileName = 'Ghost.' . $login . '.' . $gameMode . '.' . $time . '.' . $map['UId'] . '.Replay.Gbx'; | ||||
| 		 | ||||
| 		// Save ghost replay | ||||
| 		if (!$this->iControl->client->query('SaveBestGhostsReplay', $login, self::GHOSTREPLAYDIR . $fileName)) { | ||||
| 			trigger_error("Couldn't save ghost replay. " . $this->iControl->getClientErrorText()); | ||||
| 		if (!$this->mc->client->query('SaveBestGhostsReplay', $login, self::GHOSTREPLAYDIR . $fileName)) { | ||||
| 			trigger_error("Couldn't save ghost replay. " . $this->mc->getClientErrorText()); | ||||
| 			return null; | ||||
| 		} | ||||
| 		 | ||||
| @@ -335,12 +335,12 @@ class Server { | ||||
| 	 * Fetch current map | ||||
| 	 */ | ||||
| 	public function getMap() { | ||||
| 		if (!$this->iControl->client) return null; | ||||
| 		if (!$this->iControl->client->query('GetCurrentMapInfo')) { | ||||
| 			trigger_error("Couldn't fetch map info. " . $this->iControl->getClientErrorText()); | ||||
| 		if (!$this->mc->client) return null; | ||||
| 		if (!$this->mc->client->query('GetCurrentMapInfo')) { | ||||
| 			trigger_error("Couldn't fetch map info. " . $this->mc->getClientErrorText()); | ||||
| 			return null; | ||||
| 		} | ||||
| 		return $this->iControl->client->getResponse(); | ||||
| 		return $this->mc->client->getResponse(); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| @@ -353,7 +353,7 @@ class Server { | ||||
| 		if ($response['Code'] === 4) return true; | ||||
| 		// Server not yet in given status -> Wait for it... | ||||
| 		$waitBegin = time(); | ||||
| 		$timeoutTags = $this->iControl->config->xpath('timeout'); | ||||
| 		$timeoutTags = $this->mc->config->xpath('timeout'); | ||||
| 		$maxWaitTime = (!empty($timeoutTags) ? (int) $timeoutTags[0] : 20); | ||||
| 		$lastStatus = $response['Name']; | ||||
| 		error_log("Waiting for server to reach status " . $statusCode . "..."); | ||||
| @@ -370,7 +370,7 @@ class Server { | ||||
| 				// It took too long to reach the status | ||||
| 				trigger_error( | ||||
| 						"Server couldn't reach status " . $statusCode . " after " . $maxWaitTime . " seconds! " . | ||||
| 								 $this->iControl->getClientErrorText()); | ||||
| 								 $this->mc->getClientErrorText()); | ||||
| 				return false; | ||||
| 			} | ||||
| 		} | ||||
|   | ||||
| @@ -17,15 +17,15 @@ class Stats { | ||||
| 	/** | ||||
| 	 * Private properties | ||||
| 	 */ | ||||
| 	private $mControl = null; | ||||
| 	private $mc = null; | ||||
|  | ||||
| 	private $config = null; | ||||
|  | ||||
| 	/** | ||||
| 	 * Constuct stats manager | ||||
| 	 */ | ||||
| 	public function __construct($mControl) { | ||||
| 		$this->mControl = $mControl; | ||||
| 	public function __construct($mc) { | ||||
| 		$this->mc = $mc; | ||||
| 		 | ||||
| 		// Load config | ||||
| 		$this->config = Tools::loadConfig('stats.ManiaControl.xml'); | ||||
| @@ -35,11 +35,11 @@ class Stats { | ||||
| 		$this->initTables(); | ||||
| 		 | ||||
| 		// Register for needed callbacks | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_MP_ENDMAP, $this, 'handleEndMap'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERCHAT, $this, 'handlePlayerChat'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERCONNECT, $this, 'handlePlayerConnect'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERDISCONNECT, $this, 'handlePlayerDisconnect'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_TM_PLAYERFINISH, $this, 'handlePlayerFinish'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_MP_ENDMAP, $this, 'handleEndMap'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERCHAT, $this, 'handlePlayerChat'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERCONNECT, $this, 'handlePlayerConnect'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERDISCONNECT, $this, 'handlePlayerDisconnect'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_TM_PLAYERFINISH, $this, 'handlePlayerFinish'); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| @@ -78,7 +78,7 @@ class Stats { | ||||
| 		) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='Tracks player stats' AUTO_INCREMENT=1;"; | ||||
| 		 | ||||
| 		// Perform queries | ||||
| 		if (!$this->iControl->database->multiQuery($query)) { | ||||
| 		if (!$this->mc->database->multiQuery($query)) { | ||||
| 			trigger_error("Creating stats tables failed."); | ||||
| 		} | ||||
| 	} | ||||
| @@ -120,7 +120,7 @@ class Stats { | ||||
| 		} | ||||
| 		 | ||||
| 		// Perform query | ||||
| 		if (!$this->iControl->database->multiQuery($multiquery)) { | ||||
| 		if (!$this->mc->database->multiQuery($multiquery)) { | ||||
| 			trigger_error("Perform queries on end map failed."); | ||||
| 		} | ||||
| 	} | ||||
| @@ -139,7 +139,7 @@ class Stats { | ||||
| 			`Login`, | ||||
| 			`chatCount` | ||||
| 			) VALUES ( | ||||
| 			'" . $this->iControl->database->escape($login) . "', | ||||
| 			'" . $this->mc->database->escape($login) . "', | ||||
| 			1 | ||||
| 			) ON DUPLICATE KEY UPDATE | ||||
| 			`chatCount` = `chatCount` + VALUES(`chatCount`) | ||||
| @@ -147,7 +147,7 @@ class Stats { | ||||
| 		} | ||||
| 		 | ||||
| 		// Perform query | ||||
| 		if (!$this->iControl->database->multiQuery($multiquery)) { | ||||
| 		if (!$this->mc->database->multiQuery($multiquery)) { | ||||
| 			trigger_error("Perform queries on player chat failed."); | ||||
| 		} | ||||
| 	} | ||||
| @@ -174,7 +174,7 @@ class Stats { | ||||
| 		 | ||||
| 		// Track server max players | ||||
| 		if ($this->settings->track_server_max_players) { | ||||
| 			$players = $this->iControl->server->getPlayers(); | ||||
| 			$players = $this->mc->server->getPlayers(); | ||||
| 			$multiquery .= "INSERT INTO `" . self::TABLE_STATS_SERVER . "` ( | ||||
| 			`day`, | ||||
| 			`maxPlayerCount` | ||||
| @@ -193,7 +193,7 @@ class Stats { | ||||
| 			`lastJoin`, | ||||
| 			`connectCount` | ||||
| 			) VALUES ( | ||||
| 			'" . $this->iControl->database->escape($login) . "', | ||||
| 			'" . $this->mc->database->escape($login) . "', | ||||
| 			NOW(), | ||||
| 			1 | ||||
| 			) ON DUPLICATE KEY UPDATE | ||||
| @@ -203,7 +203,7 @@ class Stats { | ||||
| 		} | ||||
| 		 | ||||
| 		// Perform query | ||||
| 		if (!$this->iControl->database->multiQuery($multiquery)) { | ||||
| 		if (!$this->mc->database->multiQuery($multiquery)) { | ||||
| 			trigger_error("Perform queries on player connect failed."); | ||||
| 		} | ||||
| 	} | ||||
| @@ -218,9 +218,9 @@ class Stats { | ||||
| 		// Track player playtime | ||||
| 		if ($this->settings->track_player_playtime) { | ||||
| 			$query = "SELECT `lastJoin` FROM `" . self::TABLE_STATS_PLAYERS . "` | ||||
| 			WHERE `Login` = '" . $this->iControl->database->escape($login) . "' | ||||
| 			WHERE `Login` = '" . $this->mc->database->escape($login) . "' | ||||
| 			;"; | ||||
| 			$result = $this->iControl->database->query($query); | ||||
| 			$result = $this->mc->database->query($query); | ||||
| 			if (!$result) { | ||||
| 				// Error | ||||
| 				trigger_error("Error selecting player join time from '" . $login . "'."); | ||||
| @@ -230,12 +230,12 @@ class Stats { | ||||
| 				while ($row = $result->fetch_object()) { | ||||
| 					if (!property_exists($row, 'lastJoin')) continue; | ||||
| 					$lastJoin = strtotime($row->lastJoin); | ||||
| 					$lastJoin = ($lastJoin > $this->iControl->startTime ? $lastJoin : $this->iControl->startTime); | ||||
| 					$lastJoin = ($lastJoin > $this->mc->startTime ? $lastJoin : $this->mc->startTime); | ||||
| 					$multiquery .= "INSERT INTO `" . self::TABLE_STATS_PLAYERS . "` ( | ||||
| 					`Login`, | ||||
| 					`playTime` | ||||
| 					) VALUES ( | ||||
| 					'" . $this->iControl->database->escape($login) . "', | ||||
| 					'" . $this->mc->database->escape($login) . "', | ||||
| 					TIMESTAMPDIFF(SECOND, '" . Tools::timeToTimestamp($lastJoin) . "', NOW()) | ||||
| 					) ON DUPLICATE KEY UPDATE | ||||
| 					`playTime` = `playTime` + VALUES(`playTime`) | ||||
| @@ -246,7 +246,7 @@ class Stats { | ||||
| 		} | ||||
| 		 | ||||
| 		// Perform query | ||||
| 		if (!$this->iControl->database->multiQuery($multiquery)) { | ||||
| 		if (!$this->mc->database->multiQuery($multiquery)) { | ||||
| 			trigger_error("Perform queries on player connect failed."); | ||||
| 		} | ||||
| 	} | ||||
| @@ -280,7 +280,7 @@ class Stats { | ||||
| 			`Login`, | ||||
| 			`finishCount` | ||||
| 			) VALUES ( | ||||
| 			'" . $this->iControl->database->escape($login) . "', | ||||
| 			'" . $this->mc->database->escape($login) . "', | ||||
| 			1 | ||||
| 			) ON DUPLICATE KEY UPDATE | ||||
| 			`finishCount` = `finishCount` + VALUES(`finishCount`) | ||||
| @@ -288,7 +288,7 @@ class Stats { | ||||
| 		} | ||||
| 		 | ||||
| 		// Perform query | ||||
| 		if (!$this->iControl->database->multiQuery($multiquery)) { | ||||
| 		if (!$this->mc->database->multiQuery($multiquery)) { | ||||
| 			trigger_error("Perform queries on player finish failed."); | ||||
| 		} | ||||
| 	} | ||||
|   | ||||
| @@ -16,7 +16,7 @@ class Plugin_Chatlog extends Plugin{ | ||||
| 	/** | ||||
| 	 * Private properties | ||||
| 	 */ | ||||
| 	private $mControl = null; | ||||
| 	private $mc = null; | ||||
|  | ||||
| 	private $config = null; | ||||
|  | ||||
| @@ -25,8 +25,8 @@ class Plugin_Chatlog extends Plugin{ | ||||
| 	/** | ||||
| 	 * Constuct chatlog plugin | ||||
| 	 */ | ||||
| 	public function __construct($mControl) { | ||||
| 		$this->mControl = $mControl; | ||||
| 	public function __construct($mc) { | ||||
| 		$this->mc = $mc; | ||||
| 		 | ||||
| 		// Load config | ||||
| 		$this->config = Tools::loadConfig('chatlog.plugin.xml'); | ||||
| @@ -38,7 +38,7 @@ class Plugin_Chatlog extends Plugin{ | ||||
| 		$this->loadSettings(); | ||||
| 		 | ||||
| 		// Register for callbacksc | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERCHAT, $this, 'handlePlayerChatCallback'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERCHAT, $this, 'handlePlayerChatCallback'); | ||||
| 		 | ||||
| 		error_log('Chatlog Pugin v' . self::VERSION . ' ready!'); | ||||
| 	} | ||||
|   | ||||
| @@ -18,7 +18,7 @@ class Plugin_Karma { | ||||
| 	/** | ||||
| 	 * Private properties | ||||
| 	 */ | ||||
| 	private $mControl = null; | ||||
| 	private $mc = null; | ||||
|  | ||||
| 	private $config = null; | ||||
|  | ||||
| @@ -27,10 +27,10 @@ class Plugin_Karma { | ||||
| 	/** | ||||
| 	 * Construct plugin | ||||
| 	 * | ||||
| 	 * @param object $mControl        	 | ||||
| 	 * @param object $mc        	 | ||||
| 	 */ | ||||
| 	public function __construct($mControl) { | ||||
| 		$this->mControl = $mControl; | ||||
| 	public function __construct($mc) { | ||||
| 		$this->mc = $mc; | ||||
| 		 | ||||
| 		// Load config | ||||
| 		$this->config = Tools::loadConfig('karma.plugin.xml'); | ||||
| @@ -40,10 +40,10 @@ class Plugin_Karma { | ||||
| 		$this->initDatabase(); | ||||
| 		 | ||||
| 		// Register for callbacks | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_IC_ONINIT, $this, 'handleOnInitCallback'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_IC_BEGINMAP, $this, 'handleBeginMapCallback'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERCONNECT, $this, 'handlePlayerConnectCallback'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERMANIALINKPAGEANSWER, $this,  | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_IC_ONINIT, $this, 'handleOnInitCallback'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_IC_BEGINMAP, $this, 'handleBeginMapCallback'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERCONNECT, $this, 'handlePlayerConnectCallback'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERMANIALINKPAGEANSWER, $this,  | ||||
| 				'handleManialinkPageAnswerCallback'); | ||||
| 		 | ||||
| 		error_log('Karma Pugin v' . self::VERSION . ' ready!'); | ||||
| @@ -57,7 +57,7 @@ class Plugin_Karma { | ||||
| 			$this->sendManialinkRequested = -1; | ||||
| 			 | ||||
| 			// Send manialink to all players | ||||
| 			$players = $this->iControl->server->getPlayers(); | ||||
| 			$players = $this->mc->server->getPlayers(); | ||||
| 			foreach ($players as $player) { | ||||
| 				$login = $player['Login']; | ||||
| 				$manialink = $this->buildManialink($login); | ||||
| @@ -66,7 +66,7 @@ class Plugin_Karma { | ||||
| 					$this->sendManialinkRequested = time() + 5; | ||||
| 					continue; | ||||
| 				} | ||||
| 				Tools::sendManialinkPage($this->iControl->client, $manialink->asXml(), $login); | ||||
| 				Tools::sendManialinkPage($this->mc->client, $manialink->asXml(), $login); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| @@ -100,7 +100,7 @@ class Plugin_Karma { | ||||
| 		$login = $callback[1][0]; | ||||
| 		$manialink = $this->buildManialink($login); | ||||
| 		if (!$manialink) return; | ||||
| 		Tools::sendManialinkPage($this->iControl->client, $manialink->asXml(), $login); | ||||
| 		Tools::sendManialinkPage($this->mc->client, $manialink->asXml(), $login); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| @@ -116,9 +116,9 @@ class Plugin_Karma { | ||||
| 			PRIMARY KEY (`index`), | ||||
| 			UNIQUE KEY `player_map_vote` (`mapIndex`, `playerIndex`) | ||||
| 			) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='Save players map votes' AUTO_INCREMENT=1;"; | ||||
| 		$result = $this->iControl->database->query($query); | ||||
| 		if ($this->iControl->database->mysqli->error) { | ||||
| 			trigger_error('MySQL Error on creating karma table. ' . $this->iControl->database->mysqli->error, E_USER_ERROR); | ||||
| 		$result = $this->mc->database->query($query); | ||||
| 		if ($this->mc->database->mysqli->error) { | ||||
| 			trigger_error('MySQL Error on creating karma table. ' . $this->mc->database->mysqli->error, E_USER_ERROR); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @@ -158,9 +158,9 @@ class Plugin_Karma { | ||||
| 		 | ||||
| 		// Save vote | ||||
| 		$login = $callback[1][1]; | ||||
| 		$playerIndex = $this->iControl->database->getPlayerIndex($login); | ||||
| 		$map = $this->iControl->server->getMap(); | ||||
| 		$mapIndex = $this->iControl->database->getMapIndex($map['UId']); | ||||
| 		$playerIndex = $this->mc->database->getPlayerIndex($login); | ||||
| 		$map = $this->mc->server->getMap(); | ||||
| 		$mapIndex = $this->mc->database->getMapIndex($map['UId']); | ||||
| 		$query = "INSERT INTO `" . self::TABLE_KARMA . "` ( | ||||
| 			`mapIndex`, | ||||
| 			`playerIndex`, | ||||
| @@ -171,11 +171,11 @@ class Plugin_Karma { | ||||
| 			" . $vote . " | ||||
| 			) ON DUPLICATE KEY UPDATE | ||||
| 			`vote` = VALUES(`vote`);"; | ||||
| 		$result = $this->iControl->database->query($query); | ||||
| 		$result = $this->mc->database->query($query); | ||||
| 		if (!$result) return; | ||||
| 		 | ||||
| 		// Send success message | ||||
| 		$this->iControl->chat->sendSuccess('Vote successfully updated!', $login); | ||||
| 		$this->mc->chat->sendSuccess('Vote successfully updated!', $login); | ||||
| 		 | ||||
| 		// Send updated manialink | ||||
| 		$this->sendManialinkRequested = time() + 1; | ||||
| @@ -190,14 +190,14 @@ class Plugin_Karma { | ||||
| 		$pos_x = (float) $this->config->pos_x; | ||||
| 		$pos_y = (float) $this->config->pos_y; | ||||
| 		 | ||||
| 		$mysqli = $this->iControl->database->mysqli; | ||||
| 		$mysqli = $this->mc->database->mysqli; | ||||
| 		 | ||||
| 		// Get indezes | ||||
| 		$playerIndex = $this->iControl->database->getPlayerIndex($login); | ||||
| 		$playerIndex = $this->mc->database->getPlayerIndex($login); | ||||
| 		if ($playerIndex === null) return null; | ||||
| 		$map = $this->iControl->server->getMap(); | ||||
| 		$map = $this->mc->server->getMap(); | ||||
| 		if (!$map) return null; | ||||
| 		$mapIndex = $this->iControl->database->getMapIndex($map['UId']); | ||||
| 		$mapIndex = $this->mc->database->getMapIndex($map['UId']); | ||||
| 		if ($mapIndex === null) return null; | ||||
| 		 | ||||
| 		// Get votings | ||||
|   | ||||
| @@ -17,15 +17,15 @@ class Plugin_Obstacle extends Plugin { | ||||
| 	/** | ||||
| 	 * Private properties | ||||
| 	 */ | ||||
| 	private $mControl = null; | ||||
| 	private $mc = null; | ||||
|  | ||||
| 	private $config = null; | ||||
|  | ||||
| 	/** | ||||
| 	 * Constuct obstacle plugin | ||||
| 	 */ | ||||
| 	public function __construct($mControl) { | ||||
| 		$this->mControl = $mControl; | ||||
| 	public function __construct($mc) { | ||||
| 		$this->mc = $mc; | ||||
| 		 | ||||
| 		// Load config | ||||
| 		$this->config = Tools::loadConfig('obstacle.plugin.xml'); | ||||
| @@ -34,7 +34,7 @@ class Plugin_Obstacle extends Plugin { | ||||
| 		if (!Tools::toBool($this->config->enabled)) return; | ||||
| 		 | ||||
| 		// Register for jump command | ||||
| 		$this->iControl->commands->registerCommandHandler('jumpto', $this, 'command_jumpto'); | ||||
| 		$this->mc->commands->registerCommandHandler('jumpto', $this, 'command_jumpto'); | ||||
| 		 | ||||
| 		error_log('Obstacle Pugin v' . self::VERSION . ' ready!'); | ||||
| 	} | ||||
| @@ -45,16 +45,16 @@ class Plugin_Obstacle extends Plugin { | ||||
| 	public function command_jumpto($chat) { | ||||
| 		$login = $chat[1][1]; | ||||
| 		$rightLevel = (string) $this->config->jumps_rightlevel; | ||||
| 		if (!$this->iControl->authentication->checkRight($login, $rightLevel)) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, $rightLevel)) { | ||||
| 			// Not allowed | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 		} | ||||
| 		else { | ||||
| 			// Send jump callback | ||||
| 			$params = explode(' ', $chat[1][2], 2); | ||||
| 			$param = $login . ";" . $params[1] . ";"; | ||||
| 			if (!$this->iControl->client->query('TriggerModeScriptEvent', self::CB_JUMPTO, $param)) { | ||||
| 				trigger_error("Couldn't send jump callback for '" . $login . "'. " . $this->iControl->getClientErrorText()); | ||||
| 			if (!$this->mc->client->query('TriggerModeScriptEvent', self::CB_JUMPTO, $param)) { | ||||
| 				trigger_error("Couldn't send jump callback for '" . $login . "'. " . $this->mc->getClientErrorText()); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|   | ||||
| @@ -14,15 +14,15 @@ abstract class Plugin_Name { | ||||
| 	/** | ||||
| 	 * Private properties | ||||
| 	 */ | ||||
| 	private $mControl = null; | ||||
| 	private $mc = null; | ||||
|  | ||||
| 	/** | ||||
| 	 * Construct plugin | ||||
| 	 * | ||||
| 	 * @param object $mControl        	 | ||||
| 	 * @param object $mc        	 | ||||
| 	 */ | ||||
| 	public function __construct($mControl) { | ||||
| 		$this->mControl = $mControl; | ||||
| 	public function __construct($mc) { | ||||
| 		$this->mc = $mc; | ||||
| 		 | ||||
| 		error_log('Pugin v' . self::VERSION . ' ready!'); | ||||
| 	} | ||||
|   | ||||
| @@ -37,7 +37,7 @@ class Plugin_Records { | ||||
| 	/** | ||||
| 	 * Private properties | ||||
| 	 */ | ||||
| 	private $mControl = null; | ||||
| 	private $mc = null; | ||||
|  | ||||
| 	private $settings = null; | ||||
|  | ||||
| @@ -58,8 +58,8 @@ class Plugin_Records { | ||||
| 	/** | ||||
| 	 * Constuct plugin | ||||
| 	 */ | ||||
| 	public function __construct($mControl) { | ||||
| 		$this->mControl = $mControl; | ||||
| 	public function __construct($mc) { | ||||
| 		$this->mc = $mc; | ||||
| 		 | ||||
| 		// Load config | ||||
| 		$this->config = Tools::loadConfig('records.plugin.xml'); | ||||
| @@ -74,17 +74,17 @@ class Plugin_Records { | ||||
| 		$this->initTables(); | ||||
| 		 | ||||
| 		// Register for callbacks | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_IC_ONINIT, $this, 'handleOnInit'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_IC_1_SECOND, $this, 'handle1Second'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_IC_1_MINUTE, $this, 'handle1Minute'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_IC_3_MINUTE, $this, 'handle3Minute'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_IC_BEGINMAP, $this, 'handleMapBegin'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_IC_CLIENTUPDATED, $this, 'handleClientUpdated'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_IC_ENDMAP, $this, 'handleMapEnd'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERCONNECT, $this, 'handlePlayerConnect'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERDISCONNECT, $this, 'handlePlayerDisconnect'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_TM_PLAYERFINISH, $this, 'handlePlayerFinish'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_TM_PLAYERCHECKPOINT, $this, 'handlePlayerCheckpoint'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_IC_ONINIT, $this, 'handleOnInit'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_IC_1_SECOND, $this, 'handle1Second'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_IC_1_MINUTE, $this, 'handle1Minute'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_IC_3_MINUTE, $this, 'handle3Minute'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_IC_BEGINMAP, $this, 'handleMapBegin'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_IC_CLIENTUPDATED, $this, 'handleClientUpdated'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_IC_ENDMAP, $this, 'handleMapEnd'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERCONNECT, $this, 'handlePlayerConnect'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERDISCONNECT, $this, 'handlePlayerDisconnect'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_TM_PLAYERFINISH, $this, 'handlePlayerFinish'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_TM_PLAYERCHECKPOINT, $this, 'handlePlayerCheckpoint'); | ||||
| 		 | ||||
| 		error_log('Records Pugin v' . self::VERSION . ' ready!'); | ||||
| 	} | ||||
| @@ -93,7 +93,7 @@ class Plugin_Records { | ||||
| 	 * Init needed database tables | ||||
| 	 */ | ||||
| 	private function initTables() { | ||||
| 		$database = $this->iControl->database; | ||||
| 		$database = $this->mc->database; | ||||
| 		 | ||||
| 		// Records table | ||||
| 		$query = "CREATE TABLE IF NOT EXISTS `" . self::TABLE_RECORDS . "` ( | ||||
| @@ -227,7 +227,7 @@ class Plugin_Records { | ||||
| 		if ($init || !array_key_exists('serverData', $this->dedimaniaData) || !is_array($this->dedimaniaData['serverData'])) { | ||||
| 			$serverData = array(); | ||||
| 			$serverData['Game'] = 'TM2'; | ||||
| 			$serverInfo = $this->iControl->server->getInfo(true); | ||||
| 			$serverInfo = $this->mc->server->getInfo(true); | ||||
| 			 | ||||
| 			// Get dedimania account data | ||||
| 			$accounts = $this->config->xpath('dedimania_records/account'); | ||||
| @@ -250,9 +250,9 @@ class Plugin_Records { | ||||
| 			 | ||||
| 			// Complete seesion data | ||||
| 			$serverData['Path'] = $serverInfo['Path']; | ||||
| 			$systemInfo = $this->iControl->server->getSystemInfo(); | ||||
| 			$systemInfo = $this->mc->server->getSystemInfo(); | ||||
| 			$serverData['Packmask'] = substr($systemInfo['TitleId'], 2); | ||||
| 			$serverVersion = $this->iControl->server->getVersion(); | ||||
| 			$serverVersion = $this->mc->server->getVersion(); | ||||
| 			$serverData['ServerVersion'] = $serverVersion['Version']; | ||||
| 			$serverData['ServerBuild'] = $serverVersion['Build']; | ||||
| 			$serverData['Tool'] = 'ManiaControl'; | ||||
| @@ -352,7 +352,7 @@ class Plugin_Records { | ||||
| 		if ($this->settings->local_records_enabled) $this->sendManialink($this->manialinks[self::MLID_LOCAL], $login); | ||||
| 		 | ||||
| 		if ($this->settings->dedimania_enabled && $this->dedimaniaData['context']) { | ||||
| 			$player = $this->iControl->server->getPlayer($login, true); | ||||
| 			$player = $this->mc->server->getPlayer($login, true); | ||||
| 			if ($player) { | ||||
| 				// Send dedimania request | ||||
| 				$data = array($this->dedimaniaData['sessionId'], $player['Login'], $player['NickName'], $player['Path'],  | ||||
| @@ -435,7 +435,7 @@ class Plugin_Records { | ||||
| 	 * Build map info struct for dedimania requests | ||||
| 	 */ | ||||
| 	private function getMapInfo() { | ||||
| 		$map = $this->iControl->server->getMap(); | ||||
| 		$map = $this->mc->server->getMap(); | ||||
| 		if (!$map) return null; | ||||
| 		$mapInfo = array(); | ||||
| 		$mapInfo['UId'] = $map['UId']; | ||||
| @@ -528,12 +528,12 @@ class Plugin_Records { | ||||
| 	 * Build server info struct for callbacks | ||||
| 	 */ | ||||
| 	private function getSrvInfo() { | ||||
| 		$server = $this->iControl->server->getOptions(); | ||||
| 		$server = $this->mc->server->getOptions(); | ||||
| 		if (!$server) return null; | ||||
| 		$client = null; | ||||
| 		$players = null; | ||||
| 		$spectators = null; | ||||
| 		$this->iControl->server->getPlayers($client, $players, $spectators); | ||||
| 		$this->mc->server->getPlayers($client, $players, $spectators); | ||||
| 		if (!is_array($players) || !is_array($spectators)) return null; | ||||
| 		return array('SrvName' => $server['Name'], 'Comment' => $server['Comment'], 'Private' => (strlen($server['Password']) > 0),  | ||||
| 			'NumPlayers' => count($players), 'MaxPlayers' => $server['CurrentMaxPlayers'], 'NumSpecs' => count($spectators),  | ||||
| @@ -547,7 +547,7 @@ class Plugin_Records { | ||||
| 		$client = null; | ||||
| 		$players; | ||||
| 		$spectators; | ||||
| 		$allPlayers = $this->iControl->server->getPlayers($client, $players, $spectators); | ||||
| 		$allPlayers = $this->mc->server->getPlayers($client, $players, $spectators); | ||||
| 		if (!is_array($players) || !is_array($spectators)) return null; | ||||
| 		$playerInfo = array(); | ||||
| 		foreach ($allPlayers as $player) { | ||||
| @@ -560,9 +560,9 @@ class Plugin_Records { | ||||
| 	 * Get dedi string representation of the current game mode | ||||
| 	 */ | ||||
| 	private function getGameModeString() { | ||||
| 		$gameMode = $this->iControl->server->getGameMode(); | ||||
| 		$gameMode = $this->mc->server->getGameMode(); | ||||
| 		if ($gameMode === null) { | ||||
| 			trigger_error("Couldn't retrieve game mode. " . $this->iControl->getClientErrorText()); | ||||
| 			trigger_error("Couldn't retrieve game mode. " . $this->mc->getClientErrorText()); | ||||
| 			return null; | ||||
| 		} | ||||
| 		switch ($gameMode) { | ||||
| @@ -585,7 +585,7 @@ class Plugin_Records { | ||||
| 	 * Build votes info struct for callbacks | ||||
| 	 */ | ||||
| 	private function getVotesInfo() { | ||||
| 		$map = $this->iControl->server->getMap(); | ||||
| 		$map = $this->mc->server->getMap(); | ||||
| 		if (!$map) return null; | ||||
| 		$gameMode = $this->getGameModeString(); | ||||
| 		if (!$gameMode) return null; | ||||
| @@ -646,14 +646,14 @@ class Plugin_Records { | ||||
| 		 | ||||
| 		$login = $data[1]; | ||||
| 		$time = $data[2]; | ||||
| 		$newMap = $this->iControl->server->getMap(); | ||||
| 		$newMap = $this->mc->server->getMap(); | ||||
| 		if (!$newMap) return; | ||||
| 		if (!$this->mapInfo || $this->mapInfo['UId'] !== $newMap['UId']) { | ||||
| 			$this->mapInfo = $this->getMapInfo(); | ||||
| 		} | ||||
| 		$map = $newMap; | ||||
| 		 | ||||
| 		$player = $this->iControl->server->getPlayer($login); | ||||
| 		$player = $this->mc->server->getPlayer($login); | ||||
| 		 | ||||
| 		if ($this->settings->local_records_enabled) { | ||||
| 			// Get old record of the player | ||||
| @@ -668,13 +668,13 @@ class Plugin_Records { | ||||
| 					// Same time | ||||
| 					$message = '$<' . $player['NickName'] . '$> equalized her/his $<$o' . $oldRecord['rank'] . '.$> Local Record: ' . | ||||
| 							 Tools::formatTime($oldRecord['time']); | ||||
| 					$this->iControl->chat->sendInformation($message); | ||||
| 					$this->mc->chat->sendInformation($message); | ||||
| 					$save = false; | ||||
| 				} | ||||
| 			} | ||||
| 			if ($save) { | ||||
| 				// Save time | ||||
| 				$database = $this->iControl->database; | ||||
| 				$database = $this->mc->database; | ||||
| 				$query = "INSERT INTO `" . self::TABLE_RECORDS . "` ( | ||||
| 					`mapUId`, | ||||
| 					`Login`, | ||||
| @@ -701,7 +701,7 @@ class Plugin_Records { | ||||
| 					} | ||||
| 					$message = '$<' . $player['NickName'] . '$> ' . $improvement . ' $<$o' . $newRecord['rank'] . '.$> Local Record: ' . | ||||
| 							 Tools::formatTime($newRecord['time']); | ||||
| 					$this->iControl->chat->sendInformation($message); | ||||
| 					$this->mc->chat->sendInformation($message); | ||||
| 					$this->updateManialinks[self::MLID_LOCAL] = true; | ||||
| 				} | ||||
| 			} | ||||
| @@ -745,7 +745,7 @@ class Plugin_Records { | ||||
| 					} | ||||
| 					$message = '$<' . $player['NickName'] . '$> ' . $improvement . ' $<$o' . $newRecord['Rank'] . | ||||
| 							 '.$> Dedimania Record: ' . Tools::formatTime($newRecord['Best']); | ||||
| 					$this->iControl->chat->sendInformation($message); | ||||
| 					$this->mc->chat->sendInformation($message); | ||||
| 					$this->updateManialinks[self::MLID_DEDI] = true; | ||||
| 				} | ||||
| 			} | ||||
| @@ -859,21 +859,21 @@ class Plugin_Records { | ||||
| 		if (!$record || !$this->settings->dedimania_enabled) return; | ||||
| 		 | ||||
| 		// Set validation replay | ||||
| 		$validationReplay = $this->iControl->server->getValidationReplay($record['Login']); | ||||
| 		$validationReplay = $this->mc->server->getValidationReplay($record['Login']); | ||||
| 		if ($validationReplay) $record['VReplay'] = $validationReplay; | ||||
| 		 | ||||
| 		// Set ghost replay | ||||
| 		if ($record['Rank'] <= 1) { | ||||
| 			$dataDirectory = $this->iControl->server->getDataDirectory(); | ||||
| 			$dataDirectory = $this->mc->server->getDataDirectory(); | ||||
| 			if (!isset($this->dedimaniaData['directoryAccessChecked'])) { | ||||
| 				$access = $this->iControl->server->checkAccess($dataDirectory); | ||||
| 				$access = $this->mc->server->checkAccess($dataDirectory); | ||||
| 				if (!$access) { | ||||
| 					trigger_error("No access to the servers data directory. Can't retrieve ghost replays."); | ||||
| 				} | ||||
| 				$this->dedimaniaData['directoryAccessChecked'] = $access; | ||||
| 			} | ||||
| 			if ($this->dedimaniaData['directoryAccessChecked']) { | ||||
| 				$ghostReplay = $this->iControl->server->getGhostReplay($record['Login']); | ||||
| 				$ghostReplay = $this->mc->server->getGhostReplay($record['Login']); | ||||
| 				if ($ghostReplay) $record['Top1GReplay'] = $ghostReplay; | ||||
| 			} | ||||
| 		} | ||||
| @@ -939,15 +939,15 @@ class Plugin_Records { | ||||
| 	 * Send manialink to clients | ||||
| 	 */ | ||||
| 	private function sendManialink($manialink, $login = null) { | ||||
| 		if (!$manialink || !$this->iControl->client) return; | ||||
| 		if (!$manialink || !$this->mc->client) return; | ||||
| 		if (!$login) { | ||||
| 			if (!$this->iControl->client->query('SendDisplayManialinkPage', $manialink->asXML(), 0, false)) { | ||||
| 				trigger_error("Couldn't send manialink to players. " . $this->iControl->getClientErrorText()); | ||||
| 			if (!$this->mc->client->query('SendDisplayManialinkPage', $manialink->asXML(), 0, false)) { | ||||
| 				trigger_error("Couldn't send manialink to players. " . $this->mc->getClientErrorText()); | ||||
| 			} | ||||
| 		} | ||||
| 		else { | ||||
| 			if (!$this->iControl->client->query('SendDisplayManialinkPageToLogin', $login, $manialink->asXML(), 0, false)) { | ||||
| 				trigger_error("Couldn't send manialink to player '" . $login . "'. " . $this->iControl->getClientErrorText()); | ||||
| 			if (!$this->mc->client->query('SendDisplayManialinkPageToLogin', $login, $manialink->asXML(), 0, false)) { | ||||
| 				trigger_error("Couldn't send manialink to player '" . $login . "'. " . $this->mc->getClientErrorText()); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| @@ -967,7 +967,7 @@ class Plugin_Records { | ||||
| 	 * Update local records manialink | ||||
| 	 */ | ||||
| 	private function buildLocalManialink() { | ||||
| 		$map = $this->iControl->server->getMap(); | ||||
| 		$map = $this->mc->server->getMap(); | ||||
| 		if (!$map) { | ||||
| 			return null; | ||||
| 		} | ||||
| @@ -1146,12 +1146,12 @@ class Plugin_Records { | ||||
| 	private function getLocalRecords($mapUId, $limit = -1) { | ||||
| 		$query = "SELECT * FROM ( | ||||
| 				SELECT recs.*, @rank := @rank + 1 as `rank` FROM `" . self::TABLE_RECORDS . "` recs, (SELECT @rank := 0) ra | ||||
| 				WHERE recs.`mapUId` = '" . $this->iControl->database->escape($mapUId) . "' | ||||
| 				WHERE recs.`mapUId` = '" . $this->mc->database->escape($mapUId) . "' | ||||
| 				ORDER BY recs.`time` ASC | ||||
| 				" . ($limit > 0 ? "LIMIT " . $limit : "") . ") records | ||||
| 			LEFT JOIN `" . Database::TABLE_PLAYERS . "` players | ||||
| 			ON records.`Login` = players.`Login`;"; | ||||
| 		return $this->iControl->database->query($query); | ||||
| 		return $this->mc->database->query($query); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| @@ -1163,7 +1163,7 @@ class Plugin_Records { | ||||
| 	 */ | ||||
| 	private function getLocalRecord($mapUId, $login) { | ||||
| 		if (!$mapUId || !$login) return null; | ||||
| 		$database = $this->iControl->database; | ||||
| 		$database = $this->mc->database; | ||||
| 		$query = "SELECT records.* FROM ( | ||||
| 			SELECT recs.*, @rank := @rank + 1 as `rank` FROM `" . self::TABLE_RECORDS . "` `recs`, (SELECT @rank := 0) r | ||||
| 			WHERE recs.`mapUid` = '" . $database->escape($mapUId) . "' | ||||
|   | ||||
| @@ -23,7 +23,7 @@ class Plugin_United { | ||||
| 	/** | ||||
| 	 * Private properties | ||||
| 	 */ | ||||
| 	private $mControl = null; | ||||
| 	private $mc = null; | ||||
|  | ||||
| 	private $config = null; | ||||
|  | ||||
| @@ -46,8 +46,8 @@ class Plugin_United { | ||||
| 	/** | ||||
| 	 * Constuct plugin | ||||
| 	 */ | ||||
| 	public function __construct($mControl) { | ||||
| 		$this->mControl = $mControl; | ||||
| 	public function __construct($mc) { | ||||
| 		$this->mc = $mc; | ||||
| 		 | ||||
| 		// Load config | ||||
| 		$this->config = Tools::loadConfig('united.plugin.xml'); | ||||
| @@ -60,14 +60,14 @@ class Plugin_United { | ||||
| 		$this->loadClients(); | ||||
| 		 | ||||
| 		// Register for callbacks | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_IC_ONINIT, $this, 'handleOnInitCallback'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_IC_5_SECOND, $this, 'handle5Seconds'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERCONNECT, $this, 'handlePlayerConnect'); | ||||
| 		$this->iControl->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERMANIALINKPAGEANSWER, $this,  | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_IC_ONINIT, $this, 'handleOnInitCallback'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_IC_5_SECOND, $this, 'handle5Seconds'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERCONNECT, $this, 'handlePlayerConnect'); | ||||
| 		$this->mc->callbacks->registerCallbackHandler(Callbacks::CB_MP_PLAYERMANIALINKPAGEANSWER, $this,  | ||||
| 				'handleManialinkPageAnswer'); | ||||
| 		 | ||||
| 		// Register for commands | ||||
| 		$this->iControl->commands->registerCommandHandler('nextserver', $this, 'handleNextServerCommand'); | ||||
| 		$this->mc->commands->registerCommandHandler('nextserver', $this, 'handleNextServerCommand'); | ||||
| 		 | ||||
| 		if ($this->settings->widgets_enabled) { | ||||
| 			// Build addfavorite manialink | ||||
| @@ -88,9 +88,9 @@ class Plugin_United { | ||||
| 			 | ||||
| 			if (Tools::toBool($this->config->widgets->addfavorite->enabled)) { | ||||
| 				// Send favorite widget | ||||
| 				if (!$this->iControl->client->query('SendDisplayManialinkPage', $this->manialinks[self::ML_ADDFAVORITE]->asXml(), 0,  | ||||
| 				if (!$this->mc->client->query('SendDisplayManialinkPage', $this->manialinks[self::ML_ADDFAVORITE]->asXml(), 0,  | ||||
| 						false)) { | ||||
| 					trigger_error("Couldn't send favorite widget! " . $this->iControl->getClientErrorText()); | ||||
| 					trigger_error("Couldn't send favorite widget! " . $this->mc->getClientErrorText()); | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| @@ -106,7 +106,7 @@ class Plugin_United { | ||||
| 		$this->settings->enabled = Tools::toBool($this->config->enabled); | ||||
| 		 | ||||
| 		// Timeout | ||||
| 		$timeout = $this->iControl->server->config->xpath('timeout'); | ||||
| 		$timeout = $this->mc->server->config->xpath('timeout'); | ||||
| 		if ($timeout) { | ||||
| 			$this->settings->timeout = (int) $timeout[0]; | ||||
| 		} | ||||
| @@ -169,7 +169,7 @@ class Plugin_United { | ||||
| 			$client->readCB(); | ||||
| 			$callbacks = $client->getCBResponses(); | ||||
| 			if (!is_array($callbacks) || $client->isError()) { | ||||
| 				trigger_error("Error reading server callbacks! " . $this->iControl->getClientErrorText($client)); | ||||
| 				trigger_error("Error reading server callbacks! " . $this->mc->getClientErrorText($client)); | ||||
| 			} | ||||
| 			else { | ||||
| 				if ($client == $currentServer) { | ||||
| @@ -189,7 +189,7 @@ class Plugin_United { | ||||
| 					$this->lastStatusCheck = time(); | ||||
| 					 | ||||
| 					if (!$client->query('CheckEndMatchCondition')) { | ||||
| 						trigger_error("Couldn't get game server status. " . $this->iControl->getClientErrorText($client)); | ||||
| 						trigger_error("Couldn't get game server status. " . $this->mc->getClientErrorText($client)); | ||||
| 					} | ||||
| 					else { | ||||
| 						$response = $client->getResponse(); | ||||
| @@ -241,7 +241,7 @@ class Plugin_United { | ||||
| 	 */ | ||||
| 	public function handle5Seconds($callback = null) { | ||||
| 		// Update lobby infos | ||||
| 		$players = $this->iControl->server->getPlayers(); | ||||
| 		$players = $this->mc->server->getPlayers(); | ||||
| 		if (is_array($players)) { | ||||
| 			$playerCount = count($players); | ||||
| 			$playerLevel = 0.; | ||||
| @@ -253,7 +253,7 @@ class Plugin_United { | ||||
| 			} | ||||
| 			foreach ($this->lobbies as $lobby) { | ||||
| 				if (!$lobby->query('SetLobbyInfo', true, $playerCount, 255, $playerLevel)) { | ||||
| 					trigger_error("Couldn't update lobby info. " . $this->iControl->getClientErrorText($lobby)); | ||||
| 					trigger_error("Couldn't update lobby info. " . $this->mc->getClientErrorText($lobby)); | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| @@ -263,14 +263,14 @@ class Plugin_United { | ||||
| 		$joinLink = $this->getJoinLink(); | ||||
| 		foreach ($clients as $client) { | ||||
| 			if ($client == $this->gameServer[$this->currentClientIndex]) continue; | ||||
| 			$players = $this->iControl->server->getPlayers($client); | ||||
| 			$players = $this->mc->server->getPlayers($client); | ||||
| 			if (!is_array($players)) continue; | ||||
| 			foreach ($players as $player) { | ||||
| 				$login = $player['Login']; | ||||
| 				if (!$client->query('SendOpenLinkToLogin', $login, $joinLink, 1)) { | ||||
| 					trigger_error( | ||||
| 							"Couldn't redirect player '" . $login . "' to active game server. " . | ||||
| 									 $this->iControl->getClientErrorText($client)); | ||||
| 									 $this->mc->getClientErrorText($client)); | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| @@ -291,28 +291,28 @@ class Plugin_United { | ||||
| 					if ($add_all) { | ||||
| 						// Add all server | ||||
| 						foreach ($this->gameServer as $serverClient) { | ||||
| 							array_push($serverLogins, $this->iControl->server->getLogin($serverClient)); | ||||
| 							array_push($serverLogins, $this->mc->server->getLogin($serverClient)); | ||||
| 						} | ||||
| 						foreach ($this->lobbies as $serverClient) { | ||||
| 							array_push($serverLogins, $this->iControl->server->getLogin($serverClient)); | ||||
| 							array_push($serverLogins, $this->mc->server->getLogin($serverClient)); | ||||
| 						} | ||||
| 					} | ||||
| 					else { | ||||
| 						// Add only current server | ||||
| 						array_push($serverLogins, $this->iControl->server->getLogin()); | ||||
| 						array_push($serverLogins, $this->mc->server->getLogin()); | ||||
| 					} | ||||
| 					 | ||||
| 					// Build manialink url | ||||
| 					$manialink = 'iControl?favorite'; | ||||
| 					$manialink = 'mc?favorite'; | ||||
| 					foreach ($serverLogins as $serverLogin) { | ||||
| 						$manialink .= '&' . $serverLogin; | ||||
| 					} | ||||
| 					 | ||||
| 					// Send url to player | ||||
| 					if (!$this->iControl->client->query('SendOpenLinkToLogin', $login, $manialink, 1)) { | ||||
| 					if (!$this->mc->client->query('SendOpenLinkToLogin', $login, $manialink, 1)) { | ||||
| 						trigger_error( | ||||
| 								"Couldn't open manialink to add server to favorite for '" . $login . "'! " . | ||||
| 										 $this->iControl->getClientErrorText()); | ||||
| 										 $this->mc->getClientErrorText()); | ||||
| 					} | ||||
| 					break; | ||||
| 				} | ||||
| @@ -345,39 +345,39 @@ class Plugin_United { | ||||
| 		 | ||||
| 		// Restart map on next game server | ||||
| 		if (!$newClient->query('RestartMap')) { | ||||
| 			trigger_error("Couldn't restart map on next game server. " . $this->iControl->getClientErrorText($newClient)); | ||||
| 			trigger_error("Couldn't restart map on next game server. " . $this->mc->getClientErrorText($newClient)); | ||||
| 		} | ||||
| 		 | ||||
| 		if ($simulateMapEnd) { | ||||
| 			// Simulate EndMap on old client | ||||
| 			$this->iControl->callbacks->triggerCallback(Callbacks::CB_IC_ENDMAP, array(Callbacks::CB_IC_ENDMAP)); | ||||
| 			$this->mc->callbacks->triggerCallback(Callbacks::CB_IC_ENDMAP, array(Callbacks::CB_IC_ENDMAP)); | ||||
| 		} | ||||
| 		 | ||||
| 		// Transfer players to next server | ||||
| 		$joinLink = $this->getJoinLink($newClient); | ||||
| 		if (!$oldClient->query('GetPlayerList', 255, 0)) { | ||||
| 			trigger_error("Couldn't get player list. " . $this->iControl->getClientErrorText($oldClient)); | ||||
| 			trigger_error("Couldn't get player list. " . $this->mc->getClientErrorText($oldClient)); | ||||
| 		} | ||||
| 		else { | ||||
| 			$playerList = $oldClient->getResponse(); | ||||
| 			foreach ($playerList as $player) { | ||||
| 				$login = $player['Login']; | ||||
| 				if (!$oldClient->query('SendOpenLinkToLogin', $login, $joinLink, 1)) { | ||||
| 					trigger_error("Couldn't redirect player to next game server. " . $this->iControl->getClientErrorText($oldClient)); | ||||
| 					trigger_error("Couldn't redirect player to next game server. " . $this->mc->getClientErrorText($oldClient)); | ||||
| 				} | ||||
| 			} | ||||
| 			 | ||||
| 			$this->iControl->client = $newClient; | ||||
| 			$this->mc->client = $newClient; | ||||
| 		} | ||||
| 		 | ||||
| 		// Trigger client updated callback | ||||
| 		$this->iControl->callbacks->triggerCallback(Callbacks::CB_IC_CLIENTUPDATED, "Plugin_United.SwitchedServer"); | ||||
| 		$this->mc->callbacks->triggerCallback(Callbacks::CB_IC_CLIENTUPDATED, "Plugin_United.SwitchedServer"); | ||||
| 		 | ||||
| 		if ($simulateMapEnd) { | ||||
| 			// Simulate BeginMap on new client | ||||
| 			$map = $this->iControl->server->getMap(); | ||||
| 			$map = $this->mc->server->getMap(); | ||||
| 			if ($map) { | ||||
| 				$this->iControl->callbacks->triggerCallback(Callbacks::CB_IC_BEGINMAP, array(Callbacks::CB_IC_BEGINMAP, array($map))); | ||||
| 				$this->mc->callbacks->triggerCallback(Callbacks::CB_IC_BEGINMAP, array(Callbacks::CB_IC_BEGINMAP, array($map))); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| @@ -391,9 +391,9 @@ class Plugin_United { | ||||
| 		if (!$command) return; | ||||
| 		$login = $command[1][1]; | ||||
| 		 | ||||
| 		if (!$this->iControl->authentication->checkRight($login, 'operator')) { | ||||
| 		if (!$this->mc->authentication->checkRight($login, 'operator')) { | ||||
| 			// Not allowed | ||||
| 			$this->iControl->authentication->sendNotAllowed($login); | ||||
| 			$this->mc->authentication->sendNotAllowed($login); | ||||
| 			return; | ||||
| 		} | ||||
| 		 | ||||
| @@ -401,7 +401,7 @@ class Plugin_United { | ||||
| 		$this->switchServerRequested = time() + 3; | ||||
| 		 | ||||
| 		// Send chat message | ||||
| 		$this->iControl->chat->sendInformation("Switching to next server in 3 seconds..."); | ||||
| 		$this->mc->chat->sendInformation("Switching to next server in 3 seconds..."); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| @@ -418,7 +418,7 @@ class Plugin_United { | ||||
| 		$joinLink = $this->getJoinLink($gameserver, !$data[1]); | ||||
| 		if (!$client->query('SendOpenLinkToLogin', $login, $joinLink, 1)) { | ||||
| 			trigger_error( | ||||
| 					"United Plugin: Couldn't redirect player to current game server. " . $this->iControl->getClientErrorText($client)); | ||||
| 					"United Plugin: Couldn't redirect player to current game server. " . $this->mc->getClientErrorText($client)); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @@ -473,7 +473,7 @@ class Plugin_United { | ||||
| 			} | ||||
| 			 | ||||
| 			// Wait for server to be ready | ||||
| 			if (!$this->iControl->server->waitForStatus($client, 4)) { | ||||
| 			if (!$this->mc->server->waitForStatus($client, 4)) { | ||||
| 				trigger_error("Server couldn't get ready!", E_USER_ERROR); | ||||
| 			} | ||||
| 			 | ||||
| @@ -481,7 +481,7 @@ class Plugin_United { | ||||
| 			if (!$client->query('SetApiVersion', ManiaControl::API_VERSION)) { | ||||
| 				trigger_error( | ||||
| 						"Couldn't set API version '" . ManiaControl::API_VERSION . "'! This might cause problems. " . | ||||
| 								 $this->iControl->getClientErrorText($client)); | ||||
| 								 $this->mc->getClientErrorText($client)); | ||||
| 			} | ||||
| 			 | ||||
| 			// Set server settings | ||||
| @@ -489,30 +489,30 @@ class Plugin_United { | ||||
| 			$hideServer = ($isGameServer && $this->settings->hide_game_server ? 1 : 0); | ||||
| 			// Passwords | ||||
| 			if (!$client->query('SetServerPassword', $password)) { | ||||
| 				trigger_error("Couldn't set server join password. " . $this->iControl->getClientErrorText($client)); | ||||
| 				trigger_error("Couldn't set server join password. " . $this->mc->getClientErrorText($client)); | ||||
| 			} | ||||
| 			if (!$client->query('SetServerPasswordForSpectator', $password)) { | ||||
| 				trigger_error("Couldn't set server spec password. " . $this->iControl->getClientErrorText($client)); | ||||
| 				trigger_error("Couldn't set server spec password. " . $this->mc->getClientErrorText($client)); | ||||
| 			} | ||||
| 			// Show/Hide server | ||||
| 			if (!$client->query('SetHideServer', $hideServer)) { | ||||
| 				trigger_error( | ||||
| 						"Couldn't set server '" . ($hideServer == 0 ? 'shown' : 'hidden') . "'. " . | ||||
| 								 $this->iControl->getClientErrorText($client)); | ||||
| 								 $this->mc->getClientErrorText($client)); | ||||
| 			} | ||||
| 			 | ||||
| 			// Enable service announces | ||||
| 			if (!$client->query("DisableServiceAnnounces", false)) { | ||||
| 				trigger_error("Couldn't enable service announces. " . $this->iControl->getClientErrorText($client)); | ||||
| 				trigger_error("Couldn't enable service announces. " . $this->mc->getClientErrorText($client)); | ||||
| 			} | ||||
| 			 | ||||
| 			// Set game mode | ||||
| 			if (!$client->query('SetGameMode', $this->settings->gamemode)) { | ||||
| 				trigger_error( | ||||
| 						"Couldn't set game mode (" . $this->settings->gamemode . "). " . $this->iControl->getClientErrorText($client)); | ||||
| 						"Couldn't set game mode (" . $this->settings->gamemode . "). " . $this->mc->getClientErrorText($client)); | ||||
| 			} | ||||
| 			else if (!$client->query('RestartMap')) { | ||||
| 				trigger_error("Couldn't restart map to change game mode. " . $this->iControl->getClientErrorText($client)); | ||||
| 				trigger_error("Couldn't restart map to change game mode. " . $this->mc->getClientErrorText($client)); | ||||
| 			} | ||||
| 			 | ||||
| 			// Save client | ||||
| @@ -520,7 +520,7 @@ class Plugin_United { | ||||
| 			if ($isGameServer) { | ||||
| 				array_push($this->gameServer, $client); | ||||
| 				if (count($this->gameServer) === 1) { | ||||
| 					$this->iControl->client = $client; | ||||
| 					$this->mc->client = $client; | ||||
| 				} | ||||
| 			} | ||||
| 			else { | ||||
| @@ -543,9 +543,9 @@ class Plugin_United { | ||||
| 			 | ||||
| 			if (Tools::toBool($this->config->widgets->addfavorite->enabled)) { | ||||
| 				// Send favorite widget | ||||
| 				if (!$this->iControl->client->query('SendDisplayManialinkPageToLogin', $login,  | ||||
| 				if (!$this->mc->client->query('SendDisplayManialinkPageToLogin', $login,  | ||||
| 						$this->manialinks[self::ML_ADDFAVORITE]->asXml(), 0, false)) { | ||||
| 					trigger_error("Couldn't send favorite widget to player '" . $login . "'! " . $this->iControl->getClientErrorText()); | ||||
| 					trigger_error("Couldn't send favorite widget to player '" . $login . "'! " . $this->mc->getClientErrorText()); | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| @@ -559,14 +559,14 @@ class Plugin_United { | ||||
| 			$client = $this->gameServer[$this->currentClientIndex]; | ||||
| 		} | ||||
| 		if (!$client->query('GetSystemInfo')) { | ||||
| 			trigger_error("Couldn't fetch server system info. " . $this->iControl->getClientErrorText($client)); | ||||
| 			trigger_error("Couldn't fetch server system info. " . $this->mc->getClientErrorText($client)); | ||||
| 			return null; | ||||
| 		} | ||||
| 		else { | ||||
| 			$systemInfo = $client->getResponse(); | ||||
| 			$password = ''; | ||||
| 			if (!$client->query('GetServerPassword')) { | ||||
| 				trigger_error("Couldn't get server password. " . $this->iControl->getClientErrorText($client)); | ||||
| 				trigger_error("Couldn't get server password. " . $this->mc->getClientErrorText($client)); | ||||
| 			} | ||||
| 			else { | ||||
| 				$password = $client->getResponse(); | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| ********************************************** | ||||
| *															* | ||||
| *		mControl ManiaPlanet Server Control		* | ||||
| *		mc ManiaPlanet Server Control		* | ||||
| *				Written by steeffeen					* | ||||
| *		Contact: mail@steeffeen.com				* | ||||
| *															* | ||||
| @@ -12,30 +12,30 @@ SETUP: | ||||
|  | ||||
| 2.	Configure the needed settings: | ||||
|  | ||||
| 	2.1	Open the file 'configs/server.mControl.xml'. | ||||
| 	2.1	Open the file 'configs/server.mc.xml'. | ||||
| 			Enter your maniaplanet server information. | ||||
|  | ||||
| 	2.2	Open the file 'configs/database.mControl.xml' | ||||
| 	2.2	Open the file 'configs/database.mc.xml' | ||||
| 			Enter your mysql server information or disable database usage if you don't have a mysql server available. | ||||
|  | ||||
| 	2.3	Open the file 'configs/authentication.mControl.xml'. | ||||
| 			Add the player logins who should have access to the commands of mControl.  | ||||
| 	2.3	Open the file 'configs/authentication.mc.xml'. | ||||
| 			Add the player logins who should have access to the commands of mc.  | ||||
|  | ||||
| 3.	(Optional) Enable or disable the available plugins in the file 'configs/plugins.mControl.xml'. | ||||
| 3.	(Optional) Enable or disable the available plugins in the file 'configs/plugins.mc.xml'. | ||||
|  | ||||
| 4.	(Optional) Edit the other config files in 'configs/' in order to customize your mControl to fit your needs. | ||||
| 4.	(Optional) Edit the other config files in 'configs/' in order to customize your mc to fit your needs. | ||||
|  | ||||
| 5.	Run the tool via the shell script 'mControl.sh' (UNIX) or the batch file 'mControl.bat' (Windows) | ||||
| 5.	Run the tool via the shell script 'mc.sh' (UNIX) or the batch file 'mc.bat' (Windows) | ||||
|  | ||||
| 6.	Enjoy! | ||||
|  | ||||
|  | ||||
| INFORMATION: | ||||
|  | ||||
| - mControl is only tested on UNIX machines | ||||
| - mc is only tested on UNIX machines | ||||
| 	- even though it might run properly on Windows I can't promise it will work all the time | ||||
| 	- furthermore I can't promise that there won't be a feature in the future that makes it impossible to run mControl under Windows | ||||
| 	- in order to run mControl under Windows you have to alter the file mControl.bat and enter the path to your php.exe | ||||
| 	- furthermore I can't promise that there won't be a feature in the future that makes it impossible to run mc under Windows | ||||
| 	- in order to run mc under Windows you have to alter the file mc.bat and enter the path to your php.exe | ||||
|  | ||||
| - Tests were performed using PHP Version 5.4 | ||||
| - If you notice problems with other version please let me know | ||||
|   | ||||
		Reference in New Issue
	
	Block a user