All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.ibole.infrastructure.security.jwt.JwtProvider Maven / Gradle / Ivy

The newest version!
package com.github.ibole.infrastructure.security.jwt;

import com.github.ibole.infrastructure.cache.redis.RedisSimpleTempalte;
import com.github.ibole.infrastructure.common.exception.ProviderNotFoundException;

import java.util.ServiceLoader;

/*********************************************************************************************
 * .
 * 
 * 
 * 

* Copyright 2016, iBole Inc. All rights reserved. * *

*

*********************************************************************************************/ /** * @author bwang ([email protected]) * */ public abstract class JwtProvider { private static final JwtProvider provider = load(Thread.currentThread().getContextClassLoader()); static final JwtProvider load(ClassLoader cl) { ServiceLoader providers = ServiceLoader.load(JwtProvider.class, cl); JwtProvider best = null; for (JwtProvider current : providers) { if (!current.isAvailable()) { continue; } else if (best == null) { best = current; } else if (current.priority() > best.priority()) { best = current; } } return best; } /** * Whether this provider is available for use, taking the current environment into consideration. * If {@code false}, no other methods are safe to be called. */ protected abstract boolean isAvailable(); /** * A priority, from 0 to 10 that this provider should be used, taking the current environment into * consideration. 5 should be considered the default, and then tweaked based on environment * detection. A priority of 0 does not imply that the provider wouldn't work; just that it should * be last in line. */ protected abstract int priority(); /** * Returns the ClassLoader-wide default server. * * @throws ProviderNotFoundException if no provider is available */ public static JwtProvider provider() { if (provider == null) { throw new ProviderNotFoundException( "No functional server found. " + "Try adding a dependency on the rpc framework artifact"); } return provider; } public abstract TokenAuthenticator createTokenGenerator(RedisSimpleTempalte redisTemplate); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy