travel.wink.sdk.channel.manager.model.PageProperty Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of channel-manager-sdk-java Show documentation
Show all versions of channel-manager-sdk-java Show documentation
Java SDK for the channel manager integrators wanting to communicate with the Wink Travel Platform.
The newest version!
/*
* Wink API
* ## APIs Not every integrator needs every APIs. For that reason, we have separated APIs into context. - [Affiliate](/affiliate): All APIs related to selling travel inventory as an affiliate. - [Analytics](/analytics): All APIs related to tracking metrics across a wide variety of data source segments including, more entertaining, leaderboard metrics. - [Booking](/booking): All APIs related to creating platform bookings. - [Channel Manager](/channel-manager): All APIs related to channel managers who want to integrate with our platform. - [Extranet](/extranet): All APIs related to managing travel inventory and suppliers. - [Inventory](/inventory): All APIs related to retrieve known travel inventory as it was found using the Lookup API.. - [Lookup](/lookup): All APIs related to locating inventory by region, locale and property flags. - [Reference](/reference): All APIs related to retrieving platform-supported taxonomies. - [TripPay](/payment): All APIs related to TripPay account management, booking, mapping and integration features. ## SDKs We are actively working on supporting the most used languages out there. If you don't see your language here, reach out to us with a request to officially add your language. In the meantime, if you want to roll your own SDK, you can do so by downloading the OpenAPI spec and using one of the many available OpenAPI generators available: [https://openapi-generator.tech/docs/generators](https://openapi-generator.tech/docs/generators). - Java SDK [https://github.com/wink-travel/wink-sdk-java](https://github.com/wink-travel/wink-sdk-java) ## Usage These features are made available to you via a [REST API](https://en.wikipedia.org/wiki/Representational_state_transfer). This API is language agnostic. ## Versioning We chose to version our endpoints in a way that we hope affects your integration with us the least. You request the version of our API you wish to work with via the `Wink-Version` header. When it's time for you to upgrade, you only have to change the version number to get access to our updated endpoints. ## Release history - Follow updates on Github: https://github.com/wink-travel/wink-sdk-java/blob/master/CHANGELOG.md # Channel Manager API Wink exposes a secured REST-based, JSON API to its channel manager partners. The connection is \"channel-wide\". Partners are free to integrate with the REST-based API using any programming language. # Intended Audience This document is intended for external channel partners who wish to integrate with Wink. # Requirements - Active account with Wink. Sign up for your Channel Manager account: - Staging: [https://staging-studio.wink.travel](https://staging-studio.wink.travel). - Production: [https://studio.wink.travel](https://studio.wink.travel). - Active application. An application provides you with Oauth2 credentials you can pass to our endpoints. One is already created for you upon account creation. - Your production IP numbers. They need to be whitelisted before you can talk to our production environment. # Performance A particular attention to performance should be given when integrating with this API. A few things to be aware of: - Enable gzip compression to make payloads smaller. - Fewer large REST calls are preferred to many small ones. E.g. It is better to update many dates instead of individual dates. - It is possible to update both rate and availability with a single request. - Request only date ranges that you will use. There is no need to request an entire year if you will only be working with the first seven days. ## Reservation notification (PUSH) Wink supports PUSH notifications to communicate reservations. We also support BASIC AUTH to your endpoint. If you want to enable PUSH, add your PUSH endpoint and credentials (optional) to your account.
*
* The version of the OpenAPI document: 30.5.13
* Contact: [email protected]
*
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
* https://openapi-generator.tech
* Do not edit the class manually.
*/
package travel.wink.sdk.channel.manager.model;
import java.util.Objects;
import java.util.Arrays;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonTypeName;
import com.fasterxml.jackson.annotation.JsonValue;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import travel.wink.sdk.channel.manager.model.PageableObject;
import travel.wink.sdk.channel.manager.model.Property;
import travel.wink.sdk.channel.manager.model.SortObject;
import com.fasterxml.jackson.annotation.JsonPropertyOrder;
import com.fasterxml.jackson.annotation.JsonTypeName;
import jakarta.validation.constraints.*;
import jakarta.validation.Valid;
import org.hibernate.validator.constraints.*;
/**
* PageProperty
*/
@JsonPropertyOrder({
PageProperty.JSON_PROPERTY_TOTAL_ELEMENTS,
PageProperty.JSON_PROPERTY_TOTAL_PAGES,
PageProperty.JSON_PROPERTY_SIZE,
PageProperty.JSON_PROPERTY_CONTENT,
PageProperty.JSON_PROPERTY_NUMBER,
PageProperty.JSON_PROPERTY_SORT,
PageProperty.JSON_PROPERTY_NUMBER_OF_ELEMENTS,
PageProperty.JSON_PROPERTY_PAGEABLE,
PageProperty.JSON_PROPERTY_FIRST,
PageProperty.JSON_PROPERTY_LAST,
PageProperty.JSON_PROPERTY_EMPTY
})
@jakarta.annotation.Generated(value = "org.openapitools.codegen.languages.JavaClientCodegen", date = "2024-10-04T20:21:48.540278877+07:00[Asia/Bangkok]")
public class PageProperty {
public static final String JSON_PROPERTY_TOTAL_ELEMENTS = "totalElements";
private Long totalElements;
public static final String JSON_PROPERTY_TOTAL_PAGES = "totalPages";
private Integer totalPages;
public static final String JSON_PROPERTY_SIZE = "size";
private Integer size;
public static final String JSON_PROPERTY_CONTENT = "content";
private List content;
public static final String JSON_PROPERTY_NUMBER = "number";
private Integer number;
public static final String JSON_PROPERTY_SORT = "sort";
private List sort;
public static final String JSON_PROPERTY_NUMBER_OF_ELEMENTS = "numberOfElements";
private Integer numberOfElements;
public static final String JSON_PROPERTY_PAGEABLE = "pageable";
private PageableObject pageable;
public static final String JSON_PROPERTY_FIRST = "first";
private Boolean first;
public static final String JSON_PROPERTY_LAST = "last";
private Boolean last;
public static final String JSON_PROPERTY_EMPTY = "empty";
private Boolean empty;
public PageProperty() {
}
public PageProperty totalElements(Long totalElements) {
this.totalElements = totalElements;
return this;
}
/**
* Get totalElements
* @return totalElements
**/
@jakarta.annotation.Nullable
@JsonProperty(JSON_PROPERTY_TOTAL_ELEMENTS)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public Long getTotalElements() {
return totalElements;
}
@JsonProperty(JSON_PROPERTY_TOTAL_ELEMENTS)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public void setTotalElements(Long totalElements) {
this.totalElements = totalElements;
}
public PageProperty totalPages(Integer totalPages) {
this.totalPages = totalPages;
return this;
}
/**
* Get totalPages
* @return totalPages
**/
@jakarta.annotation.Nullable
@JsonProperty(JSON_PROPERTY_TOTAL_PAGES)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public Integer getTotalPages() {
return totalPages;
}
@JsonProperty(JSON_PROPERTY_TOTAL_PAGES)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public void setTotalPages(Integer totalPages) {
this.totalPages = totalPages;
}
public PageProperty size(Integer size) {
this.size = size;
return this;
}
/**
* Get size
* @return size
**/
@jakarta.annotation.Nullable
@JsonProperty(JSON_PROPERTY_SIZE)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public Integer getSize() {
return size;
}
@JsonProperty(JSON_PROPERTY_SIZE)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public void setSize(Integer size) {
this.size = size;
}
public PageProperty content(List content) {
this.content = content;
return this;
}
public PageProperty addContentItem(Property contentItem) {
if (this.content == null) {
this.content = new ArrayList<>();
}
this.content.add(contentItem);
return this;
}
/**
* Get content
* @return content
**/
@jakarta.annotation.Nullable
@Valid
@JsonProperty(JSON_PROPERTY_CONTENT)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public List getContent() {
return content;
}
@JsonProperty(JSON_PROPERTY_CONTENT)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public void setContent(List content) {
this.content = content;
}
public PageProperty number(Integer number) {
this.number = number;
return this;
}
/**
* Get number
* @return number
**/
@jakarta.annotation.Nullable
@JsonProperty(JSON_PROPERTY_NUMBER)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public Integer getNumber() {
return number;
}
@JsonProperty(JSON_PROPERTY_NUMBER)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public void setNumber(Integer number) {
this.number = number;
}
public PageProperty sort(List sort) {
this.sort = sort;
return this;
}
public PageProperty addSortItem(SortObject sortItem) {
if (this.sort == null) {
this.sort = new ArrayList<>();
}
this.sort.add(sortItem);
return this;
}
/**
* Get sort
* @return sort
**/
@jakarta.annotation.Nullable
@Valid
@JsonProperty(JSON_PROPERTY_SORT)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public List getSort() {
return sort;
}
@JsonProperty(JSON_PROPERTY_SORT)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public void setSort(List sort) {
this.sort = sort;
}
public PageProperty numberOfElements(Integer numberOfElements) {
this.numberOfElements = numberOfElements;
return this;
}
/**
* Get numberOfElements
* @return numberOfElements
**/
@jakarta.annotation.Nullable
@JsonProperty(JSON_PROPERTY_NUMBER_OF_ELEMENTS)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public Integer getNumberOfElements() {
return numberOfElements;
}
@JsonProperty(JSON_PROPERTY_NUMBER_OF_ELEMENTS)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public void setNumberOfElements(Integer numberOfElements) {
this.numberOfElements = numberOfElements;
}
public PageProperty pageable(PageableObject pageable) {
this.pageable = pageable;
return this;
}
/**
* Get pageable
* @return pageable
**/
@jakarta.annotation.Nullable
@Valid
@JsonProperty(JSON_PROPERTY_PAGEABLE)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public PageableObject getPageable() {
return pageable;
}
@JsonProperty(JSON_PROPERTY_PAGEABLE)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public void setPageable(PageableObject pageable) {
this.pageable = pageable;
}
public PageProperty first(Boolean first) {
this.first = first;
return this;
}
/**
* Get first
* @return first
**/
@jakarta.annotation.Nullable
@JsonProperty(JSON_PROPERTY_FIRST)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public Boolean getFirst() {
return first;
}
@JsonProperty(JSON_PROPERTY_FIRST)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public void setFirst(Boolean first) {
this.first = first;
}
public PageProperty last(Boolean last) {
this.last = last;
return this;
}
/**
* Get last
* @return last
**/
@jakarta.annotation.Nullable
@JsonProperty(JSON_PROPERTY_LAST)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public Boolean getLast() {
return last;
}
@JsonProperty(JSON_PROPERTY_LAST)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public void setLast(Boolean last) {
this.last = last;
}
public PageProperty empty(Boolean empty) {
this.empty = empty;
return this;
}
/**
* Get empty
* @return empty
**/
@jakarta.annotation.Nullable
@JsonProperty(JSON_PROPERTY_EMPTY)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public Boolean getEmpty() {
return empty;
}
@JsonProperty(JSON_PROPERTY_EMPTY)
@JsonInclude(value = JsonInclude.Include.USE_DEFAULTS)
public void setEmpty(Boolean empty) {
this.empty = empty;
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
PageProperty pageProperty = (PageProperty) o;
return Objects.equals(this.totalElements, pageProperty.totalElements) &&
Objects.equals(this.totalPages, pageProperty.totalPages) &&
Objects.equals(this.size, pageProperty.size) &&
Objects.equals(this.content, pageProperty.content) &&
Objects.equals(this.number, pageProperty.number) &&
Objects.equals(this.sort, pageProperty.sort) &&
Objects.equals(this.numberOfElements, pageProperty.numberOfElements) &&
Objects.equals(this.pageable, pageProperty.pageable) &&
Objects.equals(this.first, pageProperty.first) &&
Objects.equals(this.last, pageProperty.last) &&
Objects.equals(this.empty, pageProperty.empty);
}
@Override
public int hashCode() {
return Objects.hash(totalElements, totalPages, size, content, number, sort, numberOfElements, pageable, first, last, empty);
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("class PageProperty {\n");
sb.append(" totalElements: ").append(toIndentedString(totalElements)).append("\n");
sb.append(" totalPages: ").append(toIndentedString(totalPages)).append("\n");
sb.append(" size: ").append(toIndentedString(size)).append("\n");
sb.append(" content: ").append(toIndentedString(content)).append("\n");
sb.append(" number: ").append(toIndentedString(number)).append("\n");
sb.append(" sort: ").append(toIndentedString(sort)).append("\n");
sb.append(" numberOfElements: ").append(toIndentedString(numberOfElements)).append("\n");
sb.append(" pageable: ").append(toIndentedString(pageable)).append("\n");
sb.append(" first: ").append(toIndentedString(first)).append("\n");
sb.append(" last: ").append(toIndentedString(last)).append("\n");
sb.append(" empty: ").append(toIndentedString(empty)).append("\n");
sb.append("}");
return sb.toString();
}
/**
* Convert the given object to string with each line indented by 4 spaces
* (except the first line).
*/
private String toIndentedString(Object o) {
if (o == null) {
return "null";
}
return o.toString().replace("\n", "\n ");
}
}