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

net.java.truelicense.core.V1Encryption Maven / Gradle / Ivy

/*
 * Copyright (C) 2005-2017 Schlichtherle IT Services.
 * All rights reserved. Use is subject to license terms.
 */

package net.java.truelicense.core;

import java.io.*;
import java.security.spec.AlgorithmParameterSpec;
import java.util.concurrent.Callable;
import javax.annotation.concurrent.Immutable;
import javax.crypto.*;
import static javax.crypto.Cipher.*;
import javax.crypto.spec.*;
import net.java.truelicense.core.crypto.*;
import net.java.truelicense.core.io.*;
import net.java.truelicense.obfuscate.Obfuscate;

/**
 * The encryption for V1 format license keys.
 *
 * @author Christian Schlichtherle
 */
@Immutable
final class V1Encryption extends BasicPbeEncryption {

    @Obfuscate private static final String PBE_ALGORITHM = "PBEWithMD5andDES";

    @Obfuscate
    private static final String
            ILLEGAL_PBE_ALGORITHM = "V1 format license keys require the " + PBE_ALGORITHM + " algorithm.";

    V1Encryption(final PbeParameters pbe) {
        super(pbe);
        if (!PBE_ALGORITHM.equalsIgnoreCase(pbe.algorithm()))
            throw new IllegalArgumentException(ILLEGAL_PBE_ALGORITHM);
    }

    @Override public Sink apply(final Sink sink) {
        return new Sink() {
            @Override public OutputStream output() throws IOException {
                return wrap(new Callable() {
                    @Override public OutputStream call() throws Exception {
                        final Cipher cipher = cipher(true);
                        return new CipherOutputStream(sink.output(), cipher);
                    }
                });
            }
        };
    }

    @Override public Source unapply(final Source source) {
        return new Source() {
            @Override public InputStream input() throws IOException {
                return wrap(new Callable() {
                    @Override public InputStream call() throws Exception {
                        final Cipher cipher = cipher(false);
                        return new CipherInputStream(source.input(), cipher);
                    }
                });
            }
        };
    }

    private Cipher cipher(final boolean encrypt) throws Exception {
        // Hard coded in TrueLicense V1.
        final AlgorithmParameterSpec spec = new PBEParameterSpec(
                new byte[] {
                    (byte) 0xce, (byte) 0xfb, (byte) 0xde, (byte) 0xac,
                    (byte) 0x05, (byte) 0x02, (byte) 0x19, (byte) 0x71
                },
                2005);
        final Cipher cipher = getInstance(algorithm());
        cipher.init(encrypt ? ENCRYPT_MODE : DECRYPT_MODE, secretKey(), spec);
        return cipher;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy