reCAPTCHA v3 support and general tidy up
This commit is contained in:
@@ -52,4 +52,11 @@ ISQ::$recaptcha = array(
|
||||
'secret' => ''
|
||||
);
|
||||
|
||||
// Separate API keys for reCAPTCHA v3
|
||||
ISQ::$recaptcha_v3 = array(
|
||||
'sitekey' => '',
|
||||
'secret' => '',
|
||||
'threshold' => '0.5',
|
||||
);
|
||||
|
||||
?>
|
||||
|
||||
67
public/functions.php
Normal file
67
public/functions.php
Normal file
@@ -0,0 +1,67 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* Return which method is being used for preventing spam,
|
||||
* based on the site config.
|
||||
*
|
||||
* @return string login/recaptcha_v3/recaptcha/basic
|
||||
*/
|
||||
function is_get_antispam_method() {
|
||||
if( 1 == yourls_is_valid_user() ) {
|
||||
return 'login';
|
||||
} elseif( isset( ISQ::$recaptcha_v3['sitekey'] ) && ISQ::$recaptcha_v3['sitekey'] && isset( ISQ::$recaptcha_v3['secret'] ) && ISQ::$recaptcha_v3['secret'] ) {
|
||||
return 'recaptcha_v3';
|
||||
} elseif( isset( ISQ::$recaptcha['sitekey'] ) && ISQ::$recaptcha['sitekey'] && isset( ISQ::$recaptcha['secret'] ) && ISQ::$recaptcha['secret'] ) {
|
||||
return 'recaptcha';
|
||||
} else {
|
||||
return 'basic';
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Terminate the request without shortening the URL and
|
||||
* display an error.
|
||||
*
|
||||
* @param string $message Error message.
|
||||
* @param string $action Action message, defaults to "Go home".
|
||||
*/
|
||||
function display_error( $message, $action = null ) {
|
||||
echo '<div class="content error">';
|
||||
echo '<p class="message">' . $message . '</p>';
|
||||
|
||||
echo '<p class="action">';
|
||||
if( !empty( $action ) ) {
|
||||
echo $action;
|
||||
} else {
|
||||
echo '<a href="' . YOURLS_SITE . '" class="button">' . yourls__( '← Go home and try again', 'isq_translation' ) . '</a>';
|
||||
}
|
||||
echo '</p>';
|
||||
echo '</div>';
|
||||
|
||||
include('footer.php');
|
||||
die();
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get remote file, either using CURL or file_get_contents
|
||||
* depending on server configuration.
|
||||
*
|
||||
* @param string $url Remote file URL.
|
||||
* @return string Remote file contents.
|
||||
*/
|
||||
function get_remote_file( $url ) {
|
||||
if( function_exists( 'curl_init' ) ) {
|
||||
$curl = curl_init();
|
||||
curl_setopt( $curl, CURLOPT_URL, $url );
|
||||
curl_setopt( $curl, CURLOPT_RETURNTRANSFER, true );
|
||||
$output = curl_exec( $curl );
|
||||
curl_close( $curl );
|
||||
return $output;
|
||||
} elseif( ini_get( 'allow_url_fopen' ) ) {
|
||||
return file_get_contents( $url );
|
||||
} else {
|
||||
display_error( yourls__( 'Your server doesn\'t support reCAPTCHA. Ask your host to install cURL or turn on allow_url_fopen.', 'isq_translation' ) );
|
||||
}
|
||||
}
|
||||
@@ -48,3 +48,14 @@ if( document.querySelectorAll( '.copy-button' ).length > 0 ) {
|
||||
} );
|
||||
|
||||
}
|
||||
|
||||
// reCAPTCHA
|
||||
if( 'object' === typeof grecaptcha ) {
|
||||
grecaptcha.ready( function() {
|
||||
var sitekey = document.querySelectorAll( '#recaptcha-sitekey' )[0].innerHTML;
|
||||
|
||||
grecaptcha.execute( sitekey, {action: 'homepage'} ).then( function( token ) {
|
||||
document.querySelectorAll( '#recaptcha_token' )[0].value = token;
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user