source: sandbox/2.4.1-3/prototype/services/iCal.php @ 6357

Revision 6357, 59.0 KB checked in by gustavo, 12 years ago (diff)

Ticket #2768 - Melhorias na inserção de destinatários na criacao de mensagem

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