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

com.google.cloud.storage.HmacKey Maven / Gradle / Ivy

There is a newer version: 2.45.0
Show newest version
/*
 * Copyright 2019 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.cloud.storage;

import static com.google.cloud.storage.BackwardCompatibilityUtils.millisOffsetDateTimeCodec;

import java.io.Serializable;
import java.time.OffsetDateTime;
import java.util.Objects;

/** HMAC key for a service account. */
public class HmacKey implements Serializable {

  private static final long serialVersionUID = 3033393659217005187L;
  private final String secretKey;
  private final HmacKeyMetadata metadata;

  private HmacKey(Builder builder) {
    this.secretKey = builder.secretKey;
    this.metadata = builder.metadata;
  }

  public static Builder newBuilder(String secretKey) {
    return new Builder(secretKey);
  }

  /** Builder for {@code HmacKey} objects. * */
  public static class Builder {
    private String secretKey;
    private HmacKeyMetadata metadata;

    private Builder(String secretKey) {
      this.secretKey = secretKey;
    }

    public Builder setSecretKey(String secretKey) {
      this.secretKey = secretKey;
      return this;
    }

    public Builder setMetadata(HmacKeyMetadata metadata) {
      this.metadata = metadata;
      return this;
    }

    /** Creates an {@code HmacKey} object from this builder. * */
    public HmacKey build() {
      return new HmacKey(this);
    }
  }

  /** Returns the secret key associated with this HMAC key. * */
  public String getSecretKey() {
    return secretKey;
  }

  /** Returns the metadata associated with this HMAC key. * */
  public HmacKeyMetadata getMetadata() {
    return metadata;
  }

  @Override
  public int hashCode() {
    return Objects.hash(secretKey, metadata);
  }

  @Override
  public boolean equals(Object o) {
    if (this == o) {
      return true;
    }
    if (!(o instanceof HmacKey)) {
      return false;
    }
    HmacKey hmacKey = (HmacKey) o;
    return Objects.equals(secretKey, hmacKey.secretKey)
        && Objects.equals(metadata, hmacKey.metadata);
  }

  public enum HmacKeyState {
    ACTIVE("ACTIVE"),
    INACTIVE("INACTIVE"),
    DELETED("DELETED");

    private final String state;

    HmacKeyState(String state) {
      this.state = state;
    }
  }

  /**
   * The metadata for a service account HMAC key. This class holds all data associated with an HMAC
   * key other than the secret key.
   */
  public static class HmacKeyMetadata implements Serializable {

    private static final long serialVersionUID = 9130344756739042314L;
    private final String accessId;
    private final String etag;
    private final String id;
    private final String projectId;
    private final ServiceAccount serviceAccount;
    private final HmacKeyState state;
    private final OffsetDateTime createTime;
    private final OffsetDateTime updateTime;

    private HmacKeyMetadata(Builder builder) {
      this.accessId = builder.accessId;
      this.etag = builder.etag;
      this.id = builder.id;
      this.projectId = builder.projectId;
      this.serviceAccount = builder.serviceAccount;
      this.state = builder.state;
      this.createTime = builder.createTime;
      this.updateTime = builder.updateTime;
    }

    public static Builder newBuilder(ServiceAccount serviceAccount) {
      return new Builder(serviceAccount);
    }

    public Builder toBuilder() {
      return new Builder(this);
    }

    public static HmacKeyMetadata of(
        ServiceAccount serviceAccount, String accessId, String projectId) {
      return newBuilder(serviceAccount).setAccessId(accessId).setProjectId(projectId).build();
    }

    @Override
    public int hashCode() {
      return Objects.hash(accessId, projectId);
    }

    @Override
    public boolean equals(Object obj) {
      if (this == obj) {
        return true;
      }
      if (obj == null || getClass() != obj.getClass()) {
        return false;
      }
      final HmacKeyMetadata other = (HmacKeyMetadata) obj;
      return Objects.equals(this.accessId, other.accessId)
          && Objects.equals(this.etag, other.etag)
          && Objects.equals(this.id, other.id)
          && Objects.equals(this.projectId, other.projectId)
          && Objects.equals(this.serviceAccount, other.serviceAccount)
          && Objects.equals(this.state, other.state)
          && Objects.equals(this.createTime, other.createTime)
          && Objects.equals(this.updateTime, other.updateTime);
    }

    /**
     * Returns the access id for this HMAC key. This is the id needed to get or delete the key. *
     */
    public String getAccessId() {
      return accessId;
    }

    /**
     * Returns HTTP 1.1 Entity tag for this HMAC key.
     *
     * @see Entity Tags
     */
    public String getEtag() {
      return etag;
    }

    /** Returns the resource name of this HMAC key. * */
    public String getId() {
      return id;
    }

    /** Returns the project id associated with this HMAC key. * */
    public String getProjectId() {
      return projectId;
    }

    /** Returns the service account associated with this HMAC key. * */
    public ServiceAccount getServiceAccount() {
      return serviceAccount;
    }

    /** Returns the current state of this HMAC key. * */
    public HmacKeyState getState() {
      return state;
    }

    /**
     * Returns the creation time of this HMAC key.
     *
     * @deprecated Use {@link #getCreateTimeOffsetDateTime()}
     */
    @Deprecated
    public Long getCreateTime() {
      return millisOffsetDateTimeCodec.decode(createTime);
    }

    /** Returns the creation time of this HMAC key. * */
    public OffsetDateTime getCreateTimeOffsetDateTime() {
      return createTime;
    }

    /**
     * Returns the last updated time of this HMAC key.
     *
     * @deprecated Use {@link #getUpdateTimeOffsetDateTime()}
     */
    @Deprecated
    public Long getUpdateTime() {
      return millisOffsetDateTimeCodec.decode(updateTime);
    }

    /** Returns the last updated time of this HMAC key. * */
    public OffsetDateTime getUpdateTimeOffsetDateTime() {
      return updateTime;
    }

    /** Builder for {@code HmacKeyMetadata} objects. * */
    public static class Builder {
      private String accessId;
      private String etag;
      private String id;
      private String projectId;
      private ServiceAccount serviceAccount;
      private HmacKeyState state;
      private OffsetDateTime createTime;
      private OffsetDateTime updateTime;

      private Builder(ServiceAccount serviceAccount) {
        this.serviceAccount = serviceAccount;
      }

      private Builder(HmacKeyMetadata metadata) {
        this.accessId = metadata.accessId;
        this.etag = metadata.etag;
        this.id = metadata.id;
        this.projectId = metadata.projectId;
        this.serviceAccount = metadata.serviceAccount;
        this.state = metadata.state;
        this.createTime = metadata.createTime;
        this.updateTime = metadata.updateTime;
      }

      public Builder setAccessId(String accessId) {
        this.accessId = accessId;
        return this;
      }

      public Builder setEtag(String etag) {
        this.etag = etag;
        return this;
      }

      public Builder setId(String id) {
        this.id = id;
        return this;
      }

      public Builder setServiceAccount(ServiceAccount serviceAccount) {
        this.serviceAccount = serviceAccount;
        return this;
      }

      public Builder setState(HmacKeyState state) {
        this.state = state;
        return this;
      }

      /** @deprecated Use {@link #setCreateTimeOffsetDateTime(OffsetDateTime)} */
      @Deprecated
      public Builder setCreateTime(long createTime) {
        return setCreateTimeOffsetDateTime(millisOffsetDateTimeCodec.encode(createTime));
      }

      public Builder setCreateTimeOffsetDateTime(OffsetDateTime createTime) {
        this.createTime = createTime;
        return this;
      }

      public Builder setProjectId(String projectId) {
        this.projectId = projectId;
        return this;
      }

      /** Creates an {@code HmacKeyMetadata} object from this builder. * */
      public HmacKeyMetadata build() {
        return new HmacKeyMetadata(this);
      }

      /** @deprecated Use {@link #setUpdateTimeOffsetDateTime(OffsetDateTime)} */
      @Deprecated
      public Builder setUpdateTime(long updateTime) {
        return setUpdateTimeOffsetDateTime(millisOffsetDateTimeCodec.encode(updateTime));
      }

      public Builder setUpdateTimeOffsetDateTime(OffsetDateTime updateTime) {
        this.updateTime = updateTime;
        return this;
      }
    }
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy