modern-events-calendar-lite/app/libraries/user.php

249 lines
8.1 KiB
PHP
Raw Normal View History

2024-10-15 12:04:03 +02:00
<?php
/** no direct access **/
defined('MECEXEC') or die();
/**
* Webnus MEC User class.
* @author Webnus <info@webnus.net>
*/
class MEC_user extends MEC_base
{
/**
* @var MEC_main
*/
public $main;
/**
* @var MEC_db
*/
public $db;
/**
* @var array
*/
public $settings;
/**
* Constructor method
* @author Webnus <info@webnus.net>
*/
public function __construct()
{
// MEC Main library
$this->main = $this->getMain();
// MEC DB Library
$this->db = $this->getDB();
// MEC settings
$this->settings = $this->main->get_settings();
}
public function register($attendee, $args)
{
$name = $attendee['name'] ?? '';
$raw = (isset($attendee['reg']) and is_array($attendee['reg'])) ? $attendee['reg'] : [];
$email = $attendee['email'] ?? '';
if(!filter_var($email, FILTER_VALIDATE_EMAIL)) return false;
$reg = [];
foreach($raw as $k => $v) $reg[$k] = (is_array($v) ? $v : stripslashes($v));
$existed_user_id = $this->main->email_exists($email);
// User already exist
if($existed_user_id !== false)
{
// Map Data
$event_id = $args['event_id'] ?? 0;
if($event_id) $this->save_mapped_data($event_id, $existed_user_id, $reg);
return $existed_user_id;
}
// Update WordPress user first name and last name
if(strpos($name, ',') !== false) $ex = explode(',', $name);
else $ex = explode(' ', $name);
$first_name = $ex[0] ?? '';
$last_name = '';
if(isset($ex[1]))
{
unset($ex[0]);
$last_name = implode(' ', $ex);
}
// Register in MEC
$MEC_method = isset($args['register_in_mec']) && $args['register_in_mec'];
// Registration is disabled
if($MEC_method || (isset($this->settings['booking_registration']) && !$this->settings['booking_registration']))
{
$existed_user_id = $this->db->select("SELECT `id` FROM `#__mec_users` WHERE `email`='".$this->db->escape($email)."'", 'loadResult');
// User already exist
if($existed_user_id) return $existed_user_id;
$now = date('Y-m-d H:i:s');
$user_id = (int) $this->db->q("INSERT INTO `#__mec_users` (`first_name`,`last_name`,`email`,`reg`,`created_at`,`updated_at`) VALUES ('".$this->db->escape($first_name)."','".$this->db->escape($last_name)."','".$this->db->escape($email)."','".$this->db->escape(json_encode($reg))."','".$now."','".$now."')", "INSERT");
// Make sure we won't create MEC users with id lower than 1 million
// To avoid conflicts with wp users of course
if($user_id < 1000000)
{
$new_id = $user_id + 1000000;
$this->db->q("UPDATE `#__mec_users` SET `id`='".esc_sql($new_id)."' WHERE `id`='".esc_sql($user_id)."'");
$user_id = $new_id;
}
}
else
{
$username = $email;
$password = wp_generate_password(12, true, true);
$auto = true;
if(isset($args['username']) and trim($args['username'])) $username = $args['username'];
if(isset($args['password']) and trim($args['password']))
{
$password = $args['password'];
$auto = false;
}
if ( ! validate_username( $username ) ) {
$username = 'user-' . mt_rand( 100000000, 999999999999 );
while( username_exists( $username ) ) {
$username = 'user-' . mt_rand( 100000000, 999999999999 );
}
}
$user_id = $this->main->register_user($username, $email, $password, $auto);
$user = new stdClass();
$user->ID = $user_id;
$user->first_name = $first_name;
$user->last_name = $last_name;
wp_update_user($user);
update_user_meta($user_id, 'mec_name', $name);
update_user_meta($user_id, 'mec_reg', $reg);
update_user_meta($user_id, 'nickname', $name);
// Map Data
$event_id = $args['event_id'] ?? 0;
if($event_id) $this->save_mapped_data($event_id, $user_id, $reg);
// Set the User Role
$role = (isset($this->settings['booking_user_role']) and trim($this->settings['booking_user_role'])) ? $this->settings['booking_user_role'] : 'subscriber';
$wpuser = new WP_User($user_id);
$wpuser->set_role($role);
}
return $user_id;
}
public function save_mapped_data($event_id, $user_id, $reg)
{
$reg_fields = $this->main->get_reg_fields($event_id);
foreach($reg as $reg_id => $reg_value)
{
$reg_field = $reg_fields[$reg_id] ?? [];
if(isset($reg_field['mapping']) and trim($reg_field['mapping']))
{
$reg_value = maybe_unserialize($reg_value);
$meta_value = is_array($reg_value) ? implode(',', $reg_value) : $reg_value;
update_user_meta($user_id, $reg_field['mapping'], $meta_value);
}
}
}
public function assign($booking_id, $user_id)
{
// Registration is disabled
if(isset($this->settings['booking_registration']) and !$this->settings['booking_registration'] and !get_user_by('ID', $user_id)) update_post_meta($booking_id, 'mec_user_id', $user_id);
else update_post_meta($booking_id, 'mec_user_id', 'wp');
}
public function get($id)
{
// Registration is disabled
if(isset($this->settings['booking_registration']) and !$this->settings['booking_registration'])
{
$user = $this->mec($id);
if(!$user) $user = $this->wp($id);
}
else
{
$user = $this->wp($id);
if(!$user) $user = $this->mec($id);
}
return $user;
}
public function mec($id)
{
$data = $this->db->select("SELECT * FROM `#__mec_users` WHERE `id`=".((int) $id), 'loadObject');
if(!$data) return NULL;
$user = new stdClass();
$user->ID = $data->id;
$user->first_name = stripslashes($data->first_name);
$user->last_name = stripslashes($data->last_name);
$user->display_name = trim(stripslashes($data->first_name).' '.stripslashes($data->last_name));
$user->email = $data->email;
$user->user_email = $data->email;
$user->user_registered = $data->created_at;
$user->data = $user;
return $user;
}
public function wp($id)
{
return get_userdata($id);
}
public function booking($id)
{
$mec_user_id = get_post_meta($id, 'mec_user_id', true);
if(trim($mec_user_id) and is_numeric($mec_user_id)) return $this->mec($mec_user_id);
return $this->wp(get_post($id)->post_author);
}
public function by_email($email)
{
return $this->get($this->id('email', $email));
}
public function id($field, $value)
{
$id = NULL;
// Registration is disabled
if(isset($this->settings['booking_registration']) and !$this->settings['booking_registration'])
{
$id = $this->db->select("SELECT `id` FROM `#__mec_users` WHERE `".$field."`='".$this->db->escape($value)."'", 'loadResult');
if(!$id)
{
$user = get_user_by($field, $value);
if(isset($user->ID)) $id = $user->ID;
}
}
else
{
$user = get_user_by($field, $value);
if(isset($user->ID)) $id = $user->ID;
if(!$id) $id = $this->db->select("SELECT `id` FROM `#__mec_users` WHERE `".$field."`='".$this->db->escape($value)."'", 'loadResult');
}
return $id;
}
}