001// Generated by delombok at Fri Aug 16 13:39:53 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.Connection; 030import com.restfb.Facebook; 031import com.restfb.JsonMapper; 032import com.restfb.JsonMapper.JsonMappingCompleted; 033import com.restfb.annotation.GraphAPI; 034import com.restfb.exception.FacebookJsonMappingException; 035import com.restfb.json.Json; 036import com.restfb.json.JsonObject; 037import com.restfb.json.JsonValue; 038import com.restfb.types.features.HasComments; 039import com.restfb.types.features.HasCreatedTime; 040import com.restfb.types.features.HasMessage; 041 042/** 043 * Represents the <a href="https://developers.facebook.com/docs/graph-api/reference/post/">Post Graph API type</a>. 044 * 045 * @author <a href="http://restfb.com">Mark Allen</a> 046 * @since 1.5 047 */ 048@SuppressWarnings("deprecation") 049public class Post extends FacebookType implements HasComments, HasCreatedTime, HasMessage { 050 /** 051 * An object containing the ID and name of the user who posted the message. 052 */ 053 @Facebook 054 private From from; 055 /** 056 * Objectives under which this post can be advertised 057 */ 058 @Facebook("allowed_advertising_objects") 059 private String allowedAdvertisingObjects; 060 /** 061 * Objectives under which this post can be advertised 062 */ 063 @Facebook("allowed_advertising_objectives") 064 private List<String> allowedAdvertisingObjectives = new ArrayList<>(); 065 /** 066 * The call to action type used in any Page posts for mobile app engagement ads 067 */ 068 @Facebook("call_to_action") 069 private PostCallToAction callToAction; 070 @Facebook("child_attachments") 071 private List<Post> childAttachments = new ArrayList<>(); 072 /** 073 * If comments are being mirrored to an external site, this function returns the domain of that external site. 074 */ 075 @Facebook("comments_mirroring_domain") 076 private String commentsMirroringDomain; 077 /** 078 * The message. 079 */ 080 @Facebook 081 private String message; 082 /** 083 * ID of the parent post 084 */ 085 @Facebook("parent_id") 086 private String parentId; 087 /** 088 * The permanent static URL to the post on www.facebook.com. 089 * <p> 090 * Example: https://www.facebook.com/FacebookforDevelopers/posts/10153449196353553 091 * </p> 092 * 093 */ 094 @Facebook("permalink_url") 095 private String permalinkUrl; 096 /** 097 * If available, a link to the picture included with this post. 098 */ 099 @Facebook 100 private String picture; 101 /** 102 * The link attached to this post. 103 * 104 * Hint for Graph API 3.3: Use <code>attachment/url_unshimmed</code> instead 105 */ 106 @Facebook 107 @GraphAPI(until = "3.2") 108 private String link; 109 /** 110 * The name of the link. 111 * 112 * Hint for Graph API 3.3: Use <code>attachment/title</code> instead 113 */ 114 @Facebook 115 @GraphAPI(until = "3.2") 116 private String name; 117 /** 118 * The caption of the link (appears beneath the link name). 119 * 120 * Hint for Graph API 3.3: Use <code>attachment/title</code> instead 121 */ 122 @Facebook 123 @GraphAPI(until = "3.2") 124 private String caption; 125 /** 126 * A description of the link (appears beneath the link caption). 127 * 128 * Hint for Graph API 3.3: Use <code>attachment/description</code> instead 129 */ 130 @Facebook 131 @GraphAPI(until = "3.2") 132 private String description; 133 /** 134 * If available, the source link attached to this post (for example, a flash or video file). 135 * 136 * Hint for Graph API 3.3: Use <code>attachment/media/source</code> instead 137 */ 138 @Facebook 139 @GraphAPI(until = "3.2") 140 private String source; 141 /** 142 * The application used to create this post. 143 */ 144 @Facebook 145 private NamedFacebookType application; 146 /** 147 * A link to an icon representing the type of this post. 148 */ 149 @Facebook 150 private String icon; 151 /** 152 * The privacy settings for this post. 153 */ 154 @Facebook 155 private Privacy privacy; 156 /** 157 * Status of the promotion, if the post was promoted. 158 */ 159 @Facebook("promotion_status") 160 private String promotionStatus; 161 /** 162 * Object that controls news feed targeting for this post. 163 * 164 * To force Facebook to fill the <code>feed_targeting</code> field you have to fetch the post with the 165 * <code>fields=feed_targeting</code> parameter, otherwise the feedTargeting is <code>null</code>. 166 * 167 * 168 * @since 1.11.0 169 */ 170 @Facebook("feed_targeting") 171 private FeedTargeting feedTargeting; 172 /** 173 * Whether the viewer can send a private reply to this post (Page viewers only) 174 */ 175 @Facebook("can_reply_privately") 176 @GraphAPI(since = "2.5") 177 private Boolean canReplyPrivately; 178 /** 179 * The profile this was posted on if different from the author. 180 */ 181 @Facebook 182 @GraphAPI(since = "2.5") 183 private NamedFacebookType target; 184 /** 185 * Ads targeting information of the post. 186 */ 187 @Facebook 188 private Targeting targeting; 189 /** 190 * Timeline visibility information of the post. 191 */ 192 @Facebook("timeline_visibility") 193 private String timelineVisibility; 194 /** 195 * Duplicate mapping for "likes" since FB can return it differently in different situations. 196 */ 197 @Facebook("likes") 198 private Long likesCount = 0L; 199 /** 200 * Duplicate mapping for "likes" since FB can return it differently in different situations. 201 * 202 * -- GETTER -- The likes on this post. 203 * <p> 204 * Sometimes this can be {@code null} - check {@link #getLikesCount()} instead in that case. 205 */ 206 @Facebook 207 private Likes likes; 208 /** 209 * The time the post was initially published. 210 */ 211 @Facebook("created_time") 212 private Date createdTime; 213 /** 214 * The time of the last comment on this post. 215 */ 216 @Facebook("updated_time") 217 private Date updatedTime; 218 /** 219 * This field is available on tagged Posts. 220 */ 221 @Facebook("tagged_time") 222 private Date taggedTime; 223 /** 224 * The Facebook object id for an uploaded photo or video. 225 * 226 * Hint for Graph API 3.3: Use <code>attachment/target/id</code> instead 227 * 228 * @since 1.6.5 229 */ 230 @Facebook("object_id") 231 @GraphAPI(until = "3.2") 232 private String objectId; 233 /** 234 * The {@code status_type} of post this is, for example {@code "approved_friend"}. 235 * 236 * @since 1.6.12 237 */ 238 @Facebook("status_type") 239 private String statusType; 240 /** 241 * Text from stories not intentionally generated by users 242 * 243 * @since 1.6.16 244 */ 245 @Facebook 246 private String story; 247 /** 248 * The comments for this post. 249 */ 250 @Facebook 251 private Comments comments; 252 /** 253 * The reactions for this post. 254 */ 255 @Facebook 256 private Reactions reactions; 257 /** 258 * The place where this post occurred. 259 * 260 * @since 1.6.8 261 */ 262 @Facebook 263 private Place place; 264 @Facebook 265 private List<NamedFacebookType> to = new ArrayList<>(); 266 @Facebook 267 private List<Action> actions = new ArrayList<>(); 268 @Facebook 269 private List<Property> properties = new ArrayList<>(); 270 @Facebook("message_tags") 271 private transient String rawMessageTags; 272 private List<MessageTag> messageTags = new ArrayList<>(); 273 @Facebook("story_tags") 274 private transient String rawStoryTags; 275 private List<MessageTag> storyTags = new ArrayList<>(); 276 @Facebook("sponsor_tags") 277 private List<NamedFacebookType> sponsorTags = new ArrayList<>(); 278 @Facebook 279 private Connection<Insight> insights; 280 /** 281 * UNIX timestamp of the scheduled publish time for the post. 282 */ 283 @Facebook("scheduled_publish_time") 284 private Date scheduledPublishTime; 285 /** 286 * Number of times the post has been shared. 287 */ 288 @Facebook 289 private Shares shares; 290 /** 291 * ID of admin who created the post. 292 * 293 * Applies to pages only 294 * 295 * @since 1.10.0 296 */ 297 @Facebook("admin_creator") 298 private NamedFacebookType adminCreator; 299 /** 300 * Whether the post can be promoted on Instagram. 301 * <p> 302 * It returns the enum <code>eligible</code> if it can be promoted. Otherwise it returns an enum for why it cannot be 303 * promoted 304 * </p> 305 * 306 */ 307 @Facebook("instagram_eligibility") 308 private String instagramEligibility; 309 /** 310 * Whether or not the post references an app. 311 */ 312 @Facebook("is_app_share") 313 private Boolean isAppShare; 314 @Facebook("is_eligible_for_promotion") 315 private Boolean isEligibleForPromotion; 316 /** 317 * Whether the post has expiration time that has passed 318 */ 319 @Facebook("is_expired") 320 private Boolean isExpired; 321 /** 322 * If this post is marked as hidden (applies to Pages only). 323 * 324 * @since 1.10.0 325 */ 326 @Facebook("is_hidden") 327 private Boolean isHidden; 328 /** 329 * Whether this post can be promoted in Instagram. 330 */ 331 @Facebook("is_instagram_eligible") 332 private Boolean isInstagramEligible; 333 /** 334 * Whether the post is currently popular. 335 * 336 * Based on whether the total actions as a percentage of reach exceeds a certain threshold 337 */ 338 @Facebook("is_popular") 339 private Boolean isPopular; 340 /** 341 * Indicates whether a scheduled post was published. (applies to scheduled Page Post only, for users post and 342 * instantly published posts this value is always <code>true</code>) 343 * 344 * @since 1.10.0 345 */ 346 @Facebook("is_published") 347 private Boolean isPublished; 348 /** 349 * Whether the post is a spherical video post. 350 */ 351 @Facebook("is_spherical") 352 private Boolean isSpherical; 353 /** 354 * Whether display the end card for a multi-link share post 355 */ 356 @Facebook("multi_share_end_card") 357 private Boolean multiShareEndCard; 358 /** 359 * Whether automatically select the order of the links in multi-link share post when used in an ad 360 */ 361 @Facebook("multi_share_optimized") 362 private Boolean multiShareOptimized; 363 /** 364 * Attachments added to a post. 365 * 366 * To force Facebook to fill the <code>attachments</code> field you have to fetch the post with the 367 * <code>fields=attachments</code> parameter, otherwise the attachments are <code>null</code>. 368 */ 369 @Facebook 370 private Attachments attachments; 371 /** 372 * Full picture URL. 373 * 374 * you get the url to this posts full picture. 375 * 376 * To force Facebook to fill the <code>full_picture</code> field you have to fetch the post with the 377 * <code>fields=full_picture</code> parameter, otherwise the full_picture is <code>null</code>. 378 * 379 */ 380 @Facebook("full_picture") 381 private String fullPicture; 382 /** 383 * ID of the user or Page the post was shared from 384 */ 385 @Facebook 386 private String via; 387 388 /** 389 * A string indicating the object type of this post. 390 * 391 * Hint for Graph API 3.3: <code>attachment/media_type</code> If there is no <code>attachment</code> or <code>media_type=link</code>, the 392 * value is the same as <code>type=status</code>. 393 * 394 * @return A string indicating the object type of this post. 395 */ 396 @Override 397 @GraphAPI(until = "3.2") 398 public String getType() { 399 return super.getType(); 400 } 401 402 private static final long serialVersionUID = 3L; 403 404 /** 405 * Post-JSON-mapping operation that populates the {@code messageTags} field "by hand". 406 * <p> 407 * This is a temporary hack until we have formal public support for it/improved {@code JsonMapper} capabilities so it 408 * can handle arbitrary Map types. 409 * 410 * @param jsonMapper 411 * The {@code JsonMapper} that was used to map to this type. 412 * @since 1.6.11 413 */ 414 @JsonMappingCompleted 415 protected void jsonMappingCompleted(JsonMapper jsonMapper) { 416 if (rawMessageTags != null) { 417 messageTags = createTags(rawMessageTags, jsonMapper); 418 } 419 if (rawStoryTags != null) { 420 storyTags = createTags(rawStoryTags, jsonMapper); 421 } 422 } 423 424 private List<MessageTag> createTags(String rawTags, JsonMapper jsonMapper) { 425 try { 426 return jsonMapper.toJavaList(rawTags, MessageTag.class); 427 } catch (FacebookJsonMappingException je) { 428 } 429 // message tags not in Graph API 2.5 format, ignore this exception and try another way 430 try { 431 List<MessageTag> resultList = new ArrayList<>(); 432 JsonObject rawMessageTagsObject = jsonMapper.toJavaObject(rawTags, JsonObject.class); 433 for (String key : rawMessageTagsObject.names()) { 434 String tagArrayString = rawMessageTagsObject.get(key).toString(); 435 resultList.addAll(jsonMapper.toJavaList(tagArrayString, MessageTag.class)); 436 } 437 return resultList; 438 } catch (FacebookJsonMappingException je) { 439 return new ArrayList<>(); 440 } 441 } 442 443 444 /** 445 * Represents the undocumented {@code Property} type. 446 * 447 * @author <a href="http://restfb.com">Mark Allen</a> 448 * @since 1.6.4 449 */ 450 public static class Property extends AbstractFacebookType { 451 /** 452 * The name of the property. 453 */ 454 @Facebook 455 private String name; 456 /** 457 * The text of the property. 458 */ 459 @Facebook 460 private String text; 461 /** 462 * The URL of the property. 463 */ 464 @Facebook 465 private String href; 466 private static final long serialVersionUID = 1L; 467 468 /** 469 * The name of the property. 470 * 471 * @return The name of the property. 472 */ 473 @java.lang.SuppressWarnings("all") 474 public String getName() { 475 return this.name; 476 } 477 478 /** 479 * The name of the property. 480 */ 481 @java.lang.SuppressWarnings("all") 482 public void setName(final String name) { 483 this.name = name; 484 } 485 486 /** 487 * The text of the property. 488 * 489 * @return The text of the property. 490 */ 491 @java.lang.SuppressWarnings("all") 492 public String getText() { 493 return this.text; 494 } 495 496 /** 497 * The text of the property. 498 */ 499 @java.lang.SuppressWarnings("all") 500 public void setText(final String text) { 501 this.text = text; 502 } 503 504 /** 505 * The URL of the property. 506 * 507 * @return The URL of the property. 508 */ 509 @java.lang.SuppressWarnings("all") 510 public String getHref() { 511 return this.href; 512 } 513 514 /** 515 * The URL of the property. 516 */ 517 @java.lang.SuppressWarnings("all") 518 public void setHref(final String href) { 519 this.href = href; 520 } 521 } 522 523 524 /** 525 * Represents the <a href="http://developers.facebook.com/docs/reference/api/post">Action Graph API type</a>. 526 * 527 * @author <a href="http://restfb.com">Mark Allen</a> 528 * @since 1.5 529 */ 530 public static class Action extends AbstractFacebookType { 531 /** 532 * Gets the name of the action. 533 */ 534 @Facebook 535 private String name; 536 /** 537 * The link for the action. 538 */ 539 @Facebook 540 private String link; 541 private static final long serialVersionUID = 1L; 542 543 /** 544 * Gets the name of the action. 545 * 546 * @return Gets the name of the action. 547 */ 548 @java.lang.SuppressWarnings("all") 549 public String getName() { 550 return this.name; 551 } 552 553 /** 554 * Gets the name of the action. 555 */ 556 @java.lang.SuppressWarnings("all") 557 public void setName(final String name) { 558 this.name = name; 559 } 560 561 /** 562 * The link for the action. 563 * 564 * @return The link for the action. 565 */ 566 @java.lang.SuppressWarnings("all") 567 public String getLink() { 568 return this.link; 569 } 570 571 /** 572 * The link for the action. 573 */ 574 @java.lang.SuppressWarnings("all") 575 public void setLink(final String link) { 576 this.link = link; 577 } 578 } 579 580 581 public static class KeyedType extends NamedFacebookType { 582 private static final long serialVersionUID = 1L; 583 @Facebook 584 private String key; 585 586 @JsonMappingCompleted 587 private void replaceId() { 588 if (getId() == null && key != null) { 589 setId(key); 590 } 591 if (key == null && getId() != null) { 592 setKey(getId()); 593 } 594 } 595 596 @java.lang.SuppressWarnings("all") 597 public String getKey() { 598 return this.key; 599 } 600 601 @java.lang.SuppressWarnings("all") 602 public void setKey(final String key) { 603 this.key = key; 604 } 605 } 606 607 608 public static class Targeting extends AbstractFacebookType { 609 private static final long serialVersionUID = 1L; 610 @Facebook("geo_locations") 611 @GraphAPI(since = "2.8") 612 FeedTargeting geoLocations; 613 @Facebook 614 protected List<KeyedType> cities = new ArrayList<>(); 615 @Facebook 616 protected List<String> countries = new ArrayList<>(); 617 @Facebook 618 protected List<KeyedType> regions = new ArrayList<>(); 619 @Facebook("regions") 620 private transient String rawRegionsString; 621 622 @JsonMappingCompleted 623 private void convertList(JsonMapper mapper) { 624 if (rawRegionsString != null) { 625 JsonValue jsonValue = Json.parse(rawRegionsString); 626 if (jsonValue.isObject()) { 627 JsonObject rawRegions = jsonValue.asObject(); 628 for (String key : rawRegions.names()) { 629 String region = rawRegions.get(key).toString(); 630 regions.add(mapper.toJavaObject(region, KeyedType.class)); 631 } 632 } 633 } 634 } 635 636 @Facebook 637 protected List<Integer> locales = new ArrayList<>(); 638 639 public boolean addCity(KeyedType city) { 640 if (geoLocations != null) { 641 return geoLocations.addCity(city); 642 } 643 return cities.add(city); 644 } 645 646 public boolean addCountry(String country) { 647 if (geoLocations != null) { 648 return geoLocations.addCountry(country); 649 } 650 return countries.add(country); 651 } 652 653 public boolean addLocale(Integer locale) { 654 if (geoLocations != null) { 655 return geoLocations.addLocale(locale); 656 } 657 return locales.add(locale); 658 } 659 660 public boolean addRegion(KeyedType region) { 661 if (geoLocations != null) { 662 return geoLocations.addRegion(region); 663 } 664 return regions.add(region); 665 } 666 667 /** 668 * Values of targeting cities. 669 * 670 * Use type of adcity to find Targeting Options and use the returned key to specify. 671 * 672 * @return list of cities 673 */ 674 public List<KeyedType> getCities() { 675 if (geoLocations != null) { 676 return geoLocations.getCities(); 677 } 678 return unmodifiableList(cities); 679 } 680 681 /** 682 * Values of targeting countries. 683 * 684 * You can specify up to 25 countries. Use ISO 3166 format codes. 685 * 686 * @return list of targeting countries. 687 */ 688 public List<String> getCountries() { 689 if (geoLocations != null) { 690 return geoLocations.getCountries(); 691 } 692 return unmodifiableList(countries); 693 } 694 695 /** 696 * Targeted locales. 697 * 698 * Use type of adlocale to find Targeting Options and use the returned key to specify. 699 * 700 * @return list of locales 701 */ 702 public List<Integer> getLocales() { 703 if (geoLocations != null && !geoLocations.getLocales().isEmpty()) { 704 return geoLocations.getLocales(); 705 } 706 return unmodifiableList(locales); 707 } 708 709 /** 710 * Values of targeting regions. 711 * 712 * Use type of {@code adregion} to find Targeting Options and use the returned key to specify. 713 * 714 * @return list of regions 715 */ 716 public List<KeyedType> getRegions() { 717 if (geoLocations != null) { 718 return geoLocations.getRegions(); 719 } 720 return unmodifiableList(regions); 721 } 722 723 public boolean removeCity(NamedFacebookType city) { 724 if (geoLocations != null) { 725 return geoLocations.removeCity(city); 726 } 727 return cities.remove(city); 728 } 729 730 public boolean removeCountry(String country) { 731 if (geoLocations != null) { 732 return geoLocations.removeCountry(country); 733 } 734 return countries.remove(country); 735 } 736 737 public boolean removeLocale(Integer locale) { 738 if (geoLocations != null) { 739 return geoLocations.removeLocale(locale); 740 } 741 return locales.remove(locale); 742 } 743 744 public boolean removeRegion(NamedFacebookType region) { 745 if (geoLocations != null) { 746 return geoLocations.removeRegion(region); 747 } 748 return regions.remove(region); 749 } 750 751 @GraphAPI(since = "2.8") 752 @java.lang.SuppressWarnings("all") 753 public FeedTargeting getGeoLocations() { 754 return this.geoLocations; 755 } 756 757 @java.lang.SuppressWarnings("all") 758 public void setGeoLocations(final FeedTargeting geoLocations) { 759 this.geoLocations = geoLocations; 760 } 761 } 762 763 764 /** 765 * Object that controls news feed targeting for this post. 766 * 767 * Anyone in these groups will be more likely to see this post, others will be less likely, but may still see it 768 * anyway. Any of the targeting fields shown here can be used, none are required (applies to Pages only). 769 * 770 * Represents the <a href="http://developers.facebook.com/docs/reference/api/post#fields">Feed Targeting API type</a>. 771 */ 772 public static class FeedTargeting extends Targeting { 773 private static final long serialVersionUID = 1L; 774 /** 775 * Maximum age. 776 */ 777 @Facebook("age_max") 778 private Integer ageMax; 779 /** 780 * Must be 13 or higher. Default is 0 781 */ 782 @Facebook("age_min") 783 private Integer ageMin; 784 @Facebook("relevant_until_ts") 785 private Date relevantUntilTs; 786 @Facebook("college_majors") 787 private List<String> collegeMajors = new ArrayList<>(); 788 @Facebook("college_networks") 789 private List<FacebookType> collegeNetworks = new ArrayList<>(); 790 @Facebook("college_years") 791 private List<Integer> collegeYears = new ArrayList<>(); 792 @Facebook("education_statuses") 793 private List<Integer> educationStatuses = new ArrayList<>(); 794 @Facebook("fan_of") 795 private List<String> fanOf = new ArrayList<>(); 796 @Facebook 797 private List<Integer> genders = new ArrayList<>(); 798 @Facebook("interested_in") 799 private List<Integer> interestedIn = new ArrayList<>(); 800 @Facebook 801 private List<String> interests = new ArrayList<>(); 802 @Facebook("relationship_statuses") 803 private List<Integer> relationshipStatuses = new ArrayList<>(); 804 @Facebook("work_networks") 805 private List<NamedFacebookType> workNetworks = new ArrayList<>(); 806 807 /** 808 * Target people who majored in these college subjects. 809 * 810 * Limited to 200 college major values. Use type of adcollegemajor to find Targeting Options and use the returned 811 * name to specify. 812 * 813 * @return list of college majors 814 */ 815 public List<String> getCollegeMajors() { 816 return unmodifiableList(collegeMajors); 817 } 818 819 public boolean addCollegeMajor(String collegeMajor) { 820 return collegeMajors.add(collegeMajor); 821 } 822 823 public boolean removeCollegeMajor(String collegeMajor) { 824 return collegeMajors.remove(collegeMajor); 825 } 826 827 /** 828 * Colleges, for college graduates. 829 * 830 * Limit is 200 values. 831 * 832 * @return list of colleges 833 */ 834 public List<FacebookType> getCollegeNetworks() { 835 return unmodifiableList(collegeNetworks); 836 } 837 838 public boolean addCollegeNetwork(FacebookType collegeNetwork) { 839 return collegeNetworks.add(collegeNetwork); 840 } 841 842 public boolean removeCollegeNetwork(FacebookType collegeNetwork) { 843 return collegeNetworks.remove(collegeNetwork); 844 } 845 846 /** 847 * Array of integers for graduation year from college. 848 * 849 * @return graduation year list 850 */ 851 public List<Integer> getCollegeYears() { 852 return unmodifiableList(collegeYears); 853 } 854 855 public boolean addCollegeYear(Integer collegeYear) { 856 return collegeYears.add(collegeYear); 857 } 858 859 public boolean removeCollegeYear(Integer collegeYear) { 860 return collegeYears.remove(collegeYear); 861 } 862 863 /** 864 * Array of integers for targeting based on education level. 865 * 866 * Use 1 for high school, 2 for undergraduate, and 3 for alum (or localized equivalents). 867 * 868 * @return list of education levels 869 */ 870 public List<Integer> getEducationStatuses() { 871 return unmodifiableList(educationStatuses); 872 } 873 874 public boolean addEducationStatus(Integer educationStatus) { 875 return educationStatuses.add(educationStatus); 876 } 877 878 public boolean removeEducationStatus(Integer educationStatus) { 879 return educationStatuses.remove(educationStatus); 880 } 881 882 /** 883 * List of object ids. 884 * 885 * the user should be fan of these objects (interests). 886 * 887 * @return list of object ids 888 */ 889 public List<String> getFanOf() { 890 return unmodifiableList(fanOf); 891 } 892 893 public boolean addFanOf(String interestId) { 894 return fanOf.add(interestId); 895 } 896 897 public boolean removeFanOf(String interestId) { 898 return fanOf.remove(interestId); 899 } 900 901 /** 902 * Target specific genders. 903 * 904 * 1 targets all male viewers and 2 females. Default is to target both. 905 * 906 * @return list of genders 907 */ 908 public List<Integer> getGenders() { 909 return unmodifiableList(genders); 910 } 911 912 public boolean addGender(Integer gender) { 913 return genders.add(gender); 914 } 915 916 public boolean removeGender(Integer gender) { 917 return genders.remove(gender); 918 } 919 920 /** 921 * Indicates targeting based on the 'interested in' field of the user profile. 922 * 923 * You can specify an integer of 1 to indicate male, 2 indicates female. Default is all types. 924 * 925 * Please note 'interested in' targeting is not available in France due to local laws. 926 * 927 * @return list of 'interested in' types 928 */ 929 public List<Integer> getInterestedIn() { 930 return unmodifiableList(interestedIn); 931 } 932 933 public boolean addInterestedIn(Integer interest) { 934 return interestedIn.add(interest); 935 } 936 937 public boolean removeInterestedIn(Integer interest) { 938 return interestedIn.remove(interest); 939 } 940 941 /** 942 * Indicates targeting based on the 'interests' field of the user profile. 943 * 944 * @return list of 'interests' types 945 */ 946 public List<String> getInterests() { 947 return unmodifiableList(interests); 948 } 949 950 public boolean addInterests(String interest) { 951 return interests.add(interest); 952 } 953 954 public boolean removeInterests(String interest) { 955 return interests.remove(interest); 956 } 957 958 /** 959 * Array of integers for targeting based on relationship status. 960 * 961 * Use 1 for single, 2 for 'in a relationship', 3 for married, and 4 for engaged. Default is all types. 962 * 963 * @return list of relationship statuses 964 */ 965 public List<Integer> getRelationshipStatuses() { 966 return unmodifiableList(relationshipStatuses); 967 } 968 969 public boolean addRelationshipStatus(Integer relationshipStatus) { 970 return relationshipStatuses.add(relationshipStatus); 971 } 972 973 public boolean removeRelationshipStatus(Integer relationshipStatus) { 974 return relationshipStatuses.remove(relationshipStatus); 975 } 976 977 /** 978 * Company, organization, or other workplace. 979 * 980 * <b>Name</b>: Name of targeted workplace. Use type of adworkplace to find Targeting Options and use the returned 981 * name to specify this. 982 * 983 * <b>Id</b>: Unique ID of targeted workplace. Use type of adworkplace to find Targeting Options and use the 984 * returned key to specify this (must match paired name value). 985 * 986 * @return list of work networks 987 */ 988 public List<NamedFacebookType> getWorkNetworks() { 989 return unmodifiableList(workNetworks); 990 } 991 992 public boolean addWorkNetwork(NamedFacebookType workNetwork) { 993 return workNetworks.add(workNetwork); 994 } 995 996 public boolean removeWorkNetwork(NamedFacebookType workNetwork) { 997 return workNetworks.remove(workNetwork); 998 } 999 1000 /** 1001 * Maximum age. 1002 */ 1003 @java.lang.SuppressWarnings("all") 1004 public Integer getAgeMax() { 1005 return this.ageMax; 1006 } 1007 1008 /** 1009 * Maximum age. 1010 */ 1011 @java.lang.SuppressWarnings("all") 1012 public void setAgeMax(final Integer ageMax) { 1013 this.ageMax = ageMax; 1014 } 1015 1016 /** 1017 * Must be 13 or higher. Default is 0 1018 */ 1019 @java.lang.SuppressWarnings("all") 1020 public Integer getAgeMin() { 1021 return this.ageMin; 1022 } 1023 1024 /** 1025 * Must be 13 or higher. Default is 0 1026 */ 1027 @java.lang.SuppressWarnings("all") 1028 public void setAgeMin(final Integer ageMin) { 1029 this.ageMin = ageMin; 1030 } 1031 1032 @java.lang.SuppressWarnings("all") 1033 public Date getRelevantUntilTs() { 1034 return this.relevantUntilTs; 1035 } 1036 1037 @java.lang.SuppressWarnings("all") 1038 public void setRelevantUntilTs(final Date relevantUntilTs) { 1039 this.relevantUntilTs = relevantUntilTs; 1040 } 1041 } 1042 1043 1044 /** 1045 * Represents the Shares included the <a href="http://developers.facebook.com/docs/reference/api/post">Post</a> 1046 * response. Presently only supports count. 1047 * 1048 * @since 1.6.11 1049 */ 1050 public static class Shares extends AbstractFacebookType { 1051 /** 1052 * The number of shares. 1053 */ 1054 @Facebook 1055 private Long count = 0L; 1056 private static final long serialVersionUID = 1L; 1057 1058 /** 1059 * The number of shares. 1060 * 1061 * @return The number of shares. 1062 */ 1063 @java.lang.SuppressWarnings("all") 1064 public Long getCount() { 1065 return this.count; 1066 } 1067 1068 /** 1069 * The number of shares. 1070 */ 1071 @java.lang.SuppressWarnings("all") 1072 public void setCount(final Long count) { 1073 this.count = count; 1074 } 1075 } 1076 1077 1078 /** 1079 * Represents the attachments included in<a href="http://developers.facebook.com/docs/reference/api/post">Graph API 1080 * Post type</a>. 1081 * 1082 * @author <a href="https://github.com/kevinleturc/">Kevin Leturc</a> 1083 * @since 1.12.0 1084 */ 1085 public static class Attachments extends AbstractFacebookType { 1086 /** 1087 * All media attachments associated with this post. 1088 * 1089 * @return All media attachments associated with this post. 1090 */ 1091 @Facebook 1092 private List<StoryAttachment> data = new ArrayList<>(); 1093 private static final long serialVersionUID = 1L; 1094 1095 /** 1096 * The attachments. 1097 * 1098 * @return The attachments. 1099 */ 1100 public List<StoryAttachment> getData() { 1101 return unmodifiableList(data); 1102 } 1103 1104 public boolean addData(StoryAttachment attachment) { 1105 return data.add(attachment); 1106 } 1107 1108 public boolean removeData(StoryAttachment attachment) { 1109 return data.remove(attachment); 1110 } 1111 } 1112 1113 /** 1114 * The number of likes on this post. 1115 * 1116 * @return The number of likes on this post. 1117 */ 1118 public Long getLikesCount() { 1119 if (getLikes() != null) { 1120 return getLikes().getTotalCount(); 1121 } 1122 return likesCount; 1123 } 1124 1125 /** 1126 * The number of reactions on this post. 1127 * 1128 * @return The number of reactions on this post. 1129 */ 1130 public Long getReactionsCount() { 1131 if (getReactions() != null) { 1132 return getReactions().getTotalCount(); 1133 } 1134 return 0L; 1135 } 1136 1137 /** 1138 * The number of shares of this post. 1139 * 1140 * @return The number of shares of this post. 1141 */ 1142 public Long getSharesCount() { 1143 if (shares != null) { 1144 return shares.getCount(); 1145 } 1146 return 0L; 1147 } 1148 1149 /** 1150 * The number of comments of this post. 1151 * 1152 * @return The number of comments of this post. 1153 */ 1154 public Long getCommentsCount() { 1155 if (comments != null) { 1156 return comments.getTotalCount(); 1157 } 1158 return 0L; 1159 } 1160 1161 /** 1162 * A list of the profiles mentioned or targeted in this post. 1163 * 1164 * @return A list of the profiles mentioned or targeted in this post. 1165 */ 1166 public List<NamedFacebookType> getTo() { 1167 return unmodifiableList(to); 1168 } 1169 1170 public boolean addTo(NamedFacebookType profile) { 1171 return to.add(profile); 1172 } 1173 1174 public boolean removeTo(NamedFacebookType profile) { 1175 return to.remove(profile); 1176 } 1177 1178 /** 1179 * A list of available action names and links (including commenting, liking, and an optional app-specified action). 1180 * 1181 * @return A list of available action names and links (including commenting, liking, and an optional app-specified 1182 * action). 1183 */ 1184 public List<Action> getActions() { 1185 return unmodifiableList(actions); 1186 } 1187 1188 public boolean addAction(Action action) { 1189 return actions.add(action); 1190 } 1191 1192 public boolean removeAction(Action action) { 1193 return actions.remove(action); 1194 } 1195 1196 /** 1197 * A list of properties for this post. 1198 * <p> 1199 * This field is undocumented. 1200 * 1201 * @return A list of properties for this post. 1202 */ 1203 public List<Property> getProperties() { 1204 return unmodifiableList(properties); 1205 } 1206 1207 public boolean addProperty(Property property) { 1208 return properties.add(property); 1209 } 1210 1211 public boolean removeProperty(Property property) { 1212 return properties.remove(property); 1213 } 1214 1215 /** 1216 * Objects tagged in the message (Users, Pages, etc). 1217 * 1218 * @return Objects tagged in the message (Users, Pages, etc). 1219 * @since 1.6.10 1220 */ 1221 public List<MessageTag> getMessageTags() { 1222 return unmodifiableList(messageTags); 1223 } 1224 1225 public void addMessageTag(MessageTag messageTag) { 1226 messageTags.add(messageTag); 1227 } 1228 1229 public void removeMessageTag(MessageTag messageTag) { 1230 messageTags.remove(messageTag); 1231 } 1232 1233 /** 1234 * Objects tagged in the story (Users, Pages, etc). 1235 * 1236 * @return Objects tagged in the story (Users, Pages, etc). 1237 */ 1238 public List<MessageTag> getStoryTags() { 1239 return unmodifiableList(storyTags); 1240 } 1241 1242 public void addStoryTag(MessageTag messageTag) { 1243 storyTags.add(messageTag); 1244 } 1245 1246 public void removeStoryTag(MessageTag messageTag) { 1247 storyTags.remove(messageTag); 1248 } 1249 1250 /** 1251 * Sub-shares of a multi-link share post 1252 * 1253 * @return Sub-shares of a multi-link share post 1254 */ 1255 public List<Post> getChildAttachments() { 1256 return unmodifiableList(childAttachments); 1257 } 1258 1259 public void addChildAttachment(Post childAttachment) { 1260 childAttachments.add(childAttachment); 1261 } 1262 1263 public void removeChildAttachment(Post childAttachment) { 1264 childAttachments.remove(childAttachment); 1265 } 1266 1267 /** 1268 * A sponsor tag points to a Facebook Page. 1269 * 1270 * (Page owners can allow their business partners to directly boost their posts.) 1271 */ 1272 public List<NamedFacebookType> getSponsorTags() { 1273 return unmodifiableList(sponsorTags); 1274 } 1275 1276 public boolean addSponsorTag(NamedFacebookType sponsorTag) { 1277 return sponsorTags.add(sponsorTag); 1278 } 1279 1280 public boolean removeSponsorTag(NamedFacebookType sponsorTag) { 1281 return sponsorTags.remove(sponsorTag); 1282 } 1283 1284 /** 1285 * An object containing the ID and name of the user who posted the message. 1286 * 1287 * @return An object containing the ID and name of the user who posted the message. 1288 */ 1289 @java.lang.SuppressWarnings("all") 1290 public From getFrom() { 1291 return this.from; 1292 } 1293 1294 /** 1295 * An object containing the ID and name of the user who posted the message. 1296 */ 1297 @java.lang.SuppressWarnings("all") 1298 public void setFrom(final From from) { 1299 this.from = from; 1300 } 1301 1302 /** 1303 * Objectives under which this post can be advertised 1304 * 1305 * @return Objectives under which this post can be advertised 1306 */ 1307 @java.lang.SuppressWarnings("all") 1308 public String getAllowedAdvertisingObjects() { 1309 return this.allowedAdvertisingObjects; 1310 } 1311 1312 /** 1313 * Objectives under which this post can be advertised 1314 */ 1315 @java.lang.SuppressWarnings("all") 1316 public void setAllowedAdvertisingObjects(final String allowedAdvertisingObjects) { 1317 this.allowedAdvertisingObjects = allowedAdvertisingObjects; 1318 } 1319 1320 /** 1321 * Objectives under which this post can be advertised 1322 * 1323 * @return Objectives under which this post can be advertised 1324 */ 1325 @java.lang.SuppressWarnings("all") 1326 public List<String> getAllowedAdvertisingObjectives() { 1327 return this.allowedAdvertisingObjectives; 1328 } 1329 1330 /** 1331 * Objectives under which this post can be advertised 1332 */ 1333 @java.lang.SuppressWarnings("all") 1334 public void setAllowedAdvertisingObjectives(final List<String> allowedAdvertisingObjectives) { 1335 this.allowedAdvertisingObjectives = allowedAdvertisingObjectives; 1336 } 1337 1338 /** 1339 * The call to action type used in any Page posts for mobile app engagement ads 1340 */ 1341 @java.lang.SuppressWarnings("all") 1342 public PostCallToAction getCallToAction() { 1343 return this.callToAction; 1344 } 1345 1346 /** 1347 * The call to action type used in any Page posts for mobile app engagement ads 1348 */ 1349 @java.lang.SuppressWarnings("all") 1350 public void setCallToAction(final PostCallToAction callToAction) { 1351 this.callToAction = callToAction; 1352 } 1353 1354 /** 1355 * If comments are being mirrored to an external site, this function returns the domain of that external site. 1356 * 1357 * @return If comments are being mirrored to an external site, this function returns the domain of that external site. 1358 */ 1359 @java.lang.SuppressWarnings("all") 1360 public String getCommentsMirroringDomain() { 1361 return this.commentsMirroringDomain; 1362 } 1363 1364 /** 1365 * If comments are being mirrored to an external site, this function returns the domain of that external site. 1366 */ 1367 @java.lang.SuppressWarnings("all") 1368 public void setCommentsMirroringDomain(final String commentsMirroringDomain) { 1369 this.commentsMirroringDomain = commentsMirroringDomain; 1370 } 1371 1372 /** 1373 * The message. 1374 * 1375 * @return The message. 1376 */ 1377 @Override 1378 @java.lang.SuppressWarnings("all") 1379 public String getMessage() { 1380 return this.message; 1381 } 1382 1383 /** 1384 * The message. 1385 */ 1386 @java.lang.SuppressWarnings("all") 1387 public void setMessage(final String message) { 1388 this.message = message; 1389 } 1390 1391 /** 1392 * ID of the parent post 1393 * 1394 * @return ID of the parent post 1395 */ 1396 @java.lang.SuppressWarnings("all") 1397 public String getParentId() { 1398 return this.parentId; 1399 } 1400 1401 /** 1402 * ID of the parent post 1403 */ 1404 @java.lang.SuppressWarnings("all") 1405 public void setParentId(final String parentId) { 1406 this.parentId = parentId; 1407 } 1408 1409 /** 1410 * The permanent static URL to the post on www.facebook.com. 1411 * <p> 1412 * Example: https://www.facebook.com/FacebookforDevelopers/posts/10153449196353553 1413 * </p> 1414 * 1415 * @return The permanent static URL to the post on www.facebook.com. 1416 */ 1417 @java.lang.SuppressWarnings("all") 1418 public String getPermalinkUrl() { 1419 return this.permalinkUrl; 1420 } 1421 1422 /** 1423 * The permanent static URL to the post on www.facebook.com. 1424 * <p> 1425 * Example: https://www.facebook.com/FacebookforDevelopers/posts/10153449196353553 1426 * </p> 1427 * 1428 */ 1429 @java.lang.SuppressWarnings("all") 1430 public void setPermalinkUrl(final String permalinkUrl) { 1431 this.permalinkUrl = permalinkUrl; 1432 } 1433 1434 /** 1435 * If available, a link to the picture included with this post. 1436 * 1437 * @return If available, a link to the picture included with this post. 1438 */ 1439 @java.lang.SuppressWarnings("all") 1440 public String getPicture() { 1441 return this.picture; 1442 } 1443 1444 /** 1445 * If available, a link to the picture included with this post. 1446 */ 1447 @java.lang.SuppressWarnings("all") 1448 public void setPicture(final String picture) { 1449 this.picture = picture; 1450 } 1451 1452 /** 1453 * The link attached to this post. 1454 * 1455 * Hint for Graph API 3.3: Use <code>attachment/url_unshimmed</code> instead 1456 * 1457 * @return The link attached to this post. 1458 */ 1459 @GraphAPI(until = "3.2") 1460 @java.lang.SuppressWarnings("all") 1461 public String getLink() { 1462 return this.link; 1463 } 1464 1465 /** 1466 * The link attached to this post. 1467 * 1468 * Hint for Graph API 3.3: Use <code>attachment/url_unshimmed</code> instead 1469 */ 1470 @java.lang.SuppressWarnings("all") 1471 public void setLink(final String link) { 1472 this.link = link; 1473 } 1474 1475 /** 1476 * The name of the link. 1477 * 1478 * Hint for Graph API 3.3: Use <code>attachment/title</code> instead 1479 * 1480 * @return The name of the link. 1481 */ 1482 @GraphAPI(until = "3.2") 1483 @java.lang.SuppressWarnings("all") 1484 public String getName() { 1485 return this.name; 1486 } 1487 1488 /** 1489 * The name of the link. 1490 * 1491 * Hint for Graph API 3.3: Use <code>attachment/title</code> instead 1492 */ 1493 @java.lang.SuppressWarnings("all") 1494 public void setName(final String name) { 1495 this.name = name; 1496 } 1497 1498 /** 1499 * The caption of the link (appears beneath the link name). 1500 * 1501 * Hint for Graph API 3.3: Use <code>attachment/title</code> instead 1502 * 1503 * @return The caption of the link (appears beneath the link name). 1504 */ 1505 @GraphAPI(until = "3.2") 1506 @java.lang.SuppressWarnings("all") 1507 public String getCaption() { 1508 return this.caption; 1509 } 1510 1511 /** 1512 * The caption of the link (appears beneath the link name). 1513 * 1514 * Hint for Graph API 3.3: Use <code>attachment/title</code> instead 1515 */ 1516 @java.lang.SuppressWarnings("all") 1517 public void setCaption(final String caption) { 1518 this.caption = caption; 1519 } 1520 1521 /** 1522 * A description of the link (appears beneath the link caption). 1523 * 1524 * Hint for Graph API 3.3: Use <code>attachment/description</code> instead 1525 * 1526 * @return A description of the link (appears beneath the link caption). 1527 */ 1528 @GraphAPI(until = "3.2") 1529 @java.lang.SuppressWarnings("all") 1530 public String getDescription() { 1531 return this.description; 1532 } 1533 1534 /** 1535 * A description of the link (appears beneath the link caption). 1536 * 1537 * Hint for Graph API 3.3: Use <code>attachment/description</code> instead 1538 */ 1539 @java.lang.SuppressWarnings("all") 1540 public void setDescription(final String description) { 1541 this.description = description; 1542 } 1543 1544 /** 1545 * If available, the source link attached to this post (for example, a flash or video file). 1546 * 1547 * Hint for Graph API 3.3: Use <code>attachment/media/source</code> instead 1548 * 1549 * @return If available, the source link attached to this post (for example, a flash or video file). 1550 */ 1551 @GraphAPI(until = "3.2") 1552 @java.lang.SuppressWarnings("all") 1553 public String getSource() { 1554 return this.source; 1555 } 1556 1557 /** 1558 * If available, the source link attached to this post (for example, a flash or video file). 1559 * 1560 * Hint for Graph API 3.3: Use <code>attachment/media/source</code> instead 1561 */ 1562 @java.lang.SuppressWarnings("all") 1563 public void setSource(final String source) { 1564 this.source = source; 1565 } 1566 1567 /** 1568 * The application used to create this post. 1569 * 1570 * @return The application used to create this post. 1571 */ 1572 @java.lang.SuppressWarnings("all") 1573 public NamedFacebookType getApplication() { 1574 return this.application; 1575 } 1576 1577 /** 1578 * The application used to create this post. 1579 */ 1580 @java.lang.SuppressWarnings("all") 1581 public void setApplication(final NamedFacebookType application) { 1582 this.application = application; 1583 } 1584 1585 /** 1586 * A link to an icon representing the type of this post. 1587 * 1588 * @return A link to an icon representing the type of this post. 1589 */ 1590 @java.lang.SuppressWarnings("all") 1591 public String getIcon() { 1592 return this.icon; 1593 } 1594 1595 /** 1596 * A link to an icon representing the type of this post. 1597 */ 1598 @java.lang.SuppressWarnings("all") 1599 public void setIcon(final String icon) { 1600 this.icon = icon; 1601 } 1602 1603 /** 1604 * The privacy settings for this post. 1605 * 1606 * @return The privacy settings for this post. 1607 */ 1608 @java.lang.SuppressWarnings("all") 1609 public Privacy getPrivacy() { 1610 return this.privacy; 1611 } 1612 1613 /** 1614 * The privacy settings for this post. 1615 */ 1616 @java.lang.SuppressWarnings("all") 1617 public void setPrivacy(final Privacy privacy) { 1618 this.privacy = privacy; 1619 } 1620 1621 /** 1622 * Status of the promotion, if the post was promoted. 1623 * 1624 * @return Status of the promotion, if the post was promoted 1625 */ 1626 @java.lang.SuppressWarnings("all") 1627 public String getPromotionStatus() { 1628 return this.promotionStatus; 1629 } 1630 1631 /** 1632 * Status of the promotion, if the post was promoted. 1633 */ 1634 @java.lang.SuppressWarnings("all") 1635 public void setPromotionStatus(final String promotionStatus) { 1636 this.promotionStatus = promotionStatus; 1637 } 1638 1639 /** 1640 * Object that controls news feed targeting for this post. 1641 * 1642 * To force Facebook to fill the <code>feed_targeting</code> field you have to fetch the post with the 1643 * <code>fields=feed_targeting</code> parameter, otherwise the feedTargeting is <code>null</code>. 1644 * 1645 * 1646 * @since 1.11.0 1647 */ 1648 @java.lang.SuppressWarnings("all") 1649 public FeedTargeting getFeedTargeting() { 1650 return this.feedTargeting; 1651 } 1652 1653 /** 1654 * Object that controls news feed targeting for this post. 1655 * 1656 * To force Facebook to fill the <code>feed_targeting</code> field you have to fetch the post with the 1657 * <code>fields=feed_targeting</code> parameter, otherwise the feedTargeting is <code>null</code>. 1658 * 1659 * 1660 * @since 1.11.0 1661 */ 1662 @java.lang.SuppressWarnings("all") 1663 public void setFeedTargeting(final FeedTargeting feedTargeting) { 1664 this.feedTargeting = feedTargeting; 1665 } 1666 1667 /** 1668 * Whether the viewer can send a private reply to this post (Page viewers only) 1669 * 1670 * @return Whether the viewer can send a private reply to this post 1671 */ 1672 @GraphAPI(since = "2.5") 1673 @java.lang.SuppressWarnings("all") 1674 public Boolean getCanReplyPrivately() { 1675 return this.canReplyPrivately; 1676 } 1677 1678 /** 1679 * Whether the viewer can send a private reply to this post (Page viewers only) 1680 */ 1681 @java.lang.SuppressWarnings("all") 1682 public void setCanReplyPrivately(final Boolean canReplyPrivately) { 1683 this.canReplyPrivately = canReplyPrivately; 1684 } 1685 1686 /** 1687 * The profile this was posted on if different from the author. 1688 * 1689 * @return The profile this was posted on if different from the author 1690 */ 1691 @GraphAPI(since = "2.5") 1692 @java.lang.SuppressWarnings("all") 1693 public NamedFacebookType getTarget() { 1694 return this.target; 1695 } 1696 1697 /** 1698 * The profile this was posted on if different from the author. 1699 */ 1700 @java.lang.SuppressWarnings("all") 1701 public void setTarget(final NamedFacebookType target) { 1702 this.target = target; 1703 } 1704 1705 /** 1706 * Ads targeting information of the post. 1707 * 1708 * @return Ads targeting information of the post 1709 */ 1710 @java.lang.SuppressWarnings("all") 1711 public Targeting getTargeting() { 1712 return this.targeting; 1713 } 1714 1715 /** 1716 * Ads targeting information of the post. 1717 */ 1718 @java.lang.SuppressWarnings("all") 1719 public void setTargeting(final Targeting targeting) { 1720 this.targeting = targeting; 1721 } 1722 1723 /** 1724 * Timeline visibility information of the post. 1725 * 1726 * @return timeline visibility information of the post 1727 */ 1728 @java.lang.SuppressWarnings("all") 1729 public String getTimelineVisibility() { 1730 return this.timelineVisibility; 1731 } 1732 1733 /** 1734 * Timeline visibility information of the post. 1735 */ 1736 @java.lang.SuppressWarnings("all") 1737 public void setTimelineVisibility(final String timelineVisibility) { 1738 this.timelineVisibility = timelineVisibility; 1739 } 1740 1741 /** 1742 * Duplicate mapping for "likes" since FB can return it differently in different situations. 1743 * 1744 * -- GETTER -- The likes on this post. 1745 * <p> 1746 * Sometimes this can be {@code null} - check {@link #getLikesCount()} instead in that case. 1747 * 1748 * @return The likes on this post. 1749 */ 1750 @java.lang.SuppressWarnings("all") 1751 public Likes getLikes() { 1752 return this.likes; 1753 } 1754 1755 /** 1756 * Duplicate mapping for "likes" since FB can return it differently in different situations. 1757 * 1758 * -- GETTER -- The likes on this post. 1759 * <p> 1760 * Sometimes this can be {@code null} - check {@link #getLikesCount()} instead in that case. 1761 */ 1762 @java.lang.SuppressWarnings("all") 1763 public void setLikes(final Likes likes) { 1764 this.likes = likes; 1765 } 1766 1767 /** 1768 * The time the post was initially published. 1769 * 1770 * @return The time the post was initially published. 1771 */ 1772 @Override 1773 @java.lang.SuppressWarnings("all") 1774 public Date getCreatedTime() { 1775 return this.createdTime; 1776 } 1777 1778 /** 1779 * The time the post was initially published. 1780 */ 1781 @java.lang.SuppressWarnings("all") 1782 public void setCreatedTime(final Date createdTime) { 1783 this.createdTime = createdTime; 1784 } 1785 1786 /** 1787 * The time of the last comment on this post. 1788 * 1789 * @return The time of the last comment on this post. 1790 */ 1791 @java.lang.SuppressWarnings("all") 1792 public Date getUpdatedTime() { 1793 return this.updatedTime; 1794 } 1795 1796 /** 1797 * The time of the last comment on this post. 1798 */ 1799 @java.lang.SuppressWarnings("all") 1800 public void setUpdatedTime(final Date updatedTime) { 1801 this.updatedTime = updatedTime; 1802 } 1803 1804 /** 1805 * This field is available on tagged Posts. 1806 * 1807 * @return The tagging Date of the Post 1808 */ 1809 @java.lang.SuppressWarnings("all") 1810 public Date getTaggedTime() { 1811 return this.taggedTime; 1812 } 1813 1814 /** 1815 * This field is available on tagged Posts. 1816 */ 1817 @java.lang.SuppressWarnings("all") 1818 public void setTaggedTime(final Date taggedTime) { 1819 this.taggedTime = taggedTime; 1820 } 1821 1822 /** 1823 * The Facebook object id for an uploaded photo or video. 1824 * 1825 * Hint for Graph API 3.3: Use <code>attachment/target/id</code> instead 1826 * 1827 * @return The Facebook object id for an uploaded photo or video. 1828 * @since 1.6.5 1829 */ 1830 @GraphAPI(until = "3.2") 1831 @java.lang.SuppressWarnings("all") 1832 public String getObjectId() { 1833 return this.objectId; 1834 } 1835 1836 /** 1837 * The Facebook object id for an uploaded photo or video. 1838 * 1839 * Hint for Graph API 3.3: Use <code>attachment/target/id</code> instead 1840 * 1841 * @since 1.6.5 1842 */ 1843 @java.lang.SuppressWarnings("all") 1844 public void setObjectId(final String objectId) { 1845 this.objectId = objectId; 1846 } 1847 1848 /** 1849 * The {@code status_type} of post this is, for example {@code "approved_friend"}. 1850 * 1851 * @return The {@code status_type} of post this is, for example {@code "approved_friend"}. 1852 * @since 1.6.12 1853 */ 1854 @java.lang.SuppressWarnings("all") 1855 public String getStatusType() { 1856 return this.statusType; 1857 } 1858 1859 /** 1860 * The {@code status_type} of post this is, for example {@code "approved_friend"}. 1861 * 1862 * @since 1.6.12 1863 */ 1864 @java.lang.SuppressWarnings("all") 1865 public void setStatusType(final String statusType) { 1866 this.statusType = statusType; 1867 } 1868 1869 /** 1870 * Text from stories not intentionally generated by users 1871 * 1872 * @return Text from stories not intentionally generated by users 1873 * @since 1.6.16 1874 */ 1875 @java.lang.SuppressWarnings("all") 1876 public String getStory() { 1877 return this.story; 1878 } 1879 1880 /** 1881 * Text from stories not intentionally generated by users 1882 * 1883 * @since 1.6.16 1884 */ 1885 @java.lang.SuppressWarnings("all") 1886 public void setStory(final String story) { 1887 this.story = story; 1888 } 1889 1890 /** 1891 * The comments for this post. 1892 * 1893 * @return The comments for this post. 1894 */ 1895 @Override 1896 @java.lang.SuppressWarnings("all") 1897 public Comments getComments() { 1898 return this.comments; 1899 } 1900 1901 /** 1902 * The comments for this post. 1903 */ 1904 @java.lang.SuppressWarnings("all") 1905 public void setComments(final Comments comments) { 1906 this.comments = comments; 1907 } 1908 1909 /** 1910 * The reactions for this post. 1911 * 1912 * @return The reactions for this post. 1913 */ 1914 @java.lang.SuppressWarnings("all") 1915 public Reactions getReactions() { 1916 return this.reactions; 1917 } 1918 1919 /** 1920 * The reactions for this post. 1921 */ 1922 @java.lang.SuppressWarnings("all") 1923 public void setReactions(final Reactions reactions) { 1924 this.reactions = reactions; 1925 } 1926 1927 /** 1928 * The place where this post occurred. 1929 * 1930 * @return The place where this post occurred. 1931 * @since 1.6.8 1932 */ 1933 @java.lang.SuppressWarnings("all") 1934 public Place getPlace() { 1935 return this.place; 1936 } 1937 1938 /** 1939 * The place where this post occurred. 1940 * 1941 * @since 1.6.8 1942 */ 1943 @java.lang.SuppressWarnings("all") 1944 public void setPlace(final Place place) { 1945 this.place = place; 1946 } 1947 1948 @java.lang.SuppressWarnings("all") 1949 public Connection<Insight> getInsights() { 1950 return this.insights; 1951 } 1952 1953 @java.lang.SuppressWarnings("all") 1954 public void setInsights(final Connection<Insight> insights) { 1955 this.insights = insights; 1956 } 1957 1958 /** 1959 * UNIX timestamp of the scheduled publish time for the post. 1960 * 1961 * @return UNIX timestamp of the scheduled publish time for the post 1962 */ 1963 @java.lang.SuppressWarnings("all") 1964 public Date getScheduledPublishTime() { 1965 return this.scheduledPublishTime; 1966 } 1967 1968 /** 1969 * UNIX timestamp of the scheduled publish time for the post. 1970 */ 1971 @java.lang.SuppressWarnings("all") 1972 public void setScheduledPublishTime(final Date scheduledPublishTime) { 1973 this.scheduledPublishTime = scheduledPublishTime; 1974 } 1975 1976 /** 1977 * Number of times the post has been shared. 1978 * 1979 * @return Number of times the post has been shared 1980 */ 1981 @java.lang.SuppressWarnings("all") 1982 public Shares getShares() { 1983 return this.shares; 1984 } 1985 1986 /** 1987 * Number of times the post has been shared. 1988 */ 1989 @java.lang.SuppressWarnings("all") 1990 public void setShares(final Shares shares) { 1991 this.shares = shares; 1992 } 1993 1994 /** 1995 * ID of admin who created the post. 1996 * 1997 * Applies to pages only 1998 * 1999 * @return ID of admin who created the post. 2000 * @since 1.10.0 2001 */ 2002 @java.lang.SuppressWarnings("all") 2003 public NamedFacebookType getAdminCreator() { 2004 return this.adminCreator; 2005 } 2006 2007 /** 2008 * ID of admin who created the post. 2009 * 2010 * Applies to pages only 2011 * 2012 * @since 1.10.0 2013 */ 2014 @java.lang.SuppressWarnings("all") 2015 public void setAdminCreator(final NamedFacebookType adminCreator) { 2016 this.adminCreator = adminCreator; 2017 } 2018 2019 /** 2020 * Whether the post can be promoted on Instagram. 2021 * <p> 2022 * It returns the enum <code>eligible</code> if it can be promoted. Otherwise it returns an enum for why it cannot be 2023 * promoted 2024 * </p> 2025 * 2026 * @return Whether the post can be promoted on Instagram 2027 */ 2028 @java.lang.SuppressWarnings("all") 2029 public String getInstagramEligibility() { 2030 return this.instagramEligibility; 2031 } 2032 2033 /** 2034 * Whether the post can be promoted on Instagram. 2035 * <p> 2036 * It returns the enum <code>eligible</code> if it can be promoted. Otherwise it returns an enum for why it cannot be 2037 * promoted 2038 * </p> 2039 * 2040 */ 2041 @java.lang.SuppressWarnings("all") 2042 public void setInstagramEligibility(final String instagramEligibility) { 2043 this.instagramEligibility = instagramEligibility; 2044 } 2045 2046 /** 2047 * Whether or not the post references an app. 2048 * 2049 * @return Whether or not the post references an app 2050 */ 2051 @java.lang.SuppressWarnings("all") 2052 public Boolean getIsAppShare() { 2053 return this.isAppShare; 2054 } 2055 2056 /** 2057 * Whether or not the post references an app. 2058 */ 2059 @java.lang.SuppressWarnings("all") 2060 public void setIsAppShare(final Boolean isAppShare) { 2061 this.isAppShare = isAppShare; 2062 } 2063 2064 @java.lang.SuppressWarnings("all") 2065 public Boolean getIsEligibleForPromotion() { 2066 return this.isEligibleForPromotion; 2067 } 2068 2069 @java.lang.SuppressWarnings("all") 2070 public void setIsEligibleForPromotion(final Boolean isEligibleForPromotion) { 2071 this.isEligibleForPromotion = isEligibleForPromotion; 2072 } 2073 2074 /** 2075 * Whether the post has expiration time that has passed 2076 * 2077 * @return Whether the post has expiration time that has passed 2078 */ 2079 @java.lang.SuppressWarnings("all") 2080 public Boolean getIsExpired() { 2081 return this.isExpired; 2082 } 2083 2084 /** 2085 * Whether the post has expiration time that has passed 2086 */ 2087 @java.lang.SuppressWarnings("all") 2088 public void setIsExpired(final Boolean isExpired) { 2089 this.isExpired = isExpired; 2090 } 2091 2092 /** 2093 * If this post is marked as hidden (applies to Pages only). 2094 * 2095 * @since 1.10.0 2096 * @return if this post is marked as hidden 2097 */ 2098 @java.lang.SuppressWarnings("all") 2099 public Boolean getIsHidden() { 2100 return this.isHidden; 2101 } 2102 2103 /** 2104 * If this post is marked as hidden (applies to Pages only). 2105 * 2106 * @since 1.10.0 2107 */ 2108 @java.lang.SuppressWarnings("all") 2109 public void setIsHidden(final Boolean isHidden) { 2110 this.isHidden = isHidden; 2111 } 2112 2113 /** 2114 * Whether this post can be promoted in Instagram. 2115 * 2116 * @return Whether this post can be promoted in Instagram 2117 */ 2118 @java.lang.SuppressWarnings("all") 2119 public Boolean getIsInstagramEligible() { 2120 return this.isInstagramEligible; 2121 } 2122 2123 /** 2124 * Whether this post can be promoted in Instagram. 2125 */ 2126 @java.lang.SuppressWarnings("all") 2127 public void setIsInstagramEligible(final Boolean isInstagramEligible) { 2128 this.isInstagramEligible = isInstagramEligible; 2129 } 2130 2131 /** 2132 * Whether the post is currently popular. 2133 * 2134 * Based on whether the total actions as a percentage of reach exceeds a certain threshold 2135 * 2136 * @return Whether the post is currently popular 2137 */ 2138 @java.lang.SuppressWarnings("all") 2139 public Boolean getIsPopular() { 2140 return this.isPopular; 2141 } 2142 2143 /** 2144 * Whether the post is currently popular. 2145 * 2146 * Based on whether the total actions as a percentage of reach exceeds a certain threshold 2147 */ 2148 @java.lang.SuppressWarnings("all") 2149 public void setIsPopular(final Boolean isPopular) { 2150 this.isPopular = isPopular; 2151 } 2152 2153 /** 2154 * Indicates whether a scheduled post was published. (applies to scheduled Page Post only, for users post and 2155 * instantly published posts this value is always <code>true</code>) 2156 * 2157 * @since 1.10.0 2158 * @return indicates whether a scheduled post was published 2159 */ 2160 @java.lang.SuppressWarnings("all") 2161 public Boolean getIsPublished() { 2162 return this.isPublished; 2163 } 2164 2165 /** 2166 * Indicates whether a scheduled post was published. (applies to scheduled Page Post only, for users post and 2167 * instantly published posts this value is always <code>true</code>) 2168 * 2169 * @since 1.10.0 2170 */ 2171 @java.lang.SuppressWarnings("all") 2172 public void setIsPublished(final Boolean isPublished) { 2173 this.isPublished = isPublished; 2174 } 2175 2176 /** 2177 * Whether the post is a spherical video post. 2178 * 2179 * @return Whether the post is a spherical video post 2180 */ 2181 @java.lang.SuppressWarnings("all") 2182 public Boolean getIsSpherical() { 2183 return this.isSpherical; 2184 } 2185 2186 /** 2187 * Whether the post is a spherical video post. 2188 */ 2189 @java.lang.SuppressWarnings("all") 2190 public void setIsSpherical(final Boolean isSpherical) { 2191 this.isSpherical = isSpherical; 2192 } 2193 2194 /** 2195 * Whether display the end card for a multi-link share post 2196 */ 2197 @java.lang.SuppressWarnings("all") 2198 public Boolean getMultiShareEndCard() { 2199 return this.multiShareEndCard; 2200 } 2201 2202 /** 2203 * Whether display the end card for a multi-link share post 2204 */ 2205 @java.lang.SuppressWarnings("all") 2206 public void setMultiShareEndCard(final Boolean multiShareEndCard) { 2207 this.multiShareEndCard = multiShareEndCard; 2208 } 2209 2210 /** 2211 * Whether automatically select the order of the links in multi-link share post when used in an ad 2212 */ 2213 @java.lang.SuppressWarnings("all") 2214 public Boolean getMultiShareOptimized() { 2215 return this.multiShareOptimized; 2216 } 2217 2218 /** 2219 * Whether automatically select the order of the links in multi-link share post when used in an ad 2220 */ 2221 @java.lang.SuppressWarnings("all") 2222 public void setMultiShareOptimized(final Boolean multiShareOptimized) { 2223 this.multiShareOptimized = multiShareOptimized; 2224 } 2225 2226 /** 2227 * Attachments added to a post. 2228 * 2229 * To force Facebook to fill the <code>attachments</code> field you have to fetch the post with the 2230 * <code>fields=attachments</code> parameter, otherwise the attachments are <code>null</code>. 2231 * 2232 * @return Attachment on the post 2233 */ 2234 @java.lang.SuppressWarnings("all") 2235 public Attachments getAttachments() { 2236 return this.attachments; 2237 } 2238 2239 /** 2240 * Attachments added to a post. 2241 * 2242 * To force Facebook to fill the <code>attachments</code> field you have to fetch the post with the 2243 * <code>fields=attachments</code> parameter, otherwise the attachments are <code>null</code>. 2244 */ 2245 @java.lang.SuppressWarnings("all") 2246 public void setAttachments(final Attachments attachments) { 2247 this.attachments = attachments; 2248 } 2249 2250 /** 2251 * Full picture URL. 2252 * 2253 * you get the url to this posts full picture. 2254 * 2255 * To force Facebook to fill the <code>full_picture</code> field you have to fetch the post with the 2256 * <code>fields=full_picture</code> parameter, otherwise the full_picture is <code>null</code>. 2257 * 2258 * @return String representing the url to the post's full picture 2259 */ 2260 @java.lang.SuppressWarnings("all") 2261 public String getFullPicture() { 2262 return this.fullPicture; 2263 } 2264 2265 /** 2266 * Full picture URL. 2267 * 2268 * you get the url to this posts full picture. 2269 * 2270 * To force Facebook to fill the <code>full_picture</code> field you have to fetch the post with the 2271 * <code>fields=full_picture</code> parameter, otherwise the full_picture is <code>null</code>. 2272 * 2273 */ 2274 @java.lang.SuppressWarnings("all") 2275 public void setFullPicture(final String fullPicture) { 2276 this.fullPicture = fullPicture; 2277 } 2278 2279 /** 2280 * ID of the user or Page the post was shared from 2281 */ 2282 @java.lang.SuppressWarnings("all") 2283 public String getVia() { 2284 return this.via; 2285 } 2286 2287 /** 2288 * ID of the user or Page the post was shared from 2289 */ 2290 @java.lang.SuppressWarnings("all") 2291 public void setVia(final String via) { 2292 this.via = via; 2293 } 2294}