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

com.neilalexander.jnacl.NaCl Maven / Gradle / Ivy

//
//  Copyright (c) 2011, Neil Alexander T.
//  All rights reserved.
// 
//  Redistribution and use in source and binary forms, with
//  or without modification, are permitted provided that the following
//  conditions are met:
// 
//  - Redistributions of source code must retain the above copyright notice,
//    this list of conditions and the following disclaimer.
//  - Redistributions in binary form must reproduce the above copyright notice,
//    this list of conditions and the following disclaimer in the documentation
//    and/or other materials provided with the distribution.
// 
//  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
//  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
//  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
//  ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
//  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
//  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
//  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
//  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
//  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
//  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
//  POSSIBILITY OF SUCH DAMAGE.
//

package com.neilalexander.jnacl;

import com.neilalexander.jnacl.crypto.curve25519xsalsa20poly1305;

import java.util.Formatter;

public class NaCl {
  static final int crypto_secretbox_KEYBYTES = 32;
  static final int crypto_secretbox_NONCEBYTES = 24;
  static final int crypto_secretbox_ZEROBYTES = 32;
  static final int crypto_secretbox_BOXZEROBYTES = 16;
  static final int crypto_secretbox_BEFORENMBYTES = 32;

  private byte[] precomputed = new byte[crypto_secretbox_BEFORENMBYTES];

  public NaCl(byte[] privatekey, byte[] publickey) throws Exception {
    if (privatekey.length < crypto_secretbox_KEYBYTES)
      throw new Exception("Private key too short");

    if (publickey.length < crypto_secretbox_KEYBYTES)
      throw new Exception("Public key too short");

    curve25519xsalsa20poly1305.crypto_box_beforenm(this.precomputed, publickey, privatekey);
  }

  public NaCl(String privatekey, String publickey) throws Exception {
    this(getBinary(privatekey), getBinary(publickey));
  }

  public byte[] encrypt(byte[] input, byte[] nonce) {
    return encrypt(input, input.length, nonce);
  }

  public byte[] encrypt(byte[] input, int inputlength, byte[] nonce) {
    byte[] paddedinput = new byte[inputlength + crypto_secretbox_ZEROBYTES];
    byte[] output = new byte[inputlength + crypto_secretbox_ZEROBYTES];

    System.arraycopy(input, 0, paddedinput, crypto_secretbox_ZEROBYTES, inputlength);
    curve25519xsalsa20poly1305.crypto_box_afternm(output, paddedinput, paddedinput.length, nonce, this.precomputed);

    return output;
  }

  public byte[] decrypt(byte[] input, byte[] nonce) {
    return decrypt(input, input.length, nonce);
  }

  public byte[] decrypt(byte[] input, int inputlength, byte[] nonce) {
    byte[] paddedoutput = new byte[inputlength];
    byte[] output = new byte[inputlength - crypto_secretbox_ZEROBYTES];

    curve25519xsalsa20poly1305.crypto_box_open_afternm(paddedoutput, input, inputlength, nonce, this.precomputed);
    System.arraycopy(paddedoutput, crypto_secretbox_ZEROBYTES, output, 0, paddedoutput.length - crypto_secretbox_ZEROBYTES);

    return output;
  }

  public static byte[] getBinary(String s) {
    int len = s.length();
    byte[] data = new byte[len / 2];

    for (int i = 0; i < len; i += 2)
      data[i / 2] = (byte) ((Character.digit(s.charAt(i), 16) << 4) + Character.digit(s.charAt(i + 1), 16));

    return data;
  }

  public static String asHex(byte[] buf) {
    Formatter formatter = new Formatter();
    for (byte b : buf)
      formatter.format("%02x", b);
    return formatter.toString();
  }

  public static String asHex(int[] buf) {
    Formatter formatter = new Formatter();
    for (int b : buf)
      formatter.format("%02x", b);
    return formatter.toString();
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy