
cn.dev33.satoken.oauth2.config.SaOAuth2Config Maven / Gradle / Ivy
package cn.dev33.satoken.oauth2.config;
import cn.dev33.satoken.util.SaResult;
import java.io.Serializable;
import java.util.function.BiFunction;
import java.util.function.Supplier;
/**
* Sa-Token-OAuth2 配置类 Model
* @author kong
*
*/
public class SaOAuth2Config implements Serializable {
private static final long serialVersionUID = -6541180061782004705L;
/** 是否打开模式:授权码(Authorization Code) */
public Boolean isCode = true;
/** 是否打开模式:隐藏式(Implicit) */
public Boolean isImplicit = false;
/** 是否打开模式:密码式(Password) */
public Boolean isPassword = false;
/** 是否打开模式:凭证式(Client Credentials) */
public Boolean isClient = false;
/** 是否在每次 Refresh-Token 刷新 Access-Token 时,产生一个新的 Refresh-Token */
public Boolean isNewRefresh = false;
/** Code授权码 保存的时间(单位:秒) 默认五分钟 */
public long codeTimeout = 60 * 5;
/** Access-Token 保存的时间(单位:秒) 默认两个小时 */
public long accessTokenTimeout = 60 * 60 * 2;
/** Refresh-Token 保存的时间(单位:秒) 默认30 天 */
public long refreshTokenTimeout = 60 * 60 * 24 * 30;
/** Client-Token 保存的时间(单位:秒) 默认两个小时 */
public long clientTokenTimeout = 60 * 60 * 2;
/** Past-Client-Token 保存的时间(单位:秒) 默认为 -1,代表延续 Client-Token有效期 */
public long pastClientTokenTimeout = -1;
/**
* @return isCode
*/
public Boolean getIsCode() {
return isCode;
}
/**
* @param isCode 要设置的 isCode
*/
public void setIsCode(Boolean isCode) {
this.isCode = isCode;
}
/**
* @return isImplicit
*/
public Boolean getIsImplicit() {
return isImplicit;
}
/**
* @param isImplicit 要设置的 isImplicit
*/
public void setIsImplicit(Boolean isImplicit) {
this.isImplicit = isImplicit;
}
/**
* @return isPassword
*/
public Boolean getIsPassword() {
return isPassword;
}
/**
* @param isPassword 要设置的 isPassword
*/
public void setIsPassword(Boolean isPassword) {
this.isPassword = isPassword;
}
/**
* @return isClient
*/
public Boolean getIsClient() {
return isClient;
}
/**
* @param isClient 要设置的 isClient
*/
public void setIsClient(Boolean isClient) {
this.isClient = isClient;
}
/**
* @return isNewRefresh
*/
public Boolean getIsNewRefresh() {
return isNewRefresh;
}
/**
* @param isNewRefresh 要设置的 isNewRefresh
*/
public void setIsNewRefresh(Boolean isNewRefresh) {
this.isNewRefresh = isNewRefresh;
}
/**
* @return codeTimeout
*/
public long getCodeTimeout() {
return codeTimeout;
}
/**
* @param codeTimeout 要设置的 codeTimeout
* @return 对象自身
*/
public SaOAuth2Config setCodeTimeout(long codeTimeout) {
this.codeTimeout = codeTimeout;
return this;
}
/**
* @return accessTokenTimeout
*/
public long getAccessTokenTimeout() {
return accessTokenTimeout;
}
/**
* @param accessTokenTimeout 要设置的 accessTokenTimeout
* @return 对象自身
*/
public SaOAuth2Config setAccessTokenTimeout(long accessTokenTimeout) {
this.accessTokenTimeout = accessTokenTimeout;
return this;
}
/**
* @return refreshTokenTimeout
*/
public long getRefreshTokenTimeout() {
return refreshTokenTimeout;
}
/**
* @param refreshTokenTimeout 要设置的 refreshTokenTimeout
* @return 对象自身
*/
public SaOAuth2Config setRefreshTokenTimeout(long refreshTokenTimeout) {
this.refreshTokenTimeout = refreshTokenTimeout;
return this;
}
/**
* @return clientTokenTimeout
*/
public long getClientTokenTimeout() {
return clientTokenTimeout;
}
/**
* @param clientTokenTimeout 要设置的 clientTokenTimeout
* @return 对象自身
*/
public SaOAuth2Config setClientTokenTimeout(long clientTokenTimeout) {
this.clientTokenTimeout = clientTokenTimeout;
return this;
}
/**
* @return pastClientTokenTimeout
*/
public long getPastClientTokenTimeout() {
return pastClientTokenTimeout;
}
/**
* @param pastClientTokenTimeout 要设置的 pastClientTokenTimeout
* @return 对象自身
*/
public SaOAuth2Config setPastClientTokenTimeout(long pastClientTokenTimeout) {
this.pastClientTokenTimeout = pastClientTokenTimeout;
return this;
}
// -------------------- SaOAuth2Handle 所有回调函数 --------------------
/**
* OAuth-Server端:未登录时返回的View
*/
public Supplier
© 2015 - 2025 Weber Informatics LLC | Privacy Policy