HEX
Server: Apache/2.4.65 (Debian)
System: Linux wordpress-7cb4c6b6f6-dr82f 5.15.0-131-generic #141-Ubuntu SMP Fri Jan 10 21:18:28 UTC 2025 x86_64
User: www-data (33)
PHP: 8.3.27
Disabled: NONE
Upload Files
File: /var/www/html/wp-content/plugins/jet-engine/includes/components/relations/storage/manager.php
<?php
namespace Jet_Engine\Relations\Storage;

/**
 * Database manager class
 */

// If this file is called directly, abort.
if ( ! defined( 'WPINC' ) ) {
	die;
}

/**
 * Define Manager class
 */
class Manager {

	private $default_db      = null;
	private $default_meta_db = null;
	private $db_instances    = array();

	/**
	 * Get default DB
	 *
	 * @return [type] [description]
	 */
	public function get_default_db() {

		if ( ! $this->default_db ) {
			$this->default_db = $this->get_db_instance( 'default', $this->get_db_schema() );
		}

		return $this->default_db;

	}

	/**
	 * Get default DB
	 *
	 * @return [type] [description]
	 */
	public function get_default_meta_db() {

		if ( ! $this->default_meta_db ) {
			$this->default_meta_db = $this->get_db_instance( 'default_meta', $this->get_meta_db_schema() );
		}

		return $this->default_meta_db;

	}

	/**
	 * Returns new DB instance
	 * @param  string $table  [description]
	 * @param  array  $schema [description]
	 * @return [type]         [description]
	 */
	public function get_db_instance( $table = 'default', $schema = array() ) {

		if ( ! class_exists( '\Jet_Engine\Relations\Storage\DB' ) ) {
			require_once jet_engine()->relations->component_path( 'storage/db.php' );
		}

		$this->db_instances[ $table ] = new DB( $table, $schema );

		$keys = false;

		switch ( $table ) {
			case 'default':
				$keys = 'KEY parent_id ( rel_id, parent_object_id ), KEY child_id ( rel_id, child_object_id )';
				break;

			case 'default_meta':
				$keys = 'KEY meta_id ( rel_id, parent_object_id, child_object_id )';
				break;

			default:
				if ( false !== strpos( $table, '_meta' ) ) {
					$keys = 'KEY meta_id ( parent_object_id, child_object_id )';
				} else {
					$keys = 'KEY parent_id ( parent_object_id ), KEY child_id ( child_object_id )';
				}

				break;
		}

		$this->db_instances[ $table ]->set_table_keys( $keys );

		return $this->db_instances[ $table ];
	}

	/**
	 * Returns schema of relations table
	 *
	 * @return [type] [description]
	 */
	public function get_db_schema() {
		return array(
			'rel_id'           => 'VARCHAR(40)',
			'parent_rel'       => 'INT',
			'parent_object_id' => 'BIGINT',
			'child_object_id'  => 'BIGINT',
		);
	}

	/**
	 * Returns schema of relations meta table
	 *
	 * @return [type] [description]
	 */
	public function get_meta_db_schema() {
		return array(
			'rel_id'           => 'VARCHAR(40)',
			'parent_object_id' => 'BIGINT',
			'child_object_id'  => 'BIGINT',
			'meta_key'         => 'TEXT',
			'meta_value'       => 'TEXT',
		);
	}

}