flush_rules();
$old_version = get_option('dbem_version');
//Won't upgrade <4.300 anymore
if( $old_version != '' && $old_version < 4.1 ){
function em_update_required_notification(){
global $EM_Booking;
?>
Events Manager upgrade not complete, please upgrade to the version 4.300 or higher first from here before upgrading to this version.
$old_version || $old_version == '' ){
$retry_time = get_option('dbem_upgrade_throttle_time') ? time()-get_option('dbem_upgrade_throttle_time'):time()-3600;
if( get_option('dbem_upgrade_throttle') <= $retry_time || !get_option('dbem_upgrade_throttle') ){
// Creates the events table if necessary
update_option('dbem_upgrade_throttle_time', time()+3600);
em_create_events_table();
em_create_events_meta_table();
em_create_locations_table();
em_create_bookings_table();
em_create_tickets_table();
em_create_tickets_bookings_table();
em_set_capabilities();
em_add_options();
//New install, or Migrate?
if( $old_version < 5 && !empty($old_version) ){
update_option('dbem_upgrade_throttle', time()+(300*60));
update_option('dbem_upgrade_throttle_time', 300*60); //extend length of migration throttle
set_time_limit(300);
em_migrate_v4();
update_site_option('dbem_ms_update_nag',1);
}elseif( empty($old_version) ){
em_create_events_page();
update_option('dbem_hello_to_user',1);
}
//Upate Version
update_option('dbem_version', EM_VERSION);
delete_option('dbem_upgrade_throttle');
delete_option('dbem_upgrade_throttle_time');
//last but not least, flush the toilet
global $wp_rewrite;
$wp_rewrite->flush_rules();
update_option('dbem_flush_needed',1);
}else{
function em_upgrading_in_progress_notification(){
global $EM_Booking;
?>Events Manager upgrade still in progress. Please be patient, this message should disappear once the upgrade is complete.
get_results("SHOW KEYS FROM $table_name WHERE Key_name != 'PRIMARY'", ARRAY_A);
foreach($table_keys as $table_key_row){
if( !in_array($table_key_row['Key_name'], $clean_keys) ){
$table_key_changes[] = "ALTER TABLE $table_name DROP INDEX ".$table_key_row['Key_name'];
}elseif( in_array($table_key_row['Key_name'], $clean_keys) ){
foreach($clean_keys as $key => $clean_key){
if($table_key_row['Key_name'] == $clean_key){
unset($new_keys[$key]);
}
}
}
}
//delete duplicates
foreach($table_key_changes as $sql){
$wpdb->query($sql);
}
//add new keys
foreach($new_keys as $key){
$wpdb->query("ALTER TABLE $table_name ADD INDEX ($key)");
}
}
function em_create_events_table() {
global $wpdb, $user_level, $user_ID;
get_currentuserinfo();
require_once(ABSPATH . 'wp-admin/includes/upgrade.php');
$table_name = EM_EVENTS_TABLE;
$sql = "CREATE TABLE ".$table_name." (
event_id bigint(20) unsigned NOT NULL AUTO_INCREMENT,
post_id bigint(20) unsigned NOT NULL,
event_slug VARCHAR( 200 ) NULL DEFAULT NULL,
event_owner bigint(20) unsigned DEFAULT NULL,
event_status int(1) NULL DEFAULT NULL,
event_name text NULL DEFAULT NULL,
event_start_time time NULL DEFAULT NULL,
event_end_time time NULL DEFAULT NULL,
event_all_day int(1) NULL DEFAULT NULL,
event_start_date date NULL DEFAULT NULL,
event_end_date date NULL DEFAULT NULL,
post_content longtext NULL DEFAULT NULL,
event_rsvp bool NOT NULL DEFAULT 0,
event_spaces int(5) NULL DEFAULT 0,
event_private bool NOT NULL DEFAULT 0,
location_id bigint(20) unsigned NULL DEFAULT NULL,
recurrence_id bigint(20) unsigned NULL DEFAULT NULL,
event_category_id bigint(20) unsigned NULL DEFAULT NULL,
event_attributes text NULL DEFAULT NULL,
event_date_created datetime NULL DEFAULT NULL,
event_date_modified datetime NULL DEFAULT NULL,
recurrence bool NOT NULL DEFAULT 0,
recurrence_interval int(4) NULL DEFAULT NULL,
recurrence_freq tinytext NULL DEFAULT NULL,
recurrence_byday tinytext NULL DEFAULT NULL,
recurrence_byweekno int(4) NULL DEFAULT NULL,
recurrence_days int(4) NULL DEFAULT NULL,
blog_id bigint(20) unsigned NULL DEFAULT NULL,
group_id bigint(20) unsigned NULL DEFAULT NULL,
PRIMARY KEY (event_id)
) DEFAULT CHARSET=utf8 ;";
if( $wpdb->get_var("SHOW TABLES LIKE '$table_name'") != $table_name ){
dbDelta($sql);
//Add default events
$in_one_week = date('Y-m-d', time() + 60*60*24*7);
$in_four_weeks = date('Y-m-d', time() + 60*60*24*7*4);
$in_one_year = date('Y-m-d', time() + 60*60*24*365);
$wpdb->query("INSERT INTO ".$table_name." (event_name, event_start_date, event_end_date, event_start_time, event_end_time, location_id, event_slug, event_owner, event_status, post_id) VALUES ('Orality in James Joyce Conference', '$in_one_week', '$in_one_week', '16:00:00', '18:00:00', 1, 'oralty-in-james-joyce-conference','".get_current_user_id()."',1,0)");
$wpdb->query("INSERT INTO ".$table_name." (event_name, event_start_date, event_end_date, event_start_time, event_end_time, location_id, event_slug, event_owner, event_status, post_id) VALUES ('Traditional music session', '$in_four_weeks', '$in_four_weeks', '20:00:00', '22:00:00', 2, 'traditional-music-session','".get_current_user_id()."',1,0)");
$wpdb->query("INSERT INTO ".$table_name." (event_name, event_start_date, event_end_date, event_start_time, event_end_time, location_id, event_slug, event_owner, event_status, post_id) VALUES ('6 Nations, Italy VS Ireland', '$in_one_year', '$in_one_year', '22:00:00', '23:00:00', 3, '6-nations-italy-vs-ireland','".get_current_user_id()."',1,0)");
em_migrate_events($wpdb->get_results('SELECT * FROM '.$table_name, ARRAY_A));
}else{
if( get_option('dbem_version') < 4.939 ){
//if updating from version 4 (4.934 is beta v5) then set all statuses to 1 since it's new
$wpdb->query("ALTER TABLE $table_name CHANGE event_notes post_content longtext NULL DEFAULT NULL");
$wpdb->query("ALTER TABLE $table_name CHANGE event_name event_name text NULL DEFAULT NULL");
$wpdb->query("ALTER TABLE $table_name CHANGE location_id location_id bigint(20) unsigned NULL DEFAULT NULL");
$wpdb->query("ALTER TABLE $table_name CHANGE recurrence_id recurrence_id bigint(20) unsigned NULL DEFAULT NULL");
$wpdb->query("ALTER TABLE $table_name CHANGE event_start_time event_start_time time NULL DEFAULT NULL");
$wpdb->query("ALTER TABLE $table_name CHANGE event_end_time event_end_time time NULL DEFAULT NULL");
$wpdb->query("ALTER TABLE $table_name CHANGE event_start_date event_start_date date NULL DEFAULT NULL");
}
dbDelta($sql);
}
em_sort_out_table_nu_keys($table_name, array('event_status','post_id','blog_id','group_id'));
}
function em_create_events_meta_table(){
global $wpdb, $user_level;
$table_name = EM_META_TABLE;
// Creating the events table
$sql = "CREATE TABLE ".$table_name." (
meta_id bigint(20) unsigned NOT NULL AUTO_INCREMENT,
object_id bigint(20) unsigned NOT NULL,
meta_key varchar(255) DEFAULT NULL,
meta_value longtext,
meta_date TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
PRIMARY KEY (meta_id)
) DEFAULT CHARSET=utf8 ";
require_once(ABSPATH . 'wp-admin/includes/upgrade.php');
$old_table_name = EM_OLD_LOCATIONS_TABLE;
dbDelta($sql);
em_sort_out_table_nu_keys($table_name, array('object_id','meta_key'));
}
function em_create_locations_table() {
global $wpdb, $user_level;
$table_name = EM_LOCATIONS_TABLE;
// Creating the events table
$sql = "CREATE TABLE ".$table_name." (
location_id bigint(20) unsigned NOT NULL AUTO_INCREMENT,
post_id bigint(20) unsigned NOT NULL,
blog_id bigint(20) unsigned NULL DEFAULT NULL,
location_slug VARCHAR( 200 ) NULL DEFAULT NULL,
location_name text NULL DEFAULT NULL,
location_owner bigint(20) unsigned NOT NULL DEFAULT 0,
location_address VARCHAR( 200 ) NULL DEFAULT NULL,
location_town VARCHAR( 200 ) NULL DEFAULT NULL,
location_state VARCHAR( 200 ) NULL DEFAULT NULL,
location_postcode VARCHAR( 10 ) NULL DEFAULT NULL,
location_region VARCHAR( 200 ) NULL DEFAULT NULL,
location_country CHAR( 2 ) NULL DEFAULT NULL,
location_latitude float NULL DEFAULT NULL,
location_longitude float NULL DEFAULT NULL,
post_content longtext NULL DEFAULT NULL,
location_status int(1) NULL DEFAULT NULL,
location_private bool NOT NULL DEFAULT 0,
PRIMARY KEY (location_id)
) DEFAULT CHARSET=utf8 ;";
require_once(ABSPATH . 'wp-admin/includes/upgrade.php');
$old_table_name = EM_OLD_LOCATIONS_TABLE; //for 3.0
if($wpdb->get_var("SHOW TABLES LIKE '$table_name'") != $table_name && $wpdb->get_var("SHOW TABLES LIKE '$old_table_name'") != $old_table_name) {
dbDelta($sql);
//Add default values
$wpdb->query("INSERT INTO ".$table_name." (location_name, location_address, location_town, location_state, location_country, location_latitude, location_longitude, location_slug, location_owner, location_status, post_id) VALUES ('Arts Millenium Building', 'Newcastle Road','Galway','Galway','IE', 53.275, -9.06532, 'arts-millenium-building','".get_current_user_id()."', 1,0)");
$wpdb->query("INSERT INTO ".$table_name." (location_name, location_address, location_town, location_state, location_country, location_latitude, location_longitude, location_slug, location_owner, location_status, post_id) VALUES ('The Crane Bar', '2, Sea Road','Galway','Galway','IE', 53.2692, -9.06151, 'the-crane-bar','".get_current_user_id()."', 1, 0)");
$wpdb->query("INSERT INTO ".$table_name." (location_name, location_address, location_town, location_state, location_country, location_latitude, location_longitude, location_slug, location_owner, location_status, post_id) VALUES ('Taaffes Bar', '19 Shop Street','Galway','Galway','IE', 53.2725, -9.05321, 'taffes-bar','".get_current_user_id()."', 1, 0)");
em_migrate_locations($wpdb->get_results('SELECT * FROM '.$table_name, ARRAY_A));
}else{
if( get_option('dbem_version') < 4.938 ){
$wpdb->query("ALTER TABLE $table_name CHANGE location_description post_content longtext NULL DEFAULT NULL");
}
dbDelta($sql);
if( get_option('dbem_version') < 4.93 ){
//if updating from version 4 (4.93 is beta v5) then set all statuses to 1 since it's new
$wpdb->query("UPDATE ".$table_name." SET location_status=1");
}
}
em_sort_out_table_nu_keys($table_name, array('location_state','location_region','location_country','post_id','blog_id'));
}
function em_create_bookings_table() {
global $wpdb, $user_level;
$table_name = EM_BOOKINGS_TABLE;
$sql = "CREATE TABLE ".$table_name." (
booking_id bigint(20) unsigned NOT NULL AUTO_INCREMENT,
event_id bigint(20) unsigned NOT NULL,
person_id bigint(20) unsigned NOT NULL,
booking_spaces int(5) NOT NULL,
booking_comment text DEFAULT NULL,
booking_date TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
booking_status bool NOT NULL DEFAULT 1,
booking_price decimal(10,2) unsigned NOT NULL DEFAULT 0,
booking_meta LONGTEXT NULL,
PRIMARY KEY (booking_id)
) DEFAULT CHARSET=utf8 ;";
require_once(ABSPATH . 'wp-admin/includes/upgrade.php');
dbDelta($sql);
em_sort_out_table_nu_keys($table_name, array('event_id'));
}
//Add the categories table
function em_create_tickets_table() {
global $wpdb, $user_level;
$table_name = EM_TICKETS_TABLE;
// Creating the events table
$sql = "CREATE TABLE {$table_name} (
ticket_id BIGINT( 20 ) UNSIGNED NOT NULL AUTO_INCREMENT,
event_id BIGINT( 20 ) UNSIGNED NOT NULL ,
ticket_name TINYTEXT NOT NULL ,
ticket_description TEXT NULL ,
ticket_price DECIMAL( 10 , 2 ) NULL ,
ticket_start DATETIME NULL ,
ticket_end DATETIME NULL ,
ticket_min INT( 10 ) NULL ,
ticket_max INT( 10 ) NULL ,
ticket_spaces INT NULL ,
PRIMARY KEY (ticket_id)
) DEFAULT CHARSET=utf8 ;";
require_once(ABSPATH . 'wp-admin/includes/upgrade.php');
dbDelta($sql);
em_sort_out_table_nu_keys($table_name, array('event_id'));
}
//Add the categories table
function em_create_tickets_bookings_table() {
global $wpdb, $user_level;
$table_name = EM_TICKETS_BOOKINGS_TABLE;
// Creating the events table
$sql = "CREATE TABLE {$table_name} (
ticket_booking_id bigint(20) unsigned NOT NULL AUTO_INCREMENT,
booking_id bigint(20) unsigned NOT NULL,
ticket_id bigint(20) unsigned NOT NULL,
ticket_booking_spaces int(6) NOT NULL,
ticket_booking_price decimal(10,2) NOT NULL,
PRIMARY KEY (ticket_booking_id)
) DEFAULT CHARSET=utf8 ;";
require_once(ABSPATH . 'wp-admin/includes/upgrade.php');
dbDelta($sql);
em_sort_out_table_nu_keys($table_name, array('booking_id','ticket_id'));
}
function em_add_options() {
global $wp_locale;
$decimal_point = !empty($wp_locale->number_format['decimal_point']) ? $wp_locale->number_format['decimal_point']:'.';
$thousands_sep = !empty($wp_locale->number_format['thousands_sep']) ? $wp_locale->number_format['thousands_sep']:',';
$contact_person_email_body_localizable = __("#_BOOKINGNAME (#_BOOKINGEMAIL) will attend #_NAME on #F #j, #Y. He wants to reserve #_BOOKINGSPACES spaces.
Now there are #_BOOKEDSPACES spaces reserved, #_AVAILABLESPACES are still available.
Yours faithfully,
Events Manager - http://wp-events-plugin.com",'dbem').__('
-------------------------------
Powered by Events Manager - http://wp-events-plugin.com','dbem');
$contact_person_email_cancelled_body_localizable = __("#_BOOKINGNAME (#_BOOKINGEMAIL) cancelled his booking at #_NAME on #F #j, #Y. He wanted to reserve #_BOOKINGSPACES spaces.
Now there are #_BOOKEDSPACES spaces reserved, #_AVAILABLESPACES are still available.
Yours faithfully,
Events Manager - http://wp-events-plugin.com",'dbem').__('
-------------------------------
Powered by Events Manager - http://wp-events-plugin.com','dbem');
$respondent_email_body_localizable = __("Dear #_BOOKINGNAME,
you have successfully reserved #_BOOKINGSPACES space/spaces for #_NAME.
Yours faithfully,
#_CONTACTNAME",'dbem').__('
-------------------------------
Powered by Events Manager - http://wp-events-plugin.com','dbem');
$respondent_email_pending_body_localizable = __("Dear #_BOOKINGNAME,
You have requested #_BOOKINGSPACES space/spaces for #_NAME.
Your booking is currently pending approval by our administrators. Once approved you will receive an automatic confirmation.
Yours faithfully,
#_CONTACTNAME",'dbem').__('
-------------------------------
Powered by Events Manager - http://wp-events-plugin.com','dbem');
$respondent_email_rejected_body_localizable = __("Dear #_BOOKINGNAME,
Your requested booking for #_BOOKINGSPACES spaces at #_NAME on #F #j, #Y has been rejected.
Yours faithfully,
#_CONTACTNAME",'dbem').__('
-------------------------------
Powered by Events Manager - http://wp-events-plugin.com','dbem');
$respondent_email_cancelled_body_localizable = __("Dear #_BOOKINGNAME,
Your requested booking for #_BOOKINGSPACES spaces at #_NAME on #F #j, #Y has been cancelled.
Yours faithfully,
#_CONTACTNAME",'dbem').__('
-------------------------------
Powered by Events Manager - http://wp-events-plugin.com','dbem');
$event_approved_email_body = __("Dear #_CONTACTNAME,
Your event #_NAME on #F #j, #Y has been approved.
You can view your event here: #_EVENTURL",'dbem').__('
-------------------------------
Powered by Events Manager - http://wp-events-plugin.com','dbem');
$event_submitted_email_body = __("A new event has been submitted by #_CONTACTNAME.
Name : #_EVENTNAME
Date : #_EVENTDATES
Time : #_EVENTTIMES
Please visit #_EDITEVENTURL to review this event for approval.",'dbem').__('
-------------------------------
Powered by Events Manager - http://wp-events-plugin.com','dbem');
$event_submitted_email_body = str_replace('#_EDITEVENTURL', admin_url().'post.php?action=edit&post=#_EVENTPOSTID', $event_submitted_email_body);
$dbem_options = array(
//time formats
'dbem_time_format' => get_option('time_format'),
'dbem_date_format' => 'd/m/Y',
'dbem_dates_seperator' => ' - ',
'dbem_times_seperator' => ' - ',
//defaults
'dbem_default_category'=>0,
'dbem_default_location'=>0,
//Event List Options
'dbem_events_default_orderby' => 'event_start_date,event_start_time,event_name',
'dbem_events_default_order' => 'ASC',
'dbem_events_default_limit' => 10,
'dbem_list_events_page' => 1,
//Event Search Options
'dbem_search_form_text' => 1,
'dbem_search_form_text_label' => __('Search','dbem'),
'dbem_search_form_dates' => 1,
'dbem_search_form_categories' => 1,
'dbem_search_form_categories_label' => __('All Categories','dbem'),
'dbem_search_form_countries' => 1,
'dbem_search_form_countries_label' => __('All Countries','dbem'),
'dbem_search_form_regions' => 1,
'dbem_search_form_regions_label' => __('All Regions','dbem'),
'dbem_search_form_states' => 1,
'dbem_search_form_states_label' => __('All States','dbem'),
'dbem_search_form_towns' => 0,
'dbem_search_form_towns_label' => __('All Cities/Towns','dbem'),
//Event Form and Anon Submissions
'dbem_events_form_editor' => 1,
'dbem_events_form_reshow' => 1,
'dbem_events_form_result_success' => __('You have successfully submitted your event, which will be published pending approval.','dbem'),
'dbem_events_anonymous_submissions' => 0,
'dbem_events_anonymous_user' => 0,
'dbem_events_anonymous_result_success' => __('You have successfully submitted your event, which will be published pending approval.','dbem'),
//Event Emails
'dbem_event_submitted_email_admin' => '',
'dbem_event_submitted_email_subject' => __('Submitted Event Awaiting Approval', 'dbem'),
'dbem_event_submitted_email_body' => str_replace("
", "\n\r", $event_submitted_email_body),
'dbem_event_approved_email_subject' => __("Event Approved",'dbem'). " - #_NAME" ,
'dbem_event_approved_email_body' => str_replace("
", "\n\r", $event_approved_email_body),
//Event Formatting
'dbem_events_page_title' => __('Events','dbem'),
'dbem_events_page_scope' => 'future',
'dbem_events_page_search' => 1,
'dbem_event_list_item_format_header' => '
Date/Time |
Event |
',
'dbem_event_list_item_format' => '
#_EVENTDATES
#_EVENTTIMES
|
#_EVENTLINK
#_LOCATIONNAME, #_LOCATIONTOWN #_LOCATIONSTATE
|
',
'dbem_event_list_item_format_footer' => '
',
'dbem_display_calendar_in_events_page' => 0,
'dbem_single_event_format' => '#_MAP
Date/Time
Date(s) - #_EVENTDATES
#_EVENTTIMES
Location
#_LOCATIONLINK
Category(ies)
#_CATEGORIES
#_NOTES
{has_bookings}
Bookings
#_BOOKINGFORM
{/has_bookings}',
'dbem_event_page_title_format' => '#_NAME',
'dbem_event_all_day_message' => __('All Day','dbem'),
'dbem_no_events_message' => sprintf(__( 'No %s', 'dbem' ),__('Events','dbem')),
//Location page options
'dbem_list_locations_page' => 1,
//Location Formatting
'dbem_locations_default_orderby' => 'location_name',
'dbem_locations_default_order' => 'ASC',
'dbem_locations_default_limit' => 10,
'dbem_locations_page_title' => __('Event','dbem')." ".__('Locations','dbem'),
'dbem_no_locations_message' => sprintf(__( 'No %s', 'dbem' ),__('Locations','dbem')),
'dbem_location_default_country' => 'US',
'dbem_location_list_item_format' => '#_LOCATIONLINK- #_ADDRESS, #_LOCATIONTOWN, #_LOCATIONSTATE
',
'dbem_location_page_title_format' => '#_LOCATIONNAME',
'dbem_single_location_format' => '#_MAP
Address
#_LOCATIONADDRESS
#_LOCATIONTOWN
#_LOCATIONSTATE
#_LOCATIONREGION
#_LOCATIONPOSTCODE
#_LOCATIONCOUNTRY
#_DESCRIPTION
Upcoming Events
#_NEXTEVENTS
',
'dbem_location_no_events_message' => __('No events in this location', 'dbem'),
'dbem_location_event_list_item_header_format' => "",
'dbem_location_event_list_item_format' => "- #_EVENTLINK - #j #M #Y - #H:#i
",
'dbem_location_event_list_item_footer_format' => "
",
//Category page options
'dbem_list_categories_page' => 1,
'dbem_categories_default_limit' => 10,
'dbem_categories_default_orderby' => 'name',
'dbem_categories_default_order' => 'ASC',
//Category Formatting
'dbem_category_page_title_format' => '#_CATEGORYNAME',
'dbem_category_page_format' => '#_CATEGORYNOTESUpcoming Events
#_CATEGORYNEXTEVENTS',
'dbem_categories_page_title' => __('Event','dbem')." ".__('Categories','dbem'),
'dbem_categories_list_item_format' => '#_CATEGORYLINK',
'dbem_no_categories_message' => sprintf(__( 'No %s', 'dbem' ),__('Categories','dbem')),
'dbem_category_no_events_message' => __('No events in this category', 'dbem'),
'dbem_category_event_list_item_header_format' => '',
'dbem_category_event_list_item_format' => "- #_EVENTLINK - #j #M #Y - #H:#i
",
'dbem_category_event_list_item_footer_format' => '
',
//Tag Formatting
'dbem_tag_page_title_format' => '#_TAGNAME',
'dbem_tag_page_format' => 'Upcoming Events
#_TAGNEXTEVENTS',
'dbem_tag_no_events_message' => __('No events in this tag', 'dbem'),
'dbem_tag_event_list_item_header_format' => '',
'dbem_tag_event_list_item_format' => "- #_EVENTLINK - #j #M #Y - #H:#i
",
'dbem_tag_event_list_item_footer_format' => '
',
//RSS Stuff
'dbem_rss_limit' => 10,
'dbem_rss_scope' => 'future',
'dbem_rss_main_title' => get_bloginfo('title')." - ".__('Events', 'dbem'),
'dbem_rss_main_description' => get_bloginfo('description')." - ".__('Events', 'dbem'),
'dbem_rss_description_format' => "#j #M #y - #H:#i
#_LOCATION
#_LOCATIONADDRESS
#_LOCATIONTOWN",
'dbem_rss_title_format' => "#_NAME",
'em_rss_pubdate' => date('D, d M Y H:i:s T'),
//iCal Stuff
'dbem_ical_limit' => 0,
'dbem_ical_scope' => "future",
'dbem_ical_description_format' => "#_NAME - #_LOCATIONNAME - #j #M #y #H:#i",
//Google Maps
'dbem_gmap_is_active'=> 1,
'dbem_location_baloon_format' => "#_LOCATIONNAME
#_LOCATIONADDRESS - #_LOCATIONTOWN
Details",
'dbem_map_text_format' => '#_LOCATION#_LOCATIONADDRESS
#_LOCATIONTOWN
',
//Email Config
'dbem_email_disable_registration' => 0,
'dbem_rsvp_mail_port' => 465,
'dbem_smtp_host' => 'localhost',
'dbem_mail_sender_name' => '',
'dbem_rsvp_mail_send_method' => 'mail',
'dbem_rsvp_mail_SMTPAuth' => 1,
//Image Manipulation
'dbem_image_max_width' => 700,
'dbem_image_max_height' => 700,
'dbem_image_max_size' => 204800,
//Calendar Options
'dbem_list_date_title' => __('Events', 'dbem').' - #j #M #y',
'dbem_full_calendar_event_format' => '#_EVENTLINK',
'dbem_full_calendar_long_events' => '0',
'dbem_display_calendar_day_single_yes' => 1,
'dbem_small_calendar_event_title_format' => "#_NAME",
'dbem_small_calendar_event_title_separator' => ", ",
'dbem_display_calendar_order' => 'ASC',
'dbem_display_calendar_orderby' => 'event_name,event_start_time',
'dbem_display_calendar_events_limit' => get_option('dbem_full_calendar_events_limit',3),
'dbem_display_calendar_events_limit_msg' => __('more...','dbem'),
//General Settings
'dbem_require_location' => 0,
'dbem_locations_enabled' => 1,
'dbem_use_select_for_locations' => 0,
'dbem_attributes_enabled' => 1,
'dbem_recurrence_enabled'=> 1,
'dbem_rsvp_enabled'=> 1,
'dbem_categories_enabled'=> 1,
'dbem_tags_enabled' => 1,
'dbem_placeholders_custom' => '',
'dbem_location_attributes_enabled' => 1,
'dbem_location_placeholders_custom' => '',
//Title rewriting compatability
'dbem_disable_title_rewrites'=> false,
'dbem_title_html' => '#_PAGETITLE
',
//Bookings
'dbem_bookings_form_max' => 20,
'dbem_bookings_registration_disable' => 0,
'dbem_bookings_registration_user' => '',
'dbem_bookings_anonymous' => 1,
'dbem_bookings_approval' => 1, //approval is on by default
'dbem_bookings_approval_reserved' => 0, //overbooking before approval?
'dbem_bookings_login_form' => 1, //show login form on booking area
'dbem_bookings_approval_overbooking' => 0, //overbooking possible when approving?
'dbem_bookings_double'=>0,//double bookings or more, users can't double book by default
'dbem_bookings_user_cancellation' => 1, //can users cancel their booking?
'dbem_bookings_currency' => 'USD',
'dbem_bookings_currency_decimal_point' => $decimal_point,
'dbem_bookings_currency_thousands_sep' => $thousands_sep,
'dbem_bookings_currency_format' => '@#',
'dbem_bookings_tax' => 0, //extra tax
'dbem_bookings_tax_auto_add' => 0, //adjust prices to show tax?
//messages
'dbem_booking_feedback_pending' =>__('Booking successful, pending confirmation (you will also receive an email once confirmed).', 'dbem'),
'dbem_booking_feedback' => __('Booking successful.', 'dbem'),
'dbem_booking_feedback_full' => __('Booking cannot be made, not enough spaces available!', 'dbem'),
'dbem_booking_feedback_log_in' => __('You must log in or register to make a booking.','dbem'),
'dbem_booking_feedback_nomail' => __('However, there were some problems whilst sending confirmation emails to you and/or the event contact person. You may want to contact them directly and letting them know of this error.', 'dbem'),
'dbem_booking_feedback_error' => __('Booking could not be created','dbem').':',
'dbem_booking_feedback_email_exists' => __('This email already exists in our system, please log in to register to proceed with your booking.','dbem'),
'dbem_booking_feedback_new_user' => __('A new user account has been created for you. Please check your email for access details.','dbem'),
'dbem_booking_feedback_reg_error' => __('There was a problem creating a user account, please contact a website administrator.','dbem'),
'dbem_booking_feedback_already_booked' => __('You already have booked a seat at this event.','dbem'),
'dbem_booking_feedback_min_space' => __('You must request at least one space to book an event.','dbem'),
//Emails
'dbem_default_contact_person' => 1, //admin
'dbem_bookings_notify_admin' => 0,
'dbem_bookings_contact_email' => 1,
'dbem_bookings_contact_email_subject' => __("New Booking",'dbem'),
'dbem_bookings_contact_email_body' => str_replace("
", "\n\r", $contact_person_email_body_localizable),
'dbem_contactperson_email_cancelled_subject' => __("Booking Cancelled",'dbem'),
'dbem_contactperson_email_cancelled_body' => str_replace("
", "\n\r", $contact_person_email_cancelled_body_localizable),
'dbem_bookings_email_pending_subject' => __("Booking Pending",'dbem'),
'dbem_bookings_email_pending_body' => str_replace("
", "\n\r", $respondent_email_pending_body_localizable),
'dbem_bookings_email_rejected_subject' => __("Booking Rejected",'dbem'),
'dbem_bookings_email_rejected_body' => str_replace("
", "\n\r", $respondent_email_rejected_body_localizable),
'dbem_bookings_email_confirmed_subject' => __('Booking Confirmed','dbem'),
'dbem_bookings_email_confirmed_body' => str_replace("
", "\n\r", $respondent_email_body_localizable),
'dbem_bookings_email_cancelled_subject' => __('Booking Cancelled','dbem'),
'dbem_bookings_email_cancelled_body' => str_replace("
", "\n\r", $respondent_email_cancelled_body_localizable),
//Bookings Form - beta - not working at all yet
'dbem_bookings_page' => 'Date/Time - #j #M #Y #_12HSTARTTIME #@_{ \u\n\t\i\l j M Y}
Where - #_LOCATIONLINK
#_EXCERPT #_BOOKINGFORM'.__('Powered by','dbem').'events manager
',
'dbem_bookings_page_title' => __('Bookings - #_NAME','dbem'),
//Ticket Specific Options
'dbem_bookings_tickets_orderby' => 'ticket_price DESC, ticket_name ASC',
'dbem_bookings_tickets_priority' => 0,
'dbem_bookings_tickets_show_unavailable' => 0,
'dbem_bookings_tickets_show_loggedout' => 1,
'dbem_bookings_tickets_single' => 0,
'dbem_bookings_tickets_single_form' => 0,
//My Bookings Page
'dbem_bookings_my_title_format' => __('My Bookings','dbem'),
//Flags
'dbem_hello_to_user' => 1,
//BP Settings
'dbem_bp_events_list_format_header' => '',
'dbem_bp_events_list_format' => '- #_EVENTLINK - #j #M #Y #_12HSTARTTIME #@_{ \u\n\t\i\l j M Y}
- #_LOCATIONLINK - #_LOCATIONADDRESS, #_LOCATIONTOWN
',
'dbem_bp_events_list_format_footer' => '
',
'dbem_bp_events_list_none_format' => ''.__('No Events','dbem').'
',
/*
* Custom Post Options - set up to mimick old EM settings and install with minimal setup for most users
*/
//slugs
'dbem_cp_events_slug' => 'events',
'dbem_cp_locations_slug' => 'locations',
'dbem_taxonomy_category_slug' => 'events/categories',
'dbem_taxonomy_tag_slug' => 'events/tags',
//event cp options
'dbem_cp_events_template_page' => 0,
'dbem_cp_events_formats' => 1,
'dbem_cp_events_has_archive' => 1,
'dbem_events_default_archive_orderby' => '_start_ts',
'dbem_events_default_archive_order' => 'ASC',
'dbem_cp_events_archive_formats' => 1,
'dbem_cp_events_search_results' => 0,
'dbem_cp_events_custom_fields' => 0,
'dbem_cp_events_comments' => 1,
//location cp options
'dbem_cp_locations_template_page' => 0,
'dbem_cp_locations_formats' => 1,
'dbem_cp_locations_has_archive' => 1,
'dbem_locations_default_archive_orderby' => 'title',
'dbem_locations_default_archive_order' => 'ASC',
'dbem_cp_locations_archive_formats' => 1,
'dbem_cp_locations_search_results' => 0,
'dbem_cp_locations_custom_fields' => 0,
'dbem_cp_locations_comments' => 1,
//category cp options
'dbem_cp_categories_formats' => 1,
'dbem_categories_default_archive_orderby' => 'event_start_date,event_start_time,event_name',
'dbem_categories_default_archive_order' => 'ASC',
//category cp options
'dbem_cp_tags_formats' => 1,
'dbem_tags_default_archive_orderby' => 'event_start_date,event_start_time,event_name',
'dbem_tags_default_archive_order' => 'ASC',
);
foreach($dbem_options as $key => $value){
add_option($key, $value);
}
if( !get_option('dbem_version') ){ add_option('dbem_credits',1); }
if( get_option('dbem_version') != '' && get_option('dbem_version') < 5 ){
//make events, cats and locs pages
update_option('dbem_cp_events_template_page',1);
update_option('dbem_cp_locations_template_page',1);
//reset orderby, or convert fields to new fieldnames
$EM_Event = new EM_Event();
$orderbyvals = explode(',', get_option('dbem_events_default_orderby'));
$orderby = array();
foreach($orderbyvals as $val){
if(array_key_exists('event_'.$val, $EM_Event->fields)){
$orderby[] = 'event_'.$val;
}
}
$orderby = (count($orderby) > 0) ? implode(',',$orderby):$dbem_options['dbem_events_default_orderby'];
update_option('dbem_events_default_orderby',$orderby);
//Locations and categories weren't controlled in v4, so just reset them
update_option('dbem_locations_default_orderby','location_name');
update_option('dbem_categories_default_orderby','name');
//Update the slugs if necessary
$events_page_id = get_option ( 'dbem_events_page' );
$events_page = get_post($events_page_id);
update_option('dbem_cp_events_slug', $events_page->post_name);
update_option('dbem_taxonomy_tag_slug', $events_page->post_name.'/tags');
if( defined('EM_LOCATIONS_SLUG') && EM_LOCATIONS_SLUG != 'locations' ) update_option('dbem_cp_locations_slug', EM_LOCATIONS_SLUG);
if( defined('EM_CATEGORIES_SLUG') && EM_CATEGORIES_SLUG != 'categories' ) update_option('dbem_taxonomy_category_slug', $events_page->post_name.'/'.EM_CATEGORIES_SLUG);
}
}
function em_set_mass_caps( $roles, $caps ){
global $wp_roles;
foreach( $roles as $user_role ){
foreach($caps as $cap){
$wp_roles->add_cap($user_role, $cap);
}
}
}
function em_set_capabilities(){
//Get default roles
global $wp_roles;
if( get_option('dbem_version') == '' ){
//Assign caps in groups, as we go down, permissions are "looser"
$caps = array(
/* Event Capabilities */
'publish_events', 'delete_others_events', 'edit_others_events', 'manage_others_bookings',
/* Recurring Event Capabilties */
'publish_recurring_events', 'delete_others_recurring_events', 'edit_others_recurring_events',
/* Location Capabilities */
'publish_locations', 'delete_others_locations', 'delete_locations', 'edit_others_locations',
/* Category Capabilities */
'delete_event_categories', 'edit_event_categories'
);
em_set_mass_caps( array('administrator','editor'), $caps );
//Add all the open caps
$loose_caps = array(
'manage_bookings', 'upload_event_images',
/* Event Capabilities */
'delete_events', 'edit_events', 'read_private_events',
/* Recurring Event Capabilties */
'delete_recurring_events', 'edit_recurring_events',
/* Location Capabilities */
'edit_locations', 'read_private_locations', 'read_others_locations',
);
em_set_mass_caps( array('administrator','editor','contributor','author','subscriber'), $loose_caps);
}
if( get_option('dbem_version') && get_option('dbem_version') < 5 ){
//Add new caps that are similar to old ones
$conditional_caps = array(
'publish_events' => 'publish_locations,publish_recurring_events',
'edit_others_events' => 'edit_others_recurring_events',
'delete_others_events' => 'delete_others_recurring_events',
'edit_categories' => 'edit_event_categories,delete_event_categories',
'edit_recurrences' => 'edit_recurring_events,delete_recurring_events',
'edit_events' => 'upload_event_images'
);
$default_caps = array( 'read_private_events', 'read_private_locations' );
foreach($conditional_caps as $cond_cap => $new_caps){
foreach( $wp_roles->role_objects as $role_name => $role ){
if($role->has_cap($cond_cap)){
foreach(explode(',', $new_caps) as $new_cap){
$role->add_cap($new_cap);
}
}
}
}
em_set_mass_caps( array('administrator','editor','contributor','author','subscriber'), $default_caps);
}
}
function em_create_events_page(){
global $wpdb,$current_user;
$event_page_id = get_option('dbem_events_page');
if( empty($event_page_id) ){
$post_data = array(
'post_status' => 'publish',
'post_type' => 'page',
'ping_status' => get_option('default_ping_status'),
'post_content' => 'CONTENTS',
'post_excerpt' => 'CONTENTS',
'post_title' => __('Events','dbem')
);
$post_id = wp_insert_post($post_data, false);
if( $post_id > 0 ){
update_option('dbem_events_page', $post_id);
//Now Locations Page
$post_data = array(
'post_status' => 'publish',
'post_parent' => $post_id,
'post_type' => 'page',
'ping_status' => get_option('default_ping_status'),
'post_content' => 'CONTENTS',
'post_excerpt' => '',
'post_title' => __('Locations','dbem')
);
$loc_id = wp_insert_post($post_data, false);
update_option('dbem_locations_page', $loc_id);
//Now Categories Page
$post_data = array(
'post_status' => 'publish',
'post_parent' => $post_id,
'post_type' => 'page',
'ping_status' => get_option('default_ping_status'),
'post_content' => 'CONTENTS',
'post_excerpt' => '',
'post_title' => __('Categories','dbem')
);
$cat_id = wp_insert_post($post_data, false);
update_option('dbem_categories_page', $cat_id);
//Now Bookings Page
$post_data = array(
'post_status' => 'publish',
'post_parent' => $post_id,
'post_type' => 'page',
'ping_status' => get_option('default_ping_status'),
'post_content' => 'CONTENTS',
'post_excerpt' => '',
'post_title' => __('My Bookings','dbem'),
'post_slug' => 'my-bookings'
);
$bookings_post_id = wp_insert_post($post_data, false);
update_option('dbem_my_bookings_page', $bookings_post_id);
}
}
}
// migrate old dbem tables to new em ones
function em_migrate_v4(){
global $wpdb, $blog_id;
//before making any moves, let's create new pages for locations na dcats
$event_page_id = get_option('dbem_events_page');
if( !empty($event_page_id) ){
if( !get_option('dbem_locations_page') ){
$post_data = array(
'post_status' => 'publish',
'post_parent' => $event_page_id,
'post_type' => 'page',
'ping_status' => get_option('default_ping_status'),
'post_content' => 'CONTENTS',
'post_excerpt' => '',
'post_title' => get_option('dbem_locations_page_title', __('Locations','dbem')),
'post_slug' => get_option('dbem_cp_locations_slug')
);
$loc_post_id = wp_insert_post($post_data, false);
update_option('dbem_locations_page', $loc_post_id);
}
if( !get_option('dbem_categories_page') ){
//Now Categories Page
$post_data = array(
'post_status' => 'publish',
'post_parent' => $event_page_id,
'post_type' => 'page',
'ping_status' => get_option('default_ping_status'),
'post_content' => 'CONTENTS',
'post_excerpt' => '',
'post_title' => get_option('dbem_categories_page_title', __('Categories','dbem')),
'post_slug' => get_option('dbem_cp_categories_slug')
);
$cat_post_id = wp_insert_post($post_data, false);
update_option('dbem_categories_page', $cat_post_id);
}
if( !get_option('dbem_my_bookings_page') ){
//Now Categories Page
$post_data = array(
'post_status' => 'publish',
'post_parent' => $event_page_id,
'post_type' => 'page',
'ping_status' => get_option('default_ping_status'),
'post_content' => 'CONTENTS',
'post_excerpt' => '',
'post_title' => __('My Bookings','dbem'),
'post_slug' => 'my-bookings'
);
$bookings_post_id = wp_insert_post($post_data, false);
update_option('dbem_my_bookings_page', $bookings_post_id);
}
}
//set shared vars
$limit = 100;
//-- LOCATIONS --
if( !is_multisite() || (EM_MS_GLOBAL && is_main_site($blog_id)) || (!EM_MS_GLOBAL && is_multisite()) ){ //old locations will always belong to the main blog when migrated, since we didn't have previous blog ids
if( is_multisite() ){
$this_blog = $blog_id;
}else{
$this_blog = 0;
}
//set location statuses and blog id for all locations
$wpdb->query('UPDATE '.EM_LOCATIONS_TABLE.' SET location_status=1, blog_id='.$this_blog.' WHERE blog_id IS NULL');
//first create location posts
$sql = 'SELECT * FROM '.EM_LOCATIONS_TABLE.' WHERE post_id = 0 LIMIT '.$limit;
$locations = $wpdb->get_results($sql, ARRAY_A);
//get location image directory
$dir = (EM_IMAGE_DS == '/') ? 'locations/':'';
while( count($locations) > 0 ){
em_migrate_locations($locations);
$locations = $wpdb->get_results($sql, ARRAY_A); //get more locations and continue looping
}
}
//-- EVENTS & Recurrences --
if( is_multisite() ){
if(EM_MS_GLOBAL && is_main_blog()){
$sql = "SELECT * FROM ".EM_EVENTS_TABLE." WHERE post_id=0 AND (blog_id=$blog_id OR blog_id=0 OR blog_id IS NULL) LIMIT $limit";
}elseif(EM_MS_GLOBAL){
$sql = "SELECT * FROM ".EM_EVENTS_TABLE." WHERE post_id=0 AND blog_id=$blog_id LIMIT $limit";
}else{
$sql = "SELECT * FROM ".EM_EVENTS_TABLE." WHERE post_id=0 LIMIT $limit";
}
}else{
$sql = "SELECT * FROM ".EM_EVENTS_TABLE." WHERE post_id=0 LIMIT $limit";
}
//create posts
$events = $wpdb->get_results($sql, ARRAY_A);
while( count($events) > 0 ){
em_migrate_events($events);
$events = $wpdb->get_results($sql, ARRAY_A); //get more locations and continue looping
}
//-- CATEGORIES --
//Create the terms according to category table, use the category owner for the term ids to store this
$categories = $wpdb->get_results("SELECT * FROM ".EM_CATEGORIES_TABLE, ARRAY_A); //taking a wild-hope guess that there aren't too many categories on one site/blog
foreach( $categories as $category ){
//get all events with this category before resetting ids
$sql = "SELECT post_id FROM ".EM_EVENTS_TABLE.", ".EM_META_TABLE." WHERE event_id=object_id AND meta_key='event-category' AND meta_value='{$category['category_id']}'";
$category_posts = $wpdb->get_col($sql);
//get or create new term
$term = get_term_by('slug', $category['category_slug'], EM_TAXONOMY_CATEGORY);
if( $term === false ){
//term not created yet, let's create it
$term_array = wp_insert_term($category['category_name'], EM_TAXONOMY_CATEGORY, array(
'description' => $category['category_description'],
'slug' => $category['category_slug']
));
if( is_array($term_array) ){
//update category bg-color if used before
$wpdb->query('UPDATE '.EM_META_TABLE." SET object_id='{$term_array['term_id']}' WHERE meta_key='category-bgcolor' AND object_id={$category['category_id']}");
$wpdb->query('UPDATE '.EM_META_TABLE." SET meta_value='{$term_array['term_id']}' WHERE meta_key='event-category' AND meta_value={$category['category_id']}");
// and assign category image url if file exists
$dir = (EM_IMAGE_DS == '/') ? 'categories/':'';
foreach(array(1 => 'gif', 2 => 'jpg', 3 => 'png') as $mime_type) {
$file_name = $dir."category-{$category['category_id']}.$mime_type";
if( file_exists( EM_IMAGE_UPLOAD_DIR.$file_name) ) {
$wpdb->insert(EM_META_TABLE, array('object_id'=>$term_array['term_id'],'meta_key'=>'category-image','meta_value'=>EM_IMAGE_UPLOAD_URI.$file_name));
break;
}
}
}
}
//set event terms in wp tables
foreach($category_posts as $post_id){
wp_set_object_terms($post_id, $category['category_slug'], EM_TAXONOMY_CATEGORY, true);
}
}
update_option('dbem_migrate_images_nag', 1);
update_option('dbem_migrate_images', 1);
}
function em_migrate_events($events){
global $wpdb;
//disable actions
remove_action('save_post',array('EM_Event_Recurring_Post_Admin','save_post'));
remove_action('save_post',array('EM_Event_Post_Admin','save_post'),10,1);
$post_fields = array('event_slug','event_owner','event_name','event_attributes','post_id','post_content');
$event_metas = array(); //restart metas
foreach($events as $event){
//new post info
$post_array = array();
$post_array['post_type'] = $event['recurrence'] == 1 ? 'event-recurring' : EM_POST_TYPE_EVENT;
$post_array['post_title'] = $event['event_name'];
$post_array['post_content'] = $event['post_content'];
$post_array['post_status'] = (!isset($event['event_status']) || $event['event_status']) ? 'publish':'pending';
$post_array['post_author'] = $event['event_owner'];
$post_array['post_slug'] = $event['event_slug'];
$event['start_ts'] = strtotime($event['event_start_date']);
$event['end_ts'] = strtotime($event['event_end_date']);
//Save post, register post id in index
$post_id = wp_insert_post($post_array);
if( is_wp_error($post_id) || $post_id == 0 ){ $post_id = 999999999999999999; }//hopefully nobody blogs that much... if you do, and you're reading this, maybe you should be hiring me for the upgrade ;) }
if( $post_id != 999999999999999999 ){
$wpdb->query('UPDATE '.EM_EVENTS_TABLE." SET post_id='$post_id' WHERE event_id='{$event['event_id']}'");
//meta
foreach($event as $meta_key => $meta_val){
if( !in_array($meta_key, $post_fields) && $meta_key != 'event_attributes' ){
$event_metas[] = $wpdb->prepare("(%d, '%s', '%s')", array($post_id, '_'.$meta_key, $meta_val));
}elseif($meta_key == 'event_attributes'){
$event_attributes = unserialize($meta_val); //from em table it's serialized
if( is_array($event_attributes) ){
foreach($event_attributes as $att_key => $att_val){
$event_metas[] = $wpdb->prepare("(%d, '%s', '%s')", array($post_id, $att_key, $att_val));
}
}
}
}
}
}
//insert the metas in one go, faster than one by one
if( count($event_metas) > 0 ){
$result = $wpdb->query("INSERT INTO ".$wpdb->postmeta." (post_id,meta_key,meta_value) VALUES ".implode(',',$event_metas));
}
}
function em_migrate_locations($locations){
global $wpdb;
//disable actions
remove_action('save_post',array('EM_Location_Post_Admin','save_post'));
$location_metas = array(); //restart metas
$post_fields = array('post_id','location_slug','location_name','post_content','location_owner');
foreach($locations as $location){
//new post info
$post_array = array();
$post_array['post_type'] = EM_POST_TYPE_LOCATION;
$post_array['post_title'] = $location['location_name'];
$post_array['post_content'] = $location['post_content'];
$post_array['post_status'] = 'publish';
$post_array['post_author'] = $location['location_owner'];
//Save post, register post id in index
$post_id = wp_insert_post($post_array);
if( is_wp_error($post_id) || $post_id == 0 ){ $post_id = 999999999999999999; }//hopefully nobody blogs that much... if you do, and you're reading this, maybe you should be hiring me for the upgrade ;) }
$wpdb->query('UPDATE '.EM_LOCATIONS_TABLE." SET post_id='$post_id' WHERE location_id='{$location['location_id']}'");
//meta
foreach($location as $meta_key => $meta_val){
if( !in_array($meta_key, $post_fields) ){
$location_metas[] = $wpdb->prepare("(%d, '%s', '%s')", array($post_id, '_'.$meta_key, $meta_val));
}
}
}
//insert the metas in one go, faster than one by one
if( count($location_metas) > 0 ){
$result = $wpdb->query("INSERT INTO ".$wpdb->postmeta." (post_id,meta_key,meta_value) VALUES ".implode(',',$location_metas));
}
}
function em_migrate_uploads(){
//build array of images
global $wpdb;
$mime_types = array(1 => 'gif', 2 => 'jpg', 3 => 'png');
require_once(ABSPATH . "wp-admin" . '/includes/file.php');
require_once(ABSPATH . "wp-admin" . '/includes/image.php');
$pattern = (EM_IMAGE_DS == '/') ? EM_IMAGE_UPLOAD_DIR.'*/*':EM_IMAGE_UPLOAD_DIR.'*';
$files = glob($pattern);
$file_array = array();
foreach($files as $file){
$matches = array();
if( preg_match('/\/(events|locations\/)?(event|location)-([0-9]+).([a-zA-Z]{3})/', $file, $matches) ){
$file_array[$matches[2]][$matches[3]] = array(
'file' => $file,
'url' => EM_IMAGE_UPLOAD_URI.$matches[1].$matches[2].'-'.$matches[3].'.'.$matches[4],
'type' => 'image/'.$matches[4],
);
}
}
$result = array('success'=>0, 'fail'=>0);
if( count($file_array) > 0 ){
foreach($file_array as $type => $file_type){
foreach($file_type as $id => $attachment){
if($type == 'event'){
$post = em_get_event($id);
}elseif($type == 'location'){
$post = em_get_location($id);
}
if ( !empty($post->ID) ){
$attachment_data = array(
'post_mime_type' => $attachment['type'],
'post_title' => $post->post_title,
'post_content' => '',
'post_status' => 'inherit'
);
$attachment_id = wp_insert_attachment( $attachment_data, $attachment['file'], $post->ID );
$attachment_metadata = wp_generate_attachment_metadata( $attachment_id, $attachment['file'] );
wp_update_attachment_metadata( $attachment_id, $attachment_metadata );
//delete the old attachment
update_post_meta($post->post_id, '_thumbnail_id', $attachment_id);
//is it recurring? If so add attachment to recurrences
if( $type == 'event' && $post->is_recurring() ){
$results = $wpdb->get_col('SELECT post_id FROM '.EM_EVENTS_TABLE.' WHERE recurrence_id='.$post->event_id);
foreach ($results as $post_id){
update_post_meta($post_id, '_thumbnail_id', $attachment_id);
}
}
$result['success']++;
}
}
}
}
delete_option('dbem_migrate_images_nag');
delete_option('dbem_migrate_images');
return $result;
}
?>