1 #!/usr/bin/env python 2 3 """ 4 Common handler functionality for different entities. 5 6 Copyright (C) 2014, 2015 Paul Boddie <paul@boddie.org.uk> 7 8 This program is free software; you can redistribute it and/or modify it under 9 the terms of the GNU General Public License as published by the Free Software 10 Foundation; either version 3 of the License, or (at your option) any later 11 version. 12 13 This program is distributed in the hope that it will be useful, but WITHOUT 14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS 15 FOR A PARTICULAR PURPOSE. See the GNU General Public License for more 16 details. 17 18 You should have received a copy of the GNU General Public License along with 19 this program. If not, see <http://www.gnu.org/licenses/>. 20 """ 21 22 from imiptools.data import get_address, get_uri, make_freebusy, to_part, \ 23 uri_dict 24 from imiptools.dates import format_datetime 25 from imiptools.period import Period 26 27 class CommonFreebusy: 28 29 "Common free/busy mix-in." 30 31 def request(self): 32 33 """ 34 Respond to a request by preparing a reply containing free/busy 35 information for each indicated attendee. 36 """ 37 38 oa = self.require_organiser_and_attendees() 39 if not oa: 40 return 41 42 (organiser, organiser_attr), attendees = oa 43 44 # Get the details for each attendee. 45 46 responses = [] 47 rwrite = responses.append 48 49 # For replies, the organiser and attendee are preserved. 50 51 for attendee, attendee_attr in attendees.items(): 52 freebusy = self.store.get_freebusy(attendee) 53 54 # Indicate the actual sender of the reply. 55 56 if self.messenger: 57 attendee_attr["SENT-BY"] = get_uri(self.messenger.sender) 58 59 dtstart = self.obj.get_datetime("DTSTART") 60 dtend = self.obj.get_datetime("DTEND") 61 period = dtstart and dtend and Period(dtstart, dtend, self.get_tzid()) or None 62 63 rwrite(make_freebusy(freebusy, self.uid, organiser, organiser_attr, attendee, attendee_attr, period)) 64 65 # Return the reply. 66 67 self.add_result("REPLY", [get_address(organiser)], to_part("REPLY", responses)) 68 69 class Outgoing: 70 71 "Common outgoing message handling functionality mix-in." 72 73 def update_event_in_freebusy(self, from_organiser=True): 74 75 "Update free/busy information when handling an object." 76 77 freebusy = self.store.get_freebusy(self.user) 78 79 # Obtain the attendance attributes for this user, if available. 80 81 self.update_freebusy_for_participant(freebusy, self.user, from_organiser) 82 83 # Remove original recurrence details replaced by additional 84 # recurrences, as well as obsolete additional recurrences. 85 86 self.remove_freebusy_for_recurrences(freebusy, self.store.get_recurrences(self.user, self.uid)) 87 self.store.set_freebusy(self.user, freebusy) 88 89 if self.publisher and self.is_sharing(): 90 self.publisher.set_freebusy(self.user, freebusy) 91 92 return True 93 94 def remove_event_from_freebusy(self): 95 96 "Remove free/busy information when handling an object." 97 98 freebusy = self.store.get_freebusy(self.user) 99 self.remove_from_freebusy(freebusy) 100 self.remove_freebusy_for_recurrences(freebusy) 101 self.store.set_freebusy(self.user, freebusy) 102 103 if self.publisher and self.is_sharing(): 104 self.publisher.set_freebusy(self.user, freebusy) 105 106 # vim: tabstop=4 expandtab shiftwidth=4