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

com.google.crypto.tink.daead.AesSivParameters Maven / Gradle / Ivy

Go to download

Tink is a small cryptographic library that provides a safe, simple, agile and fast way to accomplish some common cryptographic tasks.

There is a newer version: 1.16.0
Show newest version
// Copyright 2023 Google LLC
//
// 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 com.google.crypto.tink.daead;

import com.google.errorprone.annotations.CanIgnoreReturnValue;
import com.google.errorprone.annotations.Immutable;
import java.security.GeneralSecurityException;
import java.security.InvalidAlgorithmParameterException;
import java.util.Objects;
import javax.annotation.Nullable;

/** Describes the parameters of an {@link AesSivSivKey} */
public final class AesSivParameters extends DeterministicAeadParameters {
  /** Enum-like class which describes how the prefix is computed. */
  @Immutable
  public static final class Variant {
    public static final Variant TINK = new Variant("TINK");
    public static final Variant CRUNCHY = new Variant("CRUNCHY");
    public static final Variant NO_PREFIX = new Variant("NO_PREFIX");

    private final String name;

    private Variant(String name) {
      this.name = name;
    }

    @Override
    public String toString() {
      return name;
    }
  }

  /** Builds a new AesSivParameters instance. */
  public static final class Builder {
    @Nullable private Integer keySizeBytes = null;
    private Variant variant = Variant.NO_PREFIX;

    private Builder() {}

    /**
     * Accepts key sizes of 32, 48 or 64 bytes.
     *
     * 

Note that some Tink configurations reject key sizes 32 and 48 bytes. */ @CanIgnoreReturnValue public Builder setKeySizeBytes(int keySizeBytes) throws GeneralSecurityException { if (keySizeBytes != 32 && keySizeBytes != 48 && keySizeBytes != 64) { throw new InvalidAlgorithmParameterException( String.format( "Invalid key size %d; only 32-byte, 48-byte and 64-byte AES-SIV keys are supported", keySizeBytes)); } this.keySizeBytes = keySizeBytes; return this; } @CanIgnoreReturnValue public Builder setVariant(Variant variant) { this.variant = variant; return this; } public AesSivParameters build() throws GeneralSecurityException { if (keySizeBytes == null) { throw new GeneralSecurityException("Key size is not set"); } if (variant == null) { throw new GeneralSecurityException("Variant is not set"); } return new AesSivParameters(keySizeBytes, variant); } } private final int keySizeBytes; private final Variant variant; private AesSivParameters(int keySizeBytes, Variant variant) { this.keySizeBytes = keySizeBytes; this.variant = variant; } public static Builder builder() { return new Builder(); } public int getKeySizeBytes() { return keySizeBytes; } /** Returns a variant object. */ public Variant getVariant() { return variant; } @Override public boolean equals(Object o) { if (!(o instanceof AesSivParameters)) { return false; } AesSivParameters that = (AesSivParameters) o; return that.getKeySizeBytes() == getKeySizeBytes() && that.getVariant() == getVariant(); } @Override public int hashCode() { return Objects.hash(AesSivParameters.class, keySizeBytes, variant); } @Override public boolean hasIdRequirement() { return variant != Variant.NO_PREFIX; } @Override public String toString() { return "AesSiv Parameters (variant: " + variant + ", " + keySizeBytes + "-byte key)"; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy