3 /// Blackberry database record parser class for calendar records.
7 Copyright (C) 2005-2011, Net Direct Inc. (http://www.netdirect.ca/)
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 2 of the License, or
12 (at your option) any later version.
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
18 See the GNU General Public License in the COPYING file at the
19 root directory of this project for more details.
22 #ifndef __BARRY_RECORD_CALENDAR_H__
23 #define __BARRY_RECORD_CALENDAR_H__
27 #include "r_recur_base.h"
36 // forward declarations
40 // NOTE: All classes here must be container-safe! Perhaps add sorting
41 // operators in the future.
46 /// \addtogroup RecordParserClasses
49 class BXEXPORT Calendar
: public RecurBase
52 typedef Barry::UnknownsType UnknownsType
;
62 time_t NotificationTime
; // 0 means notification is off
65 EmailAddressList Organizer
;
66 EmailAddressList AcceptedBy
;
67 EmailAddressList Invited
; // list of invited people (email a
72 /// This lists the available settings found in the device.
73 /// This list is based on information from MS Outlook 2007
74 /// (Free ==0 and Busy == 2)
75 /// This is FBTYPE in RFC2445 and is defined as
76 /// FREE, BUSY, BUSY-UNAVAILABLE and BUSY-TENTATIVE
78 enum FreeBusyFlagType
{
84 FreeBusyFlagType FreeBusyFlag
;
89 /// This is also called classification in Evolution and it
90 /// is the equivilant of public or private in outlook
91 /// Private is set to 0x2 in Outlook
92 /// RFC2445 CLASS is PUBLIC, PRIVATE, CONFIDENTIAL
100 ClassFlagType ClassFlag
;
102 uint64_t CalendarID
; // Calendar ID (usefull if devices have several calendars)
104 unsigned short TimeZoneCode
; // the time zone originally used
105 // for the recurrence data...
106 // seems to have little use, but
107 // set to your current time zone
109 bool TimeZoneValid
; // true if the record contained a
113 UnknownsType Unknowns
;
116 static FreeBusyFlagType
FreeBusyFlagProto2Rec(uint8_t f
);
117 static uint8_t FreeBusyFlagRec2Proto(FreeBusyFlagType f
);
119 static ClassFlagType
ClassFlagProto2Rec(uint8_t f
);
120 static uint8_t ClassFlagRec2Proto(ClassFlagType f
);
122 virtual void DumpSpecialFields(std::ostream
&os
) const;
125 const unsigned char* ParseField(const unsigned char *begin
,
126 const unsigned char *end
, const IConverter
*ic
= 0);
132 // Parser / Builder API (see parser.h / builder.h)
133 uint8_t GetRecType() const { return RecType
; }
134 uint32_t GetUniqueId() const { return RecordId
; }
135 void SetIds(uint8_t Type
, uint32_t Id
) { RecType
= Type
; RecordId
= Id
; }
136 void ParseHeader(const Data
&data
, size_t &offset
);
137 void ParseFields(const Data
&data
, size_t &offset
, const IConverter
*ic
= 0);
138 void BuildHeader(Data
&data
, size_t &offset
) const;
139 void BuildFields(Data
&data
, size_t &offset
, const IConverter
*ic
= 0) const;
141 // operations (common among record classes)
143 void Dump(std::ostream
&os
) const;
144 std::string
GetDescription() const;
147 bool operator<(const Calendar
&other
) const;
150 static const char * GetDBName() { return "Calendar"; }
151 static uint8_t GetDefaultRecType() { return 5; } // or 0?
154 BXEXPORT
inline std::ostream
& operator<<(std::ostream
&os
, const Calendar
&msg
) {
160 class BXEXPORT CalendarAll
: public Calendar
163 virtual void DumpSpecialFields(std::ostream
&os
) const;
166 std::string MailAccount
;
169 // Parser / Builder API (see parser.h / builder.h)
170 void ParseHeader(const Data
&data
, size_t &offset
);
176 static const char * GetDBName() { return "Calendar - All"; }
179 BXEXPORT
inline std::ostream
& operator<<(std::ostream
&os
, const CalendarAll
&msg
) {