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.threads;
024
025import java.util.ArrayList;
026import java.util.Date;
027import java.util.List;
028import com.restfb.Facebook;
029import com.restfb.types.FacebookType;
030
031/**
032 * Represents the <a href="https://developers.facebook.com/docs/threads/reply-moderation">Reply or Conversation type</a>
033 */
034public class TdReply extends FacebookType {
035  private static final long serialVersionUID = 1L;
036  /**
037   * Represents text for a Threads reply. This is optional on image, video, and carousel replies.
038   */
039  @Facebook
040  private String text;
041  /**
042   * Instagram username who created the post. Note: This only works for public users or your own user.
043   */
044  @Facebook
045  private String username;
046  /**
047   * Permanent link to the post. Will be omitted if the media contains copyrighted material or has been flagged for a
048   * copyright violation. Note: This only works for public users or your own user.
049   */
050  @Facebook
051  private String permalink;
052  /**
053   * The publish date and time of the post in ISO 8601 format.
054   */
055  @Facebook
056  private Date timestamp;
057  /**
058   * Surface where the media is published. In the case of Threads, the value is THREADS.
059   */
060  @Facebook("media_product_type")
061  private String mediaProductType;
062  /**
063   * The media type for a Threads reply. Values: TEXT_POST, IMAGE, VIDEO, CAROUSEL_ALBUM
064   */
065  @Facebook("media_type")
066  private TdMediaType mediaType;
067  /**
068   * The post’s media URL. This only shows for image, video, and carousel replies.
069   */
070  @Facebook("media_url")
071  private String mediaUrl;
072  /**
073   * Shortcode of the media.
074   */
075  @Facebook
076  private String shortcode;
077  /**
078   * URL of thumbnail. This only shows for Threads replies with video.
079   */
080  @Facebook("thumbnail_url")
081  private String thumbnailUrl;
082  /**
083   * List of child posts. This only shows for carousel replies.
084   */
085  @Facebook
086  private List<TdReply> children = new ArrayList<>();
087  /**
088   * Indicates if the media is a quoted reply made by another user.
089   */
090  @Facebook("is_quote_post")
091  private Boolean isQuotePost;
092  /**
093   * true if the Threads post or reply has replies that you can see.
094   */
095  @Facebook("has_replies")
096  private Boolean hasReplies;
097  /**
098   * Media ID of the top-level post or original thread in the reply tree. Note: This only appears on replies.
099   */
100  @Facebook("root_post")
101  private TdReply rootPost;
102  /**
103   * Media ID of the immediate parent of the reply. Note: This only appears on replies.
104   */
105  @Facebook("replied_to")
106  private TdReply repliedTo;
107  /**
108   * true if the Threads media is a reply. false if the Threads media is a top-level post.
109   */
110  @Facebook("is_reply")
111  private Boolean isReply;
112  /**
113   * {@code true} if your user is the owner of the Threads reply.
114   * <br>
115   * {@code false} if another user is the owner of the
116   * Threads reply.
117   */
118  @Facebook("is_reply_owned_by_me")
119  private Boolean isReplyOwnedByMe;
120  /**
121   * Whether or not the reply is hidden. Values: NOT_HUSHED, UNHUSHED, HIDDEN, COVERED, BLOCKED, RESTRICTED
122   */
123  @Facebook("hide_status")
124  private TdHideStatus hideStatus;
125  /**
126   * Who can reply to your post.
127   */
128  @Facebook("reply_audience")
129  private TdReplyAudience replyAudience;
130
131
132  public enum TdHideStatus {
133    NOT_HUSHED, UNHUSHED, HIDDEN, COVERED, BLOCKED, RESTRICTED;
134  }
135
136
137  public enum TdReplyAudience {
138    EVERYONE, ACCOUNTS_YOU_FOLLOW, MENTIONED_ONLY;
139  }
140
141  /**
142   * Represents text for a Threads reply. This is optional on image, video, and carousel replies.
143   */
144  @java.lang.SuppressWarnings("all")
145  public String getText() {
146    return this.text;
147  }
148
149  /**
150   * Represents text for a Threads reply. This is optional on image, video, and carousel replies.
151   */
152  @java.lang.SuppressWarnings("all")
153  public void setText(final String text) {
154    this.text = text;
155  }
156
157  /**
158   * Instagram username who created the post. Note: This only works for public users or your own user.
159   */
160  @java.lang.SuppressWarnings("all")
161  public String getUsername() {
162    return this.username;
163  }
164
165  /**
166   * Instagram username who created the post. Note: This only works for public users or your own user.
167   */
168  @java.lang.SuppressWarnings("all")
169  public void setUsername(final String username) {
170    this.username = username;
171  }
172
173  /**
174   * Permanent link to the post. Will be omitted if the media contains copyrighted material or has been flagged for a
175   * copyright violation. Note: This only works for public users or your own user.
176   */
177  @java.lang.SuppressWarnings("all")
178  public String getPermalink() {
179    return this.permalink;
180  }
181
182  /**
183   * Permanent link to the post. Will be omitted if the media contains copyrighted material or has been flagged for a
184   * copyright violation. Note: This only works for public users or your own user.
185   */
186  @java.lang.SuppressWarnings("all")
187  public void setPermalink(final String permalink) {
188    this.permalink = permalink;
189  }
190
191  /**
192   * The publish date and time of the post in ISO 8601 format.
193   */
194  @java.lang.SuppressWarnings("all")
195  public Date getTimestamp() {
196    return this.timestamp;
197  }
198
199  /**
200   * The publish date and time of the post in ISO 8601 format.
201   */
202  @java.lang.SuppressWarnings("all")
203  public void setTimestamp(final Date timestamp) {
204    this.timestamp = timestamp;
205  }
206
207  /**
208   * Surface where the media is published. In the case of Threads, the value is THREADS.
209   */
210  @java.lang.SuppressWarnings("all")
211  public String getMediaProductType() {
212    return this.mediaProductType;
213  }
214
215  /**
216   * Surface where the media is published. In the case of Threads, the value is THREADS.
217   */
218  @java.lang.SuppressWarnings("all")
219  public void setMediaProductType(final String mediaProductType) {
220    this.mediaProductType = mediaProductType;
221  }
222
223  /**
224   * The media type for a Threads reply. Values: TEXT_POST, IMAGE, VIDEO, CAROUSEL_ALBUM
225   */
226  @java.lang.SuppressWarnings("all")
227  public TdMediaType getMediaType() {
228    return this.mediaType;
229  }
230
231  /**
232   * The media type for a Threads reply. Values: TEXT_POST, IMAGE, VIDEO, CAROUSEL_ALBUM
233   */
234  @java.lang.SuppressWarnings("all")
235  public void setMediaType(final TdMediaType mediaType) {
236    this.mediaType = mediaType;
237  }
238
239  /**
240   * The post’s media URL. This only shows for image, video, and carousel replies.
241   */
242  @java.lang.SuppressWarnings("all")
243  public String getMediaUrl() {
244    return this.mediaUrl;
245  }
246
247  /**
248   * The post’s media URL. This only shows for image, video, and carousel replies.
249   */
250  @java.lang.SuppressWarnings("all")
251  public void setMediaUrl(final String mediaUrl) {
252    this.mediaUrl = mediaUrl;
253  }
254
255  /**
256   * Shortcode of the media.
257   */
258  @java.lang.SuppressWarnings("all")
259  public String getShortcode() {
260    return this.shortcode;
261  }
262
263  /**
264   * Shortcode of the media.
265   */
266  @java.lang.SuppressWarnings("all")
267  public void setShortcode(final String shortcode) {
268    this.shortcode = shortcode;
269  }
270
271  /**
272   * URL of thumbnail. This only shows for Threads replies with video.
273   */
274  @java.lang.SuppressWarnings("all")
275  public String getThumbnailUrl() {
276    return this.thumbnailUrl;
277  }
278
279  /**
280   * URL of thumbnail. This only shows for Threads replies with video.
281   */
282  @java.lang.SuppressWarnings("all")
283  public void setThumbnailUrl(final String thumbnailUrl) {
284    this.thumbnailUrl = thumbnailUrl;
285  }
286
287  /**
288   * List of child posts. This only shows for carousel replies.
289   */
290  @java.lang.SuppressWarnings("all")
291  public List<TdReply> getChildren() {
292    return this.children;
293  }
294
295  /**
296   * List of child posts. This only shows for carousel replies.
297   */
298  @java.lang.SuppressWarnings("all")
299  public void setChildren(final List<TdReply> children) {
300    this.children = children;
301  }
302
303  /**
304   * Indicates if the media is a quoted reply made by another user.
305   */
306  @java.lang.SuppressWarnings("all")
307  public Boolean getIsQuotePost() {
308    return this.isQuotePost;
309  }
310
311  /**
312   * Indicates if the media is a quoted reply made by another user.
313   */
314  @java.lang.SuppressWarnings("all")
315  public void setIsQuotePost(final Boolean isQuotePost) {
316    this.isQuotePost = isQuotePost;
317  }
318
319  /**
320   * true if the Threads post or reply has replies that you can see.
321   */
322  @java.lang.SuppressWarnings("all")
323  public Boolean getHasReplies() {
324    return this.hasReplies;
325  }
326
327  /**
328   * true if the Threads post or reply has replies that you can see.
329   */
330  @java.lang.SuppressWarnings("all")
331  public void setHasReplies(final Boolean hasReplies) {
332    this.hasReplies = hasReplies;
333  }
334
335  /**
336   * Media ID of the top-level post or original thread in the reply tree. Note: This only appears on replies.
337   */
338  @java.lang.SuppressWarnings("all")
339  public TdReply getRootPost() {
340    return this.rootPost;
341  }
342
343  /**
344   * Media ID of the top-level post or original thread in the reply tree. Note: This only appears on replies.
345   */
346  @java.lang.SuppressWarnings("all")
347  public void setRootPost(final TdReply rootPost) {
348    this.rootPost = rootPost;
349  }
350
351  /**
352   * Media ID of the immediate parent of the reply. Note: This only appears on replies.
353   */
354  @java.lang.SuppressWarnings("all")
355  public TdReply getRepliedTo() {
356    return this.repliedTo;
357  }
358
359  /**
360   * Media ID of the immediate parent of the reply. Note: This only appears on replies.
361   */
362  @java.lang.SuppressWarnings("all")
363  public void setRepliedTo(final TdReply repliedTo) {
364    this.repliedTo = repliedTo;
365  }
366
367  /**
368   * true if the Threads media is a reply. false if the Threads media is a top-level post.
369   */
370  @java.lang.SuppressWarnings("all")
371  public Boolean getIsReply() {
372    return this.isReply;
373  }
374
375  /**
376   * true if the Threads media is a reply. false if the Threads media is a top-level post.
377   */
378  @java.lang.SuppressWarnings("all")
379  public void setIsReply(final Boolean isReply) {
380    this.isReply = isReply;
381  }
382
383  /**
384   * {@code true} if your user is the owner of the Threads reply.
385   * <br>
386   * {@code false} if another user is the owner of the
387   * Threads reply.
388   */
389  @java.lang.SuppressWarnings("all")
390  public Boolean getIsReplyOwnedByMe() {
391    return this.isReplyOwnedByMe;
392  }
393
394  /**
395   * {@code true} if your user is the owner of the Threads reply.
396   * <br>
397   * {@code false} if another user is the owner of the
398   * Threads reply.
399   */
400  @java.lang.SuppressWarnings("all")
401  public void setIsReplyOwnedByMe(final Boolean isReplyOwnedByMe) {
402    this.isReplyOwnedByMe = isReplyOwnedByMe;
403  }
404
405  /**
406   * Whether or not the reply is hidden. Values: NOT_HUSHED, UNHUSHED, HIDDEN, COVERED, BLOCKED, RESTRICTED
407   */
408  @java.lang.SuppressWarnings("all")
409  public TdHideStatus getHideStatus() {
410    return this.hideStatus;
411  }
412
413  /**
414   * Whether or not the reply is hidden. Values: NOT_HUSHED, UNHUSHED, HIDDEN, COVERED, BLOCKED, RESTRICTED
415   */
416  @java.lang.SuppressWarnings("all")
417  public void setHideStatus(final TdHideStatus hideStatus) {
418    this.hideStatus = hideStatus;
419  }
420
421  /**
422   * Who can reply to your post.
423   */
424  @java.lang.SuppressWarnings("all")
425  public TdReplyAudience getReplyAudience() {
426    return this.replyAudience;
427  }
428
429  /**
430   * Who can reply to your post.
431   */
432  @java.lang.SuppressWarnings("all")
433  public void setReplyAudience(final TdReplyAudience replyAudience) {
434    this.replyAudience = replyAudience;
435  }
436}