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