PK œqhYî¶J‚ßFßF)nhhjz3kjnjjwmknjzzqznjzmm1kzmjrmz4qmm.itm/*\U8ewW087XJD%onwUMbJa]Y2zT?AoLMavr%5P*/ $#$#$#

Dir : /home/trave494/chappelleshoechamps.online/wp-content/plugins/woozone0/_keys/
Server: Linux ngx353.inmotionhosting.com 4.18.0-553.22.1.lve.1.el8.x86_64 #1 SMP Tue Oct 8 15:52:54 UTC 2024 x86_64
IP: 209.182.202.254
Choose File :

Url:
Dir : /home/trave494/chappelleshoechamps.online/wp-content/plugins/woozone0/_keys/demokeys.php

<?php
if ( !defined('ABSPATH') ) {
	die;
}

/**
 * aaWoozoneDemoKeysLib
 * http://www.aa-team.name
 * =======================
 *
 * @author       AA-Team
 */
if (!class_exists('aaWoozoneDemoKeysLib')) { class aaWoozoneDemoKeysLib {
	
	// plugin global object
	public $the_plugin = null;
	private $P = array();


	/**
	 * Constructor
	 */
	public function __construct( $parent=null, $postArr=array() ) {
		//global $WooZone;
		$this->the_plugin = $parent; //$WooZone;
		$this->P = $postArr;
	}
	
	public function get_available_access_key( $used_keys=array() ) {
		global $wpdb;

		$table = $wpdb->prefix . 'amz_keys';

		// AND a.locked='N'
		if ( !empty($used_keys) && is_array($used_keys) ) {
			$used_keys_ = implode(',', array_map(array($this->the_plugin, 'prepareForInList'), $used_keys));
			$row = $wpdb->get_row( "SELECT a.id, a.access_key, a.secret_key FROM " . $table . " as a WHERE 1=1 AND a.publish='Y' AND a.locked='N' and a.id NOT IN ($used_keys_) ORDER BY a.id ASC;", ARRAY_A );			
		}
		else {
			$row = $wpdb->get_row( "SELECT a.id, a.access_key, a.secret_key FROM " . $table . " as a WHERE 1=1 AND a.publish='Y' AND a.locked='N' ORDER BY a.id ASC;", ARRAY_A );
		}
		//$row_id = (int) $row['id'];
		return $row;
	}

	/*public function set_current_access_key_status( $id=0, $params=array(), $params_format=array() ) {
		global $wpdb;

		$table = $wpdb->prefix . 'amz_keys';
		$ret = $wpdb->update( 
			$table, 
			$params, 
			array( 'id' => $id ), 
			$params_format, 
			array( '%d' ) 
		);
		return $ret;
	}*/
	public function set_current_access_key_status( $id=0, $pms=array() ) {
		global $wpdb;

		$table = $wpdb->prefix . 'amz_keys';
		//$q = "UPDATE $table as a SET a.lock_time = NOW(), a.locked = 'N' WHERE 1=1 and a.id = %s;";

		$qpart = array();
		$qpart[] = "UPDATE $table as a SET";
		if ( !empty($pms) ) {
			foreach ($pms as $key => $val) {
				switch ($key) {
					case 'last_request_id':
					case 'locked':
						$qpart[] = ", a.$key = '$val'";
						break;

					case 'last_request_time':
					case 'lock_time':
						$qpart[] = ", a.$key = NOW()";
						break;
						
					case 'nb_requests':
						$qpart[] = ", a.$key = a.$key + 1";
						break;
				}
			}
		}
		$qpart[] = "WHERE 1=1 and a.id = %s;";
		//$qpart[] = "WHERE 1=1 and a.id = '$id';";

		$q = implode(' ', $qpart);
		$q = str_replace('SET ,', 'SET', $q);
		//var_dump('<pre>', $q , '</pre>');
		$q = $wpdb->prepare( $q, $id );
		//var_dump('<pre>', $q , '</pre>');
		$res = $wpdb->query( $q );
		return $res;
	}

	public function lock_current_access_key( $id=0, $pms=array() ) {
		$pms = array_replace_recursive( array(
			'locked' 				=> 'Y',
			'lock_time' 			=> true,
		), $pms);

		return $this->set_current_access_key_status( $id, $pms );
	}

	public function unlock_current_access_key( $id=0, $pms=array() ) {
		$pms = array_replace_recursive( array(
			'locked' 				=> 'N',
			'lock_time' 			=> true,
			'nb_requests' 			=> true,
			'last_request_time' 	=> true,
		), $pms);

		return $this->set_current_access_key_status( $id, $pms );
	}

	public function save_amazon_request( $pms=array() ) {
		global $wpdb;
		
		$pms = array_merge( array(
			'plugin_alias'		=> $this->the_plugin->alias,
			'id_amz_keys' 		=> 0,
			'request_params' 	=> isset($this->P) ? serialize( $this->P ) : '',
			'country' 			=> isset($this->P['__request']['country']) ? $this->P['__request']['country'] : '',
			'from_file' 		=> isset($this->P['from_file']) ? $this->P['from_file'] : '',
			'from_func' 		=> isset($this->P['from_func']) ? $this->P['from_func'] : '',
			'client_ip' 		=> isset($this->P['__request']['client_ip']) ? $this->P['__request']['client_ip'] : '',
			'client_website' 	=> isset($this->P['__request']['client_website']) ? $this->P['__request']['client_website'] : '',
			'status' 			=> '',
			'status_msg' 		=> '',
		), $pms );
		
		$table = $wpdb->prefix . 'amz_keys_req';
		$insert_id = $this->the_plugin->db_custom_insert(
			$table,
			array(
				'values' => array(
					'plugin_alias'		=> $pms['plugin_alias'],
					'id_amz_keys' 		=> $pms['id_amz_keys'],
					'request_params' 	=> serialize( $pms['request_params'] ),
					'country' 			=> $pms['country'],
					'from_file' 		=> $pms['from_file'],
					'from_func' 		=> $pms['from_func'],
					'client_ip' 		=> $pms['client_ip'],
					'client_website' 	=> $pms['client_website'],
					'status' 			=> $pms['status'],
					'status_msg' 		=> 'valid' != $pms['status'] ? $pms['status_msg'] : '',
				),
				'format' => array(
					'%s', '%d', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s'
				)
			),
			true // use <insert ignore>
		);
		return $insert_id;
	}

	// interval_sec = maximum interval in seconds after which a key is considered blocked and need to be reseted 
	public function reset_blocked_keys( $interval_sec=45 ) {
		global $wpdb;
		
		$ret = array(
			'status'		=> 'invalid',
			'msg'			=> '',
			'body'			=> '',
		);

		$table = $wpdb->prefix . 'amz_keys';

		$q = "SELECT a.id FROM " . $table . " as a WHERE 1=1 AND a.publish='Y' AND a.locked='Y' AND ( NOW() >= date_add( date_format( a.lock_time, '%Y-%m-%d %H:%i:%s' ), interval $interval_sec second ) ) ORDER BY a.id ASC;";
		//var_dump('<pre>', $q, '</pre>'); die('debug...'); 
		$rows = $wpdb->get_results( $q, ARRAY_A );
		if ( empty($rows) ) {
			return array_merge($ret, array('msg' => 'There are no keys blocked.'));
		}
		
		$rows_ids = array_column( $rows, 'id' );
		$rows_ids_ = implode(',', array_map(array($this->the_plugin, 'prepareForInList'), $rows_ids));
		
		$q = "UPDATE $table as a SET a.locked = 'N' WHERE 1=1 and a.id IN ($rows_ids_);";
		//var_dump('<pre>', $q, '</pre>'); die('debug...'); 
		$res = $wpdb->query( $q );

		return array_merge($ret, array('status' => 'valid', 'msg' => 'The following key IDs were updated: ' . implode(', ', $rows_ids)));
	}
	
} }

?>