57 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			57 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /*
 | |
|  * Name: Downtime
 | |
|  * Author: Shish <webmaster@shishnet.org>
 | |
|  * Link: http://code.shishnet.org/shimmie2/
 | |
|  * License: GPLv2
 | |
|  * Description: Show a "down for maintenance" page
 | |
|  * Documentation:
 | |
|  *  Once installed there will be some more options on the config page --
 | |
|  *  Ticking "disable non-admin access" will mean that regular and anonymous
 | |
|  *  users will be blocked from accessing the site, only able to view the
 | |
|  *  message specified in the box.
 | |
|  */
 | |
| 
 | |
| class Downtime extends Extension
 | |
| {
 | |
|     public function get_priority(): int
 | |
|     {
 | |
|         return 10;
 | |
|     }
 | |
| 
 | |
|     public function onSetupBuilding(SetupBuildingEvent $event)
 | |
|     {
 | |
|         $sb = new SetupBlock("Downtime");
 | |
|         $sb->add_bool_option("downtime", "Disable non-admin access: ");
 | |
|         $sb->add_longtext_option("downtime_message", "<br>");
 | |
|         $event->panel->add_block($sb);
 | |
|     }
 | |
| 
 | |
|     public function onPageRequest(PageRequestEvent $event)
 | |
|     {
 | |
|         global $config, $page, $user;
 | |
| 
 | |
|         if ($config->get_bool("downtime")) {
 | |
|             if (!$user->can(Permissions::IGNORE_DOWNTIME) && !$this->is_safe_page($event)) {
 | |
|                 $msg = $config->get_string("downtime_message");
 | |
|                 $this->theme->display_message($msg);
 | |
|                 if (!defined("UNITTEST")) {  // hax D:
 | |
|                     header("HTTP/1.0 {$page->code} Downtime");
 | |
|                     print($page->data);
 | |
|                     exit;
 | |
|                 }
 | |
|             }
 | |
|             $this->theme->display_notification($page);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     private function is_safe_page(PageRequestEvent $event)
 | |
|     {
 | |
|         if ($event->page_matches("user_admin/login")) {
 | |
|             return true;
 | |
|         } else {
 | |
|             return false;
 | |
|         }
 | |
|     }
 | |
| }
 |