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

be.atbash.ee.security.octopus.nimbus.jose.PlainObject Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2017-2022 Rudy De Busscher (https://www.atbash.be)
 *
 * 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 be.atbash.ee.security.octopus.nimbus.jose;


import be.atbash.ee.security.octopus.nimbus.util.Base64URLValue;

import java.text.ParseException;


/**
 * Unsecured (plain / {@code alg=none}) JOSE object. This class is thread-safe.
 *
 * Based on code by Vladimir Dzhuvinov
 */
public class PlainObject extends JOSEObject {


    /**
     * The header.
     */
    private final PlainHeader header;


    /**
     * Creates a new unsecured JOSE object with a default {@link
     * PlainHeader} and the specified payload.
     *
     * @param payload The payload. Must not be {@code null}.
     */
    public PlainObject(Payload payload) {

        if (payload == null) {
            throw new IllegalArgumentException("The payload must not be null");
        }

        setPayload(payload);

        header = new PlainHeader();
    }


    /**
     * Creates a new unsecured JOSE object with the specified header and
     * payload.
     *
     * @param header  The unsecured header. Must not be {@code null}.
     * @param payload The payload. Must not be {@code null}.
     */
    public PlainObject(PlainHeader header, Payload payload) {

        if (header == null) {

            throw new IllegalArgumentException("The unsecured header must not be null");
        }

        this.header = header;

        if (payload == null) {

            throw new IllegalArgumentException("The payload must not be null");
        }

        setPayload(payload);
    }


    /**
     * Creates a new unsecured JOSE object with the specified
     * Base64URL-encoded parts.
     *
     * @param firstPart  The first part, corresponding to the unsecured
     *                   header. Must not be {@code null}.
     * @param secondPart The second part, corresponding to the payload.
     *                   Must not be {@code null}.
     * @throws ParseException If parsing of the serialised parts failed.
     */
    public PlainObject(Base64URLValue firstPart, Base64URLValue secondPart)
            throws ParseException {

        if (firstPart == null) {

            throw new IllegalArgumentException("The first part must not be null");
        }

        try {
            header = PlainHeader.parse(firstPart);

        } catch (ParseException e) {

            throw new ParseException("Invalid unsecured header: " + e.getMessage(), 0);
        }

        if (secondPart == null) {

            throw new IllegalArgumentException("The second part must not be null");
        }

        setPayload(new Payload(secondPart));

        setParsedParts(firstPart, secondPart, null);
    }


    @Override
    public PlainHeader getHeader() {

        return header;
    }


    /**
     * Serialises this unsecured JOSE object to its compact format
     * consisting of Base64URL-encoded parts delimited by period ('.')
     * characters.
     *
     * 
     * [header-base64url].[payload-base64url].[]
     * 
* * @return The serialised unsecured JOSE object. */ @Override public String serialize() { return header.toBase64URL().toString() + '.' + getPayload().toBase64URL().toString() + '.'; } /** * Parses an unsecured JOSE object from the specified string in compact * format. * * @param value The string to parse. Must not be {@code null}. * @return The unsecured JOSE object. * @throws ParseException If the string couldn't be parsed to a valid * unsecured JOSE object. */ public static PlainObject parse(String value) throws ParseException { Base64URLValue[] parts = JOSEObject.split(value); if (!parts[2].toString().isEmpty()) { throw new ParseException("Unexpected third Base64URL part", 0); } return new PlainObject(parts[0], parts[1]); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy