Ignore:
Timestamp:
04/30/12 15:42:36 (12 years ago)
Author:
acoutinho
Message:

Ticket #2672 - Erro ao importar alguns ics vindos de outros aplicativos

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/prototype/services/iCal.php

    r6026 r6066  
    11<?php 
    2 require_once ROOTPATH.'/plugins/icalcreator/iCalUtilityFunctions.class.php'; 
    3 require_once ROOTPATH.'/plugins/icalcreator/iCalcreator.class.php';         
    4 require_once ROOTPATH.'/modules/calendar/constants.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'; 
    56 
    67//TODO:Timeout request 
    7 set_time_limit( 600 ); 
    8 class iCal implements Formatter  
    9 { 
    10      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 -0300 (Standard) / GMT -0200 (Daylight)' => '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' ,'E. South America Standard Time' => 'America/Sao_Paulo' , 'E. South America' => 'America/Sao_Paulo'    ); 
     8set_time_limit(600); 
     9 
     10class iCal implements Formatter { 
     11 
     12    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 -0300 (Standard) / GMT -0200 (Daylight)' => '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', 'E. South America Standard Time' => 'America/Sao_Paulo', 'E. South America' => 'America/Sao_Paulo'); 
    1113//    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');   
    12     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'); 
    13  
    14     public function format ($data , $params = false) 
    15     {            
    16         $timezones = array_flip(self::$timezonesMap); 
    17             
    18         $ical = new icalCreator(); 
    19         
    20         $ical->setProperty( 'method' , isset($params['method']) ? $params['method'] : 'PUBLISH' );         
    21         $sytemTimezone = (date_default_timezone_get()) ? date_default_timezone_get() : 'America/Sao_Paulo'; 
    22         $params['defaultTZI'] = self::nomalizeTZID((isset($params['defaultTZI']) && $params['defaultTZI'] != 'null') ? $params['defaultTZI'] : $sytemTimezone  ); 
    23        
    24         /* 
    25          * Seta propiedades obrigatorias para alguns softwares (Outlook) 
    26          */ 
    27         $ical->setProperty( 'x-wr-calname', 'Calendar Expresso' ); 
    28         $ical->setProperty( 'X-WR-CALDESC', 'Calendar Expresso' ); 
    29         $ical->setProperty( 'X-WR-TIMEZONE', isset($timezones[$params['defaultTZI']]) ? $timezones[$params['defaultTZI']] : $params['defaultTZI']);  
    30               
    31         foreach($data as $i => $v) 
    32         { 
    33                   
    34             switch ($v['type']) { 
    35                 case EVENT_ID: 
    36                      
    37                        $vevent = $ical->newComponent( 'vevent' ); 
    38                                          
    39                        $vevent->setProperty( 'summary' , $v['summary'] ); 
    40                        $vevent->setProperty( 'description' , isset($v['description']) ?  $v['description'] : ''); 
    41                        $vevent->setProperty( 'location' , $v['location'] ); 
    42                        $vevent->setProperty( 'tranp' , (isset($v['tranparent']) && $v['tranparent'] == TRANSP_TRANSPARENT )? 'TRANSPARENT' : 'OPAQUE' ); 
    43                        
    44                        $timezone = new DateTimeZone('UTC'); 
    45                        $apTimezone = self::nomalizeTZID(( isset($v['timezone']) && $v['timezone'] != 'null' ) ? $v['timezone'] : $params['defaultTZI']); 
    46                        $apTimezoneOBJ = new DateTimeZone($apTimezone); 
    47                         
    48                        $sTime = new DateTime( '@'.(int)($v['startTime'] / 1000) , $timezone );                                     
    49                        $sTime->setTimezone($apTimezoneOBJ); 
    50                        $eTime = new DateTime( '@'.(int)($v['endTime'] / 1000) , $timezone );   
    51                        $eTime->setTimezone($apTimezoneOBJ); 
    52  
    53                        if( ( isset($v['repeat']) ) && ( $v['repeat']['frequency'] != 'none' ) ) 
    54                        { 
    55                            $repeat = array(); 
    56                             
    57                            foreach ($v['repeat'] as $ir => $rv)  
    58                            { 
    59                                if($rv) 
    60                                { 
    61                                    if($ir == 'frequency' && $rv !== 'none') 
    62                                       $repeat['FREQ'] =  $rv; 
    63                                    else if($ir == 'endTime' ) 
    64                                    { 
    65                                        $time = new DateTime( '@'.(int)($rv / 1000) , $timezone );                                     
    66                                        $time->setTimezone($apTimezoneOBJ); 
    67                                        $repeat['until'] = $time->format(DATE_RFC822); 
    68                                    } 
    69                                    else if($ir == 'count') 
    70                                     $repeat[$ir] = $rv; 
    71                                    else if($ir !== 'schedulable' && $ir !== 'id' && $ir !== 'startTime') 
    72                                     $repeat[$ir] = explode(',', $rv); 
    73                                } 
    74                            } 
    75                                              
    76                            if(isset($repeat['FREQ'])) 
    77                             $vevent->setProperty('rrule' , $repeat); 
    78                        } 
    79                         
    80                        if( isset($v['allDay']) && $v['allDay'] == 1 ) 
    81                        { 
    82                            $vevent->setProperty( 'dtstart' , $sTime->format(DATE_RFC822), array( "VALUE" => "DATE" )); 
    83                            $vevent->setProperty( 'dtend' , $eTime->format(DATE_RFC822), array( "VALUE" => "DATE" )); 
    84                            $vevent->setProperty( 'X-MICROSOFT-CDO-ALLDAYEVENT', 'TRUE' ); 
    85                        } 
    86                        else 
    87                        { 
    88                            $vevent->setProperty( 'dtstart' , $sTime->format(DATE_RFC822) , array('TZID' => $apTimezone )  ); 
    89                            $vevent->setProperty( 'dtend' , $eTime->format(DATE_RFC822), array('TZID' => $apTimezone ) );  
    90                            $vevent->setProperty( 'X-MICROSOFT-CDO-ALLDAYEVENT', 'FALSE' ); 
    91                        } 
    92  
    93                                                 if(isset($v['participants']) && is_array($v['participants']) && count($v['participants']) > 0 ) 
    94                                                         $this->createAttendee($v['participants'], $vevent); 
    95  
    96                                                 if(isset($v['attachments']) && is_array($v['attachments']) && count($v['attachments']) > 0 ) 
    97                                                         $this->createAttachment($v['attachments'], $vevent); 
    98                                                          
    99                         $vevent->setProperty( 'uid' , $v['uid'] ); 
    100  
    101                        //Todo: Implementar Repetição 
    102                                             
    103                     break; 
    104  
    105                 default: 
    106                     break; 
    107             }            
    108         } 
    109                          
    110       return $ical->createCalendar(); 
    111      
    112     } 
    113         //Trata a criacao de anexos do ics 
    114         public function createAttachment($attachments, &$vevent){ 
    115                 foreach($attachments as $key => $attachment){ 
    116                         $pParams = array("ENCODING" => "BASE64", "VALUE" => "BINARY", 
    117                                                         "X-FILENAME"  => $attachment['name']); 
    118                  
    119                         $vevent->setProperty( "attach", $attachment['source'], $pParams ); 
     14    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'); 
     15 
     16    public function format($data, $params = false) { 
     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            switch ($v['type']) { 
     35                case EVENT_ID: 
     36 
     37                    $vevent = $ical->newComponent('vevent'); 
     38 
     39                    $vevent->setProperty('summary', $v['summary']); 
     40                    $vevent->setProperty('description', isset($v['description']) ? $v['description'] : ''); 
     41                    $vevent->setProperty('location', $v['location']); 
     42                    $vevent->setProperty('tranp', (isset($v['tranparent']) && $v['tranparent'] == TRANSP_TRANSPARENT ) ? 'TRANSPARENT' : 'OPAQUE' ); 
     43 
     44                    $timezone = new DateTimeZone('UTC'); 
     45                    $apTimezone = self::nomalizeTZID(( isset($v['timezone']) && $v['timezone'] != 'null' ) ? $v['timezone'] : $params['defaultTZI']); 
     46                    $apTimezoneOBJ = new DateTimeZone($apTimezone); 
     47 
     48                    $sTime = new DateTime('@' . (int) ($v['startTime'] / 1000), $timezone); 
     49                    $sTime->setTimezone($apTimezoneOBJ); 
     50                    $eTime = new DateTime('@' . (int) ($v['endTime'] / 1000), $timezone); 
     51                    $eTime->setTimezone($apTimezoneOBJ); 
     52 
     53                    if (( isset($v['repeat']) ) && ( $v['repeat']['frequency'] != 'none' )) { 
     54                        $repeat = array(); 
     55 
     56                        foreach ($v['repeat'] as $ir => $rv) { 
     57                            if ($rv) { 
     58                                if ($ir == 'frequency' && $rv !== 'none') 
     59                                    $repeat['FREQ'] = $rv; 
     60                                else if ($ir == 'endTime') { 
     61                                    $time = new DateTime('@' . (int) ($rv / 1000), $timezone); 
     62                                    $time->setTimezone($apTimezoneOBJ); 
     63                                    $repeat['until'] = $time->format(DATE_RFC822); 
     64                                } else if ($ir == 'count') 
     65                                    $repeat[$ir] = $rv; 
     66                                else if ($ir !== 'schedulable' && $ir !== 'id' && $ir !== 'startTime') 
     67                                    $repeat[$ir] = explode(',', $rv); 
     68                            } 
     69                        } 
     70 
     71                        if (isset($repeat['FREQ'])) 
     72                            $vevent->setProperty('rrule', $repeat); 
     73                    } 
     74 
     75                    if (isset($v['allDay']) && $v['allDay'] == 1) { 
     76                        $vevent->setProperty('dtstart', $sTime->format(DATE_RFC822), array("VALUE" => "DATE")); 
     77                        $vevent->setProperty('dtend', $eTime->format(DATE_RFC822), array("VALUE" => "DATE")); 
     78                        $vevent->setProperty('X-MICROSOFT-CDO-ALLDAYEVENT', 'TRUE'); 
     79                    } else { 
     80                        $vevent->setProperty('dtstart', $sTime->format(DATE_RFC822), array('TZID' => $apTimezone)); 
     81                        $vevent->setProperty('dtend', $eTime->format(DATE_RFC822), array('TZID' => $apTimezone)); 
     82                        $vevent->setProperty('X-MICROSOFT-CDO-ALLDAYEVENT', 'FALSE'); 
     83                    } 
     84 
     85                    if (isset($v['participants']) && is_array($v['participants']) && count($v['participants']) > 0) 
     86                        $this->createAttendee($v['participants'], $vevent); 
     87 
     88                    if (isset($v['attachments']) && is_array($v['attachments']) && count($v['attachments']) > 0) 
     89                        $this->createAttachment($v['attachments'], $vevent); 
     90 
     91                    $vevent->setProperty('uid', $v['uid']); 
     92 
     93                    //Todo: Implementar Repetição 
     94 
     95                    break; 
     96 
     97                default: 
     98                    break; 
     99            } 
     100        } 
     101 
     102        return $ical->createCalendar(); 
     103    } 
     104 
     105    //Trata a criacao de anexos do ics 
     106    public function createAttachment($attachments, &$vevent) { 
     107        foreach ($attachments as $key => $attachment) { 
     108            $pParams = array("ENCODING" => "BASE64", "VALUE" => "BINARY", 
     109                "X-FILENAME" => $attachment['name']); 
     110 
     111            $vevent->setProperty("attach", $attachment['source'], $pParams); 
     112        } 
     113    } 
     114 
     115    //Trata a criacao de attendees com tratamento de delegate 
     116    public function createAttendee($attendees, &$vevent) { 
     117        $delegate = array(); 
     118        foreach ($attendees as $di => $dv) { 
     119            if (isset($dv['delegatedFrom']) && $dv['delegatedFrom'] != 0) { 
     120                $delegate[$dv['delegatedFrom']] = $dv; 
     121            } 
     122        } 
     123 
     124        foreach ($attendees as $pi => $pv) { 
     125            $isResponseDelegated = false; 
     126            if (isset($pv['delegatedFrom']) && $pv['delegatedFrom'] == 0) { 
     127                if ($pv['isOrganizer'] == 1) 
     128                    $vevent->setProperty('organizer', $pv['user']['mail'], array('CN' => $pv['user']['name'])); 
     129                else { 
     130                    $pParams = array(); 
     131                    $pParams['CN'] = $pv['user']['name']; 
     132                    $pParams['PARTSTAT'] = self::_getStatus($pv['status']); 
     133 
     134                    if (isset($pv['id']) && isset($delegate[$pv['id']])) { 
     135                        $pParams['PARTSTAT'] = self::_getStatus($delegate[$pv['id']]['status']); 
     136                        $pParams['DELEGATED-TO'] = $delegate[$pv['id']]['user']['mail']; 
     137                        $pParams['CN'] = $pv['user']['name']; 
     138 
     139                        $vevent->setProperty('attendee', $pv['user']['mail'], $pParams); 
     140 
     141                        if ($delegate[$pv['id']]['status'] == STATUS_UNANSWERED) { 
     142                            $pParams['RSVP'] = $pv['receiveNotification'] == 1 ? 'TRUE' : 'FALSE'; 
     143                            unset($pParams['PARTSTAT']); 
     144                        }else 
     145                            $pParams['PARTSTAT'] = self::_getStatus($delegate[$pv['id']]['status']); 
     146 
     147                        unset($pParams['DELEGATED-TO']); 
     148                        $pParams['DELEGATED-FROM'] = $pv['user']['mail']; 
     149 
     150                        $vevent->setProperty('attendee', $delegate[$pv['id']]['user']['mail'], $pParams); 
     151                        continue; 
     152                    } 
     153                    $pParams['RSVP'] = 'TRUE'; 
     154 
     155                    $vevent->setProperty('attendee', $pv['user']['mail'], $pParams); 
    120156                } 
    121         } 
    122          
    123         //Trata a criacao de attendees com tratamento de delegate 
    124         public function createAttendee($attendees, &$vevent){ 
    125                 $delegate = array(); 
    126                 foreach ($attendees as $di => $dv){ 
    127                         if(isset($dv['delegatedFrom']) && $dv['delegatedFrom'] != 0){ 
    128                                 $delegate[$dv['delegatedFrom']] = $dv; 
    129                         } 
    130                 } 
    131  
    132                 foreach ($attendees as $pi => $pv){ 
    133                         $isResponseDelegated = false; 
    134                         if(isset($pv['delegatedFrom']) && $pv['delegatedFrom'] == 0){ 
    135                                 if($pv['isOrganizer'] == 1) 
    136                                    $vevent->setProperty( 'organizer' , $pv['user']['mail'], array( 'CN' => $pv['user']['name'])); 
    137                                 else 
    138                                 { 
    139                                         $pParams = array(); 
    140                                         $pParams['CN'] = $pv['user']['name']; 
    141                                         $pParams['PARTSTAT'] = self::_getStatus( $pv['status'] ); 
    142                                          
    143                                         if(isset($pv['id']) && isset($delegate[$pv['id']])){ 
    144                                                         $pParams['PARTSTAT'] = self::_getStatus( $delegate[$pv['id']]['status']); 
    145                                                         $pParams['DELEGATED-TO'] = $delegate[$pv['id']]['user']['mail']; 
    146                                                         $pParams['CN'] = $pv['user']['name']; 
    147                                                          
    148                                                         $vevent->setProperty( 'attendee' , $pv['user']['mail'], $pParams);   
    149                                                          
    150                                                         if($delegate[$pv['id']]['status'] == STATUS_UNANSWERED){ 
    151                                                                 $pParams['RSVP'] = $pv['receiveNotification'] == 1 ? 'TRUE' : 'FALSE'; 
    152                                                                 unset($pParams['PARTSTAT']); 
    153                                                         }else 
    154                                                                 $pParams['PARTSTAT'] = self::_getStatus( $delegate[$pv['id']]['status']); 
    155                                                          
    156                                                         unset($pParams['DELEGATED-TO']); 
    157                                                         $pParams['DELEGATED-FROM'] = $pv['user']['mail']; 
    158                                                          
    159                                                         $vevent->setProperty( 'attendee' , $delegate[$pv['id']]['user']['mail'], $pParams);   
    160                                                         continue; 
     157            } 
     158        } 
     159    } 
     160 
     161    public function parse($data, $params = false) { 
     162        Config::regSet('noAlarm', TRUE); //Evita o envio de notificação 
     163        $vcalendar = new icalCreator( ); 
     164        $vcalendar->parse(trim($data)); 
     165        $vcalendar->sort(); 
     166 
     167        $return = array(); 
     168        $method = $vcalendar->getProperty('method', FALSE, FALSE); 
     169        $params['prodid'] = $vcalendar->getProperty('prodid', false, false); 
     170 
     171        while ($component = $vcalendar->getComponent()) { 
     172            $interation = array(); 
     173            $uid = $component->getProperty('uid', false, false); //Resgata o uid do componente 
     174 
     175            switch (strtoupper($component->objName)) { 
     176                case 'VEVENT': 
     177 
     178                    switch ($method) { 
     179                        case 'PUBLISH': 
     180                            if (!$schedulable = self::_getSchedulable($uid)) 
     181                                $interation = self::_makeVEVENT($schedulable, $component, $params); 
     182                            break; 
     183 
     184                        case 'REQUEST': 
     185                            $schedulable = self::_getSchedulable($uid); 
     186 
     187                            if ($schedulable) { //Caso o evento exista 
     188                                if (!self::_existInMyCalendars($schedulable['id'])) { 
     189                                    $calendarToSchedulable = array(); 
     190                                    $calendarToSchedulable['calendar'] = $params['calendar']; 
     191                                    $calendarToSchedulable['schedulable'] = $schedulable['id']; 
     192                                    $interation['calendarToSchedulable://' . mt_rand() . '(Formatter)'] = $calendarToSchedulable; 
     193 
     194                                    if (isset($params['status'])) { 
     195                                        $pID = self::_getParticipantByMail(Config::me('mail'), $schedulable['participants']); 
     196                                        $interation['participant://' . $pID]['status'] = $params['status']; 
     197                                    } 
     198 
     199                                    Config::regSet('noAlarm', FALSE); //reativa notificação 
     200                                } else { 
     201 
     202                                    if (self::_getTime($component, 'dtstamp') > $schedulable['dtstamp'] || $component->getProperty('sequence', false, false) > $schedulable['sequence']) //Organizador esta requisitando que você atualize o evento 
     203                                        $interation = self::_makeVEVENT($schedulable, $component, $params); 
     204                                    else if ($component->getProperty('sequence', false, false) === $schedulable['sequence']) { 
     205                                        //Ler melhor rfc sobre isto 3.2.2.2 
     206                                        //Aparentemente é para retornar um ical com o evento atualizado para o attende 
     207                                    } 
     208 
     209                                    if (isset($params['status'])) { 
     210                                        $pID = self::_getParticipantByMail(Config::me('mail'), $schedulable['participants']); 
     211                                        //Verifica a importação de eventos em que não participo 
     212                                        if ($pID) { 
     213                                            $interation['participant://' . $pID]['status'] = $params['status']; 
    161214                                        } 
    162                                         $pParams['RSVP'] = 'TRUE'; 
    163                                                  
    164                                         $vevent->setProperty( 'attendee' , $pv['user']['mail'], $pParams);   
    165                                 }                        
    166                         } 
    167                 }        
    168         } 
    169        
    170     public function parse ( $data , $params = false) 
    171     { 
    172         Config::regSet('noAlarm', TRUE); //Evita o envio de notificação 
    173         $vcalendar = new icalCreator( );  
    174         $vcalendar->parse(trim($data));  
    175         $vcalendar->sort();          
    176          
    177         $return = array(); 
    178         $method = $vcalendar->getProperty('method',FALSE , FALSE); 
    179         $params['prodid'] =  $vcalendar->getProperty( 'prodid' , false , false ); 
    180                  
    181         while ($component = $vcalendar->getComponent()) 
    182         {      
    183             $interation = array(); 
    184             $uid = $component->getProperty( 'uid' , false , false ); //Resgata o uid do componente 
    185              
    186             switch (strtoupper($component->objName)) { 
    187                 case 'VEVENT': 
    188              
    189                     switch ($method)  
    190                     { 
    191                          case 'PUBLISH':             
    192                              if( !$schedulable = self::_getSchedulable($uid)) 
    193                                     $interation = self::_makeVEVENT($schedulable , $component , $params); 
    194                                break; 
    195  
    196                          case 'REQUEST': 
    197                              $schedulable = self::_getSchedulable($uid); 
    198                                
    199                              if($schedulable) //Caso o evento exista 
    200                              { 
    201                                 if(!self::_existInMyCalendars($schedulable['id'])) 
    202                                 { 
    203                                       $calendarToSchedulable = array(); 
    204                                       $calendarToSchedulable['calendar'] = $params['calendar']; 
    205                                       $calendarToSchedulable['schedulable'] = $schedulable['id']; 
    206                                       $interation['calendarToSchedulable://'.mt_rand().'(Formatter)'] = $calendarToSchedulable; 
    207                                        
    208                                       if(isset($params['status'])) 
    209                                       { 
    210                                         $pID = self::_getParticipantByMail( Config::me('mail') , $schedulable['participants'] ); 
    211                                         $interation['participant://'.$pID]['status'] = $params['status']; 
    212                                       } 
    213                                        
    214                                        Config::regSet('noAlarm', FALSE); //reativa notificação 
    215                                 } 
    216                                 else 
    217                                 { 
    218                          
    219                                     if( self::_getTime($component , 'dtstamp') > $schedulable['dtstamp'] || $component->getProperty( 'sequence' , false , false ) > $schedulable['sequence']) //Organizador esta requisitando que você atualize o evento 
    220                                        $interation = self::_makeVEVENT($schedulable , $component , $params); 
    221                                     else if ( $component->getProperty( 'sequence' , false , false ) === $schedulable['sequence'])  
    222                                     { 
    223                                         //Ler melhor rfc sobre isto 3.2.2.2 
    224                                         //Aparentemente é para retornar um ical com o evento atualizado para o attende 
    225                                     }  
    226  
    227                                                                         if(isset($params['status'])) 
    228                                     { 
    229                                                                                 $pID = self::_getParticipantByMail( Config::me('mail') , $schedulable['participants'] ); 
    230                                                                                 //Verifica a importação de eventos em que não participo 
    231                                                                                 if($pID){ 
    232                                                                                         $interation['participant://'.$pID]['status'] = $params['status']; 
    233                                                                                 } 
    234                                                                         } 
    235                                 } 
    236      
    237                              }else // Importar evento 
    238                              { 
    239                                  $interation = self::_makeVEVENT( array() , $component , $params); 
    240                                                         
    241                                  if( strpos($params['prodid'], 'kigkonsult.se') !== false ) //envia notificação para fora 
    242                                  { 
    243                                                                         
    244                                           /* Data de Inicio*/ 
    245                                            $startTime = $component->getProperty( 'dtstart', false , true ); 
    246  
    247                                             /* Tiem zone do evento*/     
    248                                             if(isset($startTime['params']['TZID'])) 
    249                                                 $sc['timezone'] = self::nomalizeTZID ($startTime['params']['TZID']);  
    250                                             else 
    251                                                 $sc['timezone'] = isset($params['calendar_timezone']) ? $params['calendar_timezone'] : 'America/Sao_Paulo';  
    252  
    253                                                 $objTimezone =  new DateTimeZone($sc['timezone']);   
    254  
    255                                                 if(isset($startTime['params']['VALUE']) && $startTime['params']['VALUE'] === 'DATE' && isset($params['calendar_timezone']) ) 
    256                                                 { 
    257                                                     $sc['allDay'] = 1; 
    258                                                     $sc['startTime'] = self::date2timestamp($startTime['value']) - self::_getTzOffset('UTC',$sc['timezone']) . '000'; 
    259                                                 } 
    260                                                 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 */ 
    261                                                     $sc['startTime'] = self::date2timestamp($startTime['value']) - self::_getTzOffset('UTC',$startTime['params']['TZID']) . '000';       
    262                                                 else 
    263                                                 { 
    264                                                     $sc['startTime'] = self::date2timestamp($startTime['value']) . '000'; 
    265                                                     if( strpos($params['prodid'], 'Outlook') !== false ) 
    266                                                     { 
    267                                                         //Se o ics veio em utc não aplicar horario de verão 
    268                                                         $sTime = new DateTime( '@'.(int)($sc['startTime'] / 1000) , new DateTimeZone('UTC') );  
    269                                                         $sTime->setTimezone($objTimezone); 
    270                                                         if($sTime->format('I')) //Se o ics veio em utc não aplicar horario de verão 
    271                                                         $sc['startTime'] = $sc['startTime'] - 3600000; 
    272                                                     } 
    273                                                 } 
    274  
    275  
    276                                             /* Data de Termino*/ 
    277                                                 $endTime = $component->getProperty( 'dtend', false , true );  
    278  
    279                                                 if(isset($endTime['params']['VALUE']) && $endTime['params']['VALUE'] === 'DATE') 
    280                                                     $sc['endTime'] = self::date2timestamp($endTime['value']) - self::_getTzOffset('UTC',$sc['timezone']) . '000'; 
    281                                                 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 */ 
    282                                                     $sc['endTime'] = self::date2timestamp($endTime['value']) - self::_getTzOffset('UTC',$endTime['params']['TZID']) . '000'; 
    283                                                 else 
    284                                                 { 
    285                                                     $sc['endTime'] = self::date2timestamp($endTime['value']) . '000'; 
    286                                                     if( strpos($params['prodid'], 'Outlook') !== false ) 
    287                                                     { 
    288                                                     //Se o ics veio em utc não aplicar horario de verão 
    289                                                         $eTime = new DateTime( '@'.(int)($sc['endTime'] / 1000)  ,new DateTimeZone('UTC'));  
    290                                                         $eTime->setTimezone($objTimezone); 
    291                                                         if($eTime->format('I'))  
    292                                                             $sc['endTime'] = $sc['endTime'] - 3600000; 
    293                                                     } 
    294                                                 }  
    295  
    296                                       
    297                                         if($uid = $component->getProperty( 'uid' , false , false )); 
    298                                              $sc['uid'] = $uid; 
    299                                               
    300                                               
    301                                         $sc['summary'] = mb_convert_encoding ( $component->getProperty( 'summary' , false , false ) , 'UTF-8' , 'UTF-8,ISO-8859-1'); 
    302  
    303                                         /* Definindo Description */ 
    304                                             if($desc = $component->getProperty( 'description' , false , false )) 
    305                                                 $sc['description'] = mb_convert_encoding (str_ireplace (array('\n','\t'), array("\n","\t"), $desc) ,'UTF-8' , 'UTF-8,ISO-8859-1'); 
    306  
    307                                         /* Definindo location */ 
    308                                             if($location = $component->getProperty( 'location' , false , false )) 
    309                                             $sc['location'] = mb_convert_encoding ( $location , 'UTF-8' , 'UTF-8,ISO-8859-1') ; 
    310                                              
    311                                                
    312                                              
    313                                         if($property = $component->getProperty('organizer',FALSE , TRUE)) 
    314                                         { 
    315                                             $participant = array(); 
    316                                             $mailUser = trim(str_replace('MAILTO:', '', $property['value'])); 
    317  
    318                                             $participantID = mt_rand().'2(Formatter)'; 
    319  
    320                                             $participant['isOrganizer'] = '1'; 
    321                                       
    322                                             $user = null;     
    323                     
    324                                             $participant['isExternal']  = 1; 
    325                                             /* Gera um randon id para o contexto formater */ 
    326                                                 $userID = mt_rand().'4(Formatter)'; 
    327  
    328                                             $user['mail'] = $mailUser; 
    329                                             $organizerMail = $mailUser; 
    330                                              
    331                                             $user['name'] =  ( isset($property['params']['CN']) ) ? $property['params']['CN'] : '';         
    332                                             $user['isExternal'] = '1'; 
    333                                             $participant['user'] = $user; 
    334  
    335                                             $sc['participants'][] = $participant; 
    336  
    337                                         } 
    338                                          
    339  
    340                                         $participant['status'] = isset($params['status']) ? $params['status'] : STATUS_ACCEPTED; 
    341                                         $participant['isOrganizer'] = '0'; 
    342                                         $participant['isExternal']  = 0; 
    343                                         $participant['user'] =  array('mail' => Config::me('mail') , 'name' => Config::me('cn')); 
    344                                         $sc['participants'][] = $participant; 
    345                                         $sc['type'] = EVENT_ID; 
    346                           
    347              
    348                                             $ical['source'] = Controller::format( array( 'service' => 'iCal' ) , array($sc) , array('method' => 'REPLY'));   
    349                                             $ical['type'] =  'application/ics'; 
    350                                             $ical['name'] = 'outlook.ics'; 
    351                                              
    352                                             $ical2['source'] = $ical['source']; 
    353                                             $ical2['type'] =  'text/calendar; method=REPLY'; 
    354                                             $ical2['name'] = 'thunderbird.ics'; 
    355                                        
    356                                             $timezone = new DateTimeZone('UTC'); 
    357                                             $sTime = new DateTime( '@'.(int)($sc['startTime'] / 1000) , $timezone ); 
    358                                             $eTime =  new DateTime( '@'.(int)($sc['endTime'] / 1000) , $timezone );  
    359  
    360                                             if(isset($sc['timezone'])) 
    361                                             { 
    362                                                 $sTime->setTimezone(new DateTimeZone($sc['timezone'])); 
    363                                                 $eTime->setTimezone(new DateTimeZone($sc['timezone'])); 
    364                                             } 
    365  
    366                                             $data = array('startDate' =>  date_format( $sTime , 'd/m/Y') , 
    367                                                             'startTime' =>  (isset($sc['allDay']) && $sc['allDay'] ) ? '' : date_format( $sTime , 'H:i') , 
    368                                                             'endDate' =>  date_format( $eTime , 'd/m/Y') , 
    369                                                             'endTime' =>  isset($sc['allDay']) ? '' :  date_format( $eTime , 'H:i') , 
    370                                                             'eventTitle' =>  $sc['summary'], 
    371                                                             'eventLocation' =>  isset($sc['location']) ?  $sc['location'] : '', 
    372                                                             'timezone' =>  ($sc['timezone']) ? $sc['timezone'] : 'UTC' , 
    373                                                             'participant' =>  (isset($part['user']['name']) ? $part['user']['name'] : $part['user']['mail']) ); 
    374  
    375                                             $subject['notificationType'] = 'Convite Aceito'; 
    376                                             $subject['eventTitle'] = mb_convert_encoding($sc['summary'],'ISO-8859-1','ISO-8859-1,UTF-8'); 
    377                                             $subject['startDate'] = date_format( $sTime , 'd/m/Y'); 
    378                                             $subject['startTime'] = ($sc['allDay']) ? '' : date_format( $sTime , 'H:i'); 
    379                                             $subject['endDate'] = date_format( $eTime , 'd/m/Y'); 
    380                                             $subject['endTime'] = ($sc['allDay']) ? '' : date_format( $eTime , 'H:i'); 
    381                                             $subject['participant'] = Config::me('uid'); 
    382                                          
    383                                        $params['status'] =  isset($params['status']) ? $params['status'] : STATUS_ACCEPTED;    
    384                                              
    385                                         switch($params['status']) 
    386                                         { 
    387                                                 case STATUS_ACCEPTED: 
    388                                                     $tpl =   'notify_accept_body'; 
    389                                                     $subject['notificationType'] = 'Convite Aceito'; 
    390                                                 break; 
    391                                                 case STATUS_TENTATIVE: 
    392                                                     $tpl =   'notify_attempt_body'; 
    393                                                     $subject['notificationType'] = 'Convite  aceito provisoriamente'; 
    394                                                 break; 
    395                                                 case STATUS_CANCELLED: 
    396                                                     $tpl =   'notify_reject_body'; 
    397                                                     $subject['notificationType'] = 'Convite rejeitado'; 
    398                                                 break; 
    399  
    400                                         } 
    401                                         require_once ROOTPATH.'/api/parseTPL.php'; 
    402                                          
    403                                         $mail = array(); 
    404                                         $mail['attachments'][] = $ical; 
    405                                         $mail['attachments'][] = $ical2; 
    406                                  
    407                                         $mail['isHtml'] = true;                          
    408                                         $mail['body'] = parseTPL::load_tpl( $data ,ROOTPATH.'/modules/calendar/templates/'.$tpl.'.tpl'); 
    409                                         $mail['subject'] = parseTPL::load_tpl( $subject ,ROOTPATH.'/modules/calendar/templates/notify_subject.tpl');; 
    410                                         $mail['from'] = '"'.Config::me('cn').'" <'.Config::me('mail').'>';  
    411                                         $mail['to'] = $organizerMail; 
    412   
    413                                          
    414                                         Controller::create( array( 'service' => 'SMTP' ), $mail );     
    415                                  } 
    416                              }                    
    417                              break;   
    418                             
    419                          case 'REFRESH': 
    420                                break;   
    421                           
    422                          case 'CANCEL': 
    423                              if($schedulable = self::_getSchedulable($uid))                               
    424                                 $interation['schedulable://'.$schedulable['id']] = false; 
    425                                break; 
    426                             
    427                          case 'ADD': 
    428                                break; 
    429                           
    430                          case 'REPLY': 
    431                              if(  $schedulable = self::_getSchedulable($uid) ) 
    432                              {                                         
    433                                    while($property = $component->getProperty('attendee',FALSE , TRUE))                                  
    434                                        if( $pID  = self::_getParticipantByMail(str_replace('MAILTO:', '', $property['value']), $schedulable['participants'])) 
    435                                             $interation['participant://'.$pID] = array( 'id' => $pID , 'status' => constant('STATUS_'.strtoupper($property['params']['PARTSTAT'])) );                             
    436                               
    437                                     $interation['schedulable://'.$schedulable['id']]['sequence']  = $schedulable['sequence'] +1;    
    438                              } 
    439                                break; 
    440                           
    441                          case 'COUNTER': 
    442                                                         if($params['acceptedSuggestion'] !== 'false' ){ 
    443                                                          
    444                                                                 $schedulable = self::_getSchedulable($uid); 
    445                                                                 $params['calendar'] = self::_existInMyCalendars($schedulable['id']); 
    446                                                                  
    447                                 $interation = self::_makeCOUNTER($schedulable , $component , $params);   
    448                                                                 Config::regSet('noAlarm', FALSE);                                        
    449                                                         }else{ 
    450                                                                 $response = array(); 
    451                                                                 $response['from'] = $params['from']; 
    452                                                                 $response['type'] = 'suggestionResponse'; 
    453                                                                 $response['status'] = 'DECLINECOUNTER'; 
    454                                                                 $response['schedulable'] = self::_getSchedulable($uid); 
    455                                                                  
    456                                                                 Controller::create( array( 'concept' => 'notification' ) , $response);  
    457                                                         } 
    458                                break; 
    459                           
    460                          case 'DECLINECOUNTER': 
    461                                break; 
    462                             
    463                          default: 
    464                               
    465                              $schedulable = self::_getSchedulable($uid); 
    466                               
    467                              if($schedulable && ( self::_getTime($component , 'dtstamp') > $schedulable['dtstamp'] || $component->getProperty( 'sequence' , false , false ) > $schedulable['sequence'])) //Caso o evento exista 
    468                              { 
    469                                  $interation = self::_makeVEVENT($schedulable , $component , $params); 
    470                                   
    471                                  if(!self::_existInMyCalendars($schedulable['id'])) 
    472                                  { 
    473                                       $calendarToSchedulable = array(); 
    474                                       $calendarToSchedulable['calendar'] = $params['calendar']; 
    475                                       $calendarToSchedulable['schedulable'] = $schedulable['id']; 
    476                                       $interation['calendarToSchedulable://'.mt_rand().'(Formatter)'] = $calendarToSchedulable; 
    477                                  } 
    478                                   
    479                              } 
    480                              else // Importar evento 
    481                                 $interation = self::_makeVEVENT( array() , $component , $params); 
    482                               
    483                               
    484                               
    485                              break; 
    486                     } 
    487                      
    488                     $return[] = $interation; 
    489                     break; 
    490                case 'VTIMEZONE': 
    491  
    492  
    493                     break; 
    494             } 
    495          
    496         } 
    497                  
    498                 return $return;    
    499     } 
    500      
    501         public function analize ( $data , $params = false) 
    502         { 
    503             $vcalendar = new icalCreator( );  
    504             $vcalendar->parse(trim($data));  
    505             $vcalendar->sort();          
    506  
    507             $return = array(); 
    508             $method = $vcalendar->getProperty('method',FALSE , FALSE); 
    509  
    510             while ($component = $vcalendar->getComponent()) 
    511             {      
    512                 $interation = array(); 
    513                 $uid = $component->getProperty( 'uid' , false , false ); //Resgata o uid do componente 
    514  
    515                 switch (strtoupper($component->objName)) { 
    516                     case 'VEVENT': 
    517  
    518                         switch ($method)  
    519                         { 
    520                              case 'PUBLISH':             
    521                                    $interation = ICAL_ACTION_IMPORT; 
    522                                    break; 
    523  
    524                              case 'REQUEST': 
    525                                  $schedulable = self::_getSchedulable($uid); 
    526                                  if($schedulable ) //Caso o evento exista 
    527                                  { 
    528                                     $isOrganizer = false; 
    529                                     $isParticipant = false; 
    530  
    531                                     foreach($schedulable['participants'] as $value) 
    532                                         if($value['user']['id'] == Config::me('uidNumber')){ 
    533                                                 $isParticipant = true; 
    534                                                 if($value['isOrganizer']) 
    535                                                         $isOrganizer = true; 
    536  
    537                                                 if(!self::_existInMyCalendars($schedulable['id'])){ 
    538                                                         $interation = ICAL_ACTION_UPDATE;  
    539                                                         $interation = ( strrpos($value['acl'], ATTENDEE_ACL_PARTICIPATION_REQUIRED) ) ? ICAL_ACTION_IMPORT_REQUIRED : ICAL_ACTION_IMPORT; 
    540                                                         break; 
    541                                                 }                                    
    542                                         }else 
    543                                     { 
    544                                         if( self::_getTime($component , 'dtstamp') > $schedulable['dtstamp'] || $component->getProperty( 'sequence' , false , false ) > $schedulable['sequence']) //Organizador esta requisitando que você atualize o evento 
    545                                            $interation = ($isOrganizer) ? ICAL_ACTION_ORGANIZER_UPDATE : ICAL_ACTION_UPDATE;    
    546                                         else 
    547                                            $interation = ($isOrganizer) ? ICAL_ACTION_ORGANIZER_NONE : ICAL_ACTION_NONE;     
    548                                     } 
    549                                                                         if(!$isParticipant) 
    550                                                                                 $interation = ICAL_ACTION_ORGANIZER_NONE; 
    551                                  }else 
    552                                    $interation =  ICAL_ACTION_IMPORT; 
    553  
    554                                  break;   
    555  
    556                              case 'REFRESH': 
    557                                    break;   
    558  
    559                              case 'CANCEL': 
    560                                     $interation = ICAL_ACTION_DELETE; 
    561                                    break; 
    562  
    563                              case 'ADD': 
    564                                    break; 
    565  
    566                              case 'REPLY': 
    567                                      $interation = ICAL_ACTION_REPLY; 
    568                                    break; 
    569  
    570                              case 'COUNTER': 
    571                                     $interation = ICAL_ACTION_SUGGESTION; 
    572                                    break; 
    573  
    574                              case 'DECLINECOUNTER': 
    575                                    $interation = ICAL_ACTION_NONE; 
    576                                                                    break; 
    577  
    578                              default: 
    579                                  $schedulable = self::_getSchedulable($uid); 
    580  
    581                                  if($schedulable && ( self::_getTime($component , 'dtstamp') > $schedulable['dtstamp'] || $component->getProperty( 'sequence' , false , false ) > $schedulable['sequence'])) //Caso o evento exista 
    582                                       $interation = ICAL_ACTION_UPDATE; 
    583                                  else if($schedulable)  
    584                                      $interation = ICAL_ACTION_NONE; 
    585                                  else // Importar evento 
    586                                       $interation = ICAL_ACTION_IMPORT; 
    587  
    588                                  break; 
    589                         } 
    590  
    591                         $return[$uid] = $interation; 
    592                         break; 
    593                    case 'VTIMEZONE': 
    594  
    595  
    596                         break; 
    597                 } 
    598  
    599             } 
    600            
    601              return $return;    
    602         } 
    603      
    604      
     215                                    } 
     216                                } 
     217                            } else { // Importar evento 
     218                                $interation = self::_makeVEVENT(array(), $component, $params); 
     219 
     220                                if (strpos($params['prodid'], 'kigkonsult.se') !== false) { //envia notificação para fora 
     221 
     222                                    /* Data de Inicio */ 
     223                                    $startTime = $component->getProperty('dtstart', false, true); 
     224 
     225                                    /* Tiem zone do evento */ 
     226                                    if (isset($startTime['params']['TZID'])) 
     227                                        $sc['timezone'] = self::nomalizeTZID($startTime['params']['TZID']); 
     228                                    else 
     229                                        $sc['timezone'] = isset($params['calendar_timezone']) ? $params['calendar_timezone'] : 'America/Sao_Paulo'; 
     230 
     231                                    $objTimezone = new DateTimeZone($sc['timezone']); 
     232 
     233                                    if (isset($startTime['params']['VALUE']) && $startTime['params']['VALUE'] === 'DATE' && isset($params['calendar_timezone'])) { 
     234                                        $sc['allDay'] = 1; 
     235                                        $sc['startTime'] = self::date2timestamp($startTime['value']) - self::_getTzOffset('UTC', $sc['timezone']) . '000'; 
     236                                    } 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 */ 
     237                                        $sc['startTime'] = self::date2timestamp($startTime['value']) - self::_getTzOffset('UTC', $startTime['params']['TZID']) . '000'; 
     238                                    else { 
     239                                        $sc['startTime'] = self::date2timestamp($startTime['value']) . '000'; 
     240                                        if (strpos($params['prodid'], 'Outlook') !== false) { 
     241                                            //Se o ics veio em utc não aplicar horario de verão 
     242                                            $sTime = new DateTime('@' . (int) ($sc['startTime'] / 1000), new DateTimeZone('UTC')); 
     243                                            $sTime->setTimezone($objTimezone); 
     244                                            if ($sTime->format('I')) //Se o ics veio em utc não aplicar horario de verão 
     245                                                $sc['startTime'] = $sc['startTime'] - 3600000; 
     246                                        } 
     247                                    } 
     248 
     249 
     250                                    /* Data de Termino */ 
     251                                    $endTime = $component->getProperty('dtend', false, true); 
     252 
     253                                    if (isset($endTime['params']['VALUE']) && $endTime['params']['VALUE'] === 'DATE') 
     254                                        $sc['endTime'] = self::date2timestamp($endTime['value']) - self::_getTzOffset('UTC', $sc['timezone']) . '000'; 
     255                                    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 */ 
     256                                        $sc['endTime'] = self::date2timestamp($endTime['value']) - self::_getTzOffset('UTC', $endTime['params']['TZID']) . '000'; 
     257                                    else { 
     258                                        $sc['endTime'] = self::date2timestamp($endTime['value']) . '000'; 
     259                                        if (strpos($params['prodid'], 'Outlook') !== false) { 
     260                                            //Se o ics veio em utc não aplicar horario de verão 
     261                                            $eTime = new DateTime('@' . (int) ($sc['endTime'] / 1000), new DateTimeZone('UTC')); 
     262                                            $eTime->setTimezone($objTimezone); 
     263                                            if ($eTime->format('I')) 
     264                                                $sc['endTime'] = $sc['endTime'] - 3600000; 
     265                                        } 
     266                                    } 
     267 
     268 
     269                                    if ($uid = $component->getProperty('uid', false, false)) 
     270                                        ; 
     271                                    $sc['uid'] = $uid; 
     272 
     273 
     274                                    $sc['summary'] = mb_convert_encoding($component->getProperty('summary', false, false), 'UTF-8', 'UTF-8,ISO-8859-1'); 
     275 
     276                                    /* Definindo Description */ 
     277                                    if ($desc = $component->getProperty('description', false, false)) 
     278                                        $sc['description'] = mb_convert_encoding(str_ireplace(array('\n', '\t'), array("\n", "\t"), $desc), 'UTF-8', 'UTF-8,ISO-8859-1'); 
     279 
     280                                    /* Definindo location */ 
     281                                    if ($location = $component->getProperty('location', false, false)) 
     282                                        $sc['location'] = mb_convert_encoding($location, 'UTF-8', 'UTF-8,ISO-8859-1'); 
     283 
     284 
     285 
     286                                    if ($property = $component->getProperty('organizer', FALSE, TRUE)) { 
     287                                        $participant = array(); 
     288                                        $mailUser = trim(str_replace('MAILTO:', '', $property['value'])); 
     289 
     290                                        $participantID = mt_rand() . '2(Formatter)'; 
     291 
     292                                        $participant['isOrganizer'] = '1'; 
     293 
     294                                        $user = null; 
     295 
     296                                        $participant['isExternal'] = 1; 
     297                                        /* Gera um randon id para o contexto formater */ 
     298                                        $userID = mt_rand() . '4(Formatter)'; 
     299 
     300                                        $user['mail'] = $mailUser; 
     301                                        $organizerMail = $mailUser; 
     302 
     303                                        $user['name'] = ( isset($property['params']['CN']) ) ? $property['params']['CN'] : ''; 
     304                                        $user['isExternal'] = '1'; 
     305                                        $participant['user'] = $user; 
     306 
     307                                        $sc['participants'][] = $participant; 
     308                                    } 
     309 
     310 
     311                                    $participant['status'] = isset($params['status']) ? $params['status'] : STATUS_ACCEPTED; 
     312                                    $participant['isOrganizer'] = '0'; 
     313                                    $participant['isExternal'] = 0; 
     314                                    $participant['user'] = array('mail' => Config::me('mail'), 'name' => Config::me('cn')); 
     315                                    $sc['participants'][] = $participant; 
     316                                    $sc['type'] = EVENT_ID; 
     317 
     318 
     319                                    $ical['source'] = Controller::format(array('service' => 'iCal'), array($sc), array('method' => 'REPLY')); 
     320                                    $ical['type'] = 'application/ics'; 
     321                                    $ical['name'] = 'outlook.ics'; 
     322 
     323                                    $ical2['source'] = $ical['source']; 
     324                                    $ical2['type'] = 'text/calendar; method=REPLY'; 
     325                                    $ical2['name'] = 'thunderbird.ics'; 
     326 
     327                                    $timezone = new DateTimeZone('UTC'); 
     328                                    $sTime = new DateTime('@' . (int) ($sc['startTime'] / 1000), $timezone); 
     329                                    $eTime = new DateTime('@' . (int) ($sc['endTime'] / 1000), $timezone); 
     330 
     331                                    if (isset($sc['timezone'])) { 
     332                                        $sTime->setTimezone(new DateTimeZone($sc['timezone'])); 
     333                                        $eTime->setTimezone(new DateTimeZone($sc['timezone'])); 
     334                                    } 
     335 
     336                                    $data = array('startDate' => date_format($sTime, 'd/m/Y'), 
     337                                        'startTime' => (isset($sc['allDay']) && $sc['allDay'] ) ? '' : date_format($sTime, 'H:i'), 
     338                                        'endDate' => date_format($eTime, 'd/m/Y'), 
     339                                        'endTime' => isset($sc['allDay']) ? '' : date_format($eTime, 'H:i'), 
     340                                        'eventTitle' => $sc['summary'], 
     341                                        'eventLocation' => isset($sc['location']) ? $sc['location'] : '', 
     342                                        'timezone' => ($sc['timezone']) ? $sc['timezone'] : 'UTC', 
     343                                        'participant' => (isset($part['user']['name']) ? $part['user']['name'] : $part['user']['mail'])); 
     344 
     345                                    $subject['notificationType'] = 'Convite Aceito'; 
     346                                    $subject['eventTitle'] = mb_convert_encoding($sc['summary'], 'ISO-8859-1', 'ISO-8859-1,UTF-8'); 
     347                                    $subject['startDate'] = date_format($sTime, 'd/m/Y'); 
     348                                    $subject['startTime'] = ($sc['allDay']) ? '' : date_format($sTime, 'H:i'); 
     349                                    $subject['endDate'] = date_format($eTime, 'd/m/Y'); 
     350                                    $subject['endTime'] = ($sc['allDay']) ? '' : date_format($eTime, 'H:i'); 
     351                                    $subject['participant'] = Config::me('uid'); 
     352 
     353                                    $params['status'] = isset($params['status']) ? $params['status'] : STATUS_ACCEPTED; 
     354 
     355                                    switch ($params['status']) { 
     356                                        case STATUS_ACCEPTED: 
     357                                            $tpl = 'notify_accept_body'; 
     358                                            $subject['notificationType'] = 'Convite Aceito'; 
     359                                            break; 
     360                                        case STATUS_TENTATIVE: 
     361                                            $tpl = 'notify_attempt_body'; 
     362                                            $subject['notificationType'] = 'Convite  aceito provisoriamente'; 
     363                                            break; 
     364                                        case STATUS_CANCELLED: 
     365                                            $tpl = 'notify_reject_body'; 
     366                                            $subject['notificationType'] = 'Convite rejeitado'; 
     367                                            break; 
     368                                    } 
     369                                    require_once ROOTPATH . '/api/parseTPL.php'; 
     370 
     371                                    $mail = array(); 
     372                                    $mail['attachments'][] = $ical; 
     373                                    $mail['attachments'][] = $ical2; 
     374 
     375                                    $mail['isHtml'] = true; 
     376                                    $mail['body'] = parseTPL::load_tpl($data, ROOTPATH . '/modules/calendar/templates/' . $tpl . '.tpl'); 
     377                                    $mail['subject'] = parseTPL::load_tpl($subject, ROOTPATH . '/modules/calendar/templates/notify_subject.tpl'); 
     378                                    ; 
     379                                    $mail['from'] = '"' . Config::me('cn') . '" <' . Config::me('mail') . '>'; 
     380                                    $mail['to'] = $organizerMail; 
     381 
     382 
     383                                    Controller::create(array('service' => 'SMTP'), $mail); 
     384                                } 
     385                            } 
     386                            break; 
     387 
     388                        case 'REFRESH': 
     389                            break; 
     390 
     391                        case 'CANCEL': 
     392                            if ($schedulable = self::_getSchedulable($uid)) 
     393                                $interation['schedulable://' . $schedulable['id']] = false; 
     394                            break; 
     395 
     396                        case 'ADD': 
     397                            break; 
     398 
     399                        case 'REPLY': 
     400                            if ($schedulable = self::_getSchedulable($uid)) { 
     401                                while ($property = $component->getProperty('attendee', FALSE, TRUE)) 
     402                                    if ($pID = self::_getParticipantByMail(str_replace('MAILTO:', '', $property['value']), $schedulable['participants'])) 
     403                                        $interation['participant://' . $pID] = array('id' => $pID, 'status' => constant('STATUS_' . strtoupper($property['params']['PARTSTAT']))); 
     404 
     405                                $interation['schedulable://' . $schedulable['id']]['sequence'] = $schedulable['sequence'] + 1; 
     406                            } 
     407                            break; 
     408 
     409                        case 'COUNTER': 
     410                            if ($params['acceptedSuggestion'] !== 'false') { 
     411 
     412                                $schedulable = self::_getSchedulable($uid); 
     413                                $params['calendar'] = self::_existInMyCalendars($schedulable['id']); 
     414 
     415                                $interation = self::_makeCOUNTER($schedulable, $component, $params); 
     416                                Config::regSet('noAlarm', FALSE); 
     417                            } else { 
     418                                $response = array(); 
     419                                $response['from'] = $params['from']; 
     420                                $response['type'] = 'suggestionResponse'; 
     421                                $response['status'] = 'DECLINECOUNTER'; 
     422                                $response['schedulable'] = self::_getSchedulable($uid); 
     423 
     424                                Controller::create(array('concept' => 'notification'), $response); 
     425                            } 
     426                            break; 
     427 
     428                        case 'DECLINECOUNTER': 
     429                            break; 
     430 
     431                        default: 
     432 
     433                            $schedulable = self::_getSchedulable($uid); 
     434 
     435                            if ($schedulable && ( self::_getTime($component, 'dtstamp') > $schedulable['dtstamp'] || $component->getProperty('sequence', false, false) > $schedulable['sequence'])) { //Caso o evento exista 
     436                                $interation = self::_makeVEVENT($schedulable, $component, $params); 
     437 
     438                                if (!self::_existInMyCalendars($schedulable['id'])) { 
     439                                    $calendarToSchedulable = array(); 
     440                                    $calendarToSchedulable['calendar'] = $params['calendar']; 
     441                                    $calendarToSchedulable['schedulable'] = $schedulable['id']; 
     442                                    $interation['calendarToSchedulable://' . mt_rand() . '(Formatter)'] = $calendarToSchedulable; 
     443                                } 
     444                            } 
     445                            else // Importar evento 
     446                                $interation = self::_makeVEVENT(array(), $component, $params); 
     447 
     448 
     449 
     450                            break; 
     451                    } 
     452 
     453                    $return[] = $interation; 
     454                    break; 
     455                case 'VTIMEZONE': 
     456 
     457 
     458                    break; 
     459            } 
     460        } 
     461 
     462        return $return; 
     463    } 
     464 
     465    public function analize($data, $params = false) { 
     466        $vcalendar = new icalCreator( ); 
     467        $vcalendar->parse(trim($data)); 
     468        $vcalendar->sort(); 
     469 
     470        $return = array(); 
     471        $method = $vcalendar->getProperty('method', FALSE, FALSE); 
     472 
     473        while ($component = $vcalendar->getComponent()) { 
     474            $interation = array(); 
     475            $uid = $component->getProperty('uid', false, false); //Resgata o uid do componente 
     476 
     477            switch (strtoupper($component->objName)) { 
     478                case 'VEVENT': 
     479 
     480                    switch ($method) { 
     481                        case 'PUBLISH': 
     482                            $interation = ICAL_ACTION_IMPORT; 
     483                            break; 
     484 
     485                        case 'REQUEST': 
     486                            $schedulable = self::_getSchedulable($uid); 
     487                            if ($schedulable) { //Caso o evento exista 
     488                                $isOrganizer = false; 
     489                                $isParticipant = false; 
     490 
     491                                foreach ($schedulable['participants'] as $value) 
     492                                    if ($value['user']['id'] == Config::me('uidNumber')) { 
     493                                        $isParticipant = true; 
     494                                        if ($value['isOrganizer']) 
     495                                            $isOrganizer = true; 
     496 
     497                                        if (!self::_existInMyCalendars($schedulable['id'])) { 
     498                                            $interation = ICAL_ACTION_UPDATE; 
     499                                            $interation = ( strrpos($value['acl'], ATTENDEE_ACL_PARTICIPATION_REQUIRED) ) ? ICAL_ACTION_IMPORT_REQUIRED : ICAL_ACTION_IMPORT; 
     500                                            break; 
     501                                        } 
     502                                    } else { 
     503                                        if (self::_getTime($component, 'dtstamp') > $schedulable['dtstamp'] || $component->getProperty('sequence', false, false) > $schedulable['sequence']) //Organizador esta requisitando que você atualize o evento 
     504                                            $interation = ($isOrganizer) ? ICAL_ACTION_ORGANIZER_UPDATE : ICAL_ACTION_UPDATE; 
     505                                        else 
     506                                            $interation = ($isOrganizer) ? ICAL_ACTION_ORGANIZER_NONE : ICAL_ACTION_NONE; 
     507                                    } 
     508                                if (!$isParticipant) 
     509                                    $interation = ICAL_ACTION_ORGANIZER_NONE; 
     510                            }else 
     511                                $interation = ICAL_ACTION_IMPORT; 
     512 
     513                            break; 
     514 
     515                        case 'REFRESH': 
     516                            break; 
     517 
     518                        case 'CANCEL': 
     519                            $interation = ICAL_ACTION_DELETE; 
     520                            break; 
     521 
     522                        case 'ADD': 
     523                            break; 
     524 
     525                        case 'REPLY': 
     526                            $interation = ICAL_ACTION_REPLY; 
     527                            break; 
     528 
     529                        case 'COUNTER': 
     530                            $interation = ICAL_ACTION_SUGGESTION; 
     531                            break; 
     532 
     533                        case 'DECLINECOUNTER': 
     534                            $interation = ICAL_ACTION_NONE; 
     535                            break; 
     536 
     537                        default: 
     538                            $schedulable = self::_getSchedulable($uid); 
     539 
     540                            if ($schedulable && ( self::_getTime($component, 'dtstamp') > $schedulable['dtstamp'] || $component->getProperty('sequence', false, false) > $schedulable['sequence'])) //Caso o evento exista 
     541                                $interation = ICAL_ACTION_UPDATE; 
     542                            else if ($schedulable) 
     543                                $interation = ICAL_ACTION_NONE; 
     544                            else // Importar evento 
     545                                $interation = ICAL_ACTION_IMPORT; 
     546 
     547                            break; 
     548                    } 
     549 
     550                    $return[$uid] = $interation; 
     551                    break; 
     552                case 'VTIMEZONE': 
     553 
     554 
     555                    break; 
     556            } 
     557        } 
     558 
     559        return $return; 
     560    } 
     561 
    605562    /* Helpers */ 
    606         private static function _getTzOffset($rTz, $oTz = null , $time = 'now')  
    607         { 
    608             if($oTz === null) { 
    609                 if(!is_string($oTz = date_default_timezone_get())) { 
    610                        return false; // A UTC timestamp was returned -- bail out! 
    611                 }  
    612             } 
    613             $origin_dtz = new DateTimeZone(self::nomalizeTZID($oTz)); 
    614             $remote_dtz = new DateTimeZone(self::nomalizeTZID($rTz)); 
    615             $origin_dt = new DateTime($time, $origin_dtz); 
    616             $remote_dt = new DateTime("now", $remote_dtz); 
    617      
    618             $offset = $origin_dtz->getOffset($origin_dt) - $remote_dtz->getOffset($remote_dt); 
    619              
    620              
    621             return $offset; 
    622         } 
    623  
    624         private function _getStatus( $id ) 
    625         { 
    626             $a = array(     
    627                         STATUS_CONFIRMED =>  'ACCEPTED', 
    628                         STATUS_CANCELLED =>  'CANCELLED', 
    629                         STATUS_TENTATIVE =>   'TENTATIVE', 
    630                         STATUS_UNANSWERED => 'NEEDS-ACTION', 
    631                         STATUS_DELEGATED =>  'DELEGATED' 
    632                       ); 
    633              
    634              return isset($a[ $id ]) ? $a[ $id ] : 'NEEDS-ACTION'; 
    635         } 
    636          
    637         private static function _getParticipantByMail( $mail , &$participants ) 
    638         {           
    639             foreach ($participants as $i => $v) 
    640                 if($v['user']['mail'] == $mail  || (isset($v['user']['mailAlternateAddress']) && in_array($mail, $v['user']['mailAlternateAddress']))) 
    641                     return $v['id'];                         
    642                  
    643             return false; 
    644         } 
    645          
    646         static private function nomalizeTZID ($TZID) 
    647         {  
    648             if(isset(self::$timezonesMap[$TZID])) 
    649                 return self::$timezonesMap[$TZID]; 
    650             else if(in_array($TZID, self::$suportedTimzones)) 
    651                 return $TZID; 
    652             else  
    653                 return date_default_timezone_get();        
    654         }    
    655          
    656         static private function date2timestamp( $datetime, $tz=null )  
    657         { 
    658             if( !isset( $datetime['hour'] )) $datetime['hour'] = '0'; 
    659             if( !isset( $datetime['min'] ))  $datetime['min']  = '0'; 
    660             if( !isset( $datetime['sec'] ))  $datetime['sec']  = '0'; 
    661           
    662             foreach( $datetime as $dkey => $dvalue )  
    663               if( 'tz' != $dkey ) 
    664                 $datetime[$dkey] = (integer) $dvalue; 
    665              
    666             if( $tz ) 
    667               $datetime['tz'] = $tz; 
    668              
    669             $offset = ( isset( $datetime['tz'] ) && ( '' < trim ( $datetime['tz'] ))) ? iCalUtilityFunctions::_tz2offset( $datetime['tz'] ) : 0; 
    670              
    671             return gmmktime( $datetime['hour'], $datetime['min'], ($datetime['sec'] + $offset), $datetime['month'], $datetime['day'], $datetime['year'] );    
    672         } 
    673  
    674                 static private function _makeCOUNTER( $schedulable , $component ,$params) 
    675         { 
    676                         $interation = array();                   
    677             $eventID = isset($schedulable['id']) ? $schedulable['id'] : mt_rand().'(Formatter)'; 
    678              
    679             /* Data de Inicio*/ 
    680                 $startTime = $component->getProperty( 'dtstart', false , true ); 
    681                                  
    682             /* Tiem zone do evento*/     
    683                if(isset($startTime['params']['TZID'])) 
    684                   $schedulable['timezone'] = self::nomalizeTZID ($startTime['params']['TZID']);  
    685                else 
    686                   $schedulable['timezone'] = isset($params['calendar_timezone']) ? $params['calendar_timezone'] : 'America/Sao_Paulo';  
    687                 
    688                 $objTimezone =  new DateTimeZone($schedulable['timezone']);   
    689                  
    690                 if($startTime['params']['VALUE'] === 'DATE' && isset($params['calendar_timezone']) ) 
    691                 { 
    692                     $schedulable['allDay'] = 1; 
    693                     $schedulable['startTime'] = self::date2timestamp($startTime['value']) - self::_getTzOffset('UTC',$schedulable['timezone'], '@'.self::date2timestamp($startTime['value'])) . '000'; 
    694                 } 
    695                 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 */ 
    696                     $schedulable['startTime'] = self::date2timestamp($startTime['value']) - self::_getTzOffset('UTC',$startTime['params']['TZID'],'@'.self::date2timestamp($startTime['value'])) . '000';       
    697                                         $schedulable['allDay'] = 0; 
    698                                 } 
    699                                 else 
    700                 { 
    701                     $schedulable['startTime'] = self::date2timestamp($startTime['value']) . '000'; 
    702                      if( strpos($params['prodid'], 'Outlook') !== false ) 
    703                     { 
    704                         //Se o ics veio em utc não aplicar horario de verão 
    705                         $sTime = new DateTime( '@'.(int)($schedulable['startTime'] / 1000) , new DateTimeZone('UTC') );  
    706                         $sTime->setTimezone($objTimezone); 
    707                         if($sTime->format('I')) //Se o ics veio em utc não aplicar horario de verão 
    708                          $schedulable['startTime'] = $schedulable['startTime'] - 3600000; 
    709                     } 
    710                 } 
    711                  
    712  
    713              /* Data de Termino*/ 
    714                 $endTime = $component->getProperty( 'dtend', false , true );  
    715  
    716                 if($endTime['params']['VALUE'] === 'DATE') 
    717                     $schedulable['endTime'] = self::date2timestamp($endTime['value']) - self::_getTzOffset('UTC',$schedulable['timezone'],'@'.self::date2timestamp($endTime['value'])) . '000'; 
    718                 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 */ 
    719                     $schedulable['endTime'] = self::date2timestamp($endTime['value']) - self::_getTzOffset('UTC',$endTime['params']['TZID'],'@'.self::date2timestamp($endTime['value'])) . '000'; 
    720                 else 
    721                 { 
    722                     $schedulable['endTime'] = self::date2timestamp($endTime['value']) . '000'; 
    723                     if( strpos($params['prodid'], 'Outlook') !== false ) 
    724                     { 
    725                     //Se o ics veio em utc não aplicar horario de verão 
    726                         $eTime = new DateTime( '@'.(int)($schedulable['endTime'] / 1000)  ,new DateTimeZone('UTC'));  
    727                         $eTime->setTimezone($objTimezone); 
    728                         if($eTime->format('I'))  
    729                             $schedulable['endTime'] = $schedulable['endTime'] - 3600000; 
    730                     
    731                                         } 
    732                                 } 
    733                         unset($schedulable['participants']);                     
    734                         $interation['schedulable://'.$eventID] = $schedulable; 
    735                           
    736             return $interation; 
    737                 } 
    738                  
    739         static private function _makeVEVENT( $schedulable , $component ,$params) 
    740         { 
    741                          
    742             $interation = array();                   
    743             $eventID = isset($schedulable['id']) ? $schedulable['id'] : mt_rand().'(Formatter)'; 
    744              
    745             /* Data de Inicio*/ 
    746                 $startTime = $component->getProperty( 'dtstart', false , true ); 
    747  
    748             /* Tiem zone do evento*/     
    749                if(isset($startTime['params']['TZID'])) 
    750                   $schedulable['timezone'] = self::nomalizeTZID ($startTime['params']['TZID']);  
    751                else 
    752                   $schedulable['timezone'] = isset($params['calendar_timezone']) ? $params['calendar_timezone'] : 'America/Sao_Paulo';  
    753                 
    754                 $objTimezone =  new DateTimeZone($schedulable['timezone']);   
    755                  
    756                 if(isset($startTime['params']['VALUE']) &&  $startTime['params']['VALUE'] === 'DATE' && isset($params['calendar_timezone']) ) 
    757                 { 
    758                     $schedulable['allDay'] = 1; 
    759                     $schedulable['startTime'] = self::date2timestamp($startTime['value']) - self::_getTzOffset('UTC',$schedulable['timezone'],'@'.self::date2timestamp($startTime['value'])) . '000'; 
    760                 } 
    761                 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 */ 
    762                     $schedulable['startTime'] = self::date2timestamp($startTime['value']) - self::_getTzOffset('UTC',$startTime['params']['TZID'],'@'.self::date2timestamp($startTime['value'])) . '000';       
    763                     $schedulable['allDay'] = 0; 
    764                 } 
     563 
     564    private static function _getTzOffset($rTz, $oTz = null, $time = 'now') { 
     565        if ($oTz === null) { 
     566            if (!is_string($oTz = date_default_timezone_get())) { 
     567                return false; // A UTC timestamp was returned -- bail out! 
     568            } 
     569        } 
     570        $origin_dtz = new DateTimeZone(self::nomalizeTZID($oTz)); 
     571        $remote_dtz = new DateTimeZone(self::nomalizeTZID($rTz)); 
     572        $origin_dt = new DateTime($time, $origin_dtz); 
     573        $remote_dt = new DateTime("now", $remote_dtz); 
     574 
     575        $offset = $origin_dtz->getOffset($origin_dt) - $remote_dtz->getOffset($remote_dt); 
     576 
     577 
     578        return $offset; 
     579    } 
     580 
     581    private function _getStatus($id) { 
     582        $a = array( 
     583            STATUS_CONFIRMED => 'ACCEPTED', 
     584            STATUS_CANCELLED => 'CANCELLED', 
     585            STATUS_TENTATIVE => 'TENTATIVE', 
     586            STATUS_UNANSWERED => 'NEEDS-ACTION', 
     587            STATUS_DELEGATED => 'DELEGATED' 
     588        ); 
     589 
     590        return isset($a[$id]) ? $a[$id] : 'NEEDS-ACTION'; 
     591    } 
     592 
     593    private static function _getParticipantByMail($mail, &$participants) { 
     594        if ($participants && $participants != '') 
     595            foreach ($participants as $i => $v) 
     596                if ((is_array($v) && isset($v['user'])) && ($v['user']['mail'] == $mail || (isset($v['user']['mailAlternateAddress']) && in_array($mail, $v['user']['mailAlternateAddress'])))) 
     597                    return $v['id']; 
     598        return false; 
     599    } 
     600 
     601    static private function nomalizeTZID($TZID) { 
     602        if (isset(self::$timezonesMap[$TZID])) 
     603            return self::$timezonesMap[$TZID]; 
     604        else if (in_array($TZID, self::$suportedTimzones)) 
     605            return $TZID; 
     606        else 
     607            return date_default_timezone_get(); 
     608    } 
     609 
     610    static private function date2timestamp($datetime, $tz = null) { 
     611        if (!isset($datetime['hour'])) 
     612            $datetime['hour'] = '0'; 
     613        if (!isset($datetime['min'])) 
     614            $datetime['min'] = '0'; 
     615        if (!isset($datetime['sec'])) 
     616            $datetime['sec'] = '0'; 
     617 
     618        foreach ($datetime as $dkey => $dvalue) 
     619            if ('tz' != $dkey) 
     620                $datetime[$dkey] = (integer) $dvalue; 
     621 
     622        if ($tz) 
     623            $datetime['tz'] = $tz; 
     624 
     625        $offset = ( isset($datetime['tz']) && ( '' < trim($datetime['tz']))) ? iCalUtilityFunctions::_tz2offset($datetime['tz']) : 0; 
     626 
     627        return gmmktime($datetime['hour'], $datetime['min'], ($datetime['sec'] + $offset), $datetime['month'], $datetime['day'], $datetime['year']); 
     628    } 
     629 
     630    static private function _makeCOUNTER($schedulable, $component, $params) { 
     631        $interation = array(); 
     632        $eventID = isset($schedulable['id']) ? $schedulable['id'] : mt_rand() . '(Formatter)'; 
     633 
     634        /* Data de Inicio */ 
     635        $startTime = $component->getProperty('dtstart', false, true); 
     636 
     637        /* Tiem zone do evento */ 
     638        if (isset($startTime['params']['TZID'])) 
     639            $schedulable['timezone'] = self::nomalizeTZID($startTime['params']['TZID']); 
     640        else 
     641            $schedulable['timezone'] = isset($params['calendar_timezone']) ? $params['calendar_timezone'] : 'America/Sao_Paulo'; 
     642 
     643        $objTimezone = new DateTimeZone($schedulable['timezone']); 
     644 
     645        if ($startTime['params']['VALUE'] === 'DATE' && isset($params['calendar_timezone'])) { 
     646            $schedulable['allDay'] = 1; 
     647            $schedulable['startTime'] = self::date2timestamp($startTime['value']) - self::_getTzOffset('UTC', $schedulable['timezone'], '@' . self::date2timestamp($startTime['value'])) . '000'; 
     648        } 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 */ 
     649            $schedulable['startTime'] = self::date2timestamp($startTime['value']) - self::_getTzOffset('UTC', $startTime['params']['TZID'], '@' . self::date2timestamp($startTime['value'])) . '000'; 
     650            $schedulable['allDay'] = 0; 
     651        } else { 
     652            $schedulable['startTime'] = self::date2timestamp($startTime['value']) . '000'; 
     653            if (strpos($params['prodid'], 'Outlook') !== false) { 
     654                //Se o ics veio em utc não aplicar horario de verão 
     655                $sTime = new DateTime('@' . (int) ($schedulable['startTime'] / 1000), new DateTimeZone('UTC')); 
     656                $sTime->setTimezone($objTimezone); 
     657                if ($sTime->format('I')) //Se o ics veio em utc não aplicar horario de verão 
     658                    $schedulable['startTime'] = $schedulable['startTime'] - 3600000; 
     659            } 
     660        } 
     661 
     662 
     663        /* Data de Termino */ 
     664        $endTime = $component->getProperty('dtend', false, true); 
     665 
     666        if ($endTime['params']['VALUE'] === 'DATE') 
     667            $schedulable['endTime'] = self::date2timestamp($endTime['value']) - self::_getTzOffset('UTC', $schedulable['timezone'], '@' . self::date2timestamp($endTime['value'])) . '000'; 
     668        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 */ 
     669            $schedulable['endTime'] = self::date2timestamp($endTime['value']) - self::_getTzOffset('UTC', $endTime['params']['TZID'], '@' . self::date2timestamp($endTime['value'])) . '000'; 
     670        else { 
     671            $schedulable['endTime'] = self::date2timestamp($endTime['value']) . '000'; 
     672            if (strpos($params['prodid'], 'Outlook') !== false) { 
     673                //Se o ics veio em utc não aplicar horario de verão 
     674                $eTime = new DateTime('@' . (int) ($schedulable['endTime'] / 1000), new DateTimeZone('UTC')); 
     675                $eTime->setTimezone($objTimezone); 
     676                if ($eTime->format('I')) 
     677                    $schedulable['endTime'] = $schedulable['endTime'] - 3600000; 
     678            } 
     679        } 
     680        unset($schedulable['participants']); 
     681        $interation['schedulable://' . $eventID] = $schedulable; 
     682 
     683        return $interation; 
     684    } 
     685 
     686    static private function _makeVEVENT($schedulable, $component, $params) { 
     687 
     688        $interation = array(); 
     689        $eventID = isset($schedulable['id']) ? $schedulable['id'] : mt_rand() . '(Formatter)'; 
     690 
     691        /* Data de Inicio */ 
     692        $startTime = $component->getProperty('dtstart', false, true); 
     693 
     694        /* Tiem zone do evento */ 
     695        if (isset($startTime['params']['TZID'])) 
     696            $schedulable['timezone'] = self::nomalizeTZID($startTime['params']['TZID']); 
     697        else 
     698            $schedulable['timezone'] = isset($params['calendar_timezone']) ? $params['calendar_timezone'] : 'America/Sao_Paulo'; 
     699 
     700        $objTimezone = new DateTimeZone($schedulable['timezone']); 
     701 
     702        if (isset($startTime['params']['VALUE']) && $startTime['params']['VALUE'] === 'DATE' && isset($params['calendar_timezone'])) { 
     703            $schedulable['allDay'] = 1; 
     704            $schedulable['startTime'] = self::date2timestamp($startTime['value']) - self::_getTzOffset('UTC', $schedulable['timezone'], '@' . self::date2timestamp($startTime['value'])) . '000'; 
     705        } 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 */ 
     706            $schedulable['startTime'] = self::date2timestamp($startTime['value']) - self::_getTzOffset('UTC', $startTime['params']['TZID'], '@' . self::date2timestamp($startTime['value'])) . '000'; 
     707            $schedulable['allDay'] = 0; 
     708        } else { 
     709            $schedulable['startTime'] = self::date2timestamp($startTime['value']) . '000'; 
     710            if (strpos($params['prodid'], 'Outlook') !== false) { 
     711                //Se o ics veio em utc não aplicar horario de verão 
     712                $sTime = new DateTime('@' . (int) ($schedulable['startTime'] / 1000), new DateTimeZone('UTC')); 
     713                $sTime->setTimezone($objTimezone); 
     714                if ($sTime->format('I')) //Se o ics veio em utc não aplicar horario de verão 
     715                    $schedulable['startTime'] = $schedulable['startTime'] - 3600000; 
     716            } 
     717        } 
     718 
     719 
     720        /* Data de Termino */ 
     721        $endTime = $component->getProperty('dtend', false, true); 
     722 
     723        if (isset($endTime['params']['VALUE']) && $endTime['params']['VALUE'] === 'DATE') 
     724            $schedulable['endTime'] = self::date2timestamp($endTime['value']) - self::_getTzOffset('UTC', $schedulable['timezone'], '@' . self::date2timestamp($endTime['value'])) . '000'; 
     725        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 */ 
     726            $schedulable['endTime'] = self::date2timestamp($endTime['value']) - self::_getTzOffset('UTC', $endTime['params']['TZID'], '@' . self::date2timestamp($endTime['value'])) . '000'; 
     727        else { 
     728            $schedulable['endTime'] = self::date2timestamp($endTime['value']) . '000'; 
     729            if (strpos($params['prodid'], 'Outlook') !== false) { 
     730                //Se o ics veio em utc não aplicar horario de verão 
     731                $eTime = new DateTime('@' . (int) ($schedulable['endTime'] / 1000), new DateTimeZone('UTC')); 
     732                $eTime->setTimezone($objTimezone); 
     733                if ($eTime->format('I')) 
     734                    $schedulable['endTime'] = $schedulable['endTime'] - 3600000; 
     735            } 
     736        } 
     737 
     738 
     739        $schedulable['summary'] = mb_convert_encoding($component->getProperty('summary', false, false), 'ISO-8859-1', 'UTF-8,ISO-8859-1'); 
     740 
     741        /* Definindo Description */ 
     742        if ($desc = $component->getProperty('description', false, false)) 
     743            $schedulable['description'] = mb_convert_encoding(str_ireplace(array('\n', '\t'), array("\n", "\t"), $desc), 'ISO-8859-1', 'UTF-8,ISO-8859-1'); 
     744 
     745        /* Definindo location */ 
     746        if ($location = $component->getProperty('location', false, false)) 
     747            $schedulable['location'] = mb_convert_encoding($location, 'ISO-8859-1', 'UTF-8,ISO-8859-1'); 
     748 
     749 
     750        /* Definindo Class */ 
     751        $class = $component->getProperty('class', false, false); 
     752        if ($class && defined(constant(strtoupper('CLASS_' . $class)))) 
     753            $schedulable['class'] = constant(strtoupper('CLASS_' . $class)); 
     754        else if (!isset($schedulable['class'])) 
     755            $schedulable['class'] = CLASS_PRIVATE; // padrão classe private 
     756 
     757        /* Definindo RRULE */ 
     758        if ($rrule = $component->getProperty('rrule', false, false)) { 
     759            /* Gera um randon id para o contexto formater */ 
     760            $repeatID = mt_rand() . '3(Formatter)'; 
     761 
     762            $repeat = array(); 
     763            $repeat['schedulable'] = $eventID; 
     764            foreach ($rrule as $i => $v) { 
     765                if (strtolower($i) == 'freq') 
     766                    $repeat['frequency'] = $v; 
     767                else if (strtolower($i) == 'until') 
     768                    $repeat['endTime'] = $v; 
    765769                else 
    766                 { 
    767                     $schedulable['startTime'] = self::date2timestamp($startTime['value']) . '000'; 
    768                      if( strpos($params['prodid'], 'Outlook') !== false ) 
    769                     { 
    770                         //Se o ics veio em utc não aplicar horario de verão 
    771                         $sTime = new DateTime( '@'.(int)($schedulable['startTime'] / 1000) , new DateTimeZone('UTC') );  
    772                         $sTime->setTimezone($objTimezone); 
    773                         if($sTime->format('I')) //Se o ics veio em utc não aplicar horario de verão 
    774                          $schedulable['startTime'] = $schedulable['startTime'] - 3600000; 
    775                     } 
    776                 } 
    777                  
    778  
    779              /* Data de Termino*/ 
    780                 $endTime = $component->getProperty( 'dtend', false , true );  
    781  
    782                 if(isset($endTime['params']['VALUE']) && $endTime['params']['VALUE'] === 'DATE') 
    783                     $schedulable['endTime'] = self::date2timestamp($endTime['value']) - self::_getTzOffset('UTC',$schedulable['timezone'],'@'.self::date2timestamp($endTime['value'])) . '000'; 
    784                 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 */ 
    785                     $schedulable['endTime'] = self::date2timestamp($endTime['value']) - self::_getTzOffset('UTC',$endTime['params']['TZID'],'@'.self::date2timestamp($endTime['value'])) . '000'; 
    786                 else 
    787                 { 
    788                     $schedulable['endTime'] = self::date2timestamp($endTime['value']) . '000'; 
    789                     if( strpos($params['prodid'], 'Outlook') !== false ) 
    790                     { 
    791                     //Se o ics veio em utc não aplicar horario de verão 
    792                         $eTime = new DateTime( '@'.(int)($schedulable['endTime'] / 1000)  ,new DateTimeZone('UTC'));  
    793                         $eTime->setTimezone($objTimezone); 
    794                         if($eTime->format('I'))  
    795                             $schedulable['endTime'] = $schedulable['endTime'] - 3600000; 
    796                     } 
    797                 } 
    798          
    799  
    800             $schedulable['summary'] = mb_convert_encoding ( $component->getProperty( 'summary' , false , false ) , 'ISO-8859-1' , 'UTF-8,ISO-8859-1'); 
    801  
    802             /* Definindo Description */ 
    803                 if($desc = $component->getProperty( 'description' , false , false )) 
    804                     $schedulable['description'] = mb_convert_encoding (str_ireplace (array('\n','\t'), array("\n","\t"), $desc) ,'ISO-8859-1'  , 'UTF-8,ISO-8859-1'); 
    805  
    806              /* Definindo location */ 
    807                 if($location = $component->getProperty( 'location' , false , false )) 
    808                     $schedulable['location'] = mb_convert_encoding ( $location , 'ISO-8859-1' , 'UTF-8,ISO-8859-1') ; 
    809  
    810  
    811             /* Definindo Class */ 
    812                 $class = $component->getProperty( 'class' , false , false ); 
    813                 if( $class && defined(constant(strtoupper('CLASS_'.$class))) ) 
    814                     $schedulable['class'] = constant(strtoupper('CLASS_'.$class)); 
    815                 else if( !isset($schedulable['class']) ) 
    816                     $schedulable['class'] = CLASS_PRIVATE ; // padrão classe private 
    817  
    818             /* Definindo RRULE */ 
    819                 if(  $rrule = $component->getProperty( 'rrule' , false , false )) 
    820                 {    
    821                     /* Gera um randon id para o contexto formater */ 
    822                         $repeatID = mt_rand().'3(Formatter)'; 
    823  
    824                     $repeat = array(); 
    825                     $repeat['schedulable'] = $eventID; 
    826                     foreach($rrule as $i => $v) 
    827                     { 
    828                         if(strtolower($i) == 'freq') 
    829                             $repeat['frequency'] = $v; 
    830                         else if(strtolower($i) == 'until') 
    831                             $repeat['endTime'] = $v; 
    832                         else 
    833                             $repeat[strtolower($i)] = $v; 
    834                     } 
    835                      
    836                     $interation['repeat://'.$repeatID] = $repeat; 
    837                 } 
    838  
    839  
    840             $schedulable['calendar'] = $params['calendar'];            
    841  
    842             $participantsInEvent = array(); 
    843  
    844             //TODO: Participants com delegated não estao sendo levados em conta 
    845             while($property = $component->getProperty('attendee',FALSE , TRUE)) 
    846             { 
    847                 $participant = array(); 
    848  
    849                 $mailUser = trim(str_replace('MAILTO:', '', $property['value'])); 
    850  
    851                 $participantID = ($tpID = self::_getParticipantByMail($mailUser, $schedulable['participants'])) ?  $tpID : mt_rand().'2(Formatter)'; 
    852                 $participant['schedulable'] = $eventID;                                       
    853                  
    854                 if(isset($params['status']) && $mailUser == Config::me('mail')) 
    855                     $participant['status'] = $params['status']; 
    856                 else 
    857                     $participant['status'] = (isset($property['params']['PARTSTAT']) && constant('STATUS_'.$property['params']['PARTSTAT']) !== null ) ? constant('STATUS_'.$property['params']['PARTSTAT']) : STATUS_UNANSWERED; 
    858                   
    859                  
    860                 $participant['isOrganizer'] = '0'; 
    861  
    862                 /* Verifica se este usuario é um usuario interno do ldap */      
    863                  $intUser = Controller::find( array( 'concept' => 'user' ) , array('id','isExternal') ,array( 'filter' => array('OR' , array('=' , 'mail' ,  $mailUser ), array('=' , 'mailAlternateAddress' ,  $mailUser ) )) );  
    864  
    865                 $user = null;     
    866                 if( $intUser && count($intUser) > 0 ) 
    867                 { 
    868                     $participant['isExternal']  = isset($intUser[0]['isExternal']) ? $intUser[0]['isExternal'] : 0; 
    869                     $participant['user'] = $intUser[0]['id']; 
    870                 } 
    871                 else 
    872                 { 
    873                     $participant['isExternal']  = 1; 
    874                      /* Gera um randon id para o contexto formater */ 
    875                         $userID = mt_rand().'4(Formatter)'; 
    876  
    877                     $user['mail'] = $mailUser; 
    878                     $user['isExternal'] = '1'; 
    879                     $user['name'] =  ( isset($property['params']['CN']) ) ? $property['params']['CN'] : ''; 
    880                     $user['participants'] = array($participantID); 
    881                     $participant['user'] = $userID; 
    882                     $interation['user://'.$userID] = $user; 
    883                 } 
    884  
    885                 $interation['participant://'.$participantID] = $participant; 
    886                 $schedulable['participants'][] = $participantID; 
    887  
    888             }; 
    889  
    890             if($property = $component->getProperty('organizer',FALSE , TRUE)) 
    891             { 
    892                 $participant = array(); 
    893                 $mailUser = trim(str_replace('MAILTO:', '', $property['value'])); 
    894  
    895                 $participantID = mt_rand().'2(Formatter)'; 
    896  
    897                 $participant['schedulable'] = $eventID; 
    898                 $participant['status'] = (isset($property['params']['PARTSTAT']) && constant('STATUS_'.$property['params']['PARTSTAT']) !== null ) ? constant('STATUS_'.$property['params']['PARTSTAT']) : STATUS_UNANSWERED; 
    899                 $participant['isOrganizer'] = '1'; 
     770                    $repeat[strtolower($i)] = $v; 
     771            } 
     772 
     773            $interation['repeat://' . $repeatID] = $repeat; 
     774        } 
     775 
     776 
     777        $schedulable['calendar'] = $params['calendar']; 
     778 
     779        $participantsInEvent = array(); 
     780 
     781        //TODO: Participants com delegated não estao sendo levados em conta 
     782        while ($property = $component->getProperty('attendee', FALSE, TRUE)) { 
     783            $participant = array(); 
     784 
     785            $mailUser = trim(str_replace('MAILTO:', '', $property['value'])); 
     786 
     787            $participantID = ($tpID = self::_getParticipantByMail($mailUser, $schedulable['participants'])) ? $tpID : mt_rand() . '2(Formatter)'; 
     788            $participant['schedulable'] = $eventID; 
     789 
     790            if (isset($params['status']) && $mailUser == Config::me('mail')) 
     791                $participant['status'] = $params['status']; 
     792            else 
     793                $participant['status'] = (isset($property['params']['PARTSTAT']) && constant('STATUS_' . $property['params']['PARTSTAT']) !== null ) ? constant('STATUS_' . $property['params']['PARTSTAT']) : STATUS_UNANSWERED; 
     794 
     795 
     796            $participant['isOrganizer'] = '0'; 
     797 
     798            /* Verifica se este usuario é um usuario interno do ldap */ 
     799            $intUser = Controller::find(array('concept' => 'user'), array('id', 'isExternal'), array('filter' => array('OR', array('=', 'mail', $mailUser), array('=', 'mailAlternateAddress', $mailUser)))); 
     800 
     801            $user = null; 
     802            if ($intUser && count($intUser) > 0) { 
     803                $participant['isExternal'] = isset($intUser[0]['isExternal']) ? $intUser[0]['isExternal'] : 0; 
     804                $participant['user'] = $intUser[0]['id']; 
     805            } else { 
     806                $participant['isExternal'] = 1; 
     807                /* Gera um randon id para o contexto formater */ 
     808                $userID = mt_rand() . '4(Formatter)'; 
     809 
     810                $user['mail'] = $mailUser; 
     811                $user['isExternal'] = '1'; 
     812                $user['name'] = ( isset($property['params']['CN']) ) ? $property['params']['CN'] : ''; 
     813                $user['participants'] = array($participantID); 
     814                $participant['user'] = $userID; 
     815                $interation['user://' . $userID] = $user; 
     816            } 
     817 
     818            $interation['participant://' . $participantID] = $participant; 
     819            $schedulable['participants'][] = $participantID; 
     820        }; 
     821 
     822        if ($property = $component->getProperty('organizer', FALSE, TRUE)) { 
     823            $participant = array(); 
     824            $mailUser = trim(str_replace('MAILTO:', '', $property['value'])); 
     825 
     826            $participantID = mt_rand() . '2(Formatter)'; 
     827 
     828            $participant['schedulable'] = $eventID; 
     829            $participant['status'] = (isset($property['params']['PARTSTAT']) && constant('STATUS_' . $property['params']['PARTSTAT']) !== null ) ? constant('STATUS_' . $property['params']['PARTSTAT']) : STATUS_UNANSWERED; 
     830            $participant['isOrganizer'] = '1'; 
     831            $participant['acl'] = 'rowi'; 
     832 
     833            /* Verifica se este usuario é um usuario interno do ldap */ 
     834            $intUser = Controller::find(array('concept' => 'user'), array('id', 'isExternal'), array('filter' => array('OR', array('=', 'mail', $mailUser), array('=', 'mailAlternateAddress', $mailUser)))); 
     835 
     836            $user = null; 
     837            if ($intUser && count($intUser) > 0) { 
     838                $participant['isExternal'] = isset($intUser[0]['isExternal']) ? $intUser[0]['isExternal'] : 0; 
     839                $participant['user'] = $intUser[0]['id']; 
     840            } else { 
     841                $participant['isExternal'] = 1; 
     842                /* Gera um randon id para o contexto formater */ 
     843                $userID = mt_rand() . '4(Formatter)'; 
     844 
     845                $user['mail'] = $mailUser; 
     846                $user['name'] = ( isset($property['params']['CN']) ) ? $property['params']['CN'] : ''; 
     847                $user['participants'] = array($participantID); 
     848                $user['isExternal'] = '1'; 
     849                $participant['user'] = $userID; 
     850                $interation['user://' . $userID] = $user; 
     851            } 
     852 
     853            $interation['participant://' . $participantID] = $participant; 
     854            $schedulable['participants'][] = $participantID; 
     855        } else if (!is_array($schedulable['participants']) || count($schedulable['participants']) < 1) {//caso não tenha organizador o usuario se torna organizador 
     856            $user = Controller::read(array('concept' => 'user', 'id' => $params['owner']), array('mail')); 
     857 
     858            if (!self::_getParticipantByMail($user['mail'], $schedulable['participants'])) { 
     859                $participantID = mt_rand() . '2(Formatter)'; 
     860 
     861                $participant['schedulable'] = $eventID; 
     862                $participant['status'] = STATUS_CONFIRMED; 
     863                $participant['isOrganizer'] = '1'; 
    900864                $participant['acl'] = 'rowi'; 
    901  
    902                 /* Verifica se este usuario é um usuario interno do ldap */      
    903                 $intUser = Controller::find( array( 'concept' => 'user' ) , array('id','isExternal') ,array( 'filter' => array('OR' , array('=' , 'mail' ,  $mailUser ), array('=' , 'mailAlternateAddress' ,  $mailUser ) )) );  
    904        
    905                 $user = null;     
    906                 if( $intUser && count($intUser) > 0 ) 
    907                 { 
    908                     $participant['isExternal']  = isset($intUser[0]['isExternal']) ? $intUser[0]['isExternal'] : 0; 
    909                     $participant['user'] = $intUser[0]['id']; 
    910                 } 
    911                 else 
    912                 { 
    913                     $participant['isExternal']  = 1; 
    914                      /* Gera um randon id para o contexto formater */ 
    915                         $userID = mt_rand().'4(Formatter)'; 
    916  
    917                     $user['mail'] = $mailUser; 
    918                     $user['name'] =  ( isset($property['params']['CN']) ) ? $property['params']['CN'] : ''; 
    919                     $user['participants'] = array($participantID); 
    920                     $user['isExternal'] = '1'; 
    921                     $participant['user'] = $userID; 
    922                     $interation['user://'.$userID] = $user; 
    923                 } 
    924  
    925                 $interation['participant://'.$participantID] = $participant; 
    926                 $schedulable['participants'][] = $participantID; 
    927  
    928             } 
    929             else if(!is_array($schedulable['participants']) || count($schedulable['participants']) < 1)//caso não tenha organizador o usuario se torna organizador 
    930             { 
    931                $user = Controller::read( array( 'concept' => 'user', 'id' => $params['owner'] ) , array('mail'));  
    932  
    933                if(!self::_getParticipantByMail($user['mail'] , $schedulable['participants'])) 
    934                { 
    935                     $participantID = mt_rand().'2(Formatter)'; 
    936  
    937                     $participant['schedulable'] = $eventID; 
    938                     $participant['status'] = STATUS_CONFIRMED; 
    939                     $participant['isOrganizer'] = '1'; 
    940                     $participant['acl'] = 'rowi'; 
    941                     $participant['isExternal']  = 0; 
    942                     $participant['user'] =  $params['owner']; 
    943                     $interation['participant://'.$participantID] = $participant; 
    944                     $schedulable['participants'][] = $participantID; 
    945                } 
    946             } 
    947  
    948              /* Definindo DTSTAMP */ 
    949             if($dtstamp = self::_getTime($component , 'dtstamp') ) 
    950                 $schedulable['dtstamp'] = $dtstamp; 
    951        
    952             /* Definindo TRANSP */ 
    953             if(($tranp = $component->getProperty( 'transp', false , true )) && $tranp && is_string($tranp) && strtoupper($tranp) == 'OPAQUE') 
    954                 $schedulable['transparent'] = 1; 
    955  
    956              /* Definindo last_update */ 
    957             if($lastUpdate =  self::_getTime($component , 'LAST-MODIFIED')) 
    958                   $schedulable['lastUpdate'] = $lastUpdate; 
    959              
    960              
    961             if($sequence = $component->getProperty( 'SEQUENCE', false , false )) 
    962                   $schedulable['sequence'] = $sequence; 
    963                
    964             if($uid = $component->getProperty( 'uid' , false , false )); 
    965                   $schedulable['uid'] = $uid; 
    966  
    967                          while($attach = $component->getProperty('ATTACH',FALSE , TRUE)){ 
    968  
    969                                 $attachCurrent = array( 'name' => $attach['params']['X-FILENAME'], 
    970                                                                 'size' => strlen($attach['value']), 
    971                                                                 'type' => self::_getContentType($attach['params']['X-FILENAME']) 
    972                                                         ); 
    973  
    974                                 $ids = Controller::find( array( 'concept' => 'attachment' ) , array('id') ,array( 'filter' => array('AND' , array( '=' , 'name' ,  $attachCurrent['name'] ), array( '=' , 'size' , $attachCurrent['size'] ), array( '=' , 'type' , $attachCurrent['type'] ))));  
    975  
    976                                 if(!is_array($ids)){ 
    977                                         $attachCurrent['source'] = $attach['value']; 
    978                                         //insere o anexo no banco e pega id para colcar no relacionamento                                
    979                                         $idAttachment =  Controller::create( array('concept' => 'attachment') , $attachCurrent ); 
    980                                 }else 
    981                                         $idAttachment = array('id' => $ids[0]['id']); 
    982                                  
    983                                 $calendarToAttachmentId = mt_rand().'2(Formatter)'; 
    984                                 $calendarToAttachment['attachment'] = $idAttachment['id'] ; 
    985                                 $calendarToAttachment['schedulable'] = $eventID ; 
    986                                 $interation['schedulableToAttachment://'.$calendarToAttachmentId] = $calendarToAttachment; 
    987                                  
    988                                 $schedulable['attachments'][] = $calendarToAttachmentId; 
    989  
    990                         } 
    991  
    992                         $interation['schedulable://'.$eventID] = $schedulable; 
    993  
    994             return $interation; 
    995         } 
    996          
    997         static private function _getSchedulable( $uid ) 
    998         { 
    999            $schedulable =  Controller::find( array( 'concept' => 'schedulable' ) , false , array ( 'filter' => array( '=' , 'uid' , $uid ), 'deepness' => 2 ));             
    1000                    return (isset($schedulable[0])) ? $schedulable[0] : false; 
    1001         } 
    1002          
    1003         static private function _existInMyCalendars( $id ) 
    1004         { 
    1005            $sig = Controller::find(array('concept' => 'calendarSignature'), array('user','calendar', 'isOwner'), array('filter' => array('AND', array( '=' , 'user' , Config::me('uidNumber') ) , array('=' , 'isOwner' , '1' ))));        
    1006            $calendars = array(); 
    1007            foreach ($sig as $val) 
    1008                $calendars[] = $val['calendar']; 
    1009             
    1010            $return =  Controller::find( array( 'concept' => 'calendarToSchedulable' ) , null , array ( 'filter' => array('AND' , array( 'IN' , 'calendar' , $calendars ),array( '=' , 'schedulable' , $id )))); 
    1011  
    1012            return (isset($return[0])) ? $return[0]['calendar'] : false; 
    1013         } 
    1014          
    1015         static private function _getTime(&$component , $property) 
    1016         { 
    1017            if($date = $component->getProperty($property , false , true )) 
    1018                 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'; 
    1019             
    1020            return false; 
    1021         } 
    1022                  
    1023                  
    1024         static private function _getContentType( $fileName ) 
    1025         { 
    1026             $strFileType = strtolower(substr ( $fileName , strrpos($fileName, '.') )); 
    1027                           
    1028                         switch( $strFileType ) 
    1029                         { 
    1030                                 case ".asf": return "video/x-ms-asf"; 
    1031                                 case ".avi": return "video/avi"; 
    1032                                 case ".doc": return "application/msword"; 
    1033                                 case ".zip": return "application/zip"; 
    1034                                 case ".xls": return "application/vnd.ms-excel"; 
    1035                                 case ".gif": return "image/gif"; 
    1036                                 case ".bmp": return "image/bmp"; 
    1037                                 case ".jpeg": 
    1038                                 case ".jpg": return "image/jpeg"; 
    1039                                 case ".wav": return "audio/wav"; 
    1040                                 case ".mp3": return "audio/mpeg3"; 
    1041                                 case ".mpeg": 
    1042                                 case ".mpg": return "video/mpeg"; 
    1043                                 case ".rtf": return "application/rtf"; 
    1044                                 case ".html": 
    1045                                 case ".htm": return "text/html"; 
    1046                                 case ".xml": return "text/xml"; 
    1047                                 case ".xsl": return "text/xsl"; 
    1048                                 case ".css": return "text/css"; 
    1049                                 case ".php": return "text/php"; 
    1050                                 case ".asp": return "text/asp"; 
    1051                                 case ".pdf": return "application/pdf"; 
    1052                                 case ".png": return "image/png"; 
    1053                                 case ".txt": return "text/plain"; 
    1054                                 case ".log": return "text/plain"; 
    1055                                 case ".wmv": return "video/x-ms-wmv"; 
    1056                                 case ".sxc": return "application/vnd.sun.xml.calc"; 
    1057                                 case ".odt": return "application/vnd.oasis.opendocument.text"; 
    1058                                 case ".stc": return "application/vnd.sun.xml.calc.template"; 
    1059                                 case ".sxd": return "application/vnd.sun.xml.draw"; 
    1060                                 case ".std": return "application/vnd.sun.xml.draw.template"; 
    1061                                 case ".sxi": return "application/vnd.sun.xml.impress"; 
    1062                                 case ".sti": return "application/vnd.sun.xml.impress.template"; 
    1063                                 case ".sxm": return "application/vnd.sun.xml.math"; 
    1064                                 case ".sxw": return "application/vnd.sun.xml.writer"; 
    1065                                 case ".sxq": return "application/vnd.sun.xml.writer.global"; 
    1066                                 case ".stw": return "application/vnd.sun.xml.writer.template"; 
    1067                                 case ".pps": return "application/vnd.ms-powerpoint"; 
    1068                                 case ".odt": return "application/vnd.oasis.opendocument.text"; 
    1069                                 case ".ott": return "application/vnd.oasis.opendocument.text-template"; 
    1070                                 case ".oth": return "application/vnd.oasis.opendocument.text-web"; 
    1071                                 case ".odm": return "application/vnd.oasis.opendocument.text-master"; 
    1072                                 case ".odg": return "application/vnd.oasis.opendocument.graphics"; 
    1073                                 case ".otg": return "application/vnd.oasis.opendocument.graphics-template"; 
    1074                                 case ".odp": return "application/vnd.oasis.opendocument.presentation"; 
    1075                                 case ".otp": return "application/vnd.oasis.opendocument.presentation-template"; 
    1076                                 case ".ods": return "application/vnd.oasis.opendocument.spreadsheet"; 
    1077                                 case ".ots": return "application/vnd.oasis.opendocument.spreadsheet-template"; 
    1078                                 case ".odc": return "application/vnd.oasis.opendocument.chart"; 
    1079                                 case ".odf": return "application/vnd.oasis.opendocument.formula"; 
    1080                                 case ".odi": return "application/vnd.oasis.opendocument.image"; 
    1081                                 case ".ndl": return "application/vnd.lotus-notes"; 
    1082                                 case ".eml": return "text/plain"; 
    1083                                 case ".ps" : return "application/postscript"; 
    1084                                 default    : return "application/octet-stream"; 
    1085                         } 
    1086         }                
     865                $participant['isExternal'] = 0; 
     866                $participant['user'] = $params['owner']; 
     867                $interation['participant://' . $participantID] = $participant; 
     868                $schedulable['participants'][] = $participantID; 
     869            } 
     870        } 
     871 
     872        /* Definindo DTSTAMP */ 
     873        if ($dtstamp = self::_getTime($component, 'dtstamp')) 
     874            $schedulable['dtstamp'] = $dtstamp; 
     875 
     876        /* Definindo TRANSP */ 
     877        if (($tranp = $component->getProperty('transp', false, true)) && $tranp && is_string($tranp) && strtoupper($tranp) == 'OPAQUE') 
     878            $schedulable['transparent'] = 1; 
     879 
     880        /* Definindo last_update */ 
     881        if ($lastUpdate = self::_getTime($component, 'LAST-MODIFIED')) 
     882            $schedulable['lastUpdate'] = $lastUpdate; 
     883 
     884 
     885        if ($sequence = $component->getProperty('SEQUENCE', false, false)) 
     886            $schedulable['sequence'] = $sequence; 
     887 
     888        if ($uid = $component->getProperty('uid', false, false)) 
     889            ; 
     890        $schedulable['uid'] = $uid; 
     891 
     892        while ($attach = $component->getProperty('ATTACH', FALSE, TRUE)) { 
     893 
     894            $attachCurrent = array('name' => $attach['params']['X-FILENAME'], 
     895                'size' => strlen($attach['value']), 
     896                'type' => self::_getContentType($attach['params']['X-FILENAME']) 
     897            ); 
     898 
     899            $ids = Controller::find(array('concept' => 'attachment'), array('id'), array('filter' => array('AND', array('=', 'name', $attachCurrent['name']), array('=', 'size', $attachCurrent['size']), array('=', 'type', $attachCurrent['type'])))); 
     900 
     901            if (!is_array($ids)) { 
     902                $attachCurrent['source'] = $attach['value']; 
     903                //insere o anexo no banco e pega id para colcar no relacionamento                                
     904                $idAttachment = Controller::create(array('concept' => 'attachment'), $attachCurrent); 
     905            }else 
     906                $idAttachment = array('id' => $ids[0]['id']); 
     907 
     908            $calendarToAttachmentId = mt_rand() . '2(Formatter)'; 
     909            $calendarToAttachment['attachment'] = $idAttachment['id']; 
     910            $calendarToAttachment['schedulable'] = $eventID; 
     911            $interation['schedulableToAttachment://' . $calendarToAttachmentId] = $calendarToAttachment; 
     912 
     913            $schedulable['attachments'][] = $calendarToAttachmentId; 
     914        } 
     915 
     916        $interation['schedulable://' . $eventID] = $schedulable; 
     917 
     918        return $interation; 
     919    } 
     920 
     921    static private function _getSchedulable($uid) { 
     922        $schedulable = Controller::find(array('concept' => 'schedulable'), false, array('filter' => array('=', 'uid', $uid), 'deepness' => 2)); 
     923        return (isset($schedulable[0])) ? $schedulable[0] : false; 
     924    } 
     925 
     926    static private function _existInMyCalendars($id) { 
     927        $sig = Controller::find(array('concept' => 'calendarSignature'), array('user', 'calendar', 'isOwner'), array('filter' => array('AND', array('=', 'user', Config::me('uidNumber')), array('=', 'isOwner', '1')))); 
     928        $calendars = array(); 
     929        foreach ($sig as $val) 
     930            $calendars[] = $val['calendar']; 
     931 
     932        $return = Controller::find(array('concept' => 'calendarToSchedulable'), null, array('filter' => array('AND', array('IN', 'calendar', $calendars), array('=', 'schedulable', $id)))); 
     933 
     934        return (isset($return[0])) ? $return[0]['calendar'] : false; 
     935    } 
     936 
     937    static private function _getTime(&$component, $property) { 
     938        if ($date = $component->getProperty($property, false, true)) 
     939            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'; 
     940 
     941        return false; 
     942    } 
     943 
     944    static private function _getContentType($fileName) { 
     945        $strFileType = strtolower(substr($fileName, strrpos($fileName, '.'))); 
     946 
     947        switch ($strFileType) { 
     948            case ".asf": return "video/x-ms-asf"; 
     949            case ".avi": return "video/avi"; 
     950            case ".doc": return "application/msword"; 
     951            case ".zip": return "application/zip"; 
     952            case ".xls": return "application/vnd.ms-excel"; 
     953            case ".gif": return "image/gif"; 
     954            case ".bmp": return "image/bmp"; 
     955            case ".jpeg": 
     956            case ".jpg": return "image/jpeg"; 
     957            case ".wav": return "audio/wav"; 
     958            case ".mp3": return "audio/mpeg3"; 
     959            case ".mpeg": 
     960            case ".mpg": return "video/mpeg"; 
     961            case ".rtf": return "application/rtf"; 
     962            case ".html": 
     963            case ".htm": return "text/html"; 
     964            case ".xml": return "text/xml"; 
     965            case ".xsl": return "text/xsl"; 
     966            case ".css": return "text/css"; 
     967            case ".php": return "text/php"; 
     968            case ".asp": return "text/asp"; 
     969            case ".pdf": return "application/pdf"; 
     970            case ".png": return "image/png"; 
     971            case ".txt": return "text/plain"; 
     972            case ".log": return "text/plain"; 
     973            case ".wmv": return "video/x-ms-wmv"; 
     974            case ".sxc": return "application/vnd.sun.xml.calc"; 
     975            case ".odt": return "application/vnd.oasis.opendocument.text"; 
     976            case ".stc": return "application/vnd.sun.xml.calc.template"; 
     977            case ".sxd": return "application/vnd.sun.xml.draw"; 
     978            case ".std": return "application/vnd.sun.xml.draw.template"; 
     979            case ".sxi": return "application/vnd.sun.xml.impress"; 
     980            case ".sti": return "application/vnd.sun.xml.impress.template"; 
     981            case ".sxm": return "application/vnd.sun.xml.math"; 
     982            case ".sxw": return "application/vnd.sun.xml.writer"; 
     983            case ".sxq": return "application/vnd.sun.xml.writer.global"; 
     984            case ".stw": return "application/vnd.sun.xml.writer.template"; 
     985            case ".pps": return "application/vnd.ms-powerpoint"; 
     986            case ".odt": return "application/vnd.oasis.opendocument.text"; 
     987            case ".ott": return "application/vnd.oasis.opendocument.text-template"; 
     988            case ".oth": return "application/vnd.oasis.opendocument.text-web"; 
     989            case ".odm": return "application/vnd.oasis.opendocument.text-master"; 
     990            case ".odg": return "application/vnd.oasis.opendocument.graphics"; 
     991            case ".otg": return "application/vnd.oasis.opendocument.graphics-template"; 
     992            case ".odp": return "application/vnd.oasis.opendocument.presentation"; 
     993            case ".otp": return "application/vnd.oasis.opendocument.presentation-template"; 
     994            case ".ods": return "application/vnd.oasis.opendocument.spreadsheet"; 
     995            case ".ots": return "application/vnd.oasis.opendocument.spreadsheet-template"; 
     996            case ".odc": return "application/vnd.oasis.opendocument.chart"; 
     997            case ".odf": return "application/vnd.oasis.opendocument.formula"; 
     998            case ".odi": return "application/vnd.oasis.opendocument.image"; 
     999            case ".ndl": return "application/vnd.lotus-notes"; 
     1000            case ".eml": return "text/plain"; 
     1001            case ".ps" : return "application/postscript"; 
     1002            default : return "application/octet-stream"; 
     1003        } 
     1004    } 
     1005 
    10871006} 
     1007 
    10881008?> 
Note: See TracChangeset for help on using the changeset viewer.