source: trunk/prototype/services/iCal.php @ 5523

Revision 5523, 55.0 KB checked in by cristiano, 12 years ago (diff)

Ticket #2434 - Compatibilidade de ics com outlook2000 e tamnho de textarea incorreto

Line 
1<?php
2
3require_once ROOTPATH.'/plugins/icalcreator/iCalUtilityFunctions.class.php';
4require_once ROOTPATH.'/plugins/icalcreator/iCalcreator.class.php';       
5require_once ROOTPATH.'/modules/calendar/constants.php';
6
7//TODO:Timeout request
8set_time_limit( 600 );
9class iCal implements Formatter
10{
11    static $timezonesMap = array ('(GMT-12.00) International Date Line West' => 'Etc/GMT+12', '(GMT-11.00) Midway Island / Samoa' => 'Pacific/Midway', '(GMT-10.00) Hawaii' => 'Pacific/Honolulu', '(GMT-09.00) Alaska' => 'America/Anchorage', '(GMT-08.00) Pacific Time (US & Canada) / Tijuana' => 'America/Los_Angeles', '(GMT-08.00) Tijuana / Baja California' => 'America/Tijuana', '(GMT-07.00) Arizona' => 'America/Phoenix', '(GMT-07.00) Chihuahua / La Paz / Mazatlan - Old' => 'America/Chihuahua', '(GMT-07.00) Mountain Time (US & Canada)' => 'America/Denver', '(GMT-06.00) Central America' => 'America/Guatemala', '(GMT-06.00) Central Time (US & Canada)' => 'America/Chicago', '(GMT-06.00) Guadalajara / Mexico City / Monterrey - Old' => 'America/Mexico_City', '(GMT-06.00) Saskatchewan' => 'America/Regina', '(GMT-05.00) Bogota / Lima / Quito' => 'America/Bogota', '(GMT-05.00) Eastern Time (US & Canada)' => 'America/New_York', '(GMT-05.00) Indiana (East)' => 'America/Indiana/Indianapolis', '(GMT-04.30) Caracas' => 'America/Caracas', '(GMT-04.00) Atlantic Time (Canada)' => 'America/Halifax', '(GMT-04.00) Georgetown' => 'America/Guyana', '(GMT-04.00) Caracas / La Paz' => 'America/La_Paz', '(GMT-04.00) Manaus' => 'America/Manaus', '(GMT-04.00) Santiago' => 'America/Santiago', '(GMT-03.30) Newfoundland' => 'America/St_Johns', '(GMT-03.00) Brasilia' => 'America/Sao_Paulo', '(GMT-03.00) Buenos Aires / Georgetown' => 'America/Argentina/Buenos_Aires', '(GMT-03.00) Greenland' => 'America/Godthab', '(GMT-03.00) Montevideo' => 'America/Montevideo', '(GMT-02.00) Mid-Atlantic' => 'Atlantic/South_Georgia', '(GMT-01.00) Azores' => 'Atlantic/Azores', '(GMT-01.00) Cape Verde Is.' => 'Atlantic/Cape_Verde', '(GMT) Casablanca' => 'Africa/Casablanca', '(GMT) Greenwich Mean Time - Dublin / Edinburgh / Lisbon / London' => 'Europe/London', '(GMT) Casablanca / Monrovia' => 'Africa/Monrovia', '(GMT+01.00) Amsterdam / Berlin / Bern / Rome / Stockholm / Vienna' => 'Europe/Berlin', '(GMT+01.00) Belgrade / Bratislava / Budapest / Ljubljana / Prague' => 'Europe/Belgrade', '(GMT+01.00) Brussels / Copenhagen / Madrid / Paris' => 'Europe/Brussels', '(GMT+01.00) Sarajevo / Skopje / Warsaw / Zagreb' => 'Europe/Warsaw', '(GMT+01.00) West Central Africa' => 'Africa/Algiers', '(GMT+02.00) Windhoek' => 'Africa/Windhoek', '(GMT+02.00) Amman' => 'Asia/Amman', '(GMT+02.00) Bucharest' => 'Europe/Athens', '(GMT+02.00) Beirut' => 'Asia/Beirut', '(GMT+02.00) Cairo' => 'Africa/Cairo', '(GMT+02.00) Harare / Pretoria' => 'Africa/Harare', '(GMT+02.00) Helsinki / Kyiv / Riga / Sofia / Tallinn / Vilnius' => 'Europe/Helsinki', '(GMT+02.00) Jerusalem' => 'Asia/Jerusalem', '(GMT+02.00) Minsk' => 'Europe/Minsk', '(GMT+03.00) Baghdad' => 'Asia/Baghdad', '(GMT+03.00) Kuwait / Riyadh' => 'Asia/Kuwait', '(GMT+03.00) Moscow / St. Petersburg / Volgograd' => 'Europe/Moscow', '(GMT+03.00) Nairobi' => 'Africa/Nairobi', '(GMT+04.00) Caucasus Standard Time' => 'Asia/Tbilisi', '(GMT+03.30) Tehran' => 'Asia/Tehran', '(GMT+04.00) Abu Dhabi / Muscat' => 'Asia/Muscat', '(GMT+04.00) Baku / Tbilisi / Yerevan' => 'Asia/Baku', '(GMT+04.00) Yerevan' => 'Asia/Yerevan', '(GMT+04.30) Kabul' => 'Asia/Kabul', '(GMT+05.00) Ekaterinburg' => 'Asia/Yekaterinburg', '(GMT+05.00) Islamabad / Karachi / Tashkent' => 'Asia/Karachi', '(GMT+05.00) Tashkent' => 'Asia/Tashkent', '(GMT+05.30) Chennai / Kolkata / Mumbai / New Delhi' => 'Asia/Kolkata', '(GMT+06.00) Sri Jayawardenepura' => 'Asia/Colombo', '(GMT+05.45) Kathmandu' => 'Asia/Katmandu', '(GMT+06.00) Almaty / Novosibirsk' => 'Asia/Novosibirsk', '(GMT+06.00) Astana / Dhaka' => 'Asia/Dhaka', '(GMT+06.30) Rangoon' => 'Asia/Rangoon', '(GMT+07.00) Bangkok / Hanoi / Jakarta' => 'Asia/Bangkok', '(GMT+07.00) Krasnoyarsk' => 'Asia/Krasnoyarsk', '(GMT+08.00) Beijing / Chongqing / Hong Kong / Urumqi' => 'Asia/Hong_Kong', '(GMT+08.00) Irkutsk / Ulaan Bataar' => 'Asia/Irkutsk', '(GMT+08.00) Kuala Lumpur / Singapore' => 'Asia/Kuala_Lumpur', '(GMT+08.00) Perth' => 'Australia/Perth', '(GMT+08.00) Taipei' => 'Asia/Taipei', '(GMT+09.00) Osaka / Sapporo / Tokyo' => 'Asia/Tokyo', '(GMT+09.00) Seoul' => 'Asia/Seoul', '(GMT+09.00) Yakutsk' => 'Asia/Yakutsk', '(GMT+09.30) Adelaide' => 'Australia/Adelaide', '(GMT+09.30) Darwin' => 'Australia/Darwin', '(GMT+10.00) Brisbane' => 'Australia/Brisbane', '(GMT+10.00) Canberra / Melbourne / Sydney' => 'Australia/Sydney', '(GMT+10.00) Guam / Port Moresby' => 'Pacific/Guam', '(GMT+10.00) Hobart' => 'Australia/Hobart', '(GMT+10.00) Vladivostok' => 'Asia/Vladivostok', '(GMT+11.00) Magadan / Solomon Is. / New Caledonia' => 'Asia/Magadan', '(GMT+12.00) Auckland / Wellington' => 'Pacific/Auckland', '(GMT+12.00) Fiji / Kamchatka / Marshall Is.' => 'Pacific/Fiji', '(GMT+13.00) Nuku\'alofa' => 'Pacific/Tongatapu' );
12//    static $timezonesOutlookID = array('Europe/London' => '1' ,'Europe/Brussels' => '3' ,'Europe/Berlin' => '4' ,'America/New_York' => '5' ,'Europe/Belgrade' => '6' ,'Europe/Minsk' => '7' ,'America/Sao_Paulo' => '8' ,'America/Halifax' => '9' ,'America/New_York' => '10' ,'America/Chicago' => '11' ,'America/Denver' => '12' ,'America/Los_Angeles' => '13' ,'America/Anchorage' => '14' ,'Pacific/Honolulu' => '15' ,'Pacific/Midway' => '16' ,'Pacific/Auckland' => '17' ,'Australia/Brisbane' => '18' ,'Australia/Adelaide' => '19' ,'Asia/Tokyo' => '20' ,'Asia/Hong_Kong' => '21' ,'Asia/Bangkok' => '22' ,'Asia/Kolkata' => '23' ,'Asia/Muscat' => '24' ,'Asia/Tehran' => '25' ,'Asia/Baghdad' => '26' ,'Asia/Jerusalem' => '27' ,'America/St_Johns' => '28' ,'Atlantic/Azores' => '29' ,'Atlantic/South_Georgia' => '30' ,'Africa/Casablanca' => '31' ,'America/La_Paz' => '33' ,'America/Indiana/Indianapolis' => '34' ,'America/Bogota' => '35' ,'America/Regina' => '36' ,'America/Mexico_City' => '37' ,'America/Phoenix' => '38' ,'Etc/GMT+12' => '39' ,'Pacific/Fiji' => '40' ,'Asia/Magadan' => '41' ,'Australia/Hobart' => '42' ,'Pacific/Guam' => '43' ,'Australia/Darwin' => '44' ,'Asia/Hong_Kong' => '45' ,'Asia/Novosibirsk' => '46' ,'Asia/Kabul' => '48' ,'Africa/Cairo' => '49' ,'Africa/Harare' => '50' ,'Europe/Moscow' => '51' ,'Australia/Sydney' => '52' ,'Australia/Sydney' => '53' ,'Australia/Adelaide' => '54' ,'Australia/Hobart' => '55' ,'America/Santiago' => '56' ,'Australia/Pert' => '57' ,'America/Tijuana' => '59' ,'Asia/Tbilisi' => '60' ,'Australia/Sydney' => '61' ,'America/Caracas' => '62' ,'Asia/Amman' => '63' ,'Asia/Baku' => '64' ,'Asia/Yerevan' => '65' ,'Europe/Moscow' => '66' ,'America/Argentina/Buenos_Aires' => '67' ,'America/Montevideo' => '72'); 
13    static $suportedTimzones = array('Africa/Abidjan' ,'Africa/Accra' ,'Africa/Addis_Ababa' ,'Africa/Algiers' ,'Africa/Asmara' ,'Africa/Asmera' ,'Africa/Bamako' ,'Africa/Bangui' ,'Africa/Banjul' ,'Africa/Bissau' ,'Africa/Blantyre' ,'Africa/Brazzaville' ,'Africa/Bujumbura' ,'Africa/Cairo' ,'Africa/Casablanca' ,'Africa/Ceuta' ,'Africa/Conakry' ,'Africa/Dakar' ,'Africa/Dar_es_Salaam' ,'Africa/Djibouti' ,'Africa/Douala' ,'Africa/El_Aaiun' ,'Africa/Freetown' ,'Africa/Gaborone' ,'Africa/Harare' ,'Africa/Johannesburg' ,'Africa/Kampala' ,'Africa/Khartoum' ,'Africa/Kigali' ,'Africa/Kinshasa' ,'Africa/Lagos' ,'Africa/Libreville' ,'Africa/Lome' ,'Africa/Luanda' ,'Africa/Lubumbashi' ,'Africa/Lusaka' ,'Africa/Malabo' ,'Africa/Maputo' ,'Africa/Maseru' ,'Africa/Mbabane' ,'Africa/Mogadishu' ,'Africa/Monrovia' ,'Africa/Nairobi' ,'Africa/Ndjamena' ,'Africa/Niamey' ,'Africa/Nouakchott' ,'Africa/Ouagadougou' ,'Africa/Porto-Novo' ,'Africa/Sao_Tome' ,'Africa/Timbuktu' ,'Africa/Tripoli' ,'Africa/Tunis' ,'Africa/Windhoek' ,'America/Adak' ,'America/Anchorage' ,'America/Anguilla' ,'America/Antigua' ,'America/Araguaina' ,'America/Argentina/Buenos_Aires' ,'America/Argentina/Catamarca' ,'America/Argentina/ComodRivadavia' ,'America/Argentina/Cordoba' ,'America/Argentina/Jujuy' ,'America/Argentina/La_Rioja' ,'America/Argentina/Mendoza' ,'America/Argentina/Rio_Gallegos' ,'America/Argentina/Salta' ,'America/Argentina/San_Juan' ,'America/Argentina/San_Luis' ,'America/Argentina/Tucuman' ,'America/Argentina/Ushuaia' ,'America/Aruba' ,'America/Asuncion' ,'America/Atikokan' ,'America/Atka' ,'America/Bahia' ,'America/Barbados' ,'America/Belem' ,'America/Belize' ,'America/Blanc-Sablon' ,'America/Boa_Vista' ,'America/Bogota' ,'America/Boise' ,'America/Buenos_Aires' ,'America/Cambridge_Bay' ,'America/Campo_Grande' ,'America/Cancun' ,'America/Caracas' ,'America/Catamarca' ,'America/Cayenne' ,'America/Cayman' ,'America/Chicago' ,'America/Chihuahua' ,'America/Coral_Harbour' ,'America/Cordoba' ,'America/Costa_Rica' ,'America/Cuiaba' ,'America/Curacao' ,'America/Danmarkshavn' ,'America/Dawson_Creek' ,'America/Dawson' ,'America/Denver' ,'America/Detroit' ,'America/Dominica' ,'America/Edmonton' ,'America/Eirunepe' ,'America/El_Salvador' ,'America/Ensenada' ,'America/Fort_Wayne' ,'America/Fortaleza' ,'America/Glace_Bay' ,'America/Godthab' ,'America/Goose_Bay' ,'America/Grand_Turk' ,'America/Grenada' ,'America/Guadeloupe' ,'America/Guatemala' ,'America/Guayaquil' ,'America/Guyana' ,'America/Halifax' ,'America/Havana' ,'America/Hermosillo' ,'America/Indiana/Indianapolis' ,'America/Indiana/Knox' ,'America/Indiana/Marengo' ,'America/Indiana/Petersburg' ,'America/Indiana/Tell_City' ,'America/Indiana/Vevay' ,'America/Indiana/Vincennes' ,'America/Indiana/Winamac' ,'America/Indianapolis' ,'America/Inuvik' ,'America/Iqaluit' ,'America/Jamaica' ,'America/Jujuy' ,'America/Juneau' ,'America/Kentucky/Louisville' ,'America/Kentucky/Monticello' ,'America/Knox_IN' ,'America/La_Paz' ,'America/Lima' ,'America/Los_Angeles' ,'America/Louisville' ,'America/Maceio' ,'America/Managua' ,'America/Manaus' ,'America/Marigot' ,'America/Martinique' ,'America/Matamoros' ,'America/Mazatlan' ,'America/Mendoza' ,'America/Menominee' ,'America/Merida' ,'America/Mexico_City' ,'America/Miquelon' ,'America/Moncton' ,'America/Monterrey' ,'America/Montevideo' ,'America/Montreal' ,'America/Montserrat' ,'America/Nassau' ,'America/New_York' ,'America/Nipigon' ,'America/Nome' ,'America/Noronha' ,'America/North_Dakota/Center' ,'America/North_Dakota/New_Salem' ,'America/Ojinaga' ,'America/Panama' ,'America/Pangnirtung' ,'America/Paramaribo' ,'America/Phoenix' ,'America/Port_of_Spain' ,'America/Port-au-Prince' ,'America/Porto_Acre' ,'America/Porto_Velho' ,'America/Puerto_Rico' ,'America/Rainy_River' ,'America/Rankin_Inlet' ,'America/Recife' ,'America/Regina' ,'America/Resolute' ,'America/Rio_Branco' ,'America/Rosario' ,'America/Santa_Isabel' ,'America/Santarem' ,'America/Santiago' ,'America/Santo_Domingo' ,'America/Sao_Paulo' ,'America/Scoresbysund' ,'America/Shiprock' ,'America/St_Barthelemy' ,'America/St_Johns' ,'America/St_Kitts' ,'America/St_Lucia' ,'America/St_Thomas' ,'America/St_Vincent' ,'America/Swift_Current' ,'America/Tegucigalpa' ,'America/Thule' ,'America/Thunder_Bay' ,'America/Tijuana' ,'America/Toronto' ,'America/Tortola' ,'America/Vancouver' ,'America/Virgin' ,'America/Whitehorse' ,'America/Winnipeg' ,'America/Yakutat' ,'America/Yellowknife' ,'Antarctica/Casey' ,'Antarctica/Davis' ,'Antarctica/DumontDUrville' ,'Antarctica/Macquarie' ,'Antarctica/Mawson' ,'Antarctica/McMurdo' ,'Antarctica/Palmer' ,'Antarctica/Rothera' ,'Antarctica/South_Pole' ,'Antarctica/Syowa' ,'Antarctica/Vostok' ,'Arctic/Longyearbyen' ,'Asia/Aden' ,'Asia/Almaty' ,'Asia/Amman' ,'Asia/Anadyr' ,'Asia/Aqtau' ,'Asia/Aqtobe' ,'Asia/Ashgabat' ,'Asia/Ashkhabad' ,'Asia/Baghdad' ,'Asia/Bahrain' ,'Asia/Baku' ,'Asia/Bangkok' ,'Asia/Beirut' ,'Asia/Bishkek' ,'Asia/Brunei' ,'Asia/Calcutta' ,'Asia/Choibalsan' ,'Asia/Chongqing' ,'Asia/Chungking' ,'Asia/Colombo' ,'Asia/Dacca' ,'Asia/Damascus' ,'Asia/Dhaka' ,'Asia/Dili' ,'Asia/Dubai' ,'Asia/Dushanbe' ,'Asia/Gaza' ,'Asia/Harbin' ,'Asia/Ho_Chi_Minh' ,'Asia/Hong_Kong' ,'Asia/Hovd' ,'Asia/Irkutsk' ,'Asia/Istanbul' ,'Asia/Jakarta' ,'Asia/Jayapura' ,'Asia/Jerusalem' ,'Asia/Kabul' ,'Asia/Kamchatka' ,'Asia/Karachi' ,'Asia/Kashgar' ,'Asia/Kathmandu' ,'Asia/Katmandu' ,'Asia/Kolkata' ,'Asia/Krasnoyarsk' ,'Asia/Kuala_Lumpur' ,'Asia/Kuching' ,'Asia/Kuwait' ,'Asia/Macao' ,'Asia/Macau' ,'Asia/Magadan' ,'Asia/Makassar' ,'Asia/Manila' ,'Asia/Muscat' ,'Asia/Nicosia' ,'Asia/Novokuznetsk' ,'Asia/Novosibirsk' ,'Asia/Omsk' ,'Asia/Oral' ,'Asia/Phnom_Penh' ,'Asia/Pontianak' ,'Asia/Pyongyang' ,'Asia/Qatar' ,'Asia/Qyzylorda' ,'Asia/Rangoon' ,'Asia/Riyadh' ,'Asia/Saigon' ,'Asia/Sakhalin' ,'Asia/Samarkand' ,'Asia/Seoul' ,'Asia/Shanghai' ,'Asia/Singapore' ,'Asia/Taipei' ,'Asia/Tashkent' ,'Asia/Tbilisi' ,'Asia/Tehran' ,'Asia/Tel_Aviv' ,'Asia/Thimbu' ,'Asia/Thimphu' ,'Asia/Tokyo' ,'Asia/Ujung_Pandang' ,'Asia/Ulaanbaatar' ,'Asia/Ulan_Bator' ,'Asia/Urumqi' ,'Asia/Vientiane' ,'Asia/Vladivostok' ,'Asia/Yakutsk' ,'Asia/Yekaterinburg' ,'Asia/Yerevan' ,'Atlantic/Azores' ,'Atlantic/Bermuda' ,'Atlantic/Canary' ,'Atlantic/Cape_Verde' ,'Atlantic/Faeroe' ,'Atlantic/Faroe' ,'Atlantic/Jan_Mayen' ,'Atlantic/Madeira' ,'Atlantic/Reykjavik' ,'Atlantic/South_Georgia' ,'Atlantic/St_Helena' ,'Atlantic/Stanley' ,'Australia/ACT' ,'Australia/Adelaide' ,'Australia/Brisbane' ,'Australia/Broken_Hill' ,'Australia/Canberra' ,'Australia/Currie' ,'Australia/Darwin' ,'Australia/Eucla' ,'Australia/Hobart' ,'Australia/LHI' ,'Australia/Lindeman' ,'Australia/Lord_Howe' ,'Australia/Melbourne' ,'Australia/NSW' ,'Australia/North' ,'Australia/Perth' ,'Australia/Queensland' ,'Australia/South' ,'Australia/Sydney' ,'Australia/Tasmania' ,'Australia/Victoria' ,'Australia/West' ,'Australia/Yancowinna' ,'Europe/Amsterdam' ,'Europe/Andorra' ,'Europe/Athens' ,'Europe/Belfast' ,'Europe/Belgrade' ,'Europe/Berlin' ,'Europe/Bratislava' ,'Europe/Brussels' ,'Europe/Bucharest' ,'Europe/Budapest' ,'Europe/Chisinau' ,'Europe/Copenhagen' ,'Europe/Dublin' ,'Europe/Gibraltar' ,'Europe/Guernsey' ,'Europe/Helsinki' ,'Europe/Isle_of_Man' ,'Europe/Istanbul' ,'Europe/Jersey' ,'Europe/Kaliningrad' ,'Europe/Kiev' ,'Europe/Lisbon' ,'Europe/Ljubljana' ,'Europe/London' ,'Europe/Luxembourg' ,'Europe/Madrid' ,'Europe/Malta' ,'Europe/Mariehamn' ,'Europe/Minsk' ,'Europe/Monaco' ,'Europe/Moscow' ,'Europe/Nicosia' ,'Europe/Oslo' ,'Europe/Paris' ,'Europe/Podgorica' ,'Europe/Prague' ,'Europe/Riga' ,'Europe/Rome' ,'Europe/Samara' ,'Europe/San_Marino' ,'Europe/Sarajevo' ,'Europe/Simferopol' ,'Europe/Skopje' ,'Europe/Sofia' ,'Europe/Stockholm' ,'Europe/Tallinn' ,'Europe/Tirane' ,'Europe/Tiraspol' ,'Europe/Uzhgorod' ,'Europe/Vaduz' ,'Europe/Vatican' ,'Europe/Vienna' ,'Europe/Vilnius' ,'Europe/Volgograd' ,'Europe/Warsaw' ,'Europe/Zagreb' ,'Europe/Zaporozhye' ,'Europe/Zurich' ,'Indian/Antananarivo' ,'Indian/Chagos' ,'Indian/Christmas' ,'Indian/Cocos' ,'Indian/Comoro' ,'Indian/Kerguelen' ,'Indian/Mahe' ,'Indian/Maldives' ,'Indian/Mauritius' ,'Indian/Mayotte' ,'Indian/Reunion' ,'Pacific/Apia' ,'Pacific/Auckland' ,'Pacific/Chatham' ,'Pacific/Easter' ,'Pacific/Efate' ,'Pacific/Enderbury' ,'Pacific/Fakaofo' ,'Pacific/Fiji' ,'Pacific/Funafuti' ,'Pacific/Galapagos' ,'Pacific/Gambier' ,'Pacific/Guadalcanal' ,'Pacific/Guam' ,'Pacific/Honolulu' ,'Pacific/Johnston' ,'Pacific/Kiritimati' ,'Pacific/Kosrae' ,'Pacific/Kwajalein' ,'Pacific/Majuro' ,'Pacific/Marquesas' ,'Pacific/Midway' ,'Pacific/Nauru' ,'Pacific/Niue' ,'Pacific/Norfolk' ,'Pacific/Noumea' ,'Pacific/Pago_Pago' ,'Pacific/Palau' ,'Pacific/Pitcairn' ,'Pacific/Ponape' ,'Pacific/Port_Moresby' ,'Pacific/Rarotonga' ,'Pacific/Saipan' ,'Pacific/Samoa' ,'Pacific/Tahiti' ,'Pacific/Tarawa' ,'Pacific/Tongatapu' ,'Pacific/Truk' ,'Pacific/Wake' ,'Pacific/Wallis' ,'Pacific/Yap' ,'UTC');
14
15    public function format ($data , $params = false)
16    {           
17        $timezones = array_flip(self::$timezonesMap);
18           
19        $ical = new icalCreator();
20       
21        $ical->setProperty( 'method' , isset($params['method']) ? $params['method'] : 'PUBLISH' );       
22        $sytemTimezone = (date_default_timezone_get()) ? date_default_timezone_get() : 'America/Sao_Paulo';
23        $params['defaultTZI'] = self::nomalizeTZID((isset($params['defaultTZI']) && $params['defaultTZI'] != 'null') ? $params['defaultTZI'] : $sytemTimezone  );
24     
25        /*
26         * Seta propiedades obrigatorias para alguns softwares (Outlook)
27         */
28        $ical->setProperty( 'x-wr-calname', 'Calendar Expresso' );
29        $ical->setProperty( 'X-WR-CALDESC', 'Calendar Expresso' );
30        $ical->setProperty( 'X-WR-TIMEZONE', isset($timezones[$params['defaultTZI']]) ? $timezones[$params['defaultTZI']] : $params['defaultTZI']);
31             
32        foreach($data as $i => $v)
33        {
34                 
35            switch ($v['type']) {
36                case EVENT_ID:
37                   
38                       $vevent = $ical->newComponent( 'vevent' );
39                       
40                       $vevent->setProperty( 'summary' , $v['summary'] );
41                       $vevent->setProperty( 'description' , $v['description'] );
42                       $vevent->setProperty( 'location' , $v['location'] );
43                       $vevent->setProperty( 'tranp' , (isset($v['tranparent']) && $v['tranparent'] == TRANSP_TRANSPARENT )? 'TRANSPARENT' : 'OPAQUE' );
44                     
45                       $timezone = new DateTimeZone('UTC');
46                       $apTimezone = self::nomalizeTZID(( isset($v['timezone']) && $v['timezone'] != 'null' ) ? $v['timezone'] : $params['defaultTZI']);
47                         
48                       $sTime = new DateTime( '@'.(int)($v['startTime'] / 1000) , $timezone );                                   
49                       $sTime->setTimezone(new DateTimeZone($apTimezone));
50                       $eTime = new DateTime( '@'.(int)($v['endTime'] / 1000) , $timezone ); 
51                       $eTime->setTimezone(new DateTimeZone($apTimezone));
52                       
53                       if( isset($v['allDay']) && $v['allDay'] == 1 )
54                       {
55                           $vevent->setProperty( 'dtstart' , $sTime->format(DATE_RFC822), array( "VALUE" => "DATE" ));
56                           $vevent->setProperty( 'dtend' , $eTime->format(DATE_RFC822), array( "VALUE" => "DATE" ));
57                           $vevent->setProperty( 'X-MICROSOFT-CDO-ALLDAYEVENT', 'TRUE' );
58                       }
59                       else
60                       {
61                           $vevent->setProperty( 'dtstart' , $sTime->format(DATE_RFC822) , array('TZID' => $apTimezone )  );
62                           $vevent->setProperty( 'dtend' , $eTime->format(DATE_RFC822), array('TZID' => $apTimezone ) );
63                           $vevent->setProperty( 'X-MICROSOFT-CDO-ALLDAYEVENT', 'FALSE' );
64                       }
65
66                                                if(isset($v['participants']) && is_array($v['participants']) && count($v['participants']) > 0 )
67                                                        $this->createAttendee($v['participants'], $vevent);
68
69                                                if(isset($v['attachments']) && is_array($v['attachments']) && count($v['attachments']) > 0 )
70                                                        $this->createAttachment($v['attachments'], $vevent);
71                                                       
72                        $vevent->setProperty( 'uid' , $v['uid'] );
73
74                       //Todo: Implementar Repetição
75                                           
76                    break;
77
78                default:
79                    break;
80            }           
81        }
82                       
83      return $ical->createCalendar();
84   
85    }
86        //Trata a criacao de anexos do ics
87        public function createAttachment($attachments, &$vevent){
88                foreach($attachments as $key => $attachment){
89                        $pParams = array("ENCODING" => "BASE64", "VALUE" => "BINARY",
90                                                        "X-FILENAME"  => $attachment['name']);
91               
92                        $vevent->setProperty( "attach", $attachment['source'], $pParams );
93                }
94        }
95       
96        //Trata a criacao de attendees com tratamento de delegate
97        public function createAttendee($attendees, &$vevent){
98                $delegate = array();
99                foreach ($attendees as $di => $dv){
100                        if($dv['delegatedFrom'] != 0){
101                                $delegate[$dv['delegatedFrom']] = $dv;
102                        }
103                }
104
105                foreach ($attendees as $pi => $pv){
106                        $isResponseDelegated = false;
107                        if($pv['delegatedFrom'] == 0){
108                                if($pv['isOrganizer'] == 1)
109                                   $vevent->setProperty( 'organizer' , $pv['user']['mail'], array( 'CN' => $pv['user']['name'] )); 
110                                else
111                                {
112                                        $pParams = array();
113                                        $pParams['CN'] = $pv['user']['name'];
114                                        $pParams['PARTSTAT'] = self::_getStatus( $pv['status'] );
115                                       
116                                        if(isset($delegate[$pv['id']])){
117                                                        $pParams['PARTSTAT'] = self::_getStatus( $delegate[$pv['id']]['status']);
118                                                        $pParams['DELEGATED-TO'] = $delegate[$pv['id']]['user']['mail'];
119                                                        $pParams['CN'] = $pv['user']['name'];
120                                                       
121                                                        $vevent->setProperty( 'attendee' , $pv['user']['mail'], $pParams); 
122                                                       
123                                                        if($delegate[$pv['id']]['status'] == STATUS_UNANSWERED){
124                                                                $pParams['RSVP'] = $pv['receiveNotification'] == 1 ? 'TRUE' : 'FALSE';
125                                                                unset($pParams['PARTSTAT']);
126                                                        }else
127                                                                $pParams['PARTSTAT'] = self::_getStatus( $delegate[$pv['id']]['status']);
128                                                       
129                                                        unset($pParams['DELEGATED-TO']);
130                                                        $pParams['DELEGATED-FROM'] = $pv['user']['mail'];
131                                                       
132                                                        $vevent->setProperty( 'attendee' , $delegate[$pv['id']]['user']['mail'], $pParams); 
133                                                        continue;
134                                        }
135                                        $pParams['RSVP'] = 'TRUE';
136                                               
137                                        $vevent->setProperty( 'attendee' , $pv['user']['mail'], $pParams); 
138                                }                       
139                        }
140                }       
141        }
142     
143    public function parse ( $data , $params = false)
144    {
145        Config::regSet('noAlarm', TRUE); //Evita o envio de notificação
146        $vcalendar = new icalCreator( );
147        $vcalendar->parse(trim($data));
148        $vcalendar->sort();         
149       
150        $return = array();
151        $method = $vcalendar->getProperty('method',FALSE , FALSE);
152        $params['prodid'] =  $vcalendar->getProperty( 'prodid' , false , false );
153               
154        while ($component = $vcalendar->getComponent())
155        {     
156            $interation = array();
157            $uid = $component->getProperty( 'uid' , false , false ); //Resgata o uid do componente
158           
159            switch (strtoupper($component->objName)) {
160                case 'VEVENT':
161                   
162                    switch ($method)
163                    {
164                         case 'PUBLISH':           
165                             if( !$schedulable = self::_getSchedulable($uid))
166                                    $interation = self::_makeVEVENT($schedulable , $component , $params);
167                               break;
168
169                         case 'REQUEST':
170                             $schedulable = self::_getSchedulable($uid);
171                             
172                             if($schedulable) //Caso o evento exista
173                             {
174                                if(!self::_existInMyCalendars($schedulable['id']))
175                                {
176                                      $calendarToSchedulable = array();
177                                      $calendarToSchedulable['calendar'] = $params['calendar'];
178                                      $calendarToSchedulable['schedulable'] = $schedulable['id'];
179                                      $interation['calendarToSchedulable://'.mt_rand().'(Formatter)'] = $calendarToSchedulable;
180                                     
181                                      if(isset($params['status']))
182                                      {
183                                        $pID = self::_getParticipantByMail( Config::me('mail') , $schedulable['participants'] );
184                                        $interation['participant://'.$pID]['status'] = $params['status'];
185                                      }
186                                     
187                                       Config::regSet('noAlarm', FALSE); //reativa notificação
188                                }
189                                else
190                                {
191                                    if( self::_getTime($component , 'dtstamp') > $schedulable['dtstamp'] || $component->getProperty( 'sequence' , false , false ) > $schedulable['sequence']) //Organizador esta requisitando que você atualize o evento
192                                       $interation = self::_makeVEVENT($schedulable , $component , $params);
193                                    else if ( $component->getProperty( 'sequence' , false , false ) === $schedulable['sequence'])
194                                    {
195                                        //Ler melhor rfc sobre isto 3.2.2.2
196                                        //Aparentemente é para retornar um ical com o evento atualizado para o attende
197                                    }
198                                }
199   
200                             }else // Importar evento
201                                $interation = self::_makeVEVENT( array() , $component , $params);
202                             
203                             break; 
204                           
205                         case 'REFRESH':
206                               break; 
207                         
208                         case 'CANCEL':
209                             if($schedulable = self::_getSchedulable($uid))                             
210                                $interation['schedulable://'.$schedulable['id']] = false;
211                               break;
212                           
213                         case 'ADD':
214                               break;
215                         
216                         case 'REPLY':
217                             if(  $schedulable = self::_getSchedulable($uid) )
218                             {
219                                   while($property = $component->getProperty('attendee',FALSE , TRUE))                                 
220                                       if( $pID  = self::_getParticipantByMail(str_replace('MAILTO:', '', $property['value']), $schedulable['participants']))
221                                            $interation['participant://'.$pID] = array( 'id' => $pID , 'status' => constant('STATUS_'.strtoupper($property['params']['PARTSTAT'])) );                           
222                             }
223                               break;
224                         
225                         case 'COUNTER':
226                                                        if($params['acceptedSuggestion'] !== 'false' ){
227                                                       
228                                                                $schedulable = self::_getSchedulable($uid);
229                                                                $params['calendar'] = self::_existInMyCalendars($schedulable['id']);
230                                                               
231                                $interation = self::_makeCOUNTER($schedulable , $component , $params); 
232                                                                Config::regSet('noAlarm', FALSE);                                       
233                                                        }else{
234                                                                $response = array();
235                                                                $response['from'] = $params['from'];
236                                                                $response['type'] = 'suggestionResponse';
237                                                                $response['status'] = 'DECLINECOUNTER';
238                                                                $response['schedulable'] = self::_getSchedulable($uid);
239                                                               
240                                                                Controller::create( array( 'concept' => 'notification' ) , $response);
241                                                        }
242                               break;
243                         
244                         case 'DECLINECOUNTER':
245                               break;
246                           
247                         default:
248                             $schedulable = self::_getSchedulable($uid);
249                             
250                             if($schedulable && ( self::_getTime($component , 'dtstamp') > $schedulable['dtstamp'] || $component->getProperty( 'sequence' , false , false ) > $schedulable['sequence'])) //Caso o evento exista
251                                $interation = self::_makeVEVENT($schedulable , $component , $params);
252                             else // Importar evento
253                                $interation = self::_makeVEVENT( array() , $component , $params);
254
255                             break;
256                    }
257                   
258                    $return[] = $interation;
259                    break;
260               case 'VTIMEZONE':
261
262
263                    break;
264            }
265       
266        }
267               
268         return $return;   
269    }
270   
271        public function analize ( $data , $params = false)
272        {
273                        $vcalendar = new icalCreator( );
274            $vcalendar->parse(trim($data));
275            $vcalendar->sort();         
276
277            $return = array();
278            $method = $vcalendar->getProperty('method',FALSE , FALSE);
279
280            while ($component = $vcalendar->getComponent())
281            {     
282                $interation = array();
283                $uid = $component->getProperty( 'uid' , false , false ); //Resgata o uid do componente
284
285                switch (strtoupper($component->objName)) {
286                    case 'VEVENT':
287
288                        switch ($method)
289                        {
290                             case 'PUBLISH':           
291                                   $interation = ICAL_ACTION_IMPORT;
292                                   break;
293
294                             case 'REQUEST':
295                                 $schedulable = self::_getSchedulable($uid);
296
297                                 if($schedulable ) //Caso o evento exista
298                                 {
299                                    if(!self::_existInMyCalendars($schedulable['id']))
300                                          $interation = ICAL_ACTION_IMPORT;   
301                                    else
302                                    {
303                                        if( self::_getTime($component , 'dtstamp') > $schedulable['dtstamp'] || $component->getProperty( 'sequence' , false , false ) > $schedulable['sequence']) //Organizador esta requisitando que você atualize o evento
304                                           $interation = ICAL_ACTION_UPDATE;   
305                                        else
306                                           $interation = ICAL_ACTION_NONE;   
307                                    }
308                                 }else
309                                   $interation =  ICAL_ACTION_IMPORT;
310
311                                 break; 
312
313                             case 'REFRESH':
314                                   break; 
315
316                             case 'CANCEL':
317                                    $interation = ICAL_ACTION_DELETE;
318                                   break;
319
320                             case 'ADD':
321                                   break;
322
323                             case 'REPLY':
324                                     $interation = ICAL_ACTION_REPLY;
325                                   break;
326
327                             case 'COUNTER':
328                                                                        $interation = ICAL_ACTION_SUGGESTION;
329                                   break;
330
331                             case 'DECLINECOUNTER':
332                                   $interation = ICAL_ACTION_NONE;
333                                                                   break;
334
335                             default:
336                                 $schedulable = self::_getSchedulable($uid);
337
338                                 if($schedulable && ( self::_getTime($component , 'dtstamp') > $schedulable['dtstamp'] || $component->getProperty( 'sequence' , false , false ) > $schedulable['sequence'])) //Caso o evento exista
339                                      $interation = ICAL_ACTION_UPDATE;
340                                 else if($schedulable)
341                                     $interation = ICAL_ACTION_NONE;
342                                 else // Importar evento
343                                      $interation = ICAL_ACTION_IMPORT;
344
345                                 break;
346                        }
347
348                        $return[$uid] = $interation;
349                        break;
350                   case 'VTIMEZONE':
351
352
353                        break;
354                }
355
356            }
357
358             return $return;   
359        }
360   
361   
362    /* Helpers */
363        private static function _getTzOffset($rTz, $oTz = null , $time = 'now')
364        {
365            if($oTz === null) {
366                if(!is_string($oTz = date_default_timezone_get())) {
367                       return false; // A UTC timestamp was returned -- bail out!
368                }
369            }
370            $origin_dtz = new DateTimeZone(self::nomalizeTZID($oTz));
371            $remote_dtz = new DateTimeZone(self::nomalizeTZID($rTz));
372            $origin_dt = new DateTime($time, $origin_dtz);
373            $remote_dt = new DateTime("now", $remote_dtz);
374   
375            $offset = $origin_dtz->getOffset($origin_dt) - $remote_dtz->getOffset($remote_dt);
376           
377           
378            return $offset;
379        }
380
381        private function _getStatus( $id )
382        {
383            $a = array(   
384                        STATUS_CONFIRMED =>  'ACCEPTED',
385                        STATUS_CANCELLED =>  'CANCELLED',
386                        STATUS_TENTATIVE =>   'TENTATIVE',
387                        STATUS_UNANSWERED => 'NEEDS-ACTION',
388                        STATUS_DELEGATED =>  'DELEGATED'
389                      );
390           
391             return isset($a[ $id ]) ? $a[ $id ] : 'NEEDS-ACTION';
392        }
393       
394        private static function _getParticipantByMail( $mail , &$participants )
395        {         
396            foreach ($participants as $i => $v)
397                if($v['user']['mail'] == $mail  || (isset($v['user']['mailAlternateAddress']) && in_array($mail, $v['user']['mailAlternateAddress'])))
398                    return $v['id'];                       
399               
400            return false;
401        }
402       
403        static private function nomalizeTZID ($TZID)
404        {
405            if(isset(self::$timezonesMap[$TZID]))
406                return self::$timezonesMap[$TZID];
407            else if(in_array($TZID, self::$suportedTimzones))
408                return $TZID;
409            else
410                return date_default_timezone_get();       
411        }   
412       
413        static private function date2timestamp( $datetime, $tz=null )
414        {
415            if( !isset( $datetime['hour'] )) $datetime['hour'] = '0';
416            if( !isset( $datetime['min'] ))  $datetime['min']  = '0';
417            if( !isset( $datetime['sec'] ))  $datetime['sec']  = '0';
418         
419            foreach( $datetime as $dkey => $dvalue )
420              if( 'tz' != $dkey )
421                $datetime[$dkey] = (integer) $dvalue;
422           
423            if( $tz )
424              $datetime['tz'] = $tz;
425           
426            $offset = ( isset( $datetime['tz'] ) && ( '' < trim ( $datetime['tz'] ))) ? iCalUtilityFunctions::_tz2offset( $datetime['tz'] ) : 0;
427           
428            return gmmktime( $datetime['hour'], $datetime['min'], ($datetime['sec'] + $offset), $datetime['month'], $datetime['day'], $datetime['year'] );   
429        }
430
431                static private function _makeCOUNTER( $schedulable , $component ,$params)
432        {
433                        $interation = array();                 
434            $eventID = isset($schedulable['id']) ? $schedulable['id'] : mt_rand().'(Formatter)';
435           
436            /* Data de Inicio*/
437                $startTime = $component->getProperty( 'dtstart', false , true );
438                               
439            /* Tiem zone do evento*/   
440               if(isset($startTime['params']['TZID']))
441                  $schedulable['timezone'] = self::nomalizeTZID ($startTime['params']['TZID']);
442               else
443                  $schedulable['timezone'] = isset($params['calendar_timezone']) ? $params['calendar_timezone'] : 'America/Sao_Paulo';
444               
445                $objTimezone =  new DateTimeZone($schedulable['timezone']); 
446               
447                if($startTime['params']['VALUE'] === 'DATE' && isset($params['calendar_timezone']) )
448                {
449                    $schedulable['allDay'] = 1;
450                    $schedulable['startTime'] = self::date2timestamp($startTime['value']) - self::_getTzOffset('UTC',$schedulable['timezone'], '@'.self::date2timestamp($startTime['value'])) . '000';
451                }
452                elseif(isset($startTime['params']['TZID']) && !isset($startTime['value']['tz'])){/* Caso não tenha um tz na data mais exista um parametro TZID deve ser aplicado o timezone do TZID a data */
453                    $schedulable['startTime'] = self::date2timestamp($startTime['value']) - self::_getTzOffset('UTC',$startTime['params']['TZID'],'@'.self::date2timestamp($startTime['value'])) . '000';     
454                                        $schedulable['allDay'] = 0;
455                                }
456                                else
457                {
458                    $schedulable['startTime'] = self::date2timestamp($startTime['value']) . '000';
459                     if( strpos($params['prodid'], 'Outlook') !== false )
460                    {
461                        //Se o ics veio em utc não aplicar horario de verão
462                        $sTime = new DateTime( '@'.(int)($schedulable['startTime'] / 1000) , new DateTimeZone('UTC') );
463                        $sTime->setTimezone($objTimezone);
464                        if($sTime->format('I')) //Se o ics veio em utc não aplicar horario de verão
465                         $schedulable['startTime'] = $schedulable['startTime'] - 3600000;
466                    }
467                }
468               
469
470             /* Data de Termino*/
471                $endTime = $component->getProperty( 'dtend', false , true );
472
473                if($endTime['params']['VALUE'] === 'DATE')
474                    $schedulable['endTime'] = self::date2timestamp($endTime['value']) - self::_getTzOffset('UTC',$schedulable['timezone'],'@'.self::date2timestamp($endTime['value'])) . '000';
475                else if(isset($endTime['params']['TZID']) && !isset($endTime['value']['tz'])) /* Caso não tenha um tz na data mais exista um parametro TZID deve ser aplicado o timezone do TZID a data */
476                    $schedulable['endTime'] = self::date2timestamp($endTime['value']) - self::_getTzOffset('UTC',$endTime['params']['TZID'],'@'.self::date2timestamp($endTime['value'])) . '000';
477                else
478                {
479                    $schedulable['endTime'] = self::date2timestamp($endTime['value']) . '000';
480                    if( strpos($params['prodid'], 'Outlook') !== false )
481                    {
482                    //Se o ics veio em utc não aplicar horario de verão
483                        $eTime = new DateTime( '@'.(int)($schedulable['endTime'] / 1000)  ,new DateTimeZone('UTC'));
484                        $eTime->setTimezone($objTimezone);
485                        if($eTime->format('I'))
486                            $schedulable['endTime'] = $schedulable['endTime'] - 3600000;
487                   
488                                        }
489                                }
490                        unset($schedulable['participants']);                   
491                        $interation['schedulable://'.$eventID] = $schedulable;
492                         
493            return $interation;
494                }
495               
496        static private function _makeVEVENT( $schedulable , $component ,$params)
497        {
498                       
499            $interation = array();                 
500            $eventID = isset($schedulable['id']) ? $schedulable['id'] : mt_rand().'(Formatter)';
501           
502            /* Data de Inicio*/
503                $startTime = $component->getProperty( 'dtstart', false , true );
504                               
505            /* Tiem zone do evento*/   
506               if(isset($startTime['params']['TZID']))
507                  $schedulable['timezone'] = self::nomalizeTZID ($startTime['params']['TZID']);
508               else
509                  $schedulable['timezone'] = isset($params['calendar_timezone']) ? $params['calendar_timezone'] : 'America/Sao_Paulo';
510               
511                $objTimezone =  new DateTimeZone($schedulable['timezone']); 
512               
513                if($startTime['params']['VALUE'] === 'DATE' && isset($params['calendar_timezone']) )
514                {
515                    $schedulable['allDay'] = 1;
516                    $schedulable['startTime'] = self::date2timestamp($startTime['value']) - self::_getTzOffset('UTC',$schedulable['timezone'],'@'.self::date2timestamp($startTime['value'])) . '000';
517                }
518                elseif(isset($startTime['params']['TZID']) && !isset($startTime['value']['tz'])){/* Caso não tenha um tz na data mais exista um parametro TZID deve ser aplicado o timezone do TZID a data */
519                    $schedulable['startTime'] = self::date2timestamp($startTime['value']) - self::_getTzOffset('UTC',$startTime['params']['TZID'],'@'.self::date2timestamp($startTime['value'])) . '000';     
520                                        $schedulable['allDay'] = 0;
521                                }
522                                else
523                {
524                    $schedulable['startTime'] = self::date2timestamp($startTime['value']) . '000';
525                     if( strpos($params['prodid'], 'Outlook') !== false )
526                    {
527                        //Se o ics veio em utc não aplicar horario de verão
528                        $sTime = new DateTime( '@'.(int)($schedulable['startTime'] / 1000) , new DateTimeZone('UTC') );
529                        $sTime->setTimezone($objTimezone);
530                        if($sTime->format('I')) //Se o ics veio em utc não aplicar horario de verão
531                         $schedulable['startTime'] = $schedulable['startTime'] - 3600000;
532                    }
533                }
534               
535
536             /* Data de Termino*/
537                $endTime = $component->getProperty( 'dtend', false , true );
538
539                if($endTime['params']['VALUE'] === 'DATE')
540                    $schedulable['endTime'] = self::date2timestamp($endTime['value']) - self::_getTzOffset('UTC',$schedulable['timezone'],'@'.self::date2timestamp($endTime['value'])) . '000';
541                else if(isset($endTime['params']['TZID']) && !isset($endTime['value']['tz'])) /* Caso não tenha um tz na data mais exista um parametro TZID deve ser aplicado o timezone do TZID a data */
542                    $schedulable['endTime'] = self::date2timestamp($endTime['value']) - self::_getTzOffset('UTC',$endTime['params']['TZID'],'@'.self::date2timestamp($endTime['value'])) . '000';
543                else
544                {
545                    $schedulable['endTime'] = self::date2timestamp($endTime['value']) . '000';
546                    if( strpos($params['prodid'], 'Outlook') !== false )
547                    {
548                    //Se o ics veio em utc não aplicar horario de verão
549                        $eTime = new DateTime( '@'.(int)($schedulable['endTime'] / 1000)  ,new DateTimeZone('UTC'));
550                        $eTime->setTimezone($objTimezone);
551                        if($eTime->format('I'))
552                            $schedulable['endTime'] = $schedulable['endTime'] - 3600000;
553                    }
554                }
555       
556
557            $schedulable['summary'] = mb_convert_encoding ( $component->getProperty( 'summary' , false , false ) , 'UTF-8' , 'UTF-8,ISO-8859-1');
558
559            /* Definindo Description */
560                if($desc = $component->getProperty( 'description' , false , false ))
561                    $schedulable['description'] = mb_convert_encoding (str_ireplace ('\n', "\n", $desc) ,'UTF-8' , 'UTF-8,ISO-8859-1');
562
563             /* Definindo location */
564                if($location = $component->getProperty( 'location' , false , false ))
565                    $schedulable['location'] = mb_convert_encoding ( $location , 'UTF-8' , 'UTF-8,ISO-8859-1') ;
566
567
568            /* Definindo Class */
569                $class = $component->getProperty( 'class' , false , false );
570                if( $class && defined(constant(strtoupper('CLASS_'.$class))) )
571                    $schedulable['class'] = constant(strtoupper('CLASS_'.$class));
572                else if( !isset($exists['class']) )
573                    $schedulable['class'] = CLASS_PRIVATE ; // padrão classe private
574
575            /* Definindo RRULE */
576                if(  $rrule = $component->getProperty( 'rrule' , false , false ))
577                {   
578                    /* Gera um randon id para o contexto formater */
579                        $repeatID = mt_rand().'3(Formatter)';
580
581                    $repeat = array();
582                    $repeat['schedulable'] = $eventID;
583                    foreach($rrule as $i => $v)
584                       $repeat[strtolower($i)] = $v;
585
586                    //$interation['repeat://'.$repeatID] = $repeat;
587                }
588
589
590            $schedulable['calendar'] = $params['calendar'];           
591
592            $participantsInEvent = array();
593
594            //TODO: Participants com delegated não estao sendo levados em conta
595            while($property = $component->getProperty('attendee',FALSE , TRUE))
596            {
597                $participant = array();
598
599                $mailUser = trim(str_replace('MAILTO:', '', $property['value']));
600
601                $participantID = mt_rand().'2(Formatter)';
602                $participant['schedulable'] = $eventID;                                     
603               
604                if(isset($params['status']) && $mailUser == Config::me('mail'))
605                    $participant['status'] = $params['status'];
606                else
607                    $participant['status'] = (isset($property['params']['PARTSTAT']) && constant('STATUS_'.$property['params']['PARTSTAT']) !== null ) ? constant('STATUS_'.$property['params']['PARTSTAT']) : STATUS_UNANSWERED;
608                 
609               
610                $participant['isOrganizer'] = '0';
611
612                /* Verifica se este usuario é um usuario interno do ldap */     
613                 $intUser = Controller::find( array( 'concept' => 'user' ) , array('id','isExternal') ,array( 'filter' => array('OR' , array('=' , 'mail' ,  $mailUser ), array('=' , 'mailAlternateAddress' ,  $mailUser ) )) );
614
615                $user = null;   
616                if( $intUser && count($intUser) > 0 )
617                {
618                    $participant['isExternal']  = isset($intUser[0]['isExternal']) ? $intUser[0]['isExternal'] : 0;
619                    $participant['user'] = $intUser[0]['id'];
620                }
621                else
622                {
623                    $participant['isExternal']  = 1;
624                     /* Gera um randon id para o contexto formater */
625                        $userID = mt_rand().'4(Formatter)';
626
627                    $user['mail'] = $mailUser;
628                    $user['isExternal'] = '1';
629                    $user['name'] =  ( isset($property['params']['CN']) ) ? $property['params']['CN'] : '';
630                    $user['participants'] = array($participantID);
631                    $participant['user'] = $userID;
632                    $interation['user://'.$userID] = $user;
633                }
634
635                $interation['participant://'.$participantID] = $participant;
636                $schedulable['participants'][] = $participantID;
637
638            };
639
640            if($property = $component->getProperty('organizer',FALSE , TRUE))
641            {
642                $participant = array();
643                $mailUser = trim(str_replace('MAILTO:', '', $property['value']));
644
645                $participantID = mt_rand().'2(Formatter)';
646
647                $participant['schedulable'] = $eventID;
648                $participant['status'] = (isset($property['params']['PARTSTAT']) && constant('STATUS_'.$property['params']['PARTSTAT']) !== null ) ? constant('STATUS_'.$property['params']['PARTSTAT']) : STATUS_UNANSWERED;
649                $participant['isOrganizer'] = '1';
650                                $participant['acl'] = 'rowi';
651
652                /* Verifica se este usuario é um usuario interno do ldap */     
653                $intUser = Controller::find( array( 'concept' => 'user' ) , array('id','isExternal') ,array( 'filter' => array('OR' , array('=' , 'mail' ,  $mailUser ), array('=' , 'mailAlternateAddress' ,  $mailUser ) )) );
654     
655                $user = null;   
656                if( $intUser && count($intUser) > 0 )
657                {
658                    $participant['isExternal']  = isset($intUser[0]['isExternal']) ? $intUser[0]['isExternal'] : 0;
659                    $participant['user'] = $intUser[0]['id'];
660                }
661                else
662                {
663                    $participant['isExternal']  = 1;
664                     /* Gera um randon id para o contexto formater */
665                        $userID = mt_rand().'4(Formatter)';
666
667                    $user['mail'] = $mailUser;
668                    $user['name'] =  ( isset($property['params']['CN']) ) ? $property['params']['CN'] : '';
669                    $user['participants'] = array($participantID);
670                    $user['isExternal'] = '1';
671                    $participant['user'] = $userID;
672                    $interation['user://'.$userID] = $user;
673                }
674
675                $interation['participant://'.$participantID] = $participant;
676                $schedulable['participants'][] = $participantID;
677
678            }
679            else if(!is_array($schedulable['participants']) || count($schedulable['participants']) < 1)//caso não tenha organizador o usuario se torna organizador
680            {
681               $user = Controller::read( array( 'concept' => 'user', 'id' => $params['owner'] ) , array('mail'));
682
683               if(!self::_getParticipantByMail($user['mail'] , $exists['participants']))
684               {
685                    $participantID = mt_rand().'2(Formatter)';
686
687                    $participant['schedulable'] = $eventID;
688                    $participant['status'] = STATUS_CONFIRMED;
689                    $participant['isOrganizer'] = '1';
690                    $participant['acl'] = 'rowi';
691                    $participant['isExternal']  = 0;
692                    $participant['user'] =  $params['owner'];
693                    $interation['participant://'.$participantID] = $participant;
694                    $schedulable['participants'][] = $participantID;
695               }
696            }
697
698             /* Definindo DTSTAMP */
699            if($dtstamp = self::_getTime($component , 'dtstamp') )
700                $schedulable['dtstamp'] = $dtstamp;
701     
702            /* Definindo TRANSP */
703            if(($tranp = $component->getProperty( 'transp', false , true )) && strtoupper($tranp) == 'OPAQUE')
704                $schedulable['transparent'] = 1;
705
706             /* Definindo last_update */
707            if($lastUpdate =  self::_getTime($component , 'LAST-MODIFIED'))
708                  $schedulable['lastUpdate'] = $lastUpdate;
709           
710           
711            if($sequence = $component->getProperty( 'SEQUENCE', false , false ))
712                  $schedulable['sequence'] = $sequence;
713             
714            if($uid = $component->getProperty( 'uid' , false , false ));
715                  $schedulable['uid'] = $uid;
716
717                         while($attach = $component->getProperty('ATTACH',FALSE , TRUE)){
718
719                                $attachCurrent = array( 'name' => $attach['params']['X-FILENAME'],
720                                                                'size' => strlen($attach['value']),
721                                                                'type' => self::_getContentType($attach['params']['X-FILENAME'])
722                                                        );
723
724                                $ids = Controller::find( array( 'concept' => 'attachment' ) , array('id') ,array( 'filter' => array('AND' , array( '=' , 'name' ,  $attachCurrent['name'] ), array( '=' , 'size' , $attachCurrent['size'] ), array( '=' , 'type' , $attachCurrent['type'] ))));
725
726                                if(!is_array($ids)){
727                                        $attachCurrent['source'] = $attach['value'];
728                                        //insere o anexo no banco e pega id para colcar no relacionamento                               
729                                        $idAttachment =  Controller::create( array('concept' => 'attachment') , $attachCurrent );
730                                }else
731                                        $idAttachment = array('id' => $ids[0]['id']);
732                               
733                                $calendarToAttachmentId = mt_rand().'2(Formatter)';
734                                $calendarToAttachment['attachment'] = $idAttachment['id'] ;
735                                $calendarToAttachment['schedulable'] = $eventID ;
736                                $interation['schedulableToAttachment://'.$calendarToAttachmentId] = $calendarToAttachment;
737                               
738                                $schedulable['attachments'][] = $calendarToAttachmentId;
739
740                        }
741
742                        $interation['schedulable://'.$eventID] = $schedulable;
743
744            return $interation;
745        }
746       
747        static private function _getSchedulable( $uid )
748        {
749           $schedulable =  Controller::find( array( 'concept' => 'schedulable' ) , null , array ( 'deepness' => '2' , 'filter' => array( '=' , 'uid' , $uid )));
750           return (isset($schedulable[0])) ? $schedulable[0] : false;
751        }
752       
753        static private function _existInMyCalendars( $id )
754        {
755           $sig = Controller::find(array('concept' => 'calendarSignature'), array('user','calendar'), array('filter' => array( '=' , 'user' , Config::me('uidNumber'))));       
756           $calendars = array();
757           foreach ($sig as $val)
758               $calendars[] = $val['calendar'];
759           
760           $return =  Controller::find( array( 'concept' => 'calendarToSchedulable' ) , null , array ( 'filter' => array('AND' , array( 'IN' , 'calendar' , $calendars ),array( '=' , 'schedulable' , $id ))));
761
762           return (isset($return[0])) ? $return[0]['calendar'] : false;
763        }
764       
765        static private function _getTime(&$component , $property)
766        {
767           if($date = $component->getProperty($property , false , true ))
768                return (isset($date['params']['TZID']) && !isset($date['value']['tz'])) ? (self::date2timestamp($date['value']) - self::_getTzOffset('UTC',$date['params']['TZID'],'@'.self::date2timestamp($date['value']))) . '000' : self::date2timestamp($date['value']) . '000';
769           
770           return false;
771        }
772               
773               
774                 static private function _getContentType( $fileName )
775        {
776            $strFileType = strtolower(substr ( $fileName , strrpos($fileName, '.') ));
777                         
778                        switch( $strFileType )
779                        {
780                                case ".asf": return "video/x-ms-asf";
781                                case ".avi": return "video/avi";
782                                case ".doc": return "application/msword";
783                                case ".zip": return "application/zip";
784                                case ".xls": return "application/vnd.ms-excel";
785                                case ".gif": return "image/gif";
786                                case ".bmp": return "image/bmp";
787                                case ".jpeg":
788                                case ".jpg": return "image/jpeg";
789                                case ".wav": return "audio/wav";
790                                case ".mp3": return "audio/mpeg3";
791                                case ".mpeg":
792                                case ".mpg": return "video/mpeg";
793                                case ".rtf": return "application/rtf";
794                                case ".html":
795                                case ".htm": return "text/html";
796                                case ".xml": return "text/xml";
797                                case ".xsl": return "text/xsl";
798                                case ".css": return "text/css";
799                                case ".php": return "text/php";
800                                case ".asp": return "text/asp";
801                                case ".pdf": return "application/pdf";
802                                case ".png": return "image/png";
803                                case ".txt": return "text/plain";
804                                case ".log": return "text/plain";
805                                case ".wmv": return "video/x-ms-wmv";
806                                case ".sxc": return "application/vnd.sun.xml.calc";
807                                case ".odt": return "application/vnd.oasis.opendocument.text";
808                                case ".stc": return "application/vnd.sun.xml.calc.template";
809                                case ".sxd": return "application/vnd.sun.xml.draw";
810                                case ".std": return "application/vnd.sun.xml.draw.template";
811                                case ".sxi": return "application/vnd.sun.xml.impress";
812                                case ".sti": return "application/vnd.sun.xml.impress.template";
813                                case ".sxm": return "application/vnd.sun.xml.math";
814                                case ".sxw": return "application/vnd.sun.xml.writer";
815                                case ".sxq": return "application/vnd.sun.xml.writer.global";
816                                case ".stw": return "application/vnd.sun.xml.writer.template";
817                                case ".pps": return "application/vnd.ms-powerpoint";
818                                case ".odt": return "application/vnd.oasis.opendocument.text";
819                                case ".ott": return "application/vnd.oasis.opendocument.text-template";
820                                case ".oth": return "application/vnd.oasis.opendocument.text-web";
821                                case ".odm": return "application/vnd.oasis.opendocument.text-master";
822                                case ".odg": return "application/vnd.oasis.opendocument.graphics";
823                                case ".otg": return "application/vnd.oasis.opendocument.graphics-template";
824                                case ".odp": return "application/vnd.oasis.opendocument.presentation";
825                                case ".otp": return "application/vnd.oasis.opendocument.presentation-template";
826                                case ".ods": return "application/vnd.oasis.opendocument.spreadsheet";
827                                case ".ots": return "application/vnd.oasis.opendocument.spreadsheet-template";
828                                case ".odc": return "application/vnd.oasis.opendocument.chart";
829                                case ".odf": return "application/vnd.oasis.opendocument.formula";
830                                case ".odi": return "application/vnd.oasis.opendocument.image";
831                                case ".ndl": return "application/vnd.lotus-notes";
832                                case ".eml": return "text/plain";
833                                case ".ps" : return "application/postscript";
834                                default    : return "application/octet-stream";
835                        }
836        }               
837}
838?>
Note: See TracBrowser for help on using the repository browser.