a7e349dd by Jeff Balicki

pen test

Signed-off-by: Jeff <jeff@gotenzing.com>
1 parent e4e4091c
Showing 19 changed files with 2881 additions and 0 deletions
<?php
//GPL license
include sanitize_file_name('gplLicense.php');
/*Updating database after verifying signature failed*/
function Beagle_WP_auto_Verify(){
global $wpdb;
$Beagle_WP_scan_table = $wpdb->prefix."beagleScanData";
$getTokenFromTbl = $wpdb->get_results( $wpdb->prepare ("SELECT * FROM $Beagle_WP_scan_table"));
$Beagle_WP_application_token = $getTokenFromTbl[0]->application_token;
$updateData = $wpdb->query( $wpdb->prepare("UPDATE $Beagle_WP_scan_table SET autoVerify = %d WHERE application_token = %s",1, $Beagle_WP_application_token));
try{
if($updateData) {
echo json_encode("succeess");
exit;
} else {
echo json_encode("failed");
exit;
}
} catch (Exception $e) {
console.log('Message: ' .$e->getMessage());
}
}
\ No newline at end of file
<?php
//GPL license
include sanitize_file_name('gplLicense.php');
/*delete the application only after the verification*/
function Beagle_WP_delete_Test() {
global $wpdb;
global $deleteID;
$Beagle_WP_scan_table = $wpdb->prefix."beagleScanData";
$result =$wpdb->get_results($wpdb->prepare("SELECT * FROM $Beagle_WP_scan_table "));
foreach ( $result as $print ){
$deleteID = $print->id;
}
try {
$updateData = $wpdb->query($wpdb->prepare("DELETE FROM $Beagle_WP_scan_table WHERE id=%d", $deleteID));
echo json_encode($updateData);
exit;
}
catch(Exception $e) {
}
}
<?php
//GPL license
include sanitize_file_name('gplLicense.php');
/*to get status of currently running test*/
function Beagle_WP_getResultOf_CurrentTestData() {
global $wpdb;
global $apiServerBaseUrl;
$Beagle_WP_scan_table = $wpdb->prefix."beagleScanData";
$getTableData = $wpdb->get_results($wpdb->prepare("SELECT * FROM $Beagle_WP_scan_table"));
foreach ( $getTableData as $entryOne ){
$Beagle_WP_access_token = $entryOne->access_token;
$Beagle_WP_application_token = $entryOne->application_token;
$BWP_result_token = $entryOne->result_token;
}
try {
if($Beagle_WP_access_token != null || $Beagle_WP_application_token != null) {
$beaglrURL = $apiServerBaseUrl.'test/result';
$getStatusDataTest = array("access_token" => $Beagle_WP_access_token, "application_token" => $Beagle_WP_application_token, "result_token" => $BWP_result_token);
$request = wp_remote_post($beaglrURL, array(
'headers' => array('Content-Type' => 'application/json; charset=utf-8'),
'body' => json_encode($getStatusDataTest),
'method' => 'POST',
'data_format' => 'body',
));
$statusResponse = json_decode(wp_remote_retrieve_body( $request ));
try {
if($statusResponse){
$updateData = $wpdb->query( $wpdb->prepare("UPDATE $Beagle_WP_scan_table SET runningStatus = %s WHERE application_token = %s","notRunning", $Beagle_WP_application_token));
}
}
catch(Exception $e) {
}
echo json_encode($statusResponse);
exit;
}
}
catch(Exception $e) {
}
}
\ No newline at end of file
<?php
//GPL license
include sanitize_file_name('gplLicense.php');
/*to get status of an ongoing test*/
function Beagle_WP_getStatusOf_CurrentTestData()
{
global $wpdb;
global $apiServerBaseUrl;
$Beagle_WP_scan_table = $wpdb->prefix . "beagleScanData";
$getTableData = $wpdb->get_results($wpdb->prepare("SELECT * FROM $Beagle_WP_scan_table"));
foreach ($getTableData as $entryOne) {
$Beagle_WP_access_token = $entryOne->access_token;
$Beagle_WP_application_token = $entryOne->application_token;
$BWP_result_token = $entryOne->result_token;
}
try {
if ($Beagle_WP_access_token != null && $Beagle_WP_application_token != null && $BWP_result_token != null) {
$beaglrURL = $apiServerBaseUrl . 'test/status';
$getStatusDataTest = array("access_token" => $Beagle_WP_access_token, "application_token" => $Beagle_WP_application_token, "result_token" => $BWP_result_token);
$request = wp_remote_post($beaglrURL, array(
'headers' => array('Content-Type' => 'application/json; charset=utf-8'),
'body' => json_encode($getStatusDataTest),
'method' => 'POST',
'data_format' => 'body',
));
$statusResponse = json_decode(wp_remote_retrieve_body($request));
try {
if ($statusResponse) {
$updateData = $wpdb->query($wpdb->prepare("UPDATE $Beagle_WP_scan_table SET status = %s WHERE application_token = %s", $statusResponse->status, $Beagle_WP_application_token));
}
echo json_encode($statusResponse);
exit;
} catch (Exception $e) {
}
}
} catch (Exception $e) {
}
}
<?php
/*
Beagle Security - WP Security, Advanced Penetration Testing, 2021 Beagle Security
This plugin is distributed under the terms of the GNU GPL
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; If not, see {License URI}.
*/
?>
\ No newline at end of file
<?php
//GPL license
include sanitize_file_name('gplLicense.php');
/*To post the signature in the wordpress root directory*/
function Beagle_WP_addDataTo_DB()
{
global $wpdb;
global $apiServerBaseUrl;
$Beagle_WP_scan_table = $wpdb->prefix . "beagleScanData";
$Beagle_WP_access_token = sanitize_text_field($_POST['access_token']);
$Beagle_WP_application_token = sanitize_text_field($_POST['application_token']);
try {
if (isset($_POST['startVerify'])) {
$Beagle_WP_dataInDB = $wpdb->get_results("SELECT * FROM $Beagle_WP_scan_table WHERE `application_token`='$Beagle_WP_application_token'");
try {
if (!$Beagle_WP_dataInDB) {
$beaglrURL = $apiServerBaseUrl . 'test/signature';
$getverifiedToken = array("access_token" => $Beagle_WP_access_token, "application_token" => $Beagle_WP_application_token);
$request = wp_remote_post($beaglrURL, array(
'headers' => array('Content-Type' => 'application/json; charset=utf-8'),
'body' => json_encode($getverifiedToken),
'method' => 'POST',
'data_format' => 'body',
));
$statusResponse = json_decode(wp_remote_retrieve_body($request));
try {
$dateLog = date("Y-m-d");
if ($statusResponse->status == "Failed") {
try {
$Beagle_WP_log_save_path = plugin_dir_path(__FILE__) . '../log.txt';
if (is_writable($Beagle_WP_log_save_path)) {
$Beagle_WP_log_open = fopen($Beagle_WP_log_save_path, "a");
$Beagle_WP_log_write = fputs($Beagle_WP_log_open, "\n" .$dateLog. " -> " .$statusResponse->message. + "\n");
fclose($Beagle_WP_log_open);
}
} catch (Exception $e) {
}
?>
<script>
function appExist() {
var errorMsg = setTimeout("document.getElementById('errMsg').style.display='none';", 4000);
}
appExist()
</script>
<div class="errormsg">
<p id="errMsg">Invalid credentials. Please try again!</p>
</div>
<?php
} else if($statusResponse == null) {
try {
$Beagle_WP_log_save_path = plugin_dir_path(__FILE__) . '../log.txt';
if (is_writable($Beagle_WP_log_save_path)) {
$Beagle_WP_log_open = fopen($Beagle_WP_log_save_path, "a");
$Beagle_WP_log_write = fputs($Beagle_WP_log_open, "\n" .$dateLog. "-> User not authorized. \n");
fclose($Beagle_WP_log_open);
}
} catch (Exception $e) {
}
?>
<script>
function appExist() {
var errorMsg = setTimeout("document.getElementById('errMsg').style.display='none';", 4000);
}
appExist()
</script>
<div class="errormsg">
<p id="errMsg">User not authorized!</p>
</div>
<?php
}
else if ($statusResponse->status == "NotVerified") {
$verifyText = $statusResponse->signature;
try {
$Beagle_WP_file_save_path = plugin_dir_path(__FILE__) . '../' . $verifyText . '.txt';
$Beagle_WP_file_save_path_test = plugin_dir_path(__FILE__) . '../fileWrightTest.txt';
if (is_writable($Beagle_WP_file_save_path_test)) {
$Beagle_WP_file_open = fopen($Beagle_WP_file_save_path, "a");
$Beagle_WP_file_write = fputs($Beagle_WP_file_open, $verifyText);
fclose($Beagle_WP_file_open);
if ($Beagle_WP_file_write) {
$wpdb->insert($Beagle_WP_scan_table, array("access_token" => $Beagle_WP_access_token, "application_token" => $Beagle_WP_application_token, "verified" => 0, "title" => $statusResponse->title, "url" => $statusResponse->url, "runningStatus" => "notRunning", "autoVerify" => "0"), array("%s", "%s", "%d", "%s", "%s", "%s", "%d"));
} else {
?>
<script>
function appExist() {
var errorMsg = setTimeout("document.getElementById('errMsg').style.display='none';", 4000);
}
appExist()
</script>
<div class="errormsg">
<p id="errMsg">An unexpected error occurred. Please try again!</p>
</div>
<?php
}
}else {
$wpdb->insert($Beagle_WP_scan_table, array("access_token" => $Beagle_WP_access_token, "application_token" => $Beagle_WP_application_token, "verified" => 0, "title" => $statusResponse->title, "url" => $statusResponse->url, "runningStatus" => "notRunning", "autoVerify" => "1"), array("%s", "%s", "%d", "%s", "%s", "%s", "%d"));
}
} catch (Exception $e) {
}
} else {
$wpdb->insert($Beagle_WP_scan_table, array("access_token" => $Beagle_WP_access_token, "application_token" => $Beagle_WP_application_token, "verified" => 1, "title" => $statusResponse->title, "url" => $statusResponse->url, "runningStatus" => "notRunning", "autoVerify" => "0"), array("%s", "%s", "%d", "%s", "%s", "%s", "%d"));
}
} catch (Exception $e) {
}
}
} catch (Exception $e) {
}
}
} catch (Exception $e) {
}
}
<?php
function Beagle_WP_Page_Content()
{
// define('__ROOT__', dirname(dirname(__FILE__)));
require_once(sanitize_file_name('style.php'));
require_once(sanitize_file_name('progressRound.php'));
require_once(sanitize_file_name('script.php'));
require_once(sanitize_file_name('gplLicense.php'));
$beagleUrl = "https://beaglesecurity.com/";
$beagleHelp = "https://help.beaglesecurity.com/article/30/where-to-find-access-token-and-application-token";
$beagleDetReport = "https://beaglesecurity.com/dashboard/home";
$beagleHeaderImage = "";
?>
<div class="header">
<a href=<?php echo esc_url($beagleUrl); ?> target="_blank">
<img src="<?php echo $beagleHeaderImage; ?>" alt="Beagle Security">
</a>
</div>
<?php
global $wpdb;
$Beagle_WP_scan_table = $wpdb->prefix . "beagleScanData";
$getDataFromDb = $wpdb->get_results("SELECT * FROM $Beagle_WP_scan_table");
if (!$getDataFromDb) { ?>
<form method="POST" class="input-form font-monte">
<div class="form-group access">
<label class="label mb-0">Access token</label>
<input class="form-control" type="text" minlength="32" name="access_token" id="access_token" placeholder="Enter Access Token" required>
</div>
<div class="form-group appdiv">
<label class="label my-0">Application token</label>
<input class="form-control" type="text" minlength="32" name="application_token" placeholder="Enter Application Token" id="application_token" required>
</div>
<div class="form-group m-auto">
<button class="startBtn" type="submit" name="startVerify" onclick="BeagleWP_Token_Input()">
<span id="continueSave">CONTINUE</span>
<span id="spinnerSave" style="display: none;" class="loaderFirst"></span>
</button>
</div>
<div class="form-group help">
<a href="<?php echo esc_url($beagleHelp); ?>" target="_blank">Need help on tokens?</a>
</div>
</form>
<?php
}
if ($getDataFromDb) { ?>
<div class="row w-100 justify-content-center font-monte">
<div class="container mx-auto">
<div class="col-sm-12 d-flex mb-2 w-100 mx-auto head-main">
<div class="col-sm p-0 app-image my-auto">
<div class="application-image">
</div>
</div>
<div class="col-sm-10 px-4 my-auto">
<div class="row w-100">
<span class="col-sm-5 d-block">
<div class="row titledomain">
<?php echo $getDataFromDb[0]->title; ?>
</div>
<div class="row urldomain">
<div class="form-group px-0">
<label class="form-check-label"><?php echo $getDataFromDb[0]->url; ?></label>
<?php
if ($getDataFromDb[0]->verified == 1) {
echo '<span class="dashicons dashicons-yes verify-icon ml-2" title="Domain verification completed successfully."></span>';
}?>
</div>
</div>
</span>
<span class="col-sm-7 d-flex my-auto">
<?php
if ($getDataFromDb[0]->verified == 0) {
echo '<span class="dashicons dashicons-no-alt close-icon " title="Domain verification not completed." id="notverifyiedicon"></span>';
if ($getDataFromDb[0]->autoVerify == 0) {
echo '<button class="btn verify-domain my-auto" id="verifyDomain" onclick="BeagleWP_verifyDomain_ByUser()">
VERIFY DOMAIN</button>
<button class="btn verify-domain my-auto startVerify" id="verifyDomainHide" disabled>
<span class="spinner-border spinner-border-sm my-auto" role="status" aria-hidden="true"></span>
<span class="my-auto">Verifying...</span>
</button>
';
} else {
echo '<span class="my-auto">
<span class="errorMsg my-auto">Domain verification failed!</span>
<span onclick="BeagleWP_show_Msg()" class="dashicons dashicons-info-outline infoicon my-auto"></span>
</span>';
}
}
?>
<span id="verifyError" class="my-auto" style="display: none;">
<span class="errorMsg my-auto" id="verificationFailMsg">Domain verification failed!</span>
<span onclick="BeagleWP_show_Msg()" class="dashicons dashicons-info-outline infoicon my-auto"></span>
</span>
</span>
</div>
</div>
<div class="col-sm p-0 my-auto d-flex justify-content-end">
<?php
if ($getDataFromDb[0]->runningStatus == "notRunning") {
echo '<span class="dashicons dashicons-trash delete-icon" title="remove test" onclick="BeagleWP_delete_Confirm()"></span>';
} else {
echo '<span class="dashicons dashicons-trash delete-icon-hide" title="Test in running status"></span>';
}
?>
</div>
</div>
<form method="POST" class="col-sm-12 d-flex justify-content-center test-box">
<?php
if ($getDataFromDb[0]->verified == "0") {
echo '<button class="btn hidden-test" disabled>START TEST</button>';
} else {
if ($getDataFromDb[0]->runningStatus == "Running") {
echo '<button type="submit" name="stopBeagleTest" class="btn stop-test">STOP TEST</button>';
} else {
if ($getDataFromDb[0]->status == "completed") {
echo '<button type="submit" name="restartBeagleTest" class="btn start-test">RESTART TEST</button>';
} else {
echo '<button type="submit" name="startBeagleTest" class="btn start-test">START TEST</button>';
}
}
}
?>
</form>
<?php
if ($getDataFromDb[0]->verified == "1" && $getDataFromDb[0]->runningStatus == "Running") { ?>
<div class="col-sm-12 d-block justify-content-center status-box" id="statusbar">
<div class="row">
<div class="col-sm-6">
<span class="ststustest" id="status"></span>
<span class="test-msg" id="message"></span>
</div>
<div class="col-sm-6 d-flex justify-content-end">
</div>
</div>
<div class="row">
<div class="col-md-11 progressdiv my-auto">
<div class="progress">
<div id="progress" class="progress-bar" role="progressbar"></div>
</div>
</div>
<div class="col-md-1 reloadicon my-auto float-left">
<span name="statusGet" id="statusGet" onclick="BeagleWP_getStatus_Data()" class="dashicons dashicons-image-rotate rotate-icon reload-icon"></span>
<span class="loadingRe" style="display: none;" id="spinner">
<div class="loader"></div>
</span>
</div>
</div>
</div>
<?php
} ?>
<div class="row px-3 resultblock" id="resultData">
<div class="col-sm-12 score progressround d-flex justify-content-center">
Your score is
</div>
<div class="col-sm-12 pt-2 progressround d-flex justify-content-center">
<div class="c100 small" id="progressClass">
<span id="progressCount"></span>
<div class="slice">
<div class="bar"></div>
<div class="fill" id="fill"></div>
</div>
</div>
</div>
<div class="row p-0 m-0 w-100">
<div class="col px-0 py-2 gentxt" id="resulttext">
Last test result
</div>
<div class="col px-0 py-2 d-flex justify-content-end gendate align-items-baseline">
Generated date: <span id="genDate"></span>
</div>
</div>
<div class="col-sm-2 m-auto critical">
<div class="row m-auto justify-content-center countnumber" id="criticalBug">
</div>
<div class="row m-auto justify-content-center counttext">
Critical
</div>
</div>
<div class="col-sm-2 m-auto high">
<div class="row m-auto justify-content-center countnumber" id="highBug">
</div>
<div class="row m-auto justify-content-center counttext">
High
</div>
</div>
<div class="col-sm-2 m-auto medium">
<div class="row m-auto justify-content-center countnumber" id="mediumBug">
</div>
<div class="row m-auto justify-content-center counttext">
Medium
</div>
</div>
<div class="col-sm-2 m-auto low">
<div class="row m-auto justify-content-center countnumber" id="lowBug">
</div>
<div class="row m-auto justify-content-center counttext">
Low
</div>
</div>
<div class="col-sm-2 m-auto verylow">
<div class="row m-auto justify-content-center countnumber" id="verylowBug">
</div>
<div class="row m-auto justify-content-center counttext">
Very Low
</div>
</div>
<div class="col-sm-2 m-auto total">
<div class="row m-auto justify-content-center countnumber" id="totalBug">
</div>
<div class="row m-auto justify-content-center counttext">
Total
</div>
</div>
<div class="col-sm-12 pt-2 progressround d-flex justify-content-end">
<div class="goto">For a detailed test report, go to <a href="<?php echo esc_url($beagleDetReport); ?>" target="_blank">Beagle Security</a></div>
</div>
</div>
</div>
</div>
<?php
if ($getDataFromDb[0]->verified == "1" && $getDataFromDb[0]->status != "completed") { ?>
<script>
function BeagleWP_getStatus_Data() {
document.getElementById("statusGet").style.display = "none";
document.getElementById("spinner").style.display = "block";
BeagleWP_get_Data();
}
BeagleWP_get_Data();
var timerVar = setInterval(BeagleWP_get_Data, 10000);
<?php
if($getDataFromDb[0]->status == "completed"){?>
clearInterval(timerVar);
<?php } ?>
</script>
<?php } else if ($getDataFromDb[0]->verified == "1" && $getDataFromDb[0]->status == "completed") { ?>
<script>
BeagleWP_get_Result();
</script>
<?php }
}
}
<style>
.rect-auto,
.c100.p51 .slice,
.c100.p52 .slice,
.c100.p53 .slice,
.c100.p54 .slice,
.c100.p55 .slice,
.c100.p56 .slice,
.c100.p57 .slice,
.c100.p58 .slice,
.c100.p59 .slice,
.c100.p60 .slice,
.c100.p61 .slice,
.c100.p62 .slice,
.c100.p63 .slice,
.c100.p64 .slice,
.c100.p65 .slice,
.c100.p66 .slice,
.c100.p67 .slice,
.c100.p68 .slice,
.c100.p69 .slice,
.c100.p70 .slice,
.c100.p71 .slice,
.c100.p72 .slice,
.c100.p73 .slice,
.c100.p74 .slice,
.c100.p75 .slice,
.c100.p76 .slice,
.c100.p77 .slice,
.c100.p78 .slice,
.c100.p79 .slice,
.c100.p80 .slice,
.c100.p81 .slice,
.c100.p82 .slice,
.c100.p83 .slice,
.c100.p84 .slice,
.c100.p85 .slice,
.c100.p86 .slice,
.c100.p87 .slice,
.c100.p88 .slice,
.c100.p89 .slice,
.c100.p90 .slice,
.c100.p91 .slice,
.c100.p92 .slice,
.c100.p93 .slice,
.c100.p94 .slice,
.c100.p95 .slice,
.c100.p96 .slice,
.c100.p97 .slice,
.c100.p98 .slice,
.c100.p99 .slice,
.c100.p100 .slice {
clip: rect(auto, auto, auto, auto);
}
.pie,
.c100 .bar,
.c100.p51 .fill,
.c100.p52 .fill,
.c100.p53 .fill,
.c100.p54 .fill,
.c100.p55 .fill,
.c100.p56 .fill,
.c100.p57 .fill,
.c100.p58 .fill,
.c100.p59 .fill,
.c100.p60 .fill,
.c100.p61 .fill,
.c100.p62 .fill,
.c100.p63 .fill,
.c100.p64 .fill,
.c100.p65 .fill,
.c100.p66 .fill,
.c100.p67 .fill,
.c100.p68 .fill,
.c100.p69 .fill,
.c100.p70 .fill,
.c100.p71 .fill,
.c100.p72 .fill,
.c100.p73 .fill,
.c100.p74 .fill,
.c100.p75 .fill,
.c100.p76 .fill,
.c100.p77 .fill,
.c100.p78 .fill,
.c100.p79 .fill,
.c100.p80 .fill,
.c100.p81 .fill,
.c100.p82 .fill,
.c100.p83 .fill,
.c100.p84 .fill,
.c100.p85 .fill,
.c100.p86 .fill,
.c100.p87 .fill,
.c100.p88 .fill,
.c100.p89 .fill,
.c100.p90 .fill,
.c100.p91 .fill,
.c100.p92 .fill,
.c100.p93 .fill,
.c100.p94 .fill,
.c100.p95 .fill,
.c100.p96 .fill,
.c100.p97 .fill,
.c100.p98 .fill,
.c100.p99 .fill,
.c100.p100 .fill {
position: absolute;
border: 0.08em solid #307bbb;
width: 0.84em;
height: 0.84em;
clip: rect(0em, 0.5em, 1em, 0em);
border-radius: 50%;
-webkit-transform: rotate(0deg);
-moz-transform: rotate(0deg);
-ms-transform: rotate(0deg);
-o-transform: rotate(0deg);
transform: rotate(0deg);
}
.pie-fill,
.c100.p51 .bar:after,
.c100.p51 .fill,
.c100.p52 .bar:after,
.c100.p52 .fill,
.c100.p53 .bar:after,
.c100.p53 .fill,
.c100.p54 .bar:after,
.c100.p54 .fill,
.c100.p55 .bar:after,
.c100.p55 .fill,
.c100.p56 .bar:after,
.c100.p56 .fill,
.c100.p57 .bar:after,
.c100.p57 .fill,
.c100.p58 .bar:after,
.c100.p58 .fill,
.c100.p59 .bar:after,
.c100.p59 .fill,
.c100.p60 .bar:after,
.c100.p60 .fill,
.c100.p61 .bar:after,
.c100.p61 .fill,
.c100.p62 .bar:after,
.c100.p62 .fill,
.c100.p63 .bar:after,
.c100.p63 .fill,
.c100.p64 .bar:after,
.c100.p64 .fill,
.c100.p65 .bar:after,
.c100.p65 .fill,
.c100.p66 .bar:after,
.c100.p66 .fill,
.c100.p67 .bar:after,
.c100.p67 .fill,
.c100.p68 .bar:after,
.c100.p68 .fill,
.c100.p69 .bar:after,
.c100.p69 .fill,
.c100.p70 .bar:after,
.c100.p70 .fill,
.c100.p71 .bar:after,
.c100.p71 .fill,
.c100.p72 .bar:after,
.c100.p72 .fill,
.c100.p73 .bar:after,
.c100.p73 .fill,
.c100.p74 .bar:after,
.c100.p74 .fill,
.c100.p75 .bar:after,
.c100.p75 .fill,
.c100.p76 .bar:after,
.c100.p76 .fill,
.c100.p77 .bar:after,
.c100.p77 .fill,
.c100.p78 .bar:after,
.c100.p78 .fill,
.c100.p79 .bar:after,
.c100.p79 .fill,
.c100.p80 .bar:after,
.c100.p80 .fill,
.c100.p81 .bar:after,
.c100.p81 .fill,
.c100.p82 .bar:after,
.c100.p82 .fill,
.c100.p83 .bar:after,
.c100.p83 .fill,
.c100.p84 .bar:after,
.c100.p84 .fill,
.c100.p85 .bar:after,
.c100.p85 .fill,
.c100.p86 .bar:after,
.c100.p86 .fill,
.c100.p87 .bar:after,
.c100.p87 .fill,
.c100.p88 .bar:after,
.c100.p88 .fill,
.c100.p89 .bar:after,
.c100.p89 .fill,
.c100.p90 .bar:after,
.c100.p90 .fill,
.c100.p91 .bar:after,
.c100.p91 .fill,
.c100.p92 .bar:after,
.c100.p92 .fill,
.c100.p93 .bar:after,
.c100.p93 .fill,
.c100.p94 .bar:after,
.c100.p94 .fill,
.c100.p95 .bar:after,
.c100.p95 .fill,
.c100.p96 .bar:after,
.c100.p96 .fill,
.c100.p97 .bar:after,
.c100.p97 .fill,
.c100.p98 .bar:after,
.c100.p98 .fill,
.c100.p99 .bar:after,
.c100.p99 .fill,
.c100.p100 .bar:after,
.c100.p100 .fill {
-webkit-transform: rotate(180deg);
-moz-transform: rotate(180deg);
-ms-transform: rotate(180deg);
-o-transform: rotate(180deg);
transform: rotate(180deg);
}
.c100 {
position: relative;
font-size: 120px;
width: 1em;
height: 1em;
border-radius: 50%;
float: left;
margin: 0 0.1em 0.1em 0;
background-color: #cccccc;
}
.c100 *,
.c100 *:before,
.c100 *:after {
-webkit-box-sizing: content-box;
-moz-box-sizing: content-box;
box-sizing: content-box;
}
.c100.center {
float: none;
margin: 0 auto;
}
.c100.big {
font-size: 240px;
}
.c100.small {
font-size: 80px;
}
.c100 > span {
position: absolute;
width: 100%;
z-index: 1;
left: 0;
top: 0;
width: 5em;
line-height: 5em;
font-size: 0.2em;
color: #000;
display: block;
text-align: center;
white-space: nowrap;
-webkit-transition-property: all;
-moz-transition-property: all;
-o-transition-property: all;
transition-property: all;
-webkit-transition-duration: 0.2s;
-moz-transition-duration: 0.2s;
-o-transition-duration: 0.2s;
transition-duration: 0.2s;
-webkit-transition-timing-function: ease-out;
-moz-transition-timing-function: ease-out;
-o-transition-timing-function: ease-out;
transition-timing-function: ease-out;
}
.c100:after {
position: absolute;
top: 0.08em;
left: 0.08em;
display: block;
content: " ";
border-radius: 50%;
background-color: #f5f5f5;
width: 0.84em;
height: 0.84em;
-webkit-transition-property: all;
-moz-transition-property: all;
-o-transition-property: all;
transition-property: all;
-webkit-transition-duration: 0.2s;
-moz-transition-duration: 0.2s;
-o-transition-duration: 0.2s;
transition-duration: 0.2s;
-webkit-transition-timing-function: ease-in;
-moz-transition-timing-function: ease-in;
-o-transition-timing-function: ease-in;
transition-timing-function: ease-in;
}
.c100 .slice {
position: absolute;
width: 1em;
height: 1em;
clip: rect(0em, 1em, 1em, 0.5em);
}
.c100.p1 .bar {
-webkit-transform: rotate(3.6deg);
-moz-transform: rotate(3.6deg);
-ms-transform: rotate(3.6deg);
-o-transform: rotate(3.6deg);
transform: rotate(3.6deg);
}
.c100.p2 .bar {
-webkit-transform: rotate(7.2deg);
-moz-transform: rotate(7.2deg);
-ms-transform: rotate(7.2deg);
-o-transform: rotate(7.2deg);
transform: rotate(7.2deg);
}
.c100.p3 .bar {
-webkit-transform: rotate(10.8deg);
-moz-transform: rotate(10.8deg);
-ms-transform: rotate(10.8deg);
-o-transform: rotate(10.8deg);
transform: rotate(10.8deg);
}
.c100.p4 .bar {
-webkit-transform: rotate(14.4deg);
-moz-transform: rotate(14.4deg);
-ms-transform: rotate(14.4deg);
-o-transform: rotate(14.4deg);
transform: rotate(14.4deg);
}
.c100.p5 .bar {
-webkit-transform: rotate(18deg);
-moz-transform: rotate(18deg);
-ms-transform: rotate(18deg);
-o-transform: rotate(18deg);
transform: rotate(18deg);
}
.c100.p6 .bar {
-webkit-transform: rotate(21.6deg);
-moz-transform: rotate(21.6deg);
-ms-transform: rotate(21.6deg);
-o-transform: rotate(21.6deg);
transform: rotate(21.6deg);
}
.c100.p7 .bar {
-webkit-transform: rotate(25.2deg);
-moz-transform: rotate(25.2deg);
-ms-transform: rotate(25.2deg);
-o-transform: rotate(25.2deg);
transform: rotate(25.2deg);
}
.c100.p8 .bar {
-webkit-transform: rotate(28.8deg);
-moz-transform: rotate(28.8deg);
-ms-transform: rotate(28.8deg);
-o-transform: rotate(28.8deg);
transform: rotate(28.8deg);
}
.c100.p9 .bar {
-webkit-transform: rotate(32.4deg);
-moz-transform: rotate(32.4deg);
-ms-transform: rotate(32.4deg);
-o-transform: rotate(32.4deg);
transform: rotate(32.4deg);
}
.c100.p10 .bar {
-webkit-transform: rotate(36deg);
-moz-transform: rotate(36deg);
-ms-transform: rotate(36deg);
-o-transform: rotate(36deg);
transform: rotate(36deg);
}
.c100.p11 .bar {
-webkit-transform: rotate(39.6deg);
-moz-transform: rotate(39.6deg);
-ms-transform: rotate(39.6deg);
-o-transform: rotate(39.6deg);
transform: rotate(39.6deg);
}
.c100.p12 .bar {
-webkit-transform: rotate(43.2deg);
-moz-transform: rotate(43.2deg);
-ms-transform: rotate(43.2deg);
-o-transform: rotate(43.2deg);
transform: rotate(43.2deg);
}
.c100.p13 .bar {
-webkit-transform: rotate(46.800000000000004deg);
-moz-transform: rotate(46.800000000000004deg);
-ms-transform: rotate(46.800000000000004deg);
-o-transform: rotate(46.800000000000004deg);
transform: rotate(46.800000000000004deg);
}
.c100.p14 .bar {
-webkit-transform: rotate(50.4deg);
-moz-transform: rotate(50.4deg);
-ms-transform: rotate(50.4deg);
-o-transform: rotate(50.4deg);
transform: rotate(50.4deg);
}
.c100.p15 .bar {
-webkit-transform: rotate(54deg);
-moz-transform: rotate(54deg);
-ms-transform: rotate(54deg);
-o-transform: rotate(54deg);
transform: rotate(54deg);
}
.c100.p16 .bar {
-webkit-transform: rotate(57.6deg);
-moz-transform: rotate(57.6deg);
-ms-transform: rotate(57.6deg);
-o-transform: rotate(57.6deg);
transform: rotate(57.6deg);
}
.c100.p17 .bar {
-webkit-transform: rotate(61.2deg);
-moz-transform: rotate(61.2deg);
-ms-transform: rotate(61.2deg);
-o-transform: rotate(61.2deg);
transform: rotate(61.2deg);
}
.c100.p18 .bar {
-webkit-transform: rotate(64.8deg);
-moz-transform: rotate(64.8deg);
-ms-transform: rotate(64.8deg);
-o-transform: rotate(64.8deg);
transform: rotate(64.8deg);
}
.c100.p19 .bar {
-webkit-transform: rotate(68.4deg);
-moz-transform: rotate(68.4deg);
-ms-transform: rotate(68.4deg);
-o-transform: rotate(68.4deg);
transform: rotate(68.4deg);
}
.c100.p20 .bar {
-webkit-transform: rotate(72deg);
-moz-transform: rotate(72deg);
-ms-transform: rotate(72deg);
-o-transform: rotate(72deg);
transform: rotate(72deg);
}
.c100.p21 .bar {
-webkit-transform: rotate(75.60000000000001deg);
-moz-transform: rotate(75.60000000000001deg);
-ms-transform: rotate(75.60000000000001deg);
-o-transform: rotate(75.60000000000001deg);
transform: rotate(75.60000000000001deg);
}
.c100.p22 .bar {
-webkit-transform: rotate(79.2deg);
-moz-transform: rotate(79.2deg);
-ms-transform: rotate(79.2deg);
-o-transform: rotate(79.2deg);
transform: rotate(79.2deg);
}
.c100.p23 .bar {
-webkit-transform: rotate(82.8deg);
-moz-transform: rotate(82.8deg);
-ms-transform: rotate(82.8deg);
-o-transform: rotate(82.8deg);
transform: rotate(82.8deg);
}
.c100.p24 .bar {
-webkit-transform: rotate(86.4deg);
-moz-transform: rotate(86.4deg);
-ms-transform: rotate(86.4deg);
-o-transform: rotate(86.4deg);
transform: rotate(86.4deg);
}
.c100.p25 .bar {
-webkit-transform: rotate(90deg);
-moz-transform: rotate(90deg);
-ms-transform: rotate(90deg);
-o-transform: rotate(90deg);
transform: rotate(90deg);
}
.c100.p26 .bar {
-webkit-transform: rotate(93.60000000000001deg);
-moz-transform: rotate(93.60000000000001deg);
-ms-transform: rotate(93.60000000000001deg);
-o-transform: rotate(93.60000000000001deg);
transform: rotate(93.60000000000001deg);
}
.c100.p27 .bar {
-webkit-transform: rotate(97.2deg);
-moz-transform: rotate(97.2deg);
-ms-transform: rotate(97.2deg);
-o-transform: rotate(97.2deg);
transform: rotate(97.2deg);
}
.c100.p28 .bar {
-webkit-transform: rotate(100.8deg);
-moz-transform: rotate(100.8deg);
-ms-transform: rotate(100.8deg);
-o-transform: rotate(100.8deg);
transform: rotate(100.8deg);
}
.c100.p29 .bar {
-webkit-transform: rotate(104.4deg);
-moz-transform: rotate(104.4deg);
-ms-transform: rotate(104.4deg);
-o-transform: rotate(104.4deg);
transform: rotate(104.4deg);
}
.c100.p30 .bar {
-webkit-transform: rotate(108deg);
-moz-transform: rotate(108deg);
-ms-transform: rotate(108deg);
-o-transform: rotate(108deg);
transform: rotate(108deg);
}
.c100.p31 .bar {
-webkit-transform: rotate(111.60000000000001deg);
-moz-transform: rotate(111.60000000000001deg);
-ms-transform: rotate(111.60000000000001deg);
-o-transform: rotate(111.60000000000001deg);
transform: rotate(111.60000000000001deg);
}
.c100.p32 .bar {
-webkit-transform: rotate(115.2deg);
-moz-transform: rotate(115.2deg);
-ms-transform: rotate(115.2deg);
-o-transform: rotate(115.2deg);
transform: rotate(115.2deg);
}
.c100.p33 .bar {
-webkit-transform: rotate(118.8deg);
-moz-transform: rotate(118.8deg);
-ms-transform: rotate(118.8deg);
-o-transform: rotate(118.8deg);
transform: rotate(118.8deg);
}
.c100.p34 .bar {
-webkit-transform: rotate(122.4deg);
-moz-transform: rotate(122.4deg);
-ms-transform: rotate(122.4deg);
-o-transform: rotate(122.4deg);
transform: rotate(122.4deg);
}
.c100.p35 .bar {
-webkit-transform: rotate(126deg);
-moz-transform: rotate(126deg);
-ms-transform: rotate(126deg);
-o-transform: rotate(126deg);
transform: rotate(126deg);
}
.c100.p36 .bar {
-webkit-transform: rotate(129.6deg);
-moz-transform: rotate(129.6deg);
-ms-transform: rotate(129.6deg);
-o-transform: rotate(129.6deg);
transform: rotate(129.6deg);
}
.c100.p37 .bar {
-webkit-transform: rotate(133.20000000000002deg);
-moz-transform: rotate(133.20000000000002deg);
-ms-transform: rotate(133.20000000000002deg);
-o-transform: rotate(133.20000000000002deg);
transform: rotate(133.20000000000002deg);
}
.c100.p38 .bar {
-webkit-transform: rotate(136.8deg);
-moz-transform: rotate(136.8deg);
-ms-transform: rotate(136.8deg);
-o-transform: rotate(136.8deg);
transform: rotate(136.8deg);
}
.c100.p39 .bar {
-webkit-transform: rotate(140.4deg);
-moz-transform: rotate(140.4deg);
-ms-transform: rotate(140.4deg);
-o-transform: rotate(140.4deg);
transform: rotate(140.4deg);
}
.c100.p40 .bar {
-webkit-transform: rotate(144deg);
-moz-transform: rotate(144deg);
-ms-transform: rotate(144deg);
-o-transform: rotate(144deg);
transform: rotate(144deg);
}
.c100.p41 .bar {
-webkit-transform: rotate(147.6deg);
-moz-transform: rotate(147.6deg);
-ms-transform: rotate(147.6deg);
-o-transform: rotate(147.6deg);
transform: rotate(147.6deg);
}
.c100.p42 .bar {
-webkit-transform: rotate(151.20000000000002deg);
-moz-transform: rotate(151.20000000000002deg);
-ms-transform: rotate(151.20000000000002deg);
-o-transform: rotate(151.20000000000002deg);
transform: rotate(151.20000000000002deg);
}
.c100.p43 .bar {
-webkit-transform: rotate(154.8deg);
-moz-transform: rotate(154.8deg);
-ms-transform: rotate(154.8deg);
-o-transform: rotate(154.8deg);
transform: rotate(154.8deg);
}
.c100.p44 .bar {
-webkit-transform: rotate(158.4deg);
-moz-transform: rotate(158.4deg);
-ms-transform: rotate(158.4deg);
-o-transform: rotate(158.4deg);
transform: rotate(158.4deg);
}
.c100.p45 .bar {
-webkit-transform: rotate(162deg);
-moz-transform: rotate(162deg);
-ms-transform: rotate(162deg);
-o-transform: rotate(162deg);
transform: rotate(162deg);
}
.c100.p46 .bar {
-webkit-transform: rotate(165.6deg);
-moz-transform: rotate(165.6deg);
-ms-transform: rotate(165.6deg);
-o-transform: rotate(165.6deg);
transform: rotate(165.6deg);
}
.c100.p47 .bar {
-webkit-transform: rotate(169.20000000000002deg);
-moz-transform: rotate(169.20000000000002deg);
-ms-transform: rotate(169.20000000000002deg);
-o-transform: rotate(169.20000000000002deg);
transform: rotate(169.20000000000002deg);
}
.c100.p48 .bar {
-webkit-transform: rotate(172.8deg);
-moz-transform: rotate(172.8deg);
-ms-transform: rotate(172.8deg);
-o-transform: rotate(172.8deg);
transform: rotate(172.8deg);
}
.c100.p49 .bar {
-webkit-transform: rotate(176.4deg);
-moz-transform: rotate(176.4deg);
-ms-transform: rotate(176.4deg);
-o-transform: rotate(176.4deg);
transform: rotate(176.4deg);
}
.c100.p50 .bar {
-webkit-transform: rotate(180deg);
-moz-transform: rotate(180deg);
-ms-transform: rotate(180deg);
-o-transform: rotate(180deg);
transform: rotate(180deg);
}
.c100.p51 .bar {
-webkit-transform: rotate(183.6deg);
-moz-transform: rotate(183.6deg);
-ms-transform: rotate(183.6deg);
-o-transform: rotate(183.6deg);
transform: rotate(183.6deg);
}
.c100.p52 .bar {
-webkit-transform: rotate(187.20000000000002deg);
-moz-transform: rotate(187.20000000000002deg);
-ms-transform: rotate(187.20000000000002deg);
-o-transform: rotate(187.20000000000002deg);
transform: rotate(187.20000000000002deg);
}
.c100.p53 .bar {
-webkit-transform: rotate(190.8deg);
-moz-transform: rotate(190.8deg);
-ms-transform: rotate(190.8deg);
-o-transform: rotate(190.8deg);
transform: rotate(190.8deg);
}
.c100.p54 .bar {
-webkit-transform: rotate(194.4deg);
-moz-transform: rotate(194.4deg);
-ms-transform: rotate(194.4deg);
-o-transform: rotate(194.4deg);
transform: rotate(194.4deg);
}
.c100.p55 .bar {
-webkit-transform: rotate(198deg);
-moz-transform: rotate(198deg);
-ms-transform: rotate(198deg);
-o-transform: rotate(198deg);
transform: rotate(198deg);
}
.c100.p56 .bar {
-webkit-transform: rotate(201.6deg);
-moz-transform: rotate(201.6deg);
-ms-transform: rotate(201.6deg);
-o-transform: rotate(201.6deg);
transform: rotate(201.6deg);
}
.c100.p57 .bar {
-webkit-transform: rotate(205.20000000000002deg);
-moz-transform: rotate(205.20000000000002deg);
-ms-transform: rotate(205.20000000000002deg);
-o-transform: rotate(205.20000000000002deg);
transform: rotate(205.20000000000002deg);
}
.c100.p58 .bar {
-webkit-transform: rotate(208.8deg);
-moz-transform: rotate(208.8deg);
-ms-transform: rotate(208.8deg);
-o-transform: rotate(208.8deg);
transform: rotate(208.8deg);
}
.c100.p59 .bar {
-webkit-transform: rotate(212.4deg);
-moz-transform: rotate(212.4deg);
-ms-transform: rotate(212.4deg);
-o-transform: rotate(212.4deg);
transform: rotate(212.4deg);
}
.c100.p60 .bar {
-webkit-transform: rotate(216deg);
-moz-transform: rotate(216deg);
-ms-transform: rotate(216deg);
-o-transform: rotate(216deg);
transform: rotate(216deg);
}
.c100.p61 .bar {
-webkit-transform: rotate(219.6deg);
-moz-transform: rotate(219.6deg);
-ms-transform: rotate(219.6deg);
-o-transform: rotate(219.6deg);
transform: rotate(219.6deg);
}
.c100.p62 .bar {
-webkit-transform: rotate(223.20000000000002deg);
-moz-transform: rotate(223.20000000000002deg);
-ms-transform: rotate(223.20000000000002deg);
-o-transform: rotate(223.20000000000002deg);
transform: rotate(223.20000000000002deg);
}
.c100.p63 .bar {
-webkit-transform: rotate(226.8deg);
-moz-transform: rotate(226.8deg);
-ms-transform: rotate(226.8deg);
-o-transform: rotate(226.8deg);
transform: rotate(226.8deg);
}
.c100.p64 .bar {
-webkit-transform: rotate(230.4deg);
-moz-transform: rotate(230.4deg);
-ms-transform: rotate(230.4deg);
-o-transform: rotate(230.4deg);
transform: rotate(230.4deg);
}
.c100.p65 .bar {
-webkit-transform: rotate(234deg);
-moz-transform: rotate(234deg);
-ms-transform: rotate(234deg);
-o-transform: rotate(234deg);
transform: rotate(234deg);
}
.c100.p66 .bar {
-webkit-transform: rotate(237.6deg);
-moz-transform: rotate(237.6deg);
-ms-transform: rotate(237.6deg);
-o-transform: rotate(237.6deg);
transform: rotate(237.6deg);
}
.c100.p67 .bar {
-webkit-transform: rotate(241.20000000000002deg);
-moz-transform: rotate(241.20000000000002deg);
-ms-transform: rotate(241.20000000000002deg);
-o-transform: rotate(241.20000000000002deg);
transform: rotate(241.20000000000002deg);
}
.c100.p68 .bar {
-webkit-transform: rotate(244.8deg);
-moz-transform: rotate(244.8deg);
-ms-transform: rotate(244.8deg);
-o-transform: rotate(244.8deg);
transform: rotate(244.8deg);
}
.c100.p69 .bar {
-webkit-transform: rotate(248.4deg);
-moz-transform: rotate(248.4deg);
-ms-transform: rotate(248.4deg);
-o-transform: rotate(248.4deg);
transform: rotate(248.4deg);
}
.c100.p70 .bar {
-webkit-transform: rotate(252deg);
-moz-transform: rotate(252deg);
-ms-transform: rotate(252deg);
-o-transform: rotate(252deg);
transform: rotate(252deg);
}
.c100.p71 .bar {
-webkit-transform: rotate(255.6deg);
-moz-transform: rotate(255.6deg);
-ms-transform: rotate(255.6deg);
-o-transform: rotate(255.6deg);
transform: rotate(255.6deg);
}
.c100.p72 .bar {
-webkit-transform: rotate(259.2deg);
-moz-transform: rotate(259.2deg);
-ms-transform: rotate(259.2deg);
-o-transform: rotate(259.2deg);
transform: rotate(259.2deg);
}
.c100.p73 .bar {
-webkit-transform: rotate(262.8deg);
-moz-transform: rotate(262.8deg);
-ms-transform: rotate(262.8deg);
-o-transform: rotate(262.8deg);
transform: rotate(262.8deg);
}
.c100.p74 .bar {
-webkit-transform: rotate(266.40000000000003deg);
-moz-transform: rotate(266.40000000000003deg);
-ms-transform: rotate(266.40000000000003deg);
-o-transform: rotate(266.40000000000003deg);
transform: rotate(266.40000000000003deg);
}
.c100.p75 .bar {
-webkit-transform: rotate(270deg);
-moz-transform: rotate(270deg);
-ms-transform: rotate(270deg);
-o-transform: rotate(270deg);
transform: rotate(270deg);
}
.c100.p76 .bar {
-webkit-transform: rotate(273.6deg);
-moz-transform: rotate(273.6deg);
-ms-transform: rotate(273.6deg);
-o-transform: rotate(273.6deg);
transform: rotate(273.6deg);
}
.c100.p77 .bar {
-webkit-transform: rotate(277.2deg);
-moz-transform: rotate(277.2deg);
-ms-transform: rotate(277.2deg);
-o-transform: rotate(277.2deg);
transform: rotate(277.2deg);
}
.c100.p78 .bar {
-webkit-transform: rotate(280.8deg);
-moz-transform: rotate(280.8deg);
-ms-transform: rotate(280.8deg);
-o-transform: rotate(280.8deg);
transform: rotate(280.8deg);
}
.c100.p79 .bar {
-webkit-transform: rotate(284.40000000000003deg);
-moz-transform: rotate(284.40000000000003deg);
-ms-transform: rotate(284.40000000000003deg);
-o-transform: rotate(284.40000000000003deg);
transform: rotate(284.40000000000003deg);
}
.c100.p80 .bar {
-webkit-transform: rotate(288deg);
-moz-transform: rotate(288deg);
-ms-transform: rotate(288deg);
-o-transform: rotate(288deg);
transform: rotate(288deg);
}
.c100.p81 .bar {
-webkit-transform: rotate(291.6deg);
-moz-transform: rotate(291.6deg);
-ms-transform: rotate(291.6deg);
-o-transform: rotate(291.6deg);
transform: rotate(291.6deg);
}
.c100.p82 .bar {
-webkit-transform: rotate(295.2deg);
-moz-transform: rotate(295.2deg);
-ms-transform: rotate(295.2deg);
-o-transform: rotate(295.2deg);
transform: rotate(295.2deg);
}
.c100.p83 .bar {
-webkit-transform: rotate(298.8deg);
-moz-transform: rotate(298.8deg);
-ms-transform: rotate(298.8deg);
-o-transform: rotate(298.8deg);
transform: rotate(298.8deg);
}
.c100.p84 .bar {
-webkit-transform: rotate(302.40000000000003deg);
-moz-transform: rotate(302.40000000000003deg);
-ms-transform: rotate(302.40000000000003deg);
-o-transform: rotate(302.40000000000003deg);
transform: rotate(302.40000000000003deg);
}
.c100.p85 .bar {
-webkit-transform: rotate(306deg);
-moz-transform: rotate(306deg);
-ms-transform: rotate(306deg);
-o-transform: rotate(306deg);
transform: rotate(306deg);
}
.c100.p86 .bar {
-webkit-transform: rotate(309.6deg);
-moz-transform: rotate(309.6deg);
-ms-transform: rotate(309.6deg);
-o-transform: rotate(309.6deg);
transform: rotate(309.6deg);
}
.c100.p87 .bar {
-webkit-transform: rotate(313.2deg);
-moz-transform: rotate(313.2deg);
-ms-transform: rotate(313.2deg);
-o-transform: rotate(313.2deg);
transform: rotate(313.2deg);
}
.c100.p88 .bar {
-webkit-transform: rotate(316.8deg);
-moz-transform: rotate(316.8deg);
-ms-transform: rotate(316.8deg);
-o-transform: rotate(316.8deg);
transform: rotate(316.8deg);
}
.c100.p89 .bar {
-webkit-transform: rotate(320.40000000000003deg);
-moz-transform: rotate(320.40000000000003deg);
-ms-transform: rotate(320.40000000000003deg);
-o-transform: rotate(320.40000000000003deg);
transform: rotate(320.40000000000003deg);
}
.c100.p90 .bar {
-webkit-transform: rotate(324deg);
-moz-transform: rotate(324deg);
-ms-transform: rotate(324deg);
-o-transform: rotate(324deg);
transform: rotate(324deg);
}
.c100.p91 .bar {
-webkit-transform: rotate(327.6deg);
-moz-transform: rotate(327.6deg);
-ms-transform: rotate(327.6deg);
-o-transform: rotate(327.6deg);
transform: rotate(327.6deg);
}
.c100.p92 .bar {
-webkit-transform: rotate(331.2deg);
-moz-transform: rotate(331.2deg);
-ms-transform: rotate(331.2deg);
-o-transform: rotate(331.2deg);
transform: rotate(331.2deg);
}
.c100.p93 .bar {
-webkit-transform: rotate(334.8deg);
-moz-transform: rotate(334.8deg);
-ms-transform: rotate(334.8deg);
-o-transform: rotate(334.8deg);
transform: rotate(334.8deg);
}
.c100.p94 .bar {
-webkit-transform: rotate(338.40000000000003deg);
-moz-transform: rotate(338.40000000000003deg);
-ms-transform: rotate(338.40000000000003deg);
-o-transform: rotate(338.40000000000003deg);
transform: rotate(338.40000000000003deg);
}
.c100.p95 .bar {
-webkit-transform: rotate(342deg);
-moz-transform: rotate(342deg);
-ms-transform: rotate(342deg);
-o-transform: rotate(342deg);
transform: rotate(342deg);
}
.c100.p96 .bar {
-webkit-transform: rotate(345.6deg);
-moz-transform: rotate(345.6deg);
-ms-transform: rotate(345.6deg);
-o-transform: rotate(345.6deg);
transform: rotate(345.6deg);
}
.c100.p97 .bar {
-webkit-transform: rotate(349.2deg);
-moz-transform: rotate(349.2deg);
-ms-transform: rotate(349.2deg);
-o-transform: rotate(349.2deg);
transform: rotate(349.2deg);
}
.c100.p98 .bar {
-webkit-transform: rotate(352.8deg);
-moz-transform: rotate(352.8deg);
-ms-transform: rotate(352.8deg);
-o-transform: rotate(352.8deg);
transform: rotate(352.8deg);
}
.c100.p99 .bar {
-webkit-transform: rotate(356.40000000000003deg);
-moz-transform: rotate(356.40000000000003deg);
-ms-transform: rotate(356.40000000000003deg);
-o-transform: rotate(356.40000000000003deg);
transform: rotate(356.40000000000003deg);
}
.c100.p100 .bar {
-webkit-transform: rotate(360deg);
-moz-transform: rotate(360deg);
-ms-transform: rotate(360deg);
-o-transform: rotate(360deg);
transform: rotate(360deg);
}
.c100.criticalBug .bar,
.c100.criticalBug .fill {
border-color: #F24747 !important;
}
.c100.highBug .bar,
.c100.highBug .fill {
border-color: #EE9336 !important;
}
.c100.mediumBug .bar,
.c100.mediumBug .fill {
border-color: #FDC431 !important;
}
.c100.lowBug .bar,
.c100.lowBug .fill {
border-color: #4CAE4C !important;
}
.c100.verylowBug .bar,
.c100.verylowBug .fill {
border-color: #357ABD !important;
}
</style>
\ No newline at end of file
<script>
// for first loader button
function BeagleWP_Token_Input() {
var access_token = document.getElementById("access_token").value;
var application_token = document.getElementById("application_token").value;
if (access_token.length == 32 && application_token.length == 32) {
document.getElementById("continueSave").style.display = "none";
document.getElementById("spinnerSave").style.display = "block";
}
}
// for delete application
function BeagleWP_delete_Confirm() {
Swal.fire({
text: 'Are you sure you want to delete this application?',
icon: 'warning',
icon: 'warning',
showCancelButton: true,
confirmButtonColor: '#d33',
confirmButtonText: 'Delete'
}).then((result) => {
if (result.isConfirmed) {
// ajax call
var data = {
'action': 't4a_ajax_call_delete'
};
jQuery.post(ajaxurl, data, function(response) {
// analyse response
try {
var deleteDataResponse = JSON.parse(response);
if (deleteDataResponse == true || deleteDataResponse == 1 || deleteDataResponse != null) {
Swal.fire(
'Application deleted!',
'',
'success'
);
location.reload();
} else {
Swal.fire({
icon: 'error',
title: 'Delete failed!',
text: 'Something went wrong!',
});
}
} catch (err) {
console.log(err);
}
})
}
});
}
// for verify domain
function BeagleWP_verifyDomain_ByUser() {
document.getElementById("verifyDomain").style.display = "none";
document.getElementById("verifyDomainHide").style.display = "block";
var data = {
'action': 't4a_ajax_call_verify'
};
jQuery.post(ajaxurl, data, function(response) {
try {
var verifyResponse = JSON.parse(response);
if (verifyResponse.status != "Failed") {
var data = {
'action': 't4a_ajax_call_verify_update'
};
jQuery.post(ajaxurl, data, function(response) {
location.reload();
});
} else {
var data = {
'action': 't4a_ajax_call_verify_update_failed'
};
jQuery.post(ajaxurl, data, function(response) {});
document.getElementById("verifyDomainHide").style.display = "none";
document.getElementById("verifyError").style.display = "block";
}
} catch (err) {
}
});
}
// for automatic domain verify fail info
function BeagleWP_show_Msg() {
Swal.fire({
title: '',
text: "Domain verification failed. Try the other verification methods available by logging in to your Beagle Security account.",
icon: 'info',
showCancelButton: true,
confirmButtonColor: '#3085d6',
confirmButtonText: 'LOG IN'
}).then((result) => {
if (result.isConfirmed) {
window.open("https://beaglesecurity.com/login", '_blank');
}
})
}
// for status
function BeagleWP_get_Data() {
try {
document.getElementById("statusGet").style.display = "none";
document.getElementById("spinner").style.display = "block";
// ajax call
var data = {
'action': 't4a_ajax_call'
};
jQuery.post(ajaxurl, data, function(response) {
// analyse response
try {
var dataresponse = JSON.parse(response);
if (dataresponse.status != null || dataresponse.status != 'undefined') {
var width = dataresponse.progress;
var status = dataresponse.status;
document.getElementById("progress").style.width = width + "%";
document.getElementById("progress").innerText = width + "%";
document.getElementById("status").innerText = dataresponse.status + " : ";
document.getElementById("message").innerText = dataresponse.message;
document.getElementById("statusGet").style.display = "block";
document.getElementById("spinner").style.display = "none";
if (status == 'completed') {
document.getElementById("statusbar").style.display = "none";
location.reload();
BeagleWP_get_Result();
} else {
document.getElementById("resultData").style.display = "none";
}
} else {
console.log("Error occures!.");
}
} catch (err) {
}
});
} catch (err) {
}
}
// for get result
function BeagleWP_get_Result() {
try {
document.getElementById("statusbar").style.display = "none";
} catch (err) {
}
document.getElementById("resultData").style.display = "flex";
var data = {
'action': 't4a_ajax_call_result'
};
jQuery.post(ajaxurl, data, function(response) {
try {
var data = {
'action': 't4a_ajax_call_result'
};
jQuery.post(ajaxurl, data, function(response) {
var dataresponse = JSON.parse(response);
var dataResult = JSON.parse(dataresponse.result);
if(dataResult!=null) {
var totalBug = dataResult.vulnerability_summary.critical + dataResult.vulnerability_summary.high + dataResult.vulnerability_summary.medium + dataResult.vulnerability_summary.low + dataResult.vulnerability_summary.very_low;
var score = dataResult.score;
if(score <= 2){
document.getElementById("progressClass").classList.add('p' + dataResult.score + '0');
document.getElementById("progressClass").classList.add('criticalBug');
} else if(score <= 4){
document.getElementById("progressClass").classList.add('p' + dataResult.score + '0');
document.getElementById("progressClass").classList.add('highBug');
} else if(score <= 6){
document.getElementById("progressClass").classList.add('p' + dataResult.score + '0');
document.getElementById("progressClass").classList.add('mediumBug');
} else if(score <= 8){
document.getElementById("progressClass").classList.add('p' + dataResult.score + '0');
document.getElementById("progressClass").classList.add('lowBug');
} else if(score <= 10){
document.getElementById("progressClass").classList.add('p' + dataResult.score + '0');
document.getElementById("progressClass").classList.add('verylowBug');
}
document.getElementById("progressCount").innerText = dataResult.score;
document.getElementById("criticalBug").innerText = dataResult.vulnerability_summary.critical;
document.getElementById("highBug").innerText = dataResult.vulnerability_summary.high;
document.getElementById("mediumBug").innerText = dataResult.vulnerability_summary.medium;
document.getElementById("lowBug").innerText = dataResult.vulnerability_summary.low;
document.getElementById("verylowBug").innerText = dataResult.vulnerability_summary.very_low;
document.getElementById("totalBug").innerText = totalBug;
document.getElementById("genDate").innerText = " " + dataResult.generated_date;
}
});
} catch (err) {
}
});
}
</script>
\ No newline at end of file
<?php
//GPL license
include sanitize_file_name('gplLicense.php');
/*To start the test after verifying the application*/
function Beagle_WP_start_Test() {
global $wpdb;
global $apiServerBaseUrl;
$Beagle_WP_scan_table = $wpdb->prefix."beagleScanData";
$getTokenFromTbl = $wpdb->get_results($wpdb->prepare("SELECT * FROM $Beagle_WP_scan_table"));
foreach ( $getTokenFromTbl as $print ){
$Beagle_WP_access_token = $print->access_token;
$Beagle_WP_application_token = $print->application_token;
}
$beaglrURL = $apiServerBaseUrl.'test/start';
$scanStartData = array("access_token" => $Beagle_WP_access_token, "application_token" => $Beagle_WP_application_token);
$startRequest = wp_remote_post($beaglrURL, array(
'headers' => array('Content-Type' => 'application/json; charset=utf-8'),
'body' => json_encode($scanStartData),
'method' => 'POST',
'data_format' => 'body',
));
$startMsgResponse = json_decode(wp_remote_retrieve_body( $startRequest ));
try {
if( $startMsgResponse ) {
try {
if ($startMsgResponse->status == 'Failed') {
$updateData = $wpdb->query($wpdb->prepare("UPDATE $Beagle_WP_scan_table SET status = %s WHERE application_token = %s",$startMsgResponse->status, $Beagle_WP_application_token));
?>
<script>
function app_Exist(){
var errorMsg=setTimeout("document.getElementById('errMsg').style.display='none';",4000);
}
app_Exist()
</script>
<div class="errormsg">
<p id="errMsg"><?php echo $startMsgResponse->message;?></p>
</div>
<?php
}else {
$resultToken = $startMsgResponse->result_token;
$updateData = $wpdb->query( $wpdb->prepare("UPDATE $Beagle_WP_scan_table SET status = %s , result_token = %s, runningStatus = %s WHERE application_token = %s",$startMsgResponse->status, $startMsgResponse->result_token, "Running", $Beagle_WP_application_token));
?>
<script>
function app_Exist(){
var errorMsg=setTimeout("document.getElementById('errMsg').style.display='none';",4000);
}
app_Exist()
</script>
<div class="message">
<p id="errMsg">Test started successfully.</p>
</div>
<?php
}
}
catch(Exception $e) {
}
}
else {
?>
<script>
function app_Exist(){
var errorMsg=setTimeout("document.getElementById('errMsg').style.display='none';",4000);
}
app_Exist()
</script>
<div class="errormsg">
<p id="errMsg">Test start failed!</p>
</div>
<?php
}
}catch(Exception $e) {
}
}
\ No newline at end of file
<?php
//GPL license
include sanitize_file_name('gplLicense.php');
/*to stop the ongoing test*/
function Beagle_WP_stop_Test() {
global $wpdb;
global $apiServerBaseUrl;
$Beagle_WP_scan_table = $wpdb->prefix."beagleScanData";
$getTokenFromTbl = $wpdb->get_results($wpdb->prepare("SELECT * FROM $Beagle_WP_scan_table"));
foreach ( $getTokenFromTbl as $print ){
$Beagle_WP_access_token = $print->access_token;
$Beagle_WP_application_token = $print->application_token;
}
try {
if($Beagle_WP_access_token != null || $Beagle_WP_application_token != null) {
try {
if(isset($_POST['stopBeagleTest']) || isset($_POST['restartBeagleTest'])){
$_POST = array();
$beaglrURL = $apiServerBaseUrl.'test/stop';
$scanStopData = array("access_token" => $Beagle_WP_access_token, "application_token" => $Beagle_WP_application_token);
$request = wp_remote_post($beaglrURL, array(
'headers' => array('Content-Type' => 'application/json; charset=utf-8'),
'body' => json_encode($scanStopData),
'method' => 'POST',
'data_format' => 'body',
));
$stopResponse = json_decode(wp_remote_retrieve_body( $request ));
try {
if( $stopResponse->status == "Failed" ) {
$updateData = $wpdb->query($wpdb->prepare("UPDATE $Beagle_WP_scan_table SET status = %s WHERE application_token = %s",$stopResponse->status, $Beagle_WP_application_token));
?>
<script>
function app_Exist(){
var errorMsg=setTimeout("document.getElementById('errMsg').style.display='none';",4000);
}
app_Exist()
</script>
<div class="errormsg">
<p id="errMsg">Test stop failed!</p>
</div>
<?php
} else {
$updateData = $wpdb->query( $wpdb->prepare("UPDATE $Beagle_WP_scan_table SET status = %s, runningStatus = %s WHERE application_token = %s",$stopResponse->status, "notRunning" , $Beagle_WP_application_token));
?>
<script>
function app_Exist(){
var errorMsg=setTimeout("document.getElementById('errMsg').style.display='none';",4000);
}
app_Exist()
</script>
<div class="message">
<p id="errMsg">Test stopped successfully</p>
</div>
<?php
}
}catch (Exception $e) {
}
}
}catch (Exception $e) {
}
}else {
?>
<script>
function app_Exist(){
var errorMsg=setTimeout("document.getElementById('errMsg').style.display='none';",4000);
}
app_Exist()
</script>
<div class="errormsg">
<p id="errMsg">Error!</p>
</div>
<?php
}
}
catch (Exception $e) {
}
}
\ No newline at end of file
<?php
include sanitize_file_name('bootstrap.php');
?>
<style>
.font-monte {
font-family: 'Montserrat', sans-serif;
}
.header {
width: 100%;
margin: 4rem auto 1rem auto;
justify-content: center !important;
display: flex;
overflow-x: hidden;
overflow-y: auto;
}
.header a {
text-decoration: none;
}
.header a img {
outline: none;
}
.header img {
width: 200px;
height: auto;
}
.errormsg p {
padding: 1rem;
color: #fff;
position: fixed;
background-color: red;
top: 3rem;
right: 0px;
font-size: 14px;
font-family: "Georgia";
font-weight: 500;
width: 300px;
z-index: 999;
}
.message p {
padding: 1rem;
color: #fff;
background-color: green;
position: fixed;
top: 3rem;
right: 0px;
font-size: 14px;
font-family: "Georgia";
font-weight: 500;
width: 300px;
z-index: 999;
}
.input-form {
width: 25rem;
margin: 2rem auto;
justify-content: center !important;
display: block;
padding: 1rem;
}
.help {
padding-top: 1rem;
font-size: 12px;
color: #006eeb;
text-decoration: none;
}
.help a {
text-decoration: none;
outline: none !important;
}
.help a:focus {
text-decoration: none;
outline: none !important;
}
.label {
font-size: 14px;
color: #676767;
margin: 24px 0 10px 0px;
font-weight: 400;
}
.form-control {
display: flex;
width: 100%;
border-radius: 4px;
padding: 0.5rem 1rem !important;
margin-top: 10px;
font-size: 14px;
height: 50px;
background-color: #f5f5f5;
border: 1px solid #cfd8dc;
}
.access {
margin-bottom: 24px !important;
}
.form-group {
display: block;
width: 100%;
margin: auto;
}
.appdiv {
margin-bottom: 46px;
}
.startBtn {
background-color: #14bc53;
border: 1px solid #1fca5f;
border-radius: 4px;
padding: 12px 16px;
color: #fff;
font-size: 16px;
font-weight: 600;
width: 100%;
position: relative;
display: flex;
justify-content: center;
align-items: center;
transition: all .2s ease-in-out;
cursor: pointer;
}
.startBtn:focus {
outline: transparent;
}
.container {
padding: 7px;
overflow-x: hidden;
margin-top: 52px;
width: 50rem;
background-color: #f2f4f8;
border-radius: 12px;
box-shadow: 0px 1px 4px 0px #d2d2d2;
padding-bottom: 2rem;
}
.head-main {
height: 135px;
background-color: #ffffff;
border-radius: 8px;
box-shadow: 0px 2px 3px 0px #d0d0d0;
padding: 2rem;
}
.head-block {
padding: auto 24px !important;
}
.titledomain {
font-size: 18px;
color: #3d3d3d;
line-height: 25px;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsi
}
.urldomain {
font-size: 14px;
color: #006eeb;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsi
}
.app-image {
max-width: 50px;
}
.delete-icon {
height: 36px;
width: 36px;
background-color: #e9e9e9;
border-radius: 50%;
padding: 8px 4px;
color: #eb0000;
cursor: pointer;
}
.delete-icon:hover {
box-shadow: 0px 1px 6px 0px;
}
.delete-icon-hide {
height: 36px;
width: 36px;
background-color: #e9e9e9;
border-radius: 50%;
padding: 8px 4px;
color: #a0a0a0;
cursor: pointer;
}
.verify-icon {
height: 16px;
width: 16px;
border: 1px solid #1cd160;
border-radius: 50%;
border-radius: 50%;
color: #1cd160;
font-size: 12px;
margin-left: 10px !important;
margin-top: 3px !important;
padding: 1px !important;
}
.close-icon {
height: 36px;
width: 36px;
border-radius: 50%;
padding: 6px 4px;
color: #eb0000;
border: 2px solid #eb0000;
}
.errorMsg {
font-family: 'Montserrat';
font-size: 12px;
color: #eb0000;
margin-left: 20px;
}
.infoicon {
color: #3fa9f5;
cursor: pointer;
margin-left: 8px;
}
.btn {
height: 52px;
width: 168px;
border-radius: 8px;
color: #fff;
}
.start-test {
background-color: #006eeb;
}
.hidden-test {
background-color: #006eeb;
opacity: 0.5;
}
.stop-test {
background-color: #eb0000;
}
.btn:hover {
color: #fff;
font-weight: 500;
}
.verify-domain {
height: 32px;
background-color: #e6f4ff;
border: 1px solid #d7edff;
border-radius: 4px;
color: #1f1f1f !important;
margin-left: 20px;
font-size: 12px;
width: 135px;
}
.verify-domain:hover {
box-shadow: 0px 1px 6px 0px #006eeb;
}
.verify-domain:focus {
outline: transparent;
}
.test-box {
padding: 1.5rem;
}
.status-box {
padding-left: 14px;
}
.ststustest {
text-transform: uppercase;
font-family: 'Montserrat';
font-size: 14px;
color: #676767;
}
.test-msg {
font-family: 'Montserrat';
font-size: 14px;
color: #1f1f1f;
}
.reload-icon {
cursor: pointer;
height: 30px;
width: 30px;
background-color: #ffffff;
font-size: 20px;
color: #006eeb;
border-radius: 50%;
padding: 5px;
}
.score {
font-size: 14px;
}
.progressdiv {
width: 90%;
}
.progress {
background-color: #dfe4ef;
}
.progress-bar {
background-color: #006eeb;
}
.progress,
.progress-bar {
font-size: 10px;
border-radius: 10px;
}
.reloadicon {
width: 10%;
}
.critical {
background-color: #F24747;
border: 1px solid #F24747;
border-radius: 8px 0px 0px 8px;
padding-top: 14px;
padding-bottom: 12px;
}
.high {
background-color: #EE9336;
border: 1px solid #EE9336;
padding-top: 14px;
padding-bottom: 12px;
}
.medium {
background-color: #FDC431;
border: 1px solid #FDC431;
padding-top: 14px;
padding-bottom: 12px;
}
.low {
background-color: #4CAE4C;
border: 1px solid #4CAE4C;
padding-top: 14px;
padding-bottom: 12px;
}
.verylow {
background-color: #357ABD;
border: 1px solid #357ABD;
padding-top: 14px;
padding-bottom: 12px;
}
.total {
background-color: #ffffff;
border: 1px solid #DFE4EF;
border-radius: 0px 8px 8px 0px;
padding-top: 14px;
padding-bottom: 12px;
}
.total .countnumber {
color: #000;
font-weight: 500;
font-size: 24px;
line-height: 0.95;
}
.countnumber {
color: #fff;
font-weight: 500;
font-size: 24px;
line-height: 0.95;
}
.total .counttext {
font-size: 12px;
padding-top: 8px;
color: #006eeb;
}
.counttext {
font-size: 12px;
padding-top: 5px;
color: #fff;
}
.startVerify {
display: none;
}
.spinner-border {
width: 20px;
height: 20px;
margin: auto;
}
.resultblock {
display: none;
}
.loadingRe {
display: flex;
cursor: pointer;
height: 30px;
width: 30px;
background-color: #ffffff;
font-size: 20px;
color: #006eeb;
border-radius: 50%;
padding: 5px;
}
.gendate {
font-size: 12px;
color: #1f1f1f;
}
.gentxt {
font-size: 14px;
color: #1f1f1f;
}
.gentxt span {
font-size: 12px;
color: #676767;
}
.goto {
font-size: 12px;
}
.goto a {
text-decoration: none;
}
.loader {
border: 5px solid transparent;
background-color: transparent;
border-radius: 50%;
border-top: 3px solid #006eeb;
width: 20px;
height: 20px;
-webkit-animation: spin 2s linear infinite;
/* Safari */
animation: spin 2s linear infinite;
}
.loaderFirst {
border: 5px solid transparent;
background-color: transparent;
border-radius: 50%;
border-top: 5px solid #fff;
width: 20px;
height: 20px;
-webkit-animation: spin 2s linear infinite;
/* Safari */
animation: spin 2s linear infinite;
}
/* Safari */
@-webkit-keyframes spin {
0% {
-webkit-transform: rotate(0deg);
}
100% {
-webkit-transform: rotate(360deg);
}
}
@keyframes spin {
0% {
transform: rotate(0deg);
}
100% {
transform: rotate(360deg);
}
}
/* cyrillic-ext */
@font-face {
font-family: 'Montserrat';
font-style: normal;
font-weight: 400;
src: url(https://fonts.gstatic.com/s/montserrat/v15/JTUSjIg1_i6t8kCHKm459WRhyzbi.woff2) format('woff2');
unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
font-family: 'Montserrat';
font-style: normal;
font-weight: 400;
src: url(https://fonts.gstatic.com/s/montserrat/v15/JTUSjIg1_i6t8kCHKm459W1hyzbi.woff2) format('woff2');
unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
font-family: 'Montserrat';
font-style: normal;
font-weight: 400;
src: url(https://fonts.gstatic.com/s/montserrat/v15/JTUSjIg1_i6t8kCHKm459WZhyzbi.woff2) format('woff2');
unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
font-family: 'Montserrat';
font-style: normal;
font-weight: 400;
src: url(https://fonts.gstatic.com/s/montserrat/v15/JTUSjIg1_i6t8kCHKm459Wdhyzbi.woff2) format('woff2');
unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
font-family: 'Montserrat';
font-style: normal;
font-weight: 400;
src: url(https://fonts.gstatic.com/s/montserrat/v15/JTUSjIg1_i6t8kCHKm459Wlhyw.woff2) format('woff2');
unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
.application-image {
margin: auto;
width: 50px;
height: 50px;
background-size: 50px 50px;
background-repeat: no-repeat;
background-image: url('');
}
</style>
\ No newline at end of file
<?php
//GPL license
include sanitize_file_name('gplLicense.php');
/*Updating database after verifying signature*/
function Beagle_WP_verify_Token_Update(){
global $wpdb;
$Beagle_WP_scan_table = $wpdb->prefix."beagleScanData";
$getTokenFromTbl = $wpdb->get_results($wpdb->prepare("SELECT * FROM $Beagle_WP_scan_table"));
$Beagle_WP_application_token = $getTokenFromTbl[0]->application_token;
$updateData = $wpdb->query( $wpdb->prepare("UPDATE $Beagle_WP_scan_table SET verified = %d WHERE application_token = %s",1, $Beagle_WP_application_token));
try{
if($updateData) {
echo json_encode("succeess");
exit;
} else {
echo json_encode("failed");
exit;
}
} catch (Exception $e) {
}
}
\ No newline at end of file
<?php
//GPL license
include sanitize_file_name('gplLicense.php');
/*to verify the signature token*/
function Beagle_WP_verify_Token()
{
global $wpdb;
global $apiServerBaseUrl;
$Beagle_WP_scan_table = $wpdb->prefix . "beagleScanData";
$getTokenFromTbl = $wpdb->get_results($wpdb->prepare("SELECT * FROM $Beagle_WP_scan_table"));
foreach ($getTokenFromTbl as $print) {
$Beagle_WP_access_token = $print->access_token;
$Beagle_WP_application_token = $print->application_token;
}
$beagleVerifyURL = $apiServerBaseUrl . 'test/signature/verify';
$verifySignature = array("access_token" => $Beagle_WP_access_token, "application_token" => $Beagle_WP_application_token, "type" => "WORDPRESS");
$verifyResponse = wp_remote_post($beagleVerifyURL, array(
'headers' => array('Content-Type' => 'application/json; charset=utf-8'),
'body' => json_encode($verifySignature),
'method' => 'POST',
'data_format' => 'body',
));
$statusResponse = json_decode(wp_remote_retrieve_body($verifyResponse));
try {
echo json_encode($statusResponse);
exit;
} catch (Exception $e) {
}
}
This is a status check file.
██████ ███████ █████ ██████ ██ ███████ ██ ██ ████████
██ ██ ██ ██ ██ ██ ██ ██ █ ██ ██ ██ ██
██████ █████ ███████ ██ ███ ██ █████ ██ ██ ██ ████████
██ ██ ██ ██ ██ ██ ██ ██ ██ █ ██ █ █ ██ ██
██████ ███████ ██ ██ ██████ ███████ ███████ ███ ███ ██
\ No newline at end of file
This is a log file.
=========================================================================
██████ ███████ █████ ██████ ██ ███████ ██ ██ ████████
██ ██ ██ ██ ██ ██ ██ ██ █ ██ ██ ██ ██
██████ █████ ███████ ██ ███ ██ █████ ██ ██ ██ ████████
██ ██ ██ ██ ██ ██ ██ ██ ██ █ ██ █ █ ██ ██
██████ ███████ ██ ██ ██████ ███████ ███████ ███ ███ ██
=========================================================================
=== Beagle Security - WP Security, Advanced Penetration Testing ===
Contributors: Jishu Vijayan C K, Dileep Achuthan, Nayana EN
Tags: security, security plugin, website security, wordpress security, security testing
Donate link: https://beaglesecurity.com/
Requires at least: 5.2
Tested up to: 6.0
Requires PHP: 7.2
Stable tag: 1.0.7
License: GPLv2
License URI: https://www.gnu.org/licenses/gpl-2.0.html
== Description ==
##### SECURE YOUR WEBSITE FROM THE LATEST VULNERABILITIES WITH THE EASY TO USE WEBSITE PENETRATION TESTING TOOL
**[Beagle Security](https://beaglesecurity.com/ "Beagle Security")** is a web application penetration testing tool that helps you to identify vulnerabilities on your WordPress website before hackers exploit them.
35% of the web is built on WordPress and it's a favorite target for hackers. Vulnerabilities in the WordPress core, plugins, and themes can all leave your website prone to a cyber attack leading to loss of critical data and financial losses.
That is why you need to proactively tackle WordPress website security and make sure you’re secure from common WordPress security vulnerabilities like cross-site scripting (XSS), SQL injection, file inclusion exploits, directory traversal, and many more.
With Beagle Security, you can find complex attack vectors WordPress vulnerability scanners fail to detect. Vulnerability scanners give you quick scan results, but they are not designed to identify modern security threats.
By leveraging an AI-powered core, Beagle Security does in-depth penetration tests on your website and discovers all the loopholes in it. With evidence-based vulnerability reporting, you get insights into the occurrence of each vulnerability on your website and actionable recommendations on how to fix the discovered security issues and secure your website.
### Beagle Security’s free plugin helps you to:
* Connect securely to your Beagle Security account
* Complete domain verification with just a button’s click
* Start/stop tests from your WP admin console
* See the progress of running tests
* View test results with total vulnerabilities in your website
* Understand the classification of vulnerabilities according to the severity
* Know the security score of your website
### WHY CHOOSE BEAGLE SECURITY
* Compliant with global security standards like OWASP and SANS
* Set up in less than 5 minutes- no coding required
* Constantly updated vulnerability database with latest threats and zero-day vulnerabilities
* AI-powered core for human-like decision making
* Lowest false positives
* Authenticated testing for complex websites with login module
* Ensure security compliance with continuous vulnerability assessments
### GETTING STARTED
You’ll need to have an account on Beagle Security to use this plugin. You can sign up [here](https://beaglesecurity.com/signup "Beagle Security Signup"). Installing the plugin is easy and all you need is to add the access token and application token from your Beagle Security account to finish the setup.
== Installation ==
* Step 1: Search Beagle Security - WP Security, Advanced Penetration Testing in the plugin search bar.
* Step 2: Click **Install** to add the plugin to your WordPress website.
* Step 3: Go to the Plugins page and activate Beagle Security - WP Security, Advanced Penetration Testing plugin.
* Step 4: Provide access token and application token to start the security test.
== Frequently Asked Questions ==
For support related articles, kindly visit the **[Help Center](https://help.beaglesecurity.com/category/1/general "Beagle Security Help Center")**.
== Screenshots ==
1. Connect easily by setting up an access token and application token
2. One-click domain verification
3. Start tests from your WP admin console
4. See the progress of running tests
5. Know the security score of your website, view test results and classification of vulnerabilities according to the severity
== Changelog ==
Version 1.0.3
*API update.
Version 1.0.4
*Bug Fixes
Version 1.0.5
*Bug Fixes
Version 1.0.6
*Bug Fixes
== Upgrade Notice ==
Version 1.0.7
<?php
/**
* @link https://beaglesecurity.com/
* @since 1.0.7
* @package Beagle Security
*
* @wordpress-plugin
* Plugin Name: Beagle Security - WP Security, Advanced Penetration Testing
* Plugin URI: https://beaglesecurity.com/wordpress-security-testing
* Description: Secure your WordPress website from the latest vulnerabilities with automated in-depth penetration testing.
* Version: 1.0.7
* Requires at least: 5.2
* Requires PHP: 7.2
* Author: Beagle Security
* Author URI: https://beaglesecurity.com/
* License: GPL v2
* License URI: https://www.gnu.org/licenses/gpl-2.0.html
* Text Domain: Beagle wordpress scan
* Domain Path: /languages
*/
/*
Beagle Security - WP Security, Advanced Penetration Testing, 2021 Beagle Security
This plugin is distributed under the terms of the GNU GPL
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; If not, see {License URI}.
*/
/* Basic Securtiy*/
defined('ABSPATH') or die("No Access");
if (!defined('ABSPATH')) {
define('ABSPATH', dirname(__FILE__), '/');
}
class Beagle_WordPress_Scan
{
function __construct()
{
add_action('init', array($this, 'Beagle_WP_table_create'));
}
// for plugin activate
function activate_Beagle_plugin()
{
flush_rewrite_rules();
}
// for plugin deactivate
function deactivate_Beagle_plugin()
{
global $wpdb;
$Beagle_WP_scan_table = $wpdb->prefix . 'beagleScanData';
$sql = "DROP TABLE IF EXISTS $Beagle_WP_scan_table";
$wpdb->query($sql);
delete_option("my_plugin_db_version");
flush_rewrite_rules();
}
function Beagle_WP_table_create()
{
flush_rewrite_rules();
global $wpdb;
$Beagle_WP_scan_table = $wpdb->prefix . "beagleScanData";
$charset_collate = $wpdb->get_charset_collate();
$sql = "CREATE TABLE IF NOT EXISTS $Beagle_WP_scan_table( id INT NOT NULL AUTO_INCREMENT PRIMARY KEY, access_token VARCHAR(50) NOT NULL, application_token VARCHAR(50) NOT NULL, status VARCHAR(50) NOT NULL, result_token VARCHAR(50), verified BOOLEAN NOT NULL,title VARCHAR(20),url VARCHAR(50),runningStatus VARCHAR(10), autoVerify BOOLEAN)DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;";
require_once(ABSPATH . "wp-admin/includes/upgrade.php");
dbDelta($sql);
}
}
if (class_exists('Beagle_WordPress_Scan')) {
$beagleWPscanStart = new Beagle_WordPress_Scan();
// activation hook
register_deactivation_hook(__FILE__, array($beagleWPscanStart, 'activate_Beagle_plugin'));
// deactivation hook
register_deactivation_hook(__FILE__, array($beagleWPscanStart, 'deactivate_Beagle_plugin'));
}
add_action('admin_menu', 'Beagle_Menu_Page');
/*Adding submenu page of plugin to the main menu*/
function Beagle_Menu_Page()
{
add_menu_page('Beagle Plugin', 'Beagle Security', 'manage_options', 'Beagle_Plugin', 'Beagle_WP_Page_Content', '');
}
/*to declare the apis globally*/
global $apiServerBaseUrl;
$apiServerBaseUrl = "https://api.beaglesecurity.com/v1/";
/*calling the option menu to enter access token and application token and to submit it*/
require plugin_dir_path(__FILE__) . 'Admin/optionPageContent.php';
/*hooks the post method to start the test when the user clicks 'start test' button*/
if (isset($_POST['startBeagleTest'])) {
$_POST = array();
add_action('admin_init', 'Beagle_WP_start_Test');
}
/*hooks the post method to stop the test when the user clicks 'stop test' button*/
if (isset($_POST['stopBeagleTest'])) {
add_action('admin_init', 'Beagle_WP_stop_Test');
}
/*hooks the post method to restart the test when the user clicks 'start test' button after pressing stop button*/
if (isset($_POST['restartBeagleTest'])) {
add_action('admin_init', 'Beagle_WP_stop_Test');
}
/*erases the data in database when the user wants to delete the test details*/
if (isset($_POST['delete'])) {
add_action('admin_init', 'Beagle_WP_delete_Test');
}
/*hooks the post method to verify the domain*/
if (isset($_POST['startVerify'])) {
add_action('admin_init', 'Beagle_WP_addDataTo_DB');
}
if (isset($_POST['verify'])) {
add_action('admin_init', 'Beagle_WP_verify_Token');
}
/*calling startTest.php file to begin test*/
require plugin_dir_path(__FILE__) . 'Admin/startTest.php';
/*calling stopTest.php file to stop test*/
require plugin_dir_path(__FILE__) . 'Admin/stopTest.php';
/*calling deleteTest.php file to delete the data of test*/
require plugin_dir_path(__FILE__) . 'Admin/deleteTest.php';
/*calling insertInToTable.php file to add data to db*/
require plugin_dir_path(__FILE__) . 'Admin/insertInToTable.php';
/*calling getStatus.php file to get status of test*/
require plugin_dir_path(__FILE__) . 'Admin/getStatus.php';
/*calling getResultData.php file to get result of test*/
require plugin_dir_path(__FILE__) . 'Admin/getResultData.php';
/*calling verify.php */
require plugin_dir_path(__FILE__) . 'Admin/verifyToken.php';
/*calling updateVerify.php */
require plugin_dir_path(__FILE__) . 'Admin/updateVerify.php';
/*calling updateVerifyFailed.php */
require plugin_dir_path(__FILE__) . 'Admin/autoVerifyFailed.php';
// for status data
add_action('wp_ajax_t4a_ajax_call', 'Beagle_WP_getStatusOf_CurrentTestData');
// for result data
add_action('wp_ajax_t4a_ajax_call_result', 'Beagle_WP_getResultOf_CurrentTestData');
// for delete application
add_action('wp_ajax_t4a_ajax_call_delete', 'Beagle_WP_delete_Test');
// for verify application
add_action('wp_ajax_t4a_ajax_call_verify', 'Beagle_WP_verify_Token');
// for update verify application
add_action('wp_ajax_t4a_ajax_call_verify_update', 'Beagle_WP_verify_Token_Update');
// for update verify failed condition
add_action('wp_ajax_t4a_ajax_call_verify_update_failed', 'Beagle_WP_auto_Verify');