Changeset 737 for trunk/Common
- Timestamp:
- Apr 14, 2015, 10:16:16 PM (10 years ago)
- Location:
- trunk/Common
- Files:
-
- 3 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/Common/Form/Form.php
r719 r737 49 49 ($this->FormManager->FormTypes[$Item['Type']]['Type'] != 'ManyToOne'))) 50 50 { 51 if(!array_key_exists($Index, $this->Values) and isset($Item['Default'])) 51 if(!array_key_exists($Index, $this->Values) and isset($Item['Default'])) 52 52 $this->Values[$Index] = $Item['Default']; 53 53 } … … 85 85 ); 86 86 foreach($this->Definition['Items'] as $Index => $Item) 87 if(!array_key_exists('Hidden', $Item) or ($Item['Hidden'] == false)) 87 if(!array_key_exists('Hidden', $Item) or ($Item['Hidden'] == false)) 88 88 if(!array_key_exists($Item['Type'], $this->FormManager->FormTypes) or 89 89 (array_key_exists($Item['Type'], $this->FormManager->FormTypes) and … … 302 302 $Parameters); 303 303 } 304 } else 304 } else 305 305 { 306 306 if(isset($Item['Default'])) { … … 418 418 unset($this->FormTypes[$Name]); 419 419 } 420 421 function UpdateSQLMeta() 422 { 423 $this->Database->query('DELETE FROM ModelField'); 424 $this->Database->query('DELETE FROM Model'); 425 $this->Database->query('DELETE FROM DataType WHERE Parent IS NOT NULL'); 426 $this->Database->query('DELETE FROM DataType'); 427 428 foreach($this->Type->TypeDefinitionList as $Name => $Type) 429 { 430 $DbResult = $this->Database->select('DataType', 'Id', 'Name="'.$Name.'"'); 431 if($DbResult->num_rows == 0) 432 { 433 $this->Database->insert('DataType', array('Name' => $Name, 434 'Title' => $Type['Class'])); 435 } else 436 { 437 $DbRow = $DbResult->fetch_assoc(); 438 $this->Database->update('DataType', 'Id='.$DbRow['Id'], array('Name' => $Name, 439 'Title' => $Type['Class'])); 440 } 441 } 442 443 foreach($this->Classes as $Class) 444 if(!array_key_exists('SQL', $Class) and ($Class['Table'] != '')) 445 { 446 $DbResult = $this->Database->query('SELECT * FROM information_schema.tables WHERE table_schema = "centrala_big" 447 AND table_name = "'.$Class['Table'].'" LIMIT 1'); 448 if($DbResult->num_rows == 0) continue; 449 450 echo($Class['Table'].'<br>'); 451 $Module = 1; 452 $DbResult = $this->Database->select('Model', 'Id', 'Name="'.$Class['Table'].'"'); 453 if($DbResult->num_rows == 0) 454 { 455 $this->Database->insert('Model', array('Name' => $Class['Table'], 'Title' => $Class['Title'], 'Module' => $Module)); 456 $Model = $this->Database->insert_id; 457 } else 458 { 459 $DbRow = $DbResult->fetch_assoc(); 460 $Model = $DbRow['Id']; 461 $this->Database->update('Model', 'Id='.$DbRow['Id'], array('Name' => $Class['Table'], 462 'Title' => $Class['Title'], 'Module' => $Module)); 463 } 464 465 foreach($Class['Items'] as $Name => $Field) 466 { 467 echo($Name.', '); 468 $DbResult = $this->Database->select('DataType', 'Id', 'Name="'.$Field['Type'].'"'); 469 if($DbResult->num_rows > 0) 470 { 471 $DbRow = $DbResult->fetch_assoc(); 472 $Type = $DbRow['Id']; 473 } else { 474 $Type = $this->FormTypes[$Field['Type']]; 475 476 // Search parent type 477 $DbResult = $this->Database->select('DataType', 'Id', 'Name="'.$Type['Type'].'"'); 478 if($DbResult->num_rows > 0) 479 { 480 $DbRow = $DbResult->fetch_assoc(); 481 $ParentType = $DbRow['Id']; 482 } else $ParentType = null; 483 484 $this->Database->insert('DataType', array('Name' => $Field['Type'], 485 'Title' => '', 'Parent' => $ParentType)); 486 $Type = $this->Database->insert_id; 487 } 488 489 $DbResult = $this->Database->select('ModelField', 'Id', '(Name="'.$Name.'") AND (Model='.$Model.')'); 490 if($DbResult->num_rows == 0) 491 { 492 $this->Database->insert('ModelField', array('Name' => $Name, 493 'Title' => $Field['Caption'], 'Model' => $Model, 'Type' => $Type)); 494 } else 495 { 496 $DbRow = $DbResult->fetch_assoc(); 497 $this->Database->update('ModelField', 'Id='.$DbRow['Id'], array('Name' => $Name, 498 'Title' => $Field['Caption'], 'Model' => $Model, 'Type' => $Type)); 499 } 500 } 501 echo('<br>'); 502 } 503 } 420 504 } -
trunk/Common/Form/Types/Type.php
r659 r737 60 60 'Image' => array('Name' => 'Image', 'Class' => 'Image', 'ParentType' => '', 'Parameters' => array()), 61 61 'TimeDiff' => array('Name' => 'TimeDiff', 'Class' => 'TimeDiff', 'ParentType' => 'Integer', 'Parameters' => array()), 62 'Reference' => array('Name' => 'Reference', 'Class' => 'Reference', 'ParentType' => 'Integer', 'Parameters' => array()), 63 'ManyToOne' => array('Name' => 'ManyToOne', 'Class' => 'ManyToOne', 'ParentType' => '', 'Parameters' => array()), 62 64 ); 63 65 } -
trunk/Common/Setup/Setup.php
r731 r737 15 15 var $Updates; 16 16 var $ConfigDir; 17 17 18 18 function __construct($System) 19 19 { … … 24 24 $this->ConfigDir = dirname(__FILE__).'/../..'; 25 25 } 26 26 27 27 function LoginPanel() 28 28 { … … 36 36 return($Output); 37 37 } 38 38 39 39 function ControlPanel() 40 40 { 41 41 global $YesNo; 42 42 $Output = ''; 43 43 44 44 $Output .= 'Je připojení k databázi: '.$YesNo[$this->UpdateManager->Database->Connected()].'<br/>'; 45 45 if($this->UpdateManager->Database->Connected()) … … 58 58 $Output .= '<a href="?action=uninstall">Odinstalovat</a> '; 59 59 $Output .= '<a href="?action=modules">Správa modulů</a> '; 60 $Output .= '<a href="?action=models">Přegenerovat modely</a> '; 60 61 } else $Output .= '<a href="?action=install">Instalovat</a> '; 61 62 } … … 65 66 return($Output); 66 67 } 67 68 68 69 function Show() 69 70 { 70 71 global $ConfigDefinition, $DatabaseRevision, $Config, $Updates; 71 72 72 73 $this->UpdateManager = $this->System->Setup->UpdateManager; 73 74 $DefaultConfig = new DefaultConfig(); 74 75 $this->ConfigDefinition = $DefaultConfig->Get(); 75 76 $this->DatabaseRevision = $DatabaseRevision; 76 $this->Config = &$Config; 77 $this->Config = &$Config; 77 78 78 79 $Output = ''; … … 85 86 $Output .= $this->LoginPanel(); 86 87 } else 87 { 88 { 88 89 if(array_key_exists('action', $_GET)) $Action = $_GET['action']; 89 90 else $Action = ''; … … 94 95 $Output .= $this->LoginPanel(); 95 96 } else 97 if($Action == 'models') 98 { 99 $this->System->FormManager->UpdateSQLMeta(); 100 } else 96 101 if($Action == 'upgrade') 97 102 { 98 103 $Output .= '<h3>Povýšení</h3>'; 99 try { 104 try { 100 105 $Output .= $this->System->Setup->Upgrade(); 101 106 } catch (Exception $E) { … … 134 139 if($Action == 'modules') 135 140 { 136 $Output .= $this->ShowModules(); 141 $Output .= $this->ShowModules(); 137 142 } else 138 143 if($Action == 'configure_save') … … 161 166 return($Output); 162 167 } 163 168 164 169 function ShowModules() 165 170 { … … 201 206 return($Output); 202 207 } 203 208 204 209 function ShowList() 205 210 { 206 211 global $YesNo; 207 212 208 213 $Output = ''; 209 214 210 215 $Pageing = new Paging(); 211 216 $Pageing->TotalCount = count($this->System->ModuleManager->Modules); … … 227 232 else $Dependencies = ' '; 228 233 $Actions = ''; 229 if($Module->Installed == true) 234 if($Module->Installed == true) 230 235 { 231 236 $Actions .= ' <a href="?action=modules&op=uninstall&name='.$Module->Name.'">Odinstalovat</a>'; … … 234 239 if($Module->InstalledVersion != $Module->Version) $Actions .= ' <a href="?action=modules&op=upgrade&name='.$Module->Name.'">Povýšit</a>'; 235 240 } else $Actions .= ' <a href="?action=modules&op=install&name='.$Module->Name.'">Instalovat</a>'; 236 241 237 242 $Table->Table->Cells[] = array($Module->Name, 238 $Module->Creator, $Module->Version, 243 $Module->Creator, $Module->Version, 239 244 $Module->License, $YesNo[$Module->Installed], 240 245 $YesNo[$Module->Enabled], $Module->Description, 241 246 $Dependencies, $Actions); 242 247 } 243 $Output .= $Pageing->Show(); 248 $Output .= $Pageing->Show(); 244 249 $Output .= $Table->Show(); 245 $Output .= $Pageing->Show(); 250 $Output .= $Pageing->Show(); 246 251 //$Output .= '<p><a href="?A=SaveToDb">Uložit do databáze</a></p>'; 247 252 return($Output); 248 253 } 249 254 250 255 function PrepareConfig($Config) 251 256 { … … 283 288 return($Output); 284 289 } 285 290 286 291 function ConfigSave($DefaultConfig) 287 292 { … … 319 324 return($Output); 320 325 } 321 326 322 327 function CreateConfig($Config) 323 328 { 324 329 $Output = "<?php\n\n". 325 330 "\$IsDeveloper = in_array(\$_SERVER['REMOTE_ADDR'], array('127.0.0.1'));\n\n"; 326 331 327 332 foreach($this->ConfigDefinition as $Def) 328 333 { … … 353 358 if(!$this->Database->Connected()) $Output .= 'Nelze se připojit k databázi.<br>'; 354 359 else { 355 if(!$this->System->Setup->UpdateManager->IsInstalled()) 360 if(!$this->System->Setup->UpdateManager->IsInstalled()) 356 361 $Output .= 'Systém vyžaduje instalaci databáze.<br>'; 357 362 else 358 if(!$this->System->Setup->UpdateManager->IsUpToDate()) 363 if(!$this->System->Setup->UpdateManager->IsUpToDate()) 359 364 $Output .= 'Systém vyžaduje aktualizaci databáze.<br>'; 360 365 } … … 367 372 { 368 373 var $UpdateManager; 369 374 370 375 function Start() 371 376 { 372 377 global $DatabaseRevision; 373 378 374 379 $this->System->RegisterPage('', 'PageSetupRedirect'); 375 380 $this->System->RegisterPage('setup', 'PageSetup'); … … 382 387 $this->UpdateManager->Trace = $Updates->Get(); 383 388 $this->UpdateManager->InstallMethod = 'FullInstall'; 384 } 385 389 } 390 386 391 function Stop() 387 392 { … … 390 395 $this->System->UnregisterPage('setup'); 391 396 } 392 397 393 398 function CheckState() 394 399 { … … 396 401 $this->UpdateManager->IsUpToDate()); 397 402 } 398 403 399 404 function Install() 400 405 { 401 406 global $DatabaseRevision; 402 407 403 408 $this->Database->query('CREATE TABLE IF NOT EXISTS `SystemVersion` ( 404 409 `Id` int(11) NOT NULL AUTO_INCREMENT, … … 415 420 ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;"); 416 421 } 417 422 418 423 function Uninstall() 419 424 { … … 422 427 $this->Database->query('DROP TABLE `SystemVersion`'); 423 428 } 424 429 425 430 function IsInstalled() 426 431 { … … 428 433 return($DbResult->num_rows > 0); 429 434 } 430 435 431 436 function Upgrade() 432 437 {
Note:
See TracChangeset
for help on using the changeset viewer.