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

org.soulwing.jwt.api.JWS Maven / Gradle / Ivy

/*
 * File created on Mar 8, 2019
 *
 * Copyright (c) 2019 Carl Harris, Jr
 * and others as noted
 *
 * Licensed 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 org.soulwing.jwt.api;

import java.util.Arrays;

import org.soulwing.jwt.api.exceptions.JWTConfigurationException;
import org.soulwing.jwt.api.exceptions.JWTSignatureException;

/**
 * A JSON Web Signature operator.
 * 

* Using the builder interface, a user of this API creates an object that can * be used to sign payloads (creating a JWS in Compact Serialization encoding) * and/or to validate a JWS in Compact Serialization encoding and obtain the * encapsulated payload. *

* An instance returned by the builder can be used for multiple, possibly * concurrent signing and/or validation operations. * * @author Carl Harris */ @SuppressWarnings("unused") public interface JWS { /** * An enumeration of standard algorithms for signatures */ enum Algorithm { none, HS256, HS384, HS512, RS256, RS384, RS512, ES256, ES384, ES512, PS256, PS384, PS512; public String toToken() { return name(); } public static JWS.Algorithm of(String token) { return Arrays.stream(values()) .filter(v -> v.toToken().equals(token)) .findFirst() .orElseThrow(() -> new IllegalArgumentException( "unrecognized algorithm name: `" + token + "`")); } } /** * A builder for a JSON Web Signature operator. */ interface Builder { /** * Sets the key provider to use to obtain keys for signature or validation * operations. * @param keyProvider key provider * @return this builder */ Builder keyProvider(KeyProvider keyProvider); /** * Sets the algorithm to use for signature generation of validation. * @param algorithm algorithm * @return this builder */ Builder algorithm(Algorithm algorithm); /** * Creates a JSON Web Signature operator using the configuration of this * builder. * @return signature operator * @throws JWTConfigurationException if an error occurs in creating the * signature operator */ JWS build() throws JWTConfigurationException; } /** * Creates a signed Compact Serialization of a JWS using the given payload. * @param payload payload * @return signed JWS object * @throws JWTSignatureException if an exception occurs in creating the * signature */ String sign(String payload) throws JWTSignatureException; /** * Verifies the signature and extracts the encapsulated payload of a JWS. * @param encoded signed JWS in Compact Serialization encoding * @return payload encapsulated in the source JWS * @throws JWTSignatureException if the signature is invalid or an error * occurs in trying to validate it */ String verify(String encoded) throws JWTSignatureException; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy