Uname: Linux p3plzcpnl499967.prod.phx3.secureserver.net 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
Software: Apache
PHP version: 8.2.30 [ PHP INFO ] PHP os: Linux
Server Ip: 208.109.40.231
Your Ip: 216.73.216.26
User: nayff91c5tsx (10005085) | Group: nayff91c5tsx (10005085)
Safe Mode: OFF
Disable Function:
NONE

name : bookings-meta.php
<?php

namespace JET_ABAF\DB\Tables;

defined( 'ABSPATH' ) || exit; // Exit if accessed directly.

class Bookings_Meta extends Base {

	/**
	 * Return table slug.
	 *
	 * @since 3.3.0
	 *
	 * @return string
	 */
	public function table_slug() {
		return 'bookings_meta';
	}

	/**
	 * Schema.
	 *
	 * Returns bookings meta table columns schema.
	 *
	 * @since  3.3.0
	 *
	 * @return string[]
	 */
	public function schema() {
		return [
			'ID'         => 'bigint(20) NOT NULL AUTO_INCREMENT',
			'booking_id' => 'bigint(20)',
			'meta_key'   => 'text',
			'meta_value' => 'longtext',
		];
	}

	/**
	 * Returns table schema.
	 *
	 * @since 3.3.0
	 *
	 * @return string
	 */
	public function get_table_schema() {

		$default_columns = $this->schema();
		$columns_schema  = '';

		foreach ( $default_columns as $column => $desc ) {
			$columns_schema .= $column . ' ' . $desc . ',';
		}

		$table           = $this->table();
		$charset_collate = $this->wpdb()->get_charset_collate();

		return "CREATE TABLE $table ( $columns_schema PRIMARY KEY (ID) ) $charset_collate;";

	}

	/**
	 * Sets a meta for a booking.
	 *
	 * @since 3.3.0
	 *
	 * @param int|string $booking_id Booking ID.
	 * @param string     $meta_key   Booking meta key name.
	 * @param mixed      $meta_value Booking meta value.
	 */
	public function set_meta( $booking_id, $meta_key, $meta_value ) {

		$table  = $this->table();
		$exists = $this->wpdb()->get_results( "SELECT ID FROM $table WHERE booking_id = $booking_id AND meta_key = '$meta_key' LIMIT 1" );

		if ( ! empty( $exists ) ) {
			$this->update( [ 'meta_value' => $meta_value ], [ 'ID' => $exists[0]->ID ] );
		} else {
			$this->insert( [ 'booking_id' => $booking_id, 'meta_key' => $meta_key, 'meta_value' => $meta_value ] );
		}

	}

	/**
	 * Gets a meta for a booking.
	 *
	 * @since 3.3.0
	 *
	 * @param int|string $booking_id Booking ID.
	 * @param string     $meta_key   Booking meta key name.
	 *
	 * @return false
	 */
	public function get_meta( $booking_id, $meta_key ) {

		$table = $this->table();
		$item  = $this->wpdb()->get_results( "SELECT meta_value FROM $table WHERE booking_id = $booking_id AND meta_key = '$meta_key' LIMIT 1" );

		if ( empty( $item ) ) {
			return false;
		} else {
			return $item[0]->meta_value;
		}

	}

}
© 2026 GrazzMean