org.dromara.jpom.oauth2.platform.MaxKeyOauth2Config Maven / Gradle / Ivy
/*
* Copyright (c) 2019 Of Him Code Technology Studio
* Jpom is licensed under Mulan PSL v2.
* You can use this software according to the terms and conditions of the Mulan PSL v2.
* You may obtain a copy of Mulan PSL v2 at:
* http://license.coscl.org.cn/MulanPSL2
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT, MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
* See the Mulan PSL v2 for more details.
*/
package org.dromara.jpom.oauth2.platform;
import cn.hutool.core.lang.RegexPool;
import cn.hutool.core.lang.Validator;
import cn.hutool.core.util.StrUtil;
import lombok.Data;
import lombok.EqualsAndHashCode;
import me.zhyd.oauth.request.AuthRequest;
import org.dromara.jpom.common.i18n.I18nMessageUtil;
import org.dromara.jpom.oauth2.AuthOauth2MaxKeyRequest;
import org.dromara.jpom.oauth2.BaseOauth2Config;
import org.dromara.jpom.oauth2.Oauth2MaxKeyAuthSource;
import org.springframework.util.Assert;
/**
* @author bwcx_jzy
* @since 2023/3/26
*/
@EqualsAndHashCode(callSuper = true)
@Data
public class MaxKeyOauth2Config extends BaseOauth2Config {
public static final String KEY = "OAUTH_CONFIG_CUSTOM_OAUTH2";
private String authorizationUri;
private String accessTokenUri;
private String userInfoUri;
/**
* 验证数据
*/
public void check() {
super.check();
Validator.validateMatchRegex(RegexPool.URL_HTTP, this.authorizationUri, I18nMessageUtil.get("i18n.configure_correct_auth_url.22e7"));
Validator.validateMatchRegex(RegexPool.URL_HTTP, this.accessTokenUri, I18nMessageUtil.get("i18n.configure_correct_token_url.7bba"));
Validator.validateMatchRegex(RegexPool.URL_HTTP, this.userInfoUri, I18nMessageUtil.get("i18n.configure_correct_user_info_url.1276"));
}
@Override
public String provide() {
return "maxkey";
}
public AuthRequest authRequest() {
Assert.state(this.enabled(), StrUtil.format(I18nMessageUtil.get("i18n.oauth2_not_enabled.c8b7"), this.provide()));
Oauth2MaxKeyAuthSource oauth2MaxKeyAuthSource = new Oauth2MaxKeyAuthSource(this);
return new AuthOauth2MaxKeyRequest(this.authConfig(), oauth2MaxKeyAuthSource);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy