001// Generated by delombok at Fri Dec 27 11:33:37 UTC 2024
002/*
003 * Copyright (c) 2010-2024 Mark Allen, Norbert Bartels.
004 *
005 * Permission is hereby granted, free of charge, to any person obtaining a copy
006 * of this software and associated documentation files (the "Software"), to deal
007 * in the Software without restriction, including without limitation the rights
008 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
009 * copies of the Software, and to permit persons to whom the Software is
010 * furnished to do so, subject to the following conditions:
011 *
012 * The above copyright notice and this permission notice shall be included in
013 * all copies or substantial portions of the Software.
014 *
015 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
016 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
017 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
018 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
019 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
020 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
021 * THE SOFTWARE.
022 */
023package com.restfb.types;
024
025import static java.util.Collections.unmodifiableList;
026import java.util.ArrayList;
027import java.util.Date;
028import java.util.List;
029import com.restfb.Facebook;
030
031/**
032 * Represents the <a href="http://developers.facebook.com/docs/reference/api/page/#conversations"> Conversation Graph
033 * API type</a>.
034 * 
035 * @author <a href="http://restfb.com">Mark Allen</a>
036 * @author Felipe Kurkowski
037 */
038public class Conversation extends FacebookType {
039  /**
040   * A URL for this conversation.
041   * 
042   */
043  @Facebook
044  private String link;
045  /**
046   * The subject of this conversation.
047   * 
048   */
049  @Facebook
050  private String subject;
051  /**
052   * The title of a message in the conversation
053   * 
054   */
055  @Facebook
056  private String snippet;
057  /**
058   * The new identifier for threads effective after September 24, 2017
059   */
060  @Facebook("thread_key")
061  private String threadKey;
062  /**
063   * Last update time of the conversation
064   * 
065   */
066  @Facebook("updated_time")
067  private Date updatedTime;
068  /**
069   * The number of messages in the conversation
070   * 
071   */
072  @Facebook("message_count")
073  private Long messageCount;
074  /**
075   * The name of the message folder or source.
076   */
077  @Facebook
078  private String name;
079  /**
080   * The number of unread messages in the conversation
081   * <p>
082   * Facebook does not send the unread count if there aren't any new messages. In order to keep data consistency, we set
083   * the default value to zero. If this value is sent, the {@link com.restfb.JsonMapper} will override it.
084   * 
085   */
086  @Facebook("unread_count")
087  private Long unreadCount = 0L;
088  /**
089   * Wallpaper to display as a background for the thread
090   */
091  @Facebook
092  private String wallpaper;
093  @Facebook
094  private List<Tag> tags = new ArrayList<>();
095  @Facebook
096  private List<ExtendedReferenceType> participants = new ArrayList<>();
097  @Facebook("former_participants")
098  private List<NamedFacebookType> formerParticipants = new ArrayList<>();
099  @Facebook
100  private List<NamedFacebookType> senders = new ArrayList<>();
101  /**
102   * Whether The Page can reply to the conversation
103   * 
104   */
105  @Facebook("can_reply")
106  private Boolean canReply;
107  /**
108   * Whether you are subscribed to the conversation
109   * 
110   */
111  @Facebook("is_subscribed")
112  private Boolean subscribed;
113  @Facebook
114  private List<Message> messages = new ArrayList<>();
115  private static final long serialVersionUID = 1L;
116
117
118  /**
119   * Represents the <a href="http://developers.facebook.com/docs/reference/api/page/#conversations"> Tag Graph API
120   * type</a>.
121   * 
122   * @author <a href="http://restfb.com">Mark Allen</a>
123   * @author Felipe Kurkowski
124   */
125  public static class Tag extends AbstractFacebookType {
126    /**
127     * The name field for this type.
128     * 
129     */
130    @Facebook
131    private String name;
132    private static final long serialVersionUID = 1L;
133
134    /**
135     * The name field for this type.
136     * 
137     * @return The name field for this type.
138     */
139    @java.lang.SuppressWarnings("all")
140    public String getName() {
141      return this.name;
142    }
143
144    /**
145     * The name field for this type.
146     * 
147     */
148    @java.lang.SuppressWarnings("all")
149    public void setName(final String name) {
150      this.name = name;
151    }
152  }
153
154  /**
155   * A list of tags indicating the message folder, and whether the conversation is read and seen.
156   * 
157   * @return A list of tags indicating the message folder, and whether the conversation is read and seen.
158   */
159  public List<Tag> getTags() {
160    return unmodifiableList(tags);
161  }
162
163  public boolean addTag(Tag tag) {
164    return tags.add(tag);
165  }
166
167  public boolean removeTag(Tag tag) {
168    return tags.remove(tag);
169  }
170
171  /**
172   * Users who are on this message conversation
173   * 
174   * @return Users who are on this message conversation
175   */
176  public List<ExtendedReferenceType> getParticipants() {
177    return unmodifiableList(participants);
178  }
179
180  public boolean addParticipant(ExtendedReferenceType participant) {
181    return participants.add(participant);
182  }
183
184  public boolean removeParticipant(ExtendedReferenceType participant) {
185    return participants.remove(participant);
186  }
187
188  /**
189   * Users who send a message on the conversation
190   * 
191   * @return Users who send a message on the conversation
192   */
193  public List<NamedFacebookType> getSenders() {
194    return unmodifiableList(senders);
195  }
196
197  public boolean addSender(NamedFacebookType sender) {
198    return senders.add(sender);
199  }
200
201  public boolean removeSender(NamedFacebookType sender) {
202    return senders.remove(sender);
203  }
204
205  /**
206   * List of all messages in the conversation
207   * 
208   * @return List of all messages in the conversation
209   */
210  public List<Message> getMessages() {
211    return unmodifiableList(messages);
212  }
213
214  public boolean addMessage(Message message) {
215    return messages.add(message);
216  }
217
218  public boolean removeMessage(Message message) {
219    return messages.remove(message);
220  }
221
222  /**
223   * Users who used to be on this message conversation.
224   * 
225   * @return Users who used to be on this message conversation.
226   */
227  public List<NamedFacebookType> getFormerParticipants() {
228    return unmodifiableList(formerParticipants);
229  }
230
231  public boolean addFormerParticipant(NamedFacebookType formerParticipant) {
232    return formerParticipants.add(formerParticipant);
233  }
234
235  public boolean removeFormerParticipant(NamedFacebookType formerParticipant) {
236    return formerParticipants.remove(formerParticipant);
237  }
238
239  /**
240   * A URL for this conversation.
241   * 
242   * @return A URL for this conversation.
243   */
244  @java.lang.SuppressWarnings("all")
245  public String getLink() {
246    return this.link;
247  }
248
249  /**
250   * A URL for this conversation.
251   * 
252   */
253  @java.lang.SuppressWarnings("all")
254  public void setLink(final String link) {
255    this.link = link;
256  }
257
258  /**
259   * The subject of this conversation.
260   * 
261   * @return The subject of this conversation.
262   */
263  @java.lang.SuppressWarnings("all")
264  public String getSubject() {
265    return this.subject;
266  }
267
268  /**
269   * The subject of this conversation.
270   * 
271   */
272  @java.lang.SuppressWarnings("all")
273  public void setSubject(final String subject) {
274    this.subject = subject;
275  }
276
277  /**
278   * The title of a message in the conversation
279   * 
280   * @return The title of a message in the conversation
281   */
282  @java.lang.SuppressWarnings("all")
283  public String getSnippet() {
284    return this.snippet;
285  }
286
287  /**
288   * The title of a message in the conversation
289   * 
290   */
291  @java.lang.SuppressWarnings("all")
292  public void setSnippet(final String snippet) {
293    this.snippet = snippet;
294  }
295
296  /**
297   * The new identifier for threads effective after September 24, 2017
298   *
299   * @return The new identifier for threads effective after September 24, 2017
300   */
301  @java.lang.SuppressWarnings("all")
302  public String getThreadKey() {
303    return this.threadKey;
304  }
305
306  /**
307   * The new identifier for threads effective after September 24, 2017
308   */
309  @java.lang.SuppressWarnings("all")
310  public void setThreadKey(final String threadKey) {
311    this.threadKey = threadKey;
312  }
313
314  /**
315   * Last update time of the conversation
316   * 
317   * @return Last update time of the conversation
318   */
319  @java.lang.SuppressWarnings("all")
320  public Date getUpdatedTime() {
321    return this.updatedTime;
322  }
323
324  /**
325   * Last update time of the conversation
326   * 
327   */
328  @java.lang.SuppressWarnings("all")
329  public void setUpdatedTime(final Date updatedTime) {
330    this.updatedTime = updatedTime;
331  }
332
333  /**
334   * The number of messages in the conversation
335   * 
336   * @return The number of messages in the conversation
337   */
338  @java.lang.SuppressWarnings("all")
339  public Long getMessageCount() {
340    return this.messageCount;
341  }
342
343  /**
344   * The number of messages in the conversation
345   * 
346   */
347  @java.lang.SuppressWarnings("all")
348  public void setMessageCount(final Long messageCount) {
349    this.messageCount = messageCount;
350  }
351
352  /**
353   * The name of the message folder or source.
354   *
355   * @return The name of the message folder or source
356   */
357  @java.lang.SuppressWarnings("all")
358  public String getName() {
359    return this.name;
360  }
361
362  /**
363   * The name of the message folder or source.
364   */
365  @java.lang.SuppressWarnings("all")
366  public void setName(final String name) {
367    this.name = name;
368  }
369
370  /**
371   * The number of unread messages in the conversation
372   * <p>
373   * Facebook does not send the unread count if there aren't any new messages. In order to keep data consistency, we set
374   * the default value to zero. If this value is sent, the {@link com.restfb.JsonMapper} will override it.
375   * 
376   * @return The number of unread messages in the conversation
377   */
378  @java.lang.SuppressWarnings("all")
379  public Long getUnreadCount() {
380    return this.unreadCount;
381  }
382
383  /**
384   * The number of unread messages in the conversation
385   * <p>
386   * Facebook does not send the unread count if there aren't any new messages. In order to keep data consistency, we set
387   * the default value to zero. If this value is sent, the {@link com.restfb.JsonMapper} will override it.
388   * 
389   */
390  @java.lang.SuppressWarnings("all")
391  public void setUnreadCount(final Long unreadCount) {
392    this.unreadCount = unreadCount;
393  }
394
395  /**
396   * Wallpaper to display as a background for the thread
397   *
398   * @return Wallpaper to display as a background for the thread
399   */
400  @java.lang.SuppressWarnings("all")
401  public String getWallpaper() {
402    return this.wallpaper;
403  }
404
405  /**
406   * Wallpaper to display as a background for the thread
407   */
408  @java.lang.SuppressWarnings("all")
409  public void setWallpaper(final String wallpaper) {
410    this.wallpaper = wallpaper;
411  }
412
413  /**
414   * Whether The Page can reply to the conversation
415   * 
416   * @return Whether The Page can reply to the conversation
417   */
418  @java.lang.SuppressWarnings("all")
419  public Boolean getCanReply() {
420    return this.canReply;
421  }
422
423  /**
424   * Whether The Page can reply to the conversation
425   * 
426   */
427  @java.lang.SuppressWarnings("all")
428  public void setCanReply(final Boolean canReply) {
429    this.canReply = canReply;
430  }
431
432  /**
433   * Whether you are subscribed to the conversation
434   * 
435   * @return Whether you are subscribed to the conversation
436   */
437  @java.lang.SuppressWarnings("all")
438  public Boolean getSubscribed() {
439    return this.subscribed;
440  }
441
442  /**
443   * Whether you are subscribed to the conversation
444   * 
445   */
446  @java.lang.SuppressWarnings("all")
447  public void setSubscribed(final Boolean subscribed) {
448    this.subscribed = subscribed;
449  }
450}