2016-12-04 22:17:08 +01:00
< ? php
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
/* Pi - hole : A black hole for Internet advertisements
* ( c ) 2017 Pi - hole , LLC ( https :// pi - hole . net )
* Network - wide ad blocking via your own hardware .
*
* This file is copyright under the latest version of the EUPL .
* Please see LICENSE file for your rights under this license . */
// Function to validate server name (Including underscores & IPv6)
ini_set ( " pcre.recursion_limit " , 1500 );
function validate_server_name ( $domain ) { // Cr: http://stackoverflow.com/a/4694816
if ( filter_var ( $domain , FILTER_VALIDATE_IP , FILTER_FLAG_IPV6 )) return TRUE ;
return ( preg_match ( " /^([a-z \ d]((-|_)*[a-z \ d])*)( \ .([a-z \ d]((-|_)*[a-z \ d])*))* $ /i " , $domain ) // Valid chars check
&& preg_match ( " /^. { 1,253} $ / " , $domain ) // Overall length check
&& preg_match ( " /^[^ \ .] { 1,63}( \ .[^ \ .] { 1,63})* $ / " , $domain )); // Length of each label
}
2017-05-18 10:54:26 +02:00
// Validate HTTP_HOST output
if ( validate_server_name ( $_SERVER [ " HTTP_HOST " ]) === TRUE ) {
$serverName = $_SERVER [ " HTTP_HOST " ];
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
} else {
2017-05-18 10:54:26 +02:00
die ( " [ERROR]: <code>HTTP_HOST</code> header output does not appear to be valid: <code> " . $_SERVER [ " HTTP_HOST " ] . " </code> " );
2017-03-29 00:02:00 +02:00
}
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
// Get values from setupVars.conf
$setupVars = parse_ini_file ( " /etc/pihole/setupVars.conf " );
$svFQDN = ( ! empty ( $setupVars [ " FQDN " ]) && validate_server_name ( $setupVars [ " FQDN " ]) === TRUE ) ? $setupVars [ " FQDN " ] : " " ;
$svPasswd = ! empty ( $setupVars [ " WEBPASSWORD " ]);
$svEmail = ( ! empty ( $setupVars [ " ADMIN_EMAIL " ]) && filter_var ( $setupVars [ " ADMIN_EMAIL " ], FILTER_VALIDATE_EMAIL )) ? $setupVars [ " ADMIN_EMAIL " ] : " " ;
unset ( $setupVars );
2016-12-04 22:17:08 +01:00
2017-05-03 07:33:50 +02:00
// Set landing page name, found within /var/www/html/pihole/
$landPage = " ../landing.php " ;
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
// Set empty array for hostnames to be accepted as self address for splash page
$authorizedHosts = [];
// Append FQDN to $authorizedHosts
if ( ! empty ( $svFQDN )) array_push ( $authorizedHosts , $svFQDN );
// Append virtual hostname to $authorizedHosts
if ( ! empty ( $_SERVER [ " VIRTUAL_HOST " ])) {
if ( validate_server_name ( $_SERVER [ " VIRTUAL_HOST " ]) === TRUE ) {
array_push ( $authorizedHosts , $_SERVER [ " VIRTUAL_HOST " ]);
} else {
die ( " [ERROR]: <code>VIRTUAL_HOST</code> header output does not appear to be valid: <code> " . $_SERVER [ " VIRTUAL_HOST " ] . " </code> " );
}
2017-03-05 06:58:21 +01:00
}
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
// Set which extension types get rendered as "Website Blocked" (Including "" for index file extensions)
$validExtTypes = array ( " asp " , " htm " , " html " , " php " , " rss " , " xml " , " " );
2016-12-04 22:17:08 +01:00
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
// Get extension of current URL
$currentUrlExt = pathinfo ( $_SERVER [ " REQUEST_URI " ], PATHINFO_EXTENSION );
2016-12-04 22:17:08 +01:00
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
// Set mobile friendly viewport
$viewPort = '<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>' ;
// Set response header
function setHeader ( $type = " x " ) {
header ( " X-Pi-hole: A black hole for Internet advertisements. " );
if ( isset ( $type ) && $type === " js " ) header ( " Content-Type: application/javascript " );
2017-03-29 00:02:00 +02:00
}
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
// Determine block page redirect
if ( $serverName === " pi.hole " ) {
exit ( header ( " Location: /admin " ));
} elseif ( filter_var ( $serverName , FILTER_VALIDATE_IP ) || in_array ( $serverName , $authorizedHosts )) {
// Show splash page or landing page when directly browsing via IP or auth'd hostname
$splashPage = "
< html >< head >
$viewPort
2017-05-03 07:29:43 +02:00
< link rel = 'stylesheet' href = '/pihole/blockingpage.css' type = 'text/css' />
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
</ head >< body id = 'splashpage' >< img src = '/admin/img/logo.svg' />< br /> Pi -< b > hole </ b >: Your black hole for Internet advertisements </ body ></ html >
" ;
$pageType = is_file ( getcwd () . " / $landPage " ) ? include $landPage : " $splashPage " ;
unset ( $serverName , $svFQDN , $svPasswd , $svEmail , $authorizedHosts , $validExtTypes , $currentUrlExt , $viewPort );
exit ( $pageType );
} elseif ( $currentUrlExt === " js " ) {
// Set Javascript redirect for blocked sources
exit ( setHeader ( " js " ) . 'var x = "Pi-hole: A black hole for Internet advertisements."' );
} elseif ( strpos ( $_SERVER [ " REQUEST_URI " ], " ? " ) !== FALSE && isset ( $_SERVER [ " HTTP_REFERER " ])) {
// Set blank image upon receiving REQUEST_URI w/ query string & HTTP_REFERRER (Presumably from iframe)
exit ( setHeader () . ' < html >
< head >< script > window . close (); </ script ></ head >
< body >< img src = "  " ></ body >
</ html > ' );
} elseif ( ! in_array ( $currentUrlExt , $validExtTypes ) || substr_count ( $_SERVER [ " REQUEST_URI " ], " ? " )) {
// Set svg image upon receiving non $validExtTypes URL extension or query string (Presumably not from an iframe)
$blockImg = '<a href="/"><svg xmlns="http://www.w3.org/2000/svg" width="110" height="16"><defs><style>a {text-decoration: none;} circle {stroke: rgba(152,2,2,0.5); fill: none; stroke-width: 2;} rect {fill: rgba(152,2,2,0.5);} text {opacity: 0.3; font: 11px Arial;}</style></defs><circle cx="8" cy="8" r="7"/><rect x="10.3" y="-6" width="2" height="12" transform="rotate(45)"/><text x="19.3" y="12">Blocked by Pi-hole</text></svg></a>' ;
exit ( setHeader () . " <html>
< head > $viewPort </ head >
< body > $blockImg </ body >
</ html > " );
2016-12-04 22:17:08 +01:00
}
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
/* Start processing block page from here */
// Get Pi-hole core branch name
$phBranch = exec ( " cd /etc/.pihole/ && git rev-parse --abbrev-ref HEAD " );
if ( $phBranch !== " master " ) {
error_reporting ( E_ALL );
ini_set ( " display_errors " , 1 );
ini_set ( " display_startup_errors " , 1 );
2016-12-04 22:17:08 +01:00
}
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
// Validate SERVER_IP output
if ( filter_var ( $_SERVER [ 'SERVER_ADDR' ], FILTER_VALIDATE_IP )) {
$serverAddr = $_SERVER [ " SERVER_ADDR " ];
} else {
die ( " [ERROR]: <code>SERVER_IP</code> header output does not appear to be valid: <code> " . $_SERVER [ " SERVER_ADDR " ] . " </code> " );
}
// Determine placeholder text based off $svPasswd presence
$wlPlaceHolder = empty ( $svPasswd ) ? " No admin password set " : " Javascript disabled " ;
// Get admin email address
$bpAskAdmin = ! empty ( $svEmail ) ? '<a href="mailto:' . $svEmail . '?subject=Site Blocked: ' . $serverName . '"></a>' : " <span/> " ;
// Determine if at least one block list has been generated
if ( empty ( glob ( " /etc/pihole/list.0.*.domains " ))) die ( " [ERROR]: There are no domain lists generated lists within <code>/etc/pihole/</code>! Please update gravity by running <code>pihole -g</code>, or repair Pi-hole using <code>pihole -r</code>. " );
// Get contents of adlist.list
$adLists = is_file ( " /etc/pihole/adlists.list " ) ? " /etc/pihole/adlists.list " : " /etc/pihole/adlists.default " ;
if ( ! is_file ( $adLists )) die ( " [ERROR]: Unable to find file: <code> $adLists </code> " );
// Get all URLs starting with "http" or "www" from $adLists and re-index array numerically
$adlistsUrls = array_values ( preg_grep ( " /(^http)|(^www)/i " , file ( $adLists , FILE_IGNORE_NEW_LINES )));
if ( empty ( $adlistsUrls )) die ( " [ERROR]: There are no adlist URL's found within <code> $adLists </code> " );
$adlistsCount = count ( $adlistsUrls ) + 3 ; // +1 because array starts at 0, +2 for Blacklist & Wildcard lists
// Get results of queryads.php exact search
ini_set ( " default_socket_timeout " , 3 );
function queryAds ( $serverName ) {
$preQueryTime = microtime ( true ) - $_SERVER [ " REQUEST_TIME_FLOAT " ];
$queryAds = file ( " http://127.0.0.1/admin/scripts/pi-hole/php/queryads.php?domain= $serverName &exact " , FILE_IGNORE_NEW_LINES );
$queryTime = sprintf ( " %.0f " , ( microtime ( true ) - $_SERVER [ " REQUEST_TIME_FLOAT " ]) - $preQueryTime );
try {
if ( $queryTime >= ini_get ( " default_socket_timeout " )) {
throw new Exception ( " Connection timeout ( " . ini_get ( " default_socket_timeout " ) . " s) " );
} elseif ( $queryAds [ 0 ][ 0 ] === " : " ) {
if ( strpos ( $queryAds [ 0 ], " Invalid " ) !== FALSE ) throw new Exception ( " Invalid Domain ( $serverName ) " );
if ( strpos ( $queryAds [ 0 ], " No exact " ) !== FALSE ) return array ( " 0 " => " none " );
throw new Exception ( " Unhandled error message (<code> $queryAds[0] </code>) " );
} elseif ( $queryAds [ 0 ][ 0 ] !== " / " ) {
throw new Exception ( " Unexpected output (<code> $queryAds[0] </code>) " );
}
return $queryAds ;
} catch ( Exception $e ) {
return array ( " 0 " => " error " , " 1 " => $e -> getMessage ());
}
}
$queryAds = queryAds ( $serverName );
if ( $queryAds [ 0 ] === " error " ) {
die ( " [ERROR]: Unable to parse results from <i>queryads.php</i>: <code> " . $queryAds [ 1 ] . " </code> " );
}
// Filter, sort, and count $queryAds array
if ( $queryAds [ 0 ] !== " none " ) {
$queryAds = preg_replace ( " /( \ /etc \ /pihole \ /)|( \ /etc \ /dnsmasq \ .d \ /)/ " , " " , $queryAds );
$queryAds = preg_replace ( " /(^list \ .)|( \ ..*domains)/ " , " " , $queryAds );
$featuredTotal = count ( $queryAds );
2016-12-04 22:17:08 +01:00
}
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
// Determine if domain has been blacklisted or wildcarded
if ( $queryAds [ 0 ] === " blacklist.txt " ) {
$intBlacklist = array ( " π " => $queryAds [ 0 ]);
$queryAds [ 0 ] = " π " ; // Manually blacklisted sites do not have a number
$notableFlagClass = " blacklist " ;
2017-05-11 12:10:40 +02:00
} elseif ( $queryAds [ 0 ] === " whitelist.txt " ) {
$intBlacklist = array ( " π " => $queryAds [ 0 ]);
$queryAds [ 0 ] = " π " ;
$notableFlagClass = " noblock " ;
$wlInfo = " recentwl " ;
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
} elseif ( $queryAds [ 0 ] === " 03-pihole-wildcard.conf " ) {
$intBlacklist = array ( " π " => $queryAds [ 0 ]);
$queryAds [ 0 ] = " π " ;
$notableFlagClass = " wildcard " ;
} elseif ( $queryAds [ 0 ] === " none " ) {
$featuredTotal = " 0 " ;
$notableFlagClass = " noblock " ;
2016-12-04 22:17:08 +01:00
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
// Determine appropriate info message if CNAME exists
$dnsRecord = dns_get_record ( " $serverName " )[ 0 ];
if ( array_key_exists ( " target " , $dnsRecord )) {
$wlInfo = $dnsRecord [ 'target' ];
} else {
2017-05-11 12:10:40 +02:00
$wlInfo = " unknown " ;
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
}
2016-12-05 12:12:01 +01:00
}
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
// Merge $intBlacklist with $adlistsUrls if domain has been blacklisted or wildcarded
if ( isset ( $intBlacklist )) $adlistsUrls = array_merge ( $intBlacklist , $adlistsUrls );
// Set #bpOutput notification
$wlOutputClass = ( isset ( $wlInfo ) && $wlInfo === " recentwl " ) ? $wlInfo : " hidden " ;
$wlOutput = ( isset ( $wlInfo ) && $wlInfo !== " recentwl " ) ? " <a href='http:// $wlInfo '> $wlInfo </a> " : " " ;
// Get Pi-hole core version
if ( $phBranch !== " master " ) {
$phVersion = exec ( " cd /etc/.pihole/ && git describe --long --dirty --tags " );
$execTime = microtime ( true ) - $_SERVER [ " REQUEST_TIME_FLOAT " ];
} else {
$phVersion = exec ( " cd /etc/.pihole/ && git describe --tags --abbrev=0 " );
}
2016-12-04 22:17:08 +01:00
?>
<! DOCTYPE html >
2017-03-25 16:11:37 +01:00
< html >
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
<!-- Pi - hole : A black hole for Internet advertisements
* ( c ) 2017 Pi - hole , LLC ( https :// pi - hole . net )
* Network - wide ad blocking via your own hardware .
*
* This file is copyright under the latest version of the EUPL . -->
2016-12-04 22:17:08 +01:00
< head >
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
< meta charset = " UTF-8 " >
< ? = $viewPort ?>
< ? = setHeader () ?>
< meta name = " robots " content = " noindex,nofollow " />
< meta http - equiv = " x-dns-prefetch-control " content = " off " >
< link rel = " shortcut icon " href = " http://<?= $serverAddr ?>/admin/img/favicon.png " type = " image/x-icon " />
2017-05-08 11:33:45 +02:00
< link rel = " stylesheet " href = " http://<?= $serverAddr ?>/pihole/blockingpage.css " type = " text/css " />
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
< title > ● < ? = $serverName ?> </title>
< script src = " http://<?= $serverAddr ?>/admin/scripts/vendor/jquery.min.js " ></ script >
< script >
window . onload = function () {
< ? php
// Remove href fallback from "Back to safety" button
if ( $featuredTotal > 0 ) echo '$("#bpBack").removeAttr("href");' ;
// Enable whitelisting if $svPasswd is present & JS is available
if ( ! empty ( $svPasswd ) && $featuredTotal > 0 ) {
echo '$("#bpWLPassword, #bpWhitelist").prop("disabled", false);' ;
echo '$("#bpWLPassword").attr("placeholder", "Password");' ;
}
?>
}
</ script >
2016-08-20 02:45:17 +02:00
</ head >
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
< body id = " blockpage " >< div id = " bpWrapper " >
2016-12-04 22:17:08 +01:00
< header >
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
< h1 id = " bpTitle " >
< a class = " title " href = " / " >< ? php //Website Blocked ?></a>
</ h1 >
< div class = " spc " ></ div >
< input id = " bpAboutToggle " type = " checkbox " />
< div id = " bpAbout " >
< div class = " aboutPH " >
< div class = " aboutImg " /></ div >
< p > Open Source Ad Blocker
< small > Designed for Raspberry Pi </ small >
</ p >
</ div >
< div class = " aboutLink " >
< a class = " linkPH " href = " https://github.com/pi-hole/pi-hole/wiki/What-is-Pi-hole%3F-A-simple-explanation " >< ? php //About PH ?></a>
< ? php if ( ! empty ( $svEmail )) echo '<a class="linkEmail" href="mailto:' . $svEmail . '"></a>' ; ?>
</ div >
</ div >
< div id = " bpAlt " >
< label class = " altBtn " for = " bpAboutToggle " >< ? php //Why am I here? ?></label>
</ div >
2016-12-04 22:17:08 +01:00
</ header >
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
2016-12-04 22:17:08 +01:00
< main >
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
< div id = " bpOutput " class = " <?= $wlOutputClass ?> " >< ? = $wlOutput ?> </div>
< div id = " bpBlock " >
< p class = " blockMsg " >< ? = $serverName ?> </p>
</ div >
< ? php if ( isset ( $notableFlagClass )) { ?>
< div id = " bpFlag " >
< p class = " flagMsg <?= $notableFlagClass ?> " ></ p >
</ div >
< ? php } ?>
< div id = " bpHelpTxt " >< ? = $bpAskAdmin ?> </div>
< div id = " bpButtons " class = " buttons " >
< a id = " bpBack " onclick = " javascript:history.back() " href = " about:home " ></ a >
< ? php if ( $featuredTotal > 0 ) echo '<label id="bpInfo" for="bpMoreToggle"></label>' ; ?>
</ div >
< input id = " bpMoreToggle " type = " checkbox " >
< div id = " bpMoreInfo " >
< span id = " bpFoundIn " >< span >< ? = $featuredTotal ?> </span><?=$adlistsCount ?></span>
< pre id = 'bpQueryOutput' >< ? php if ( $featuredTotal > 0 ) foreach ( $queryAds as $num ) { echo " <span>[ $num ]:</span> $adlistsUrls[$num] \n " ; } ?> </pre>
< form id = " bpWLButtons " class = " buttons " >
< input id = " bpWLDomain " type = " text " value = " <?= $serverName ?> " disabled />
< input id = " bpWLPassword " type = " password " placeholder = " <?= $wlPlaceHolder ?> " disabled />< button id = " bpWhitelist " type = " button " disabled ></ button >
</ form >
</ div >
2016-12-04 22:17:08 +01:00
</ main >
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
< footer >< span >< ? = date ( " l g:i A, F dS " ); ?> .</span> Pi-hole <?=$phVersion ?> (<?=gethostname()."/".$serverAddr; if (isset($execTime)) printf("/%.2fs", $execTime); ?>)</footer>
</ div >
2016-12-05 12:12:01 +01:00
< script >
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
function add () {
$ ( " #bpOutput " ) . removeClass ( " hidden error exception " );
$ ( " #bpOutput " ) . addClass ( " add " );
var domain = " <?= $serverName ?> " ;
var pw = $ ( " #bpWLPassword " );
if ( domain . length === 0 ) {
return ;
2016-12-30 18:59:05 +01:00
}
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
$ . ajax ({
url : " /admin/scripts/pi-hole/php/add.php " ,
method : " post " ,
data : { " domain " : domain , " list " : " white " , " pw " : pw . val ()},
success : function ( response ) {
if ( response . indexOf ( " Pi-hole blocking " ) !== - 1 ) {
setTimeout ( function (){ window . location . reload ( 1 );}, 10000 );
$ ( " #bpOutput " ) . removeClass ( " add " );
$ ( " #bpOutput " ) . addClass ( " success " );
} else {
$ ( " #bpOutput " ) . removeClass ( " add " );
$ ( " #bpOutput " ) . addClass ( " error " );
$ ( " #bpOutput " ) . html ( " " + response + " " );
}
},
error : function ( jqXHR , exception ) {
$ ( " #bpOutput " ) . removeClass ( " add " );
$ ( " #bpOutput " ) . addClass ( " exception " );
}
});
}
< ? php if ( $featuredTotal > 0 ) { ?>
$ ( document ) . keypress ( function ( e ) {
if ( e . which === 13 && $ ( " #bpWLPassword " ) . is ( " :focus " )) {
add ();
}
});
$ ( " #bpWhitelist " ) . on ( " click " , function () {
add ();
});
< ? php } ?>
2016-12-05 12:12:01 +01:00
</ script >
Update index.php
* An "About Pi-hole" link on the block page provides an ELI5 explanation to those not familiar with Pi-hole
* An email contact link on the block page provides users of your Pi-hole with a means to easily get in touch with you
* Browsing to your Pi-hole's address will show a simple "landing page", which can be replaced by adding "landing.php" within "/var/www/html"
* Users manually browsing to file/image based content (i.e: non HTML based content) on blocked sites will be greeted with a small "Blocked by Pi-hole" image
* Sites that are manually blacklisted will display a notice of this on the block page
* Sites that aren't directly blocked, but have a CNAME record, will show a notification on the block page (e.g: If raw.githubusercontent.com is not blocked, but github.map.fastly.net is)
* On the block page, "Back to Safety" now directs the user to "about:home" if Javascript is disabled
* Whitelisting is disabled for installs without a password, or if a client does not have Javascript
* Known issues:
* Admin Console needs a text field under "Web User Interface" where the admin can enter a preferred contact email when a site needs to be whitelisted, to be saved to setupVars.conf with the key "ADMIN_EMAIL"
* Admin Console needs a text field under "Networking" where the admin can enter their Pi-hole's externally contactable FQDN, allowing access to their landing page when browsing to mypi.duckdns.org, to be saved to setupVars.conf with the key "FQDN"
* I am not aware of expected output of `$_SERVER["VIRTUAL_HOST"]`, so I have assumed it should be filtered as if it's a domain
2017-05-02 09:06:31 +02:00
</ body ></ html >