Solved

Strange error message when generating dynamic iCalendar events

Posted on 2008-06-11
2
309 Views
Last Modified: 2011-10-19
I am using PHP to generate iCalendar events using data from a MySQL DB.  To my eye, the .ics file it generates is well formed, but I keep getting an import error that says "This error can appear if you have attempted to save a recurring Lunar appointment in iCalendar format. To avoid this error, set the appointment option to Gregorian instead of Lunar."  I can not figure out what's wrong.  Below is the code, attached is a sample .ics file that this code generates (in txt format due to upload restrictions).  Any help would be appreciated, thanks!
<?php
    header("Content-Type: text/Calendar");
    header("Content-Disposition: inline; filename=sample.ics");
	
	include_once("config.inc");
	include_once("display-functions.inc");
 
	$intTrainingID=$_REQUEST['id'];
 
	$qr="SELECT * FROM tblTrainingClasses WHERE intTrainingID='$intTrainingID'";
	$result=odbc_exec($dbconn, $qr) or die ("Could not execute query...".obdc_errormsg($dbconn));
  	$intUserID=odbc_result($result,"intUserID");
  	
  	$datClassEnd=odbc_result($result,"datClassEnd");
  	$datRequest=odbc_result($result,"datRequest");
 
	$vCalStart = date("Ymd", strtotime($datClassStart))."T090000";
	$vCalEnd = date("Ymd", strtotime($datClassEnd))."T180000";
?>
BEGIN:VCALENDAR<?="\r\n"?>
PRODID:-//Microsoft Corporation//Outlook 10.0 MIMEDIR//EN<?="\r\n"?>
VERSION:2.0<?="\r\n"?>
METHOD:REQUEST<?="\r\n"?>
BEGIN:VEVENT<?="\r\n"?>
DTSTAMP:<?php echo $vCalStart . "Z\r\n"; ?>
DTSTART:<?php echo $vCalStart . "Z\r\n"; ?>
DTEND:<?php echo $vCalEnd . "Z\r\n"; ?>
SUMMARY:<?php echo "sample summary\r\n"; ?>
DESCRIPTION:<?php echo "sample description will be filled in later\r\n"; ?>
UID:123<?="\r\n"?>
X-MICROSOFT-CDO-IMPORTANCE:1<?="\r\n"?>
PRIORITY:3<?="\r\n"?>
CLASS:PUBLIC<?="\r\n"?>
END:VEVENT<?="\r\n"?>
END:VCALENDAR

Open in new window

sample.txt
0
Comment
Question by:lghaman123
2 Comments
 
LVL 109

Accepted Solution

by:
Ray Paseur earned 500 total points
ID: 21773165
You might want to lose that VERSION statement.  See the post here:
http://calendarswamp.blogspot.com/2005/08/outlook-2003-for-ical-import-use.html

I've attached my own iCal code below that seems to be working OK.  There are some function calls that may look kind of "pidgin" but I'm sure you will be able to see the patterns OK.

HTH, ~Ray
<?php // LAPRBass vcal_generator.php
$config_page= getcwd() . '/_config.php'; require_once($config_page);
 
$t_key	= get_clean_numeric_string($_GET[t]);
if (!is_numeric($t_key)) { die("Error T"); }
 
$tsql	= "SELECT * FROM {$my_dbt_prefix}_TOURNAMENTS WHERE _key = $t_key LIMIT 1";
if (!$t	= mysql_query("$tsql", $db_connection)) { non_fatal_query_error($tsql); die(); }
if (!$t_rows= mysql_num_rows($t)) { die("Error T=$t_key"); }
$trow	= mysql_fetch_assoc($t);
foreach ($trow as $k => $v) { $$k = stripslashes($v); } 
 
$csql	= "SELECT * FROM {$my_dbt_prefix}_SERIES WHERE _key = $c_key LIMIT 1";
if (!$c	= mysql_query("$csql", $db_connection)) { non_fatal_query_error($csql); die(); }
if (!$c_rows= mysql_num_rows($c)) { die('Error C=$c_key'); }
$crow	= mysql_fetch_assoc($c);
foreach ($crow as $k => $v) { $$k = stripslashes($v); }
 
$p_date		= date('l, F j, Y', strtotime($date));
$p_start	= date('g:ia', strtotime($start));
$p_finish	= date('g:ia', strtotime($finish));
$my_start	= date('D, M j, Y g:ia', strtotime($p_date .' '. $p_start));
 
$vcalstart	= date("Ymd", strtotime($date)) .'T'. date("His", strtotime($start));
$vcalend	= date("Ymd", strtotime($date)) .'T'. date("His", strtotime($finish));
 
$summary	 = "LAPRBASS Tournament: $p_date";
 
$dump		 = "";
$dump		.= "$year $name" . "=0D=0A";
$dump		.= "Mark your calendar for $my_start" . "=0D=0A";
if ($launch != "") { $dump .= "Launch: $launch" . " =0D=0A"; }
if ($title  != "") { $dump .= "$title" . " =0D=0A"; }
$dump		.= "http://www.LAPRBASS.com" . "=0D=0A";
 
$filename = "LAPRBASS" . $t_key . ".vcs";
 
header("Content-Type: text/x-vCalendar");
header("Content-Disposition: inline; filename=$filename");
 
?>
BEGIN:VCALENDAR
VERSION:1.0
PRODID:LAPRBASS Web Calendar
BEGIN:VEVENT
SUMMARY:<?php echo "$summary\n"; ?>
DESCRIPTION;ENCODING=QUOTED-PRINTABLE: <?php echo "$dump\n"; ?>
DTSTART:<?php echo "$vcalstart\n"; ?>
DTEND:<?php echo "$vcalend\n"; ?>
END:VEVENT
END:VCALENDAR

Open in new window

0
 

Author Comment

by:lghaman123
ID: 21823943
Hi Ray, sorry for the delayed response, I got temporarily moved to a different project.  I tried a very similar variation of this code at one point.  After more testing I actually determined that the error was an error being output by my config file which I had included.  This code is definitely working for me now that I fixed my other situation.  Thanks!
0

Featured Post

NFR key for Veeam Backup for Microsoft Office 365

Veeam is happy to provide a free NFR license (for 1 year, up to 10 users). This license allows for the non‑production use of Veeam Backup for Microsoft Office 365 in your home lab without any feature limitations.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Excel macro : save an outlook 2010 mail message to a folder 4 39
Wordpress Pagination 1 29
Show Ruler in Outlook 2010 STILL NOT SHOWING! 4 25
Ajax and PHP 4 31
What does UTC stand for?  “Coordinated Universal Time” – Think of this as the true time on Planet Earth that never changes with the exception of minor leap seconds here and there to account for the changes in the planet's rotation.   What does th…
Finding original email is quite difficult due to their duplicates. From this article, you will come to know why multiple duplicates of same emails appear and how to delete duplicate emails from Outlook securely and instantly while vital emails remai…
The viewer will learn how to count occurrences of each item in an array.
CodeTwo Sync for iCloud (http://www.codetwo.com/sync-for-icloud?sts=6554) automatically synchronizes your Outlook 2016, 2013, 2010 or 2007 folders with iCloud folders available via iCloud Control Panel. This lets you automatically sync them with…

827 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question