1 //******************************************************************
\r
3 // Copyright 2016 Samsung Electronics All Rights Reserved.
\r
5 //-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
\r
7 // Licensed under the Apache License, Version 2.0 (the "License");
\r
8 // you may not use this file except in compliance with the License.
\r
9 // You may obtain a copy of the License at
\r
11 // http://www.apache.org/licenses/LICENSE-2.0
\r
13 // Unless required by applicable law or agreed to in writing, software
\r
14 // distributed under the License is distributed on an "AS IS" BASIS,
\r
15 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
\r
16 // See the License for the specific language governing permissions and
\r
17 // limitations under the License.
\r
19 //-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
\r
24 * This file contains Notification service Message representation.
\r
27 #ifndef _NS_MESSAGE_H_
\r
28 #define _NS_MESSAGE_H_
\r
31 #include "NSMediaContents.h"
\r
39 * @brief This class provides a set of APIs for Notification service Message .
\r
44 /** NSMessageType - enumeration for Notification service MessageType*/
\r
45 enum class NSMessageType
\r
47 NS_MESSAGE_ALERT = 0,
\r
48 NS_MESSAGE_NOTICE = 1,
\r
49 NS_MESSAGE_EVENT = 2,
\r
50 NS_MESSAGE_INFO = 3,
\r
54 * Constructor of NSMessage.
\r
56 NSMessage(): m_messageId(0), m_type(NSMessageType::NS_MESSAGE_ALERT), m_ttl(0),
\r
57 m_mediaContents(new NSMediaContents) { }
\r
60 * Constructor of NSMessage.
\r
62 * @param msg - pointer to NSMessage struct to initialize.
\r
64 NSMessage(::NSMessage *msg);
\r
67 * Copy Constructor of NSMessage.
\r
69 * @param msg - NSMessage to initialize.
\r
71 NSMessage(const NSMessage &msg);
\r
74 * Copy assignment operator of NSMessage.
\r
76 * @param msg - NSMessage to initialize.
\r
77 * @return NSMessage object reference
\r
79 NSMessage &operator=(const NSMessage &msg);
\r
82 * Destructor of NSMessage.
\r
87 * This method is for getting Message Id from the Notification service Message.
\r
89 * @return Id as uint64_t.
\r
91 uint64_t getMessageId() const;
\r
94 * This method is for getting Provider Id from the Notification service Message.
\r
96 * @return Id as string.
\r
98 std::string getProviderId() const;
\r
101 * This method is for getting type from the Notification service Message.
\r
103 * @return type as NSMessageType.
\r
105 NSMessageType getType() const;
\r
108 * This method is for setting type from the Notification service Message.
\r
110 * @param type as NSMessageType.
\r
112 void setType(const NSMessageType &type);
\r
115 * This method is for getting time from the Notification service Message.
\r
117 * @return time as string.
\r
119 std::string getTime() const;
\r
122 * This method is for setting time from the Notification service Message.
\r
124 * @param time as string.
\r
126 void setTime(const std::string &time);
\r
129 * This method is for getting time to live from the Notification service Message.
\r
131 * @return ttl as uint64_t.
\r
133 uint64_t getTTL() const;
\r
136 * This method is for setting time to live from the Notification service Message.
\r
138 * @param ttl as uint64_t.
\r
140 void setTTL(const uint64_t &ttl);
\r
143 * This method is for getting Title from the Notification service Message.
\r
145 * @return Title as string.
\r
147 std::string getTitle() const;
\r
150 * This method is for setting Title from the Notification service Message.
\r
152 * @param title as string.
\r
154 void setTitle(const std::string &title);
\r
157 * This method is for getting contentText from the Notification service Message.
\r
159 * @return contentText as string.
\r
161 std::string getContentText() const;
\r
164 * This method is for setting contentText from the Notification service Message.
\r
166 * @param contextText as string.
\r
168 void setContentText(const std::string &contextText);
\r
171 * This method is for getting sourceName from the Notification service Message.
\r
173 * @return sourceName as string.
\r
175 std::string getSourceName() const;
\r
178 * This method is for setting sourceName from the Notification service Message.
\r
180 * @param sourceName as string.
\r
182 void setSourceName(const std::string &sourceName);
\r
185 * This method is for getting mediaContents from the Notification service Message.
\r
187 * @return mediaContents as NSMediaContents pointer.
\r
189 NSMediaContents *getMediaContents() const;
\r
192 * This method is for setting mediaContents from the Notification service Message.
\r
194 * @param mediaContents as NSMediaContents pointer.
\r
196 void setMediaContents(NSMediaContents *mediaContents);
\r
199 * This method is for getting Topic from the Notification service Message.
\r
201 * @return Topic as string.
\r
203 std::string getTopic() const;
\r
206 * This method is for setting Topic for the Notification service Message.
\r
208 * @return Topic as string.
\r
210 void setTopic(const std::string &topic);
\r
213 uint64_t m_messageId;
\r
214 std::string m_providerId;
\r
216 NSMessageType m_type;
\r
217 std::string m_time;
\r
219 std::string m_title;
\r
220 std::string m_contentText;
\r
221 std::string m_sourceName;
\r
222 NSMediaContents *m_mediaContents;
\r
223 std::string m_topic;
\r
228 #endif /* _NS_MESSAGE_H_ */
\r