HEX
Server: LiteSpeed
System: Linux s166.bitcommand.com 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64
User: h340499 (1922)
PHP: 8.2.16
Disabled: exec,system,passthru,shell_exec,proc_close,proc_open,dl,popen,show_source,posix_kill,posix_mkfifo,posix_getpwuid,posix_setpgid,posix_setsid,posix_setuid,posix_setgid,posix_seteuid,posix_setegid,posix_uname
Upload Files
File: /home/h340499/public_html/wp-content/plugins/learnpress/inc/Databases/QuestionAnswersDB.php
<?php

namespace LearnPress\Databases;

use Exception;
use LearnPress\Filters\QuestionAnswersFilter;
use LP_Database;

if ( ! defined( 'ABSPATH' ) ) {
	exit; // Exit if accessed directly
}

/**
 * Class QuestionAnswersDB
 *
 * @instead of LP_Question_Answers_DB
 * @since 4.2.9
 * @version 1.0.1
 */
class QuestionAnswersDB extends DataBase {
	private static $_instance;

	protected function __construct() {
		parent::__construct();
	}

	public static function getInstance() {
		if ( is_null( self::$_instance ) ) {
			self::$_instance = new self();
		}

		return self::$_instance;
	}

	/**
	 * Get question answers
	 *
	 * @throws Exception
	 */
	public function get_question_answers( QuestionAnswersFilter $filter, &$total_rows = 0 ) {
		$filter->fields = array_merge( $filter->all_fields, $filter->fields );

		if ( empty( $filter->collection ) ) {
			$filter->collection = $this->tb_lp_question_answers;
		}

		if ( empty( $filter->collection_alias ) ) {
			$filter->collection_alias = 'qa';
		}

		// By question answer id
		if ( ! empty( $filter->question_answer_id ) ) {
			$filter->where[] = $this->wpdb->prepare( "AND {$filter->collection_alias}.question_answer_id = %d", $filter->question_answer_id );
		}

		// By question id
		if ( ! empty( $filter->question_id ) ) {
			$filter->where[] = $this->wpdb->prepare( "AND {$filter->collection_alias}.question_id = %d", $filter->question_id );
		}

		// By title
		if ( ! empty( $filter->title ) ) {
			$filter->where[] = $this->wpdb->prepare( "AND {$filter->collection_alias}.title LIKE %s", '%' . $this->wpdb->esc_like( $filter->title ) . '%' );
		}

		return $this->execute( $filter, $total_rows );
	}

	/**
	 * Get last answer number order on question.
	 *
	 * @throws Exception
	 */
	public function get_last_number_order( int $question_id = 0 ): int {
		$query = $this->wpdb->prepare(
			"SELECT MAX(`order`)
			FROM $this->tb_lp_question_answers
			WHERE question_id = %d",
			$question_id
		);

		$number_order = intval( $this->wpdb->get_var( $query ) );

		$this->check_execute_has_error();

		return $number_order;
	}
}