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 java.util.Date;
026import com.restfb.Facebook;
027import com.restfb.types.features.HasCreatedTime;
028
029/**
030 * Represents the <a href="https://developers.facebook.com/docs/graph-api/reference/v2.5/open-graph-rating/"> Open Graph
031 * Rating API type</a>.
032 *
033 * @author Alexander Nenkov
034 * @since 1.20.0
035 */
036public class OpenGraphRating extends FacebookType implements HasCreatedTime {
037  /**
038   * When the reviewer rated this object.
039   */
040  @Facebook("created_time")
041  private Date createdTime;
042  /**
043   * Was a rating included
044   */
045  @Facebook("has_rating")
046  private Boolean hasRating;
047  /**
048   * Was there text in the rating
049   */
050  @Facebook("has_review")
051  private Boolean hasReview;
052  /**
053   * Rating
054   */
055  @Facebook("rating")
056  private Integer rating;
057  /**
058   * Review text included in the review
059   */
060  @Facebook("review_text")
061  private String reviewText;
062  /**
063   * Person who rated the object
064   */
065  @Facebook("reviewer")
066  private User reviewer;
067  /**
068   * Recommendation field for change on August 17, 2018
069   * <p>
070   * for more information check here:
071   * <a href="https://www.facebook.com/business/recommendations">https://www.facebook.com/business/recommendations</a>
072   */
073  @Facebook("recommendation_type")
074  private RecommendationType recommendationType;
075  /**
076   * Open Graph story generated by the rating action
077   */
078  @Facebook("open_graph_story")
079  private PageRating openGraphStory;
080
081  /**
082   * If OpenGraphRating is a new recommendation
083   * 
084   * @return <code>true</code> if it is a recommendation, <code>false</code> if it's a rating
085   */
086  public boolean isRecommendation() {
087    return rating == null;
088  }
089
090  /**
091   * When the reviewer rated this object.
092   *
093   * @return When the reviewer rated this object.
094   */
095  @Override
096  @java.lang.SuppressWarnings("all")
097  public Date getCreatedTime() {
098    return this.createdTime;
099  }
100
101  /**
102   * When the reviewer rated this object.
103   */
104  @java.lang.SuppressWarnings("all")
105  public void setCreatedTime(final Date createdTime) {
106    this.createdTime = createdTime;
107  }
108
109  /**
110   * Was a rating included
111   *
112   * @return Was a rating included
113   */
114  @java.lang.SuppressWarnings("all")
115  public Boolean getHasRating() {
116    return this.hasRating;
117  }
118
119  /**
120   * Was a rating included
121   */
122  @java.lang.SuppressWarnings("all")
123  public void setHasRating(final Boolean hasRating) {
124    this.hasRating = hasRating;
125  }
126
127  /**
128   * Was there text in the rating
129   *
130   * @return Was there text in the rating
131   */
132  @java.lang.SuppressWarnings("all")
133  public Boolean getHasReview() {
134    return this.hasReview;
135  }
136
137  /**
138   * Was there text in the rating
139   */
140  @java.lang.SuppressWarnings("all")
141  public void setHasReview(final Boolean hasReview) {
142    this.hasReview = hasReview;
143  }
144
145  /**
146   * Rating
147   *
148   * @return Rating
149   */
150  @java.lang.SuppressWarnings("all")
151  public Integer getRating() {
152    return this.rating;
153  }
154
155  /**
156   * Rating
157   */
158  @java.lang.SuppressWarnings("all")
159  public void setRating(final Integer rating) {
160    this.rating = rating;
161  }
162
163  /**
164   * Review text included in the review
165   *
166   * @return Review text included in the review
167   */
168  @java.lang.SuppressWarnings("all")
169  public String getReviewText() {
170    return this.reviewText;
171  }
172
173  /**
174   * Review text included in the review
175   */
176  @java.lang.SuppressWarnings("all")
177  public void setReviewText(final String reviewText) {
178    this.reviewText = reviewText;
179  }
180
181  /**
182   * Person who rated the object
183   *
184   * @return Person who rated the object
185   */
186  @java.lang.SuppressWarnings("all")
187  public User getReviewer() {
188    return this.reviewer;
189  }
190
191  /**
192   * Person who rated the object
193   */
194  @java.lang.SuppressWarnings("all")
195  public void setReviewer(final User reviewer) {
196    this.reviewer = reviewer;
197  }
198
199  /**
200   * Recommendation field for change on August 17, 2018
201   * <p>
202   * for more information check here:
203   * <a href="https://www.facebook.com/business/recommendations">https://www.facebook.com/business/recommendations</a>
204   *
205   * @return the recommendation type
206   */
207  @java.lang.SuppressWarnings("all")
208  public RecommendationType getRecommendationType() {
209    return this.recommendationType;
210  }
211
212  /**
213   * Recommendation field for change on August 17, 2018
214   * <p>
215   * for more information check here:
216   * <a href="https://www.facebook.com/business/recommendations">https://www.facebook.com/business/recommendations</a>
217   */
218  @java.lang.SuppressWarnings("all")
219  public void setRecommendationType(final RecommendationType recommendationType) {
220    this.recommendationType = recommendationType;
221  }
222
223  /**
224   * Open Graph story generated by the rating action
225   *
226   * @return Open Graph story generated by the rating action
227   */
228  @java.lang.SuppressWarnings("all")
229  public PageRating getOpenGraphStory() {
230    return this.openGraphStory;
231  }
232
233  /**
234   * Open Graph story generated by the rating action
235   */
236  @java.lang.SuppressWarnings("all")
237  public void setOpenGraphStory(final PageRating openGraphStory) {
238    this.openGraphStory = openGraphStory;
239  }
240}