Changeset 6066 for trunk/prototype/services/iCal.php
- Timestamp:
- 04/30/12 15:42:36 (12 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/prototype/services/iCal.php
r6026 r6066 1 1 <?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 3 require_once ROOTPATH . '/plugins/icalcreator/iCalUtilityFunctions.class.php'; 4 require_once ROOTPATH . '/plugins/icalcreator/iCalcreator.class.php'; 5 require_once ROOTPATH . '/modules/calendar/constants.php'; 5 6 6 7 //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' ); 8 set_time_limit(600); 9 10 class 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'); 11 13 // 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); 120 156 } 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']; 161 214 } 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 605 562 /* 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; 765 769 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'; 900 864 $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 1087 1006 } 1007 1088 1008 ?>
Note: See TracChangeset
for help on using the changeset viewer.