File "view.html.php"
Full Path: /home/romayxjt/public_html/wp-content/plugins/vikbooking/admin/views/importbftpp/view.html.php
File size: 21.97 KB
MIME-type: text/x-php
Charset: utf-8
<?php
/**
* @package VikBooking
* @subpackage com_vikbooking
* @author Alessio Gaggii - e4j - Extensionsforjoomla.com
* @copyright Copyright (C) 2018 e4j - Extensionsforjoomla.com. All rights reserved.
* @license GNU General Public License version 2 or later; see LICENSE
* @link https://vikwp.com
*/
defined('ABSPATH') or die('No script kiddies please!');
// import Joomla view library
jimport('joomla.application.component.view');
class VikBookingViewImportbftpp extends JViewVikBooking
{
function display($tpl = null)
{
// Set the toolbar
$this->addToolBar();
$dbo = JFactory::getDbo();
// make sure there is at least one room-type in order to allow the bookings import
$setup_completed = 0;
$vbo_rooms = array();
$q = "SELECT `id`,`name` FROM `#__vikbooking_rooms`;";
$dbo->setQuery($q);
$dbo->execute();
if ($dbo->getNumRows()) {
$records = $dbo->loadAssocList();
foreach ($records as $record) {
$vbo_rooms[$record['id']] = $record['name'];
}
// change flag for setup completed
$setup_completed = 1;
}
// process actions
$plugins = VikBooking::canImportBookingsFromThirdPartyPlugins();
$tpbookings = array();
$tprooms = array();
$tpp = VikRequest::getString('tpp', '', 'request');
$bimported = array();
if (!empty($tpp) && $setup_completed && is_array($plugins) && isset($plugins[$tpp])) {
// grab the import information for this third party plugin
$bimported = get_option("vikbooking_importbftpp_{$tpp}", null);
$bimported = !empty($bimported) ? json_decode($bimported, true) : array();
$bimported = !is_array($bimported) ? array() : $bimported;
// load bookings from this third party plugin
switch ($tpp) {
case 'mphb':
// read bookings data
$q = "SELECT `p`.`ID`,`p`.`post_date`,`p`.`post_status`,`pm`.`meta_key`,`pm`.`meta_value` FROM `#__posts` AS `p` LEFT JOIN `#__postmeta` `pm` ON `p`.`ID`=`pm`.`post_id` WHERE `p`.`post_type`=" . $dbo->quote('mphb_booking') . " ORDER BY `p`.`post_date` DESC;";
$dbo->setQuery($q);
$dbo->execute();
if (!$dbo->getNumRows()) {
// no bookings found
break;
}
// build records
$records = $dbo->loadAssocList();
foreach ($records as $record) {
if (empty($record['ID'])) {
continue;
}
// raw booking structure
if (!isset($tpbookings[$record['ID']])) {
$tpbookings[$record['ID']] = array(
'id' => $record['ID'],
'dt' => $record['post_date'],
'last_import' => null,
'status' => $record['post_status'],
'metas' => array(),
'rooms_metas' => array(),
'room_ids' => array(),
'room_parties' => array(),
'infos' => array(),
);
}
// push meta assoc
$tpbookings[$record['ID']]['metas'][$record['meta_key']] = $record['meta_value'];
// gather booking information
if (stripos($record['meta_key'], 'first_name') !== false) {
$tpbookings[$record['ID']]['infos']['first_name'] = $record['meta_value'];
}
if (stripos($record['meta_key'], 'last_name') !== false) {
$tpbookings[$record['ID']]['infos']['last_name'] = $record['meta_value'];
}
if (stripos($record['meta_key'], 'email') !== false) {
$tpbookings[$record['ID']]['infos']['email'] = $record['meta_value'];
}
if (stripos($record['meta_key'], 'check_in') !== false) {
$tpbookings[$record['ID']]['infos']['checkin'] = $record['meta_value'];
}
if (stripos($record['meta_key'], 'check_out') !== false) {
$tpbookings[$record['ID']]['infos']['checkout'] = $record['meta_value'];
}
if (stripos($record['meta_key'], 'phone') !== false && !empty($record['meta_value'])) {
$tpbookings[$record['ID']]['infos']['phone'] = $record['meta_value'];
}
if (stripos($record['meta_key'], 'city') !== false && !empty($record['meta_value'])) {
$tpbookings[$record['ID']]['infos']['city'] = $record['meta_value'];
}
if (stripos($record['meta_key'], 'address') !== false && !empty($record['meta_value'])) {
$tpbookings[$record['ID']]['infos']['address'] = $record['meta_value'];
}
if (stripos($record['meta_key'], 'zip') !== false && !empty($record['meta_value'])) {
$tpbookings[$record['ID']]['infos']['zip'] = $record['meta_value'];
}
if (stripos($record['meta_key'], 'country') !== false && !empty($record['meta_value'])) {
$tpbookings[$record['ID']]['infos']['country'] = $record['meta_value'];
}
if (stripos($record['meta_key'], 'total_price') !== false && !empty($record['meta_value'])) {
$tpbookings[$record['ID']]['infos']['total'] = $record['meta_value'];
}
if (stripos($record['meta_key'], 'language') !== false && !empty($record['meta_value'])) {
$tpbookings[$record['ID']]['infos']['language'] = $record['meta_value'];
}
// check whether this booking was already imported
if (count($bimported)) {
foreach ($bimported as $old_import) {
if (!isset($old_import['bids']) || !isset($old_import['dt']) || !is_array($old_import['bids'])) {
continue;
}
if (in_array($record['ID'], $old_import['bids'])) {
// last import date found
$tpbookings[$record['ID']]['last_import'] = $old_import['dt'];
break;
}
}
}
}
// grab room info details
$q = "SELECT `p`.`ID`,`p`.`post_parent`,`pm`.`meta_key`,`pm`.`meta_value` FROM `#__posts` AS `p` LEFT JOIN `#__postmeta` `pm` ON `p`.`ID`=`pm`.`post_id` WHERE `p`.`post_parent` IN (" . implode(', ', array_keys($tpbookings)) . ") AND `p`.`post_type`=" . $dbo->quote('mphb_reserved_room') . " ORDER BY `p`.`post_parent` ASC;";
$dbo->setQuery($q);
$dbo->execute();
if ($dbo->getNumRows()) {
$rooms_data = $dbo->loadAssocList();
$rooms_meta_assoc = array();
foreach ($rooms_data as $room_data) {
if (!isset($tpbookings[$room_data['post_parent']])) {
continue;
}
// push rooms meta assoc
$tpbookings[$room_data['post_parent']]['rooms_metas'][$room_data['meta_key']] = $room_data['meta_value'];
if (stripos($room_data['meta_key'], 'mphb_room_id') !== false) {
// push room identifier
array_push($tpbookings[$room_data['post_parent']]['room_ids'], $room_data['meta_value']);
// save post ID for this room booked
$rooms_meta_assoc[$room_data['ID']] = $room_data['meta_value'];
}
}
foreach ($rooms_meta_assoc as $rmetapid => $rmetarid) {
foreach ($rooms_data as $room_data) {
if (!isset($tpbookings[$room_data['post_parent']])) {
continue;
}
if ($rmetapid == $room_data['ID'] && stripos($room_data['meta_key'], 'adults') !== false) {
if (!isset($tpbookings[$room_data['post_parent']]['room_parties'][$rmetarid])) {
$tpbookings[$room_data['post_parent']]['room_parties'][$rmetarid] = array(
'adults' => 1,
'children' => 0,
);
}
// update room party adults
$tpbookings[$room_data['post_parent']]['room_parties'][$rmetarid]['adults'] = (int)$room_data['meta_value'];
}
if ($rmetapid == $room_data['ID'] && stripos($room_data['meta_key'], 'children') !== false) {
if (!isset($tpbookings[$room_data['post_parent']]['room_parties'][$rmetarid])) {
$tpbookings[$room_data['post_parent']]['room_parties'][$rmetarid] = array(
'adults' => 1,
'children' => 0,
);
}
// update room party children
$tpbookings[$room_data['post_parent']]['room_parties'][$rmetarid]['children'] = (int)$room_data['meta_value'];
}
}
}
}
// build the third party rooms relations
$q = "SELECT `ID`,`post_title` FROM `#__posts` WHERE `post_type`=" . $dbo->quote('mphb_room') . ";";
$dbo->setQuery($q);
$dbo->execute();
if ($dbo->getNumRows()) {
$records = $dbo->loadAssocList();
foreach ($records as $record) {
$tprooms[$record['ID']] = $record['post_title'];
}
}
// unset all bookings with no rooms found, with non existing rooms or without required information
foreach ($tpbookings as $bid => $booking) {
if (!count($booking['room_ids'])) {
unset($tpbookings[$bid]);
continue;
}
foreach ($booking['room_ids'] as $tprid) {
if (!isset($tprooms[$tprid])) {
unset($tpbookings[$bid]);
break 2;
}
}
// make sure the check-in and check-out dates are defined
if (empty($booking['infos']['checkin']) || empty($booking['infos']['checkout'])) {
unset($tpbookings[$bid]);
continue;
}
}
break;
default:
// plugin unsupported
break;
}
// check whether some bookings have been requested for import
$do_import = VikRequest::getInt('do_import', 0, 'request');
$tpp_rooms_map = VikRequest::getVar('tpp_rooms', array(), 'request', 'array');
$vbo_rooms_map = VikRequest::getVar('vbo_rooms', array(), 'request', 'array');
$tpp_bids = VikRequest::getVar('tpp_bids', array(), 'request', 'array');
if ($do_import && is_array($tpp_rooms_map) && is_array($vbo_rooms_map) && is_array($tpp_bids) && count($vbo_rooms_map) && count($tpp_bids)) {
// let this method proceed with the import
$this->importThirdPartyReservations($tpp, $tpbookings, $tpp_rooms_map, $vbo_rooms_map, $tpp_bids);
}
}
$this->setup_completed = $setup_completed;
$this->vbo_rooms = $vbo_rooms;
$this->plugins = $plugins;
$this->tpbookings = $tpbookings;
$this->tprooms = $tprooms;
$this->tpp = $tpp;
// Display the template
parent::display($tpl);
}
/**
* Do the import of the requested bookings like if this was a task of a controller.
*
* @param string $tpp the name of the third party plugin.
* @param array $tpbookings all third party bookings read.
* @param array $tpp_rooms_map third party room IDs involved.
* @param array $vbo_rooms_map corresponding VBO room IDs selected.
* @param array $tpp_bids selected reservation IDs (as keys).
*
* @return mixed void on success by redirecting the page, false on failure by setting a system error message.
*
* @since 1.3.5
*/
private function importThirdPartyReservations($tpp, $tpbookings, $tpp_rooms_map, $vbo_rooms_map, $tpp_bids)
{
// set the execution time to 5 minutes
@ini_set('max_execution_time', 300);
$dbo = JFactory::getDbo();
$app = JFactory::getApplication();
// date format
$vbo_df = VikBooking::getDateFormat(true);
if ($vbo_df == "%d/%m/%Y") {
$vbo_df = 'd/m/Y';
} elseif ($vbo_df == "%m/%d/%Y") {
$vbo_df = 'm/d/Y';
} else {
$vbo_df = 'Y/m/d';
}
// check-in/check-out times
$pcheckinh = 0;
$pcheckinm = 0;
$pcheckouth = 0;
$pcheckoutm = 0;
$timeopst = VikBooking::getTimeOpenStore();
if (is_array($timeopst)) {
$opent = VikBooking::getHoursMinutes($timeopst[0]);
$closet = VikBooking::getHoursMinutes($timeopst[1]);
$pcheckinh = $opent[0];
$pcheckinm = $opent[1];
$pcheckouth = $closet[0];
$pcheckoutm = $closet[1];
}
// Assign room specific unit
$set_room_indexes = VikBooking::autoRoomUnit();
// vars validation
if (empty($tpp)) {
VikError::raiseWarning('', 'Missing third party plugin name');
return false;
}
if (!is_array($tpbookings) || !count($tpbookings)) {
VikError::raiseWarning('', 'No reservations found from third party plugin');
return false;
}
// build the rooms mapping data
$rooms_mapping = array();
foreach ($tpp_rooms_map as $k => $v) {
if (empty($vbo_rooms_map[$k])) {
continue;
}
$rooms_mapping[$v] = $vbo_rooms_map[$k];
}
if (!count($rooms_mapping)) {
VikError::raiseWarning('', 'No corresponding rooms of Vik Booking selected');
return false;
}
// loop over the requested bookings for import
$tot_bookings_imported = 0;
$bookings_imported_ids = array();
foreach ($tpp_bids as $tpbid => $val) {
if (!isset($tpbookings[$tpbid])) {
// booking not read
continue;
}
// build customer raw data
$custdata = '';
$first_name = null;
$last_name = null;
$email = null;
$phone = null;
$country = null;
$customer_extrainfo = array();
if (!empty($tpbookings[$tpbid]['infos']['first_name'])) {
$custdata .= JText::translate('VBCUSTOMERFIRSTNAME') . ': ' . $tpbookings[$tpbid]['infos']['first_name'] . "\n";
$first_name = $tpbookings[$tpbid]['infos']['first_name'];
}
if (!empty($tpbookings[$tpbid]['infos']['last_name'])) {
$custdata .= JText::translate('VBCUSTOMERLASTNAME') . ': ' . $tpbookings[$tpbid]['infos']['last_name'] . "\n";
$last_name = $tpbookings[$tpbid]['infos']['last_name'];
}
if (!empty($tpbookings[$tpbid]['infos']['email'])) {
$custdata .= JText::translate('VBCUSTOMEREMAIL') . ': ' . $tpbookings[$tpbid]['infos']['email'] . "\n";
$email = $tpbookings[$tpbid]['infos']['email'];
}
if (!empty($tpbookings[$tpbid]['infos']['phone'])) {
$custdata .= JText::translate('VBCUSTOMERPHONE') . ': ' . $tpbookings[$tpbid]['infos']['phone'] . "\n";
$phone = $tpbookings[$tpbid]['infos']['phone'];
}
if (!empty($tpbookings[$tpbid]['infos']['address'])) {
$custdata .= JText::translate('ORDER_ADDRESS') . ': ' . $tpbookings[$tpbid]['infos']['address'] . "\n";
$customer_extrainfo['address'] = $tpbookings[$tpbid]['infos']['address'];
}
if (!empty($tpbookings[$tpbid]['infos']['zip'])) {
$custdata .= JText::translate('ORDER_ZIP') . ': ' . $tpbookings[$tpbid]['infos']['zip'] . "\n";
$customer_extrainfo['zip'] = $tpbookings[$tpbid]['infos']['zip'];
}
if (!empty($tpbookings[$tpbid]['infos']['city'])) {
$custdata .= JText::translate('ORDER_CITY') . ': ' . $tpbookings[$tpbid]['infos']['city'] . "\n";
$customer_extrainfo['city'] = $tpbookings[$tpbid]['infos']['city'];
}
if (!empty($tpbookings[$tpbid]['infos']['country'])) {
$custdata .= JText::translate('VBCUSTOMERCOUNTRY') . ': ' . $tpbookings[$tpbid]['infos']['country'] . "\n";
$country = $tpbookings[$tpbid]['infos']['country'];
}
$custdata = rtrim($custdata, "\n");
// build stay dates and tot nights
$checkin_ts = VikBooking::getDateTimestamp(date($vbo_df, strtotime($tpbookings[$tpbid]['infos']['checkin'])), $pcheckinh, $pcheckinm);
$checkout_ts = VikBooking::getDateTimestamp(date($vbo_df, strtotime($tpbookings[$tpbid]['infos']['checkout'])), $pcheckouth, $pcheckoutm);
if (!$checkin_ts || !$checkout_ts) {
VikError::raiseWarning('', 'Invalid dates for third party reservation #' . $tpbid);
continue;
}
$tot_nights = $this->countReservationNights($tpbookings[$tpbid]['infos']['checkin'], $tpbookings[$tpbid]['infos']['checkout']);
// prepare customer record
$cpin = VikBooking::getCPinIstance();
$cpin->is_admin = true;
if (count($customer_extrainfo)) {
$cpin->setCustomerExtraInfo($customer_extrainfo);
}
// adjust the country code
$country = $cpin->get3CharCountry($country);
// save customer details
$cpin->saveCustomerDetails($first_name, $last_name, $email, $phone, $country, array());
// check booking status
$new_status = 'confirmed';
if (stripos($tpbookings[$tpbid]['status'], 'cancel') !== false || stripos($tpbookings[$tpbid]['status'], 'abandon') !== false) {
$new_status = 'cancelled';
} elseif (stripos($tpbookings[$tpbid]['status'], 'pending') !== false) {
$new_status = 'standby';
}
// store busy record(s) by making sure we know the VBO room ID
$booking_busy_ids = array();
if ($new_status == 'confirmed') {
foreach ($tpbookings[$tpbid]['room_ids'] as $orid => $tprid) {
if (!isset($rooms_mapping[$tprid])) {
// corresponding room ID not found, unset the key
unset($tpbookings[$tpbid]['room_ids'][$orid]);
continue;
}
$q = "INSERT INTO `#__vikbooking_busy` (`idroom`,`checkin`,`checkout`,`realback`) VALUES(" . (int)$rooms_mapping[$tprid] . ", {$checkin_ts}, {$checkout_ts}, {$checkout_ts});";
$dbo->setQuery($q);
$dbo->execute();
$lid = $dbo->insertid();
if (!empty($lid)) {
array_push($booking_busy_ids, $lid);
} else {
unset($tpbookings[$tpbid]['room_ids'][$orid]);
}
}
}
// make sure some rooms were booked
if ($new_status == 'confirmed' && !count($booking_busy_ids)) {
VikError::raiseWarning('', 'Could not occupy rooms for third party reservation #' . $tpbid);
continue;
}
// store reservation
$res_obj = new stdClass;
$res_obj->custdata = $custdata;
$res_obj->ts = strtotime($tpbookings[$tpbid]['dt']);
$res_obj->status = $new_status;
$res_obj->days = $tot_nights;
$res_obj->checkin = $checkin_ts;
$res_obj->checkout = $checkout_ts;
$res_obj->custmail = $email;
$res_obj->sid = VikBooking::getSecretLink();
$res_obj->roomsnum = count($tpbookings[$tpbid]['room_ids']);
$res_obj->total = !empty($tpbookings[$tpbid]['infos']['total']) ? (float)$tpbookings[$tpbid]['infos']['total'] : 0;
$res_obj->country = $country;
$res_obj->phone = $phone;
$res_obj->closure = 0;
$dbo->insertObject('#__vikbooking_orders', $res_obj, 'id');
if (!isset($res_obj->id) || empty($res_obj->id)) {
VikError::raiseWarning('', 'Could not import third party reservation #' . $tpbid);
continue;
}
$newoid = $res_obj->id;
// check if some of the rooms booked have shared calendars
if ($new_status == 'confirmed') {
foreach ($tpbookings[$tpbid]['room_ids'] as $orid => $tprid) {
// we do this before storing the relation records
VikBooking::updateSharedCalendars($newoid, array($rooms_mapping[$tprid]), $checkin_ts, $checkout_ts);
}
// Confirmation Number
$confirmnumber = VikBooking::generateConfirmNumber($newoid, true);
// store relations between busy records and new booking
foreach ($booking_busy_ids as $lid) {
$q = "INSERT INTO `#__vikbooking_ordersbusy` (`idorder`, `idbusy`) VALUES(" . (int)$newoid . ", " . (int)$lid . ");";
$dbo->setQuery($q);
$dbo->execute();
}
}
// write room records
foreach ($tpbookings[$tpbid]['room_ids'] as $orid => $tprid) {
// Assign room specific unit
$room_indexes_usemap = array();
$room_indexes = $set_room_indexes === true ? VikBooking::getRoomUnitNumsAvailable(array('id' => $newoid, 'checkin' => $checkin_ts, 'checkout' => $checkout_ts), $rooms_mapping[$tprid]) : array();
$use_ind_key = 0;
if (count($room_indexes)) {
if (!array_key_exists($rooms_mapping[$tprid], $room_indexes_usemap)) {
$room_indexes_usemap[$rooms_mapping[$tprid]] = $use_ind_key;
} else {
$use_ind_key = $room_indexes_usemap[$rooms_mapping[$tprid]];
}
}
// room cost and room party
$r_cust_cost = !empty($tpbookings[$tpbid]['infos']['total']) ? ($tpbookings[$tpbid]['infos']['total'] / count($tpbookings[$tpbid]['room_ids'])) : 0;
$room_adults = isset($tpbookings[$tpbid]['room_parties'][$tprid]) && isset($tpbookings[$tpbid]['room_parties'][$tprid]['adults']) ? (int)$tpbookings[$tpbid]['room_parties'][$tprid]['adults'] : 1;
$room_children = isset($tpbookings[$tpbid]['room_parties'][$tprid]) && isset($tpbookings[$tpbid]['room_parties'][$tprid]['children']) ? (int)$tpbookings[$tpbid]['room_parties'][$tprid]['children'] : 0;
$order_room_obj = new stdClass;
$order_room_obj->idorder = $newoid;
$order_room_obj->idroom = $rooms_mapping[$tprid];
$order_room_obj->adults = $room_adults;
$order_room_obj->children = $room_children;
$order_room_obj->idtar = null;
$order_room_obj->roomindex = count($room_indexes) ? (int)$room_indexes[$use_ind_key] : null;
$order_room_obj->cust_cost = $r_cust_cost;
$dbo->insertObject('#__vikbooking_ordersrooms', $order_room_obj, 'id');
// Assign room specific unit
if (count($room_indexes)) {
$room_indexes_usemap[$rooms_mapping[$tprid]]++;
}
}
// Assign Customer Booking
$cpin->saveCustomerBooking($newoid);
// Booking History
VikBooking::getBookingHistoryInstance()->setBid($newoid)->store('NB', JText::translate('VBO_IMPBFTPP_BOOKHIST_DESCR') . " ({$tpbid})");
// increase bookings counter
$tot_bookings_imported++;
// store third party booking ID
array_push($bookings_imported_ids, $tpbid);
}
if (!$tot_bookings_imported) {
VikError::raiseWarning('', JText::sprintf('VBO_IMPBFTPP_IMPORT_TOTRES', $tot_bookings_imported));
return false;
}
// update option containing the imported bookings for this third party plugin
$bimported = get_option("vikbooking_importbftpp_{$tpp}", null);
$bimported = !empty($bimported) ? json_decode($bimported, true) : array();
$bimported = !is_array($bimported) ? array() : $bimported;
// push new import data
array_push($bimported, array(
'dt' => date('Y-m-d H:i:s'),
'bids' => $bookings_imported_ids,
));
update_option("vikbooking_importbftpp_{$tpp}", json_encode($bimported));
// redirect to Vik Booking - All Bookings page by setting a success message
$app->enqueueMessage(JText::sprintf('VBO_IMPBFTPP_IMPORT_TOTRES', $tot_bookings_imported));
$app->redirect('index.php?option=com_vikbooking&task=orders');
// do not let the View be rendered
exit;
}
/**
* Counts the total number of nights of stay from the given stay dates.
*
* @param string $checkin parsable checkin date into a timestamp.
* @param string $checkout parsable checkout date into a timestamp.
*
* @return int the total number of nights of stay.
*/
private function countReservationNights($checkin, $checkout)
{
$nights = 1;
$in_ts = strtotime($checkin);
$out_ts = strtotime($checkout);
if (!$in_ts || !$out_ts || $in_ts >= $out_ts) {
return $nights;
}
$in_info = getdate($in_ts);
$nights = 0;
while (date('Y-m-d', $in_info[0]) != date('Y-m-d', $out_ts)) {
$nights++;
$in_info = getdate(mktime(0, 0, 0, $in_info['mon'], ($in_info['mday'] + 1), $in_info['year']));
}
return $nights < 1 ? 1 : $nights;
}
/**
* Sets the toolbar
*/
protected function addToolBar()
{
JToolBarHelper::title(JText::translate('VBOMAINIMPORTBFTPPTITLE'), 'vikbooking');
JToolBarHelper::cancel( 'canceldash', JText::translate('VBBACK'));
JToolBarHelper::spacer();
}
}