HEX
Server: Apache/2.4.6 (CentOS) OpenSSL/1.0.2k-fips PHP/8.0.30
System: Linux multiplicar 3.10.0-1160.102.1.el7.x86_64 #1 SMP Tue Oct 17 15:42:21 UTC 2023 x86_64
User: root (0)
PHP: 8.0.30
Disabled: NONE
Upload Files
File: /var/www/html/digisferach.sumar.com.py/wp-content/plugins/peepso/classes/like.php
<?php

class PeepSoLike
{
	const TABLE = 'peepso_likes';

	private $like_count = array();
    private $user_liked = array();

    private static $instance;

    public static function get_instance() {
        if(!self::$instance) {
            self::$instance = new self();
        }

        return self::$instance;
    }


    public function __construct() {}


	public function add_like($item_id, $module_id, $user_id, $type = 1, $act_id = 0)
	{
	    $this->like_count = array();
	    $this->user_liked = array();

		$data = array(
			'like_user_id' => intval($user_id),			// user_id adding the like
			'like_external_id' => intval($item_id),		// id of item being liked; i.e. post_id
			'like_module_id' => intval($module_id),
			'like_type' => intval($type),
		);

		global $wpdb;
		$wpdb->hide_errors();							// turn off errors, in case someone likes something twice

		if($wpdb->insert($wpdb->prefix . self::TABLE, $data)) {

			// increase like ranking on activity
			if ($act_id != 0 && $module_id == PeepSoActivity::MODULE_ID) {
				$rank = new PeepSoActivityRanking();
				$rank->add_like_count($act_id);
			}

			// fire the action
			do_action('peepso_action_like_add', (object) $data);

			$wpdb->show_errors();
			return (TRUE);
		}

		$wpdb->show_errors();
		return (FALSE);
	}


	/*
	 * Removes a like record from the database
	 * @param int $item_id The item that was liked, such as a post_id
	 * @param int $module_id The module that is removing the like, such as Activity Stream (MODULE_ID = 1)
	 * @param int $user_id The user id of the person removing the like
	 * $param int $type The type of the like; can be different for each module. Example: Activity Stream
	 *				can use 1 for 'likes' and 2 for 'unlikes'
	 * $param int act_id The activity id used for activity ranking
	 * @return Boolean TRUE for successfully adding the like
	 */
	public function remove_like($item_id, $module_id, $user_id, $type = 1, $act_id = 0)
	{
        $this->like_count = array();
        $this->user_liked = array();
        
        $data = array(
			'like_user_id' => intval($user_id),
			'like_external_id' => intval($item_id),
			'like_module_id' => intval($module_id),
			'like_type' => intval($type),
		);

		global $wpdb;
		$wpdb->hide_errors();							// turn off errors, in case of removing something not there
		$res = $wpdb->delete($wpdb->prefix . self::TABLE, $data);
		
		// decrease like ranking on activity
		if ($act_id != 0 && $module_id == PeepSoActivity::MODULE_ID) {
			$rank = new PeepSoActivityRanking();
			$rank->add_like_count($act_id);
		}

		// fire the action
		do_action('peepso_action_like_remove', (object) $data);
		
		$wpdb->show_errors();
		return (TRUE);
	}


	/*
	 * Return number of "likes" found for a given item
	 * @param int $item_id the `like_external_id` column value
	 * @param int $module_id the module that the item id comes from
	 * @return int The number of records found
	 */
	public function get_like_count($item_id, $module_id = NULL, $type = NULL)
	{
	    $key = "$item_id|$module_id|$type";
	    if(!array_key_exists($key, $this->like_count)) {
            global $wpdb;

            $sql = $wpdb->prepare("SELECT COUNT(*) FROM `{$wpdb->prefix}" . self::TABLE . "` " . " WHERE `like_external_id`=%d ", $item_id);

            if (NULL !== $module_id)
                $sql .= $wpdb->prepare(" AND `like_module_id`=%d ", $module_id);
            else {
                // if module is NULL add a where condition and set module to a number
                // this allows us to keep the same parameter order in prepare()
                $module_id = 0;
                $sql .= $wpdb->prepare(" AND 0=%d ", $module_id);
            }

            if (NULL !== $type) {
                $sql .= $wpdb->prepare(" AND `like_type`=%d ", $type);
            }

            $res = $wpdb->get_var($sql);

            $this->like_count[$key] = (intval($res));
        }

        return $this->like_count[$key];
	}


	/*
	 * Return user_id and user_login values for all users that liked a specific item
	 * @param int $item_id the `like_external_id` column value
	 * @param int $module_id the module that the item id comes from
	 * @param int $type An optional type value for the item
	 * @return array A list of user ids and login names that liked the specified item
	 */
	public function get_like_names($item_id, $module_id, $type = NULL)
	{
		global $wpdb;
		$sql = $wpdb->prepare("SELECT `users`.`ID`, `users`.`user_login` " .
				" FROM `{$wpdb->prefix}" . self::TABLE . "` `like` " .
				" LEFT JOIN `{$wpdb->users}` `users` ON `users`.`ID`=`like`.`like_user_id` " .
				" WHERE `like_external_id`=%d AND `like_module_id`=%d ", $item_id, $module_id);

		if (NULL !== $type) {
            $sql .= $wpdb->prepare(" AND `like_type`=%d ", $type);
        }

		$res = $wpdb->get_results($sql);
		return ($res);
	}


	/*
	 * Return user_id and user_login values for all users that liked a specific item
	 * @param int $item_id the `like_external_id` column value
	 * @param int $module_id the module that the item id comes from	
	 * @param int $user_id The User ID of the person liking
	 * @return boolean TRUE or FALSE whether $user_id has liked $item_id
	 */
	public function user_liked($item_id, $module_id, $user_id)
	{
        $key = "$item_id|$module_id|$user_id";
        if(!array_key_exists($key, $this->user_liked)) {
            global $wpdb;
            $sql = "SELECT COUNT(*) AS `count` " .
                " FROM `{$wpdb->prefix}" . self::TABLE . "` `like` " .
                " WHERE `like_external_id`=%d AND `like_module_id`=%d AND `like_user_id`=%d";

            $count = $wpdb->get_var($wpdb->prepare($sql, $item_id, $module_id, $user_id));

            $this->user_liked[$key] = ($count > 0);
        }

        return $this->user_liked[$key];
	}


	/*
	 * Return likes by module
	 * @param int $module_id The module id from which the like came from
	 * @param array $date_range (optional) Where clause to be added
	 * @return array Count-date pair of number of likes per day
	 */
	public function get_likes_graph_data_by_module($module_id, $date_range = NULL)
	{
		global $wpdb;

		$base_query = '
			SELECT 
				COUNT(ID) AS `post_count`, DATE_FORMAT(`like_timestamp`, "%Y-%m-%d") AS `_post_date` 
				FROM `'. $wpdb->prefix . self::TABLE . '` pa 
				LEFT JOIN `'. $wpdb->posts . '`
					ON `pa`.`like_external_id` = `'. $wpdb->posts . '`.`ID`
				WHERE `pa`.`like_module_id` = %d ';

		if (is_array($date_range)) {
			$base_query .= ' AND (DATE_FORMAT(`like_timestamp`, "%Y-%m-%d") >= "' . $date_range['from'] . '" AND
				DATE_FORMAT(`like_timestamp`, "%Y-%m-%d") <= "' . $date_range['to'] . '") ';
		}

		$base_query .= ' GROUP BY `_post_date`';

		return $wpdb->get_results(
			$wpdb->prepare($base_query, $module_id)
		);
	}

	/*
	 * Return likes by module
	 * @param int $module_id The module id from which the like came from
	 * @param array $date_range (optional) Where clause to be added
	 * @return array Count-date pair of number of likes per day
	 */
	public function get_likes_graph_data($date_range = NULL)
	{
		global $wpdb;

		$base_query = '
			SELECT 
				COUNT(ID) AS `post_count`, DATE_FORMAT(`like_timestamp`, "%Y-%m-%d") AS `_post_date` 
				FROM `'. $wpdb->prefix . self::TABLE . '` pa 
				LEFT JOIN `'. $wpdb->posts . '`
					ON `pa`.`like_external_id` = `'. $wpdb->posts . '`.`ID` ';

		if (is_array($date_range)) {
			$base_query .= ' WHERE (DATE_FORMAT(`like_timestamp`, "%Y-%m-%d") >= "' . $date_range['from'] . '" AND
				DATE_FORMAT(`like_timestamp`, "%Y-%m-%d") <= "' . $date_range['to'] . '") ';
		}

		$base_query .= ' GROUP BY `_post_date`';

		return $wpdb->get_results(
			$base_query
		);
	}
}

// EOF