001// Generated by delombok at Fri Dec 27 11:33:38 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.ads; 024 025import java.util.ArrayList; 026import java.util.Collections; 027import java.util.Date; 028import java.util.List; 029import com.restfb.Facebook; 030import com.restfb.types.features.HasCreatedTime; 031 032/** 033 * Represents the <a href="https://developers.facebook.com/docs/marketing-api/reference/ad-image">AdGroup Image type</a> 034 */ 035public class AdImage extends NamedAdsObject implements HasCreatedTime { 036 private static final long serialVersionUID = 1L; 037 /** 038 * The ad account that owns the image 039 */ 040 @Facebook("account_id") 041 private String accountId; 042 /** 043 * The hash which uniquely identifies the image. 044 */ 045 @Facebook 046 private String hash; 047 /** 048 * A temporary URL which the image can be retrieved at. NOTE: do not use this URL in ad creative creation 049 */ 050 @Facebook 051 private String url; 052 /** 053 * A temporary URL pointing to a version of the image resized to fit withing a 128x128 pixel box 054 */ 055 @Facebook("url_128") 056 private String url128; 057 /** 058 * A permanent URL of the image to use in story creatives. 059 */ 060 @Facebook("permalink_url") 061 private String permalinkUrl; 062 /** 063 * The width of the image. 064 */ 065 @Facebook 066 private String width; 067 /** 068 * The height of the image. 069 */ 070 @Facebook 071 private String height; 072 /** 073 * The width of the image that was originally uploaded. 074 */ 075 @Facebook("original_width") 076 private String originalWidth; 077 /** 078 * The height of the image that was originally uploaded. 079 */ 080 @Facebook("original_height") 081 private String originalHeight; 082 /** 083 * Status of the image 084 */ 085 @Facebook 086 private String status; 087 /** 088 * Time the image was created 089 */ 090 @Facebook("created_time") 091 private Date createdTime; 092 /** 093 * Time the image was updated 094 */ 095 @Facebook("updated_time") 096 private Date updatedTime; 097 private final List<AdCreative> creatives = new ArrayList<>(); 098 099 public boolean addCreative(AdCreative creative) { 100 return creatives.add(creative); 101 } 102 103 public boolean removeCreative(AdCreative creative) { 104 return creatives.remove(creative); 105 } 106 107 /** 108 * A list of ad creative IDs that this ad image is being used in. 109 * 110 * @return A list of ad creative IDs that this ad image is being used in 111 */ 112 public List<AdCreative> getCreatives() { 113 return Collections.unmodifiableList(creatives); 114 } 115 116 /** 117 * The ad account that owns the image 118 */ 119 @java.lang.SuppressWarnings("all") 120 public String getAccountId() { 121 return this.accountId; 122 } 123 124 /** 125 * The ad account that owns the image 126 */ 127 @java.lang.SuppressWarnings("all") 128 public void setAccountId(final String accountId) { 129 this.accountId = accountId; 130 } 131 132 /** 133 * The hash which uniquely identifies the image. 134 */ 135 @java.lang.SuppressWarnings("all") 136 public String getHash() { 137 return this.hash; 138 } 139 140 /** 141 * The hash which uniquely identifies the image. 142 */ 143 @java.lang.SuppressWarnings("all") 144 public void setHash(final String hash) { 145 this.hash = hash; 146 } 147 148 /** 149 * A temporary URL which the image can be retrieved at. NOTE: do not use this URL in ad creative creation 150 */ 151 @java.lang.SuppressWarnings("all") 152 public String getUrl() { 153 return this.url; 154 } 155 156 /** 157 * A temporary URL which the image can be retrieved at. NOTE: do not use this URL in ad creative creation 158 */ 159 @java.lang.SuppressWarnings("all") 160 public void setUrl(final String url) { 161 this.url = url; 162 } 163 164 /** 165 * A temporary URL pointing to a version of the image resized to fit withing a 128x128 pixel box 166 */ 167 @java.lang.SuppressWarnings("all") 168 public String getUrl128() { 169 return this.url128; 170 } 171 172 /** 173 * A temporary URL pointing to a version of the image resized to fit withing a 128x128 pixel box 174 */ 175 @java.lang.SuppressWarnings("all") 176 public void setUrl128(final String url128) { 177 this.url128 = url128; 178 } 179 180 /** 181 * A permanent URL of the image to use in story creatives. 182 */ 183 @java.lang.SuppressWarnings("all") 184 public String getPermalinkUrl() { 185 return this.permalinkUrl; 186 } 187 188 /** 189 * A permanent URL of the image to use in story creatives. 190 */ 191 @java.lang.SuppressWarnings("all") 192 public void setPermalinkUrl(final String permalinkUrl) { 193 this.permalinkUrl = permalinkUrl; 194 } 195 196 /** 197 * The width of the image. 198 */ 199 @java.lang.SuppressWarnings("all") 200 public String getWidth() { 201 return this.width; 202 } 203 204 /** 205 * The width of the image. 206 */ 207 @java.lang.SuppressWarnings("all") 208 public void setWidth(final String width) { 209 this.width = width; 210 } 211 212 /** 213 * The height of the image. 214 */ 215 @java.lang.SuppressWarnings("all") 216 public String getHeight() { 217 return this.height; 218 } 219 220 /** 221 * The height of the image. 222 */ 223 @java.lang.SuppressWarnings("all") 224 public void setHeight(final String height) { 225 this.height = height; 226 } 227 228 /** 229 * The width of the image that was originally uploaded. 230 */ 231 @java.lang.SuppressWarnings("all") 232 public String getOriginalWidth() { 233 return this.originalWidth; 234 } 235 236 /** 237 * The width of the image that was originally uploaded. 238 */ 239 @java.lang.SuppressWarnings("all") 240 public void setOriginalWidth(final String originalWidth) { 241 this.originalWidth = originalWidth; 242 } 243 244 /** 245 * The height of the image that was originally uploaded. 246 */ 247 @java.lang.SuppressWarnings("all") 248 public String getOriginalHeight() { 249 return this.originalHeight; 250 } 251 252 /** 253 * The height of the image that was originally uploaded. 254 */ 255 @java.lang.SuppressWarnings("all") 256 public void setOriginalHeight(final String originalHeight) { 257 this.originalHeight = originalHeight; 258 } 259 260 /** 261 * Status of the image 262 */ 263 @java.lang.SuppressWarnings("all") 264 public String getStatus() { 265 return this.status; 266 } 267 268 /** 269 * Status of the image 270 */ 271 @java.lang.SuppressWarnings("all") 272 public void setStatus(final String status) { 273 this.status = status; 274 } 275 276 /** 277 * Time the image was created 278 */ 279 @Override 280 @java.lang.SuppressWarnings("all") 281 public Date getCreatedTime() { 282 return this.createdTime; 283 } 284 285 /** 286 * Time the image was created 287 */ 288 @java.lang.SuppressWarnings("all") 289 public void setCreatedTime(final Date createdTime) { 290 this.createdTime = createdTime; 291 } 292 293 /** 294 * Time the image was updated 295 */ 296 @java.lang.SuppressWarnings("all") 297 public Date getUpdatedTime() { 298 return this.updatedTime; 299 } 300 301 /** 302 * Time the image was updated 303 */ 304 @java.lang.SuppressWarnings("all") 305 public void setUpdatedTime(final Date updatedTime) { 306 this.updatedTime = updatedTime; 307 } 308}