net.leanix.dropkit.apiclient.auth.responses.AccessTokenResponse Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of leanix-synclog-sdk-java Show documentation
Show all versions of leanix-synclog-sdk-java Show documentation
SDK for Java to access LeanIX Synclog REST API
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package net.leanix.dropkit.apiclient.auth.responses;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonProperty;
import javax.xml.bind.annotation.XmlRootElement;
import java.util.Date;
/**
* Bean representation of a Access Token response. See this
* section of the spec for more info.
*
*/
@XmlRootElement
@JsonInclude(JsonInclude.Include.NON_NULL)
@JsonIgnoreProperties(ignoreUnknown = true)
public class AccessTokenResponse {
@JsonProperty("access_token")
private String accessToken;
@JsonProperty("token_type")
private String tokenType;
@JsonProperty("expires_in")
private long expiresIn;
@JsonProperty("refresh_token")
private String refreshToken;
private String scope;
/**
* Token needs to be at least 60 sec valid, otherwise it is considered expired
*/
private static int LEAD_TIME = 60;
@JsonIgnore
private Date expires;
public AccessTokenResponse() {
super();
}
public AccessTokenResponse(String accessToken, String tokenType, long expiresIn, String refreshToken, String scope) {
super();
this.accessToken = accessToken;
this.tokenType = tokenType;
this.expiresIn = expiresIn;
this.refreshToken = refreshToken;
this.scope = scope;
this.calcExpires();
}
public void calcExpires() {
this.expires = new Date(System.currentTimeMillis() + (this.expiresIn * 1000));
}
public Date getExpires() {
return this.expires;
}
public boolean isExpired() {
return (this.expires.getTime() - (LEAD_TIME * 1000)) < System.currentTimeMillis();
}
/**
* @return the accessToken
*/
public String getAccessToken() {
return accessToken;
}
/**
* @param accessToken the accessToken to set
*/
public void setAccessToken(String accessToken) {
this.accessToken = accessToken;
}
/**
* @return the tokenType
*/
public String getTokenType() {
return tokenType;
}
/**
* @param tokenType the tokenType to set
*/
public void setTokenType(String tokenType) {
this.tokenType = tokenType;
}
/**
* @return the expiresIn
*/
public long getExpiresIn() {
return expiresIn;
}
/**
* @param expiresIn the expiresIn to set
*/
public void setExpiresIn(long expiresIn) {
this.expiresIn = expiresIn;
this.calcExpires();
}
/**
* @return the refreshToken
*/
public String getRefreshToken() {
return refreshToken;
}
/**
* @param refreshToken the refreshToken to set
*/
public void setRefreshToken(String refreshToken) {
this.refreshToken = refreshToken;
}
/**
* @return the scope
*/
public String getScope() {
return scope;
}
/**
* @param scope the scope to set
*/
public void setScope(String scope) {
this.scope = scope;
}
/* (non-Javadoc)
* @see java.lang.Object#toString()
*/
@Override
public String toString() {
return "AccessTokenResponse [accessToken=" + accessToken + ", tokenType=" + tokenType + ", expiresIn=" + expiresIn
+ ", refreshToken=" + refreshToken + ", scope=" + scope + "]";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy