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

com.couchbase.client.java.manager.analytics.link.S3ExternalAnalyticsLink Maven / Gradle / Ivy

/*
 * Copyright 2021 Couchbase, Inc.
 *
 * 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.couchbase.client.java.manager.analytics.link;

import com.couchbase.client.core.annotation.SinceCouchbase;
import com.couchbase.client.core.deps.com.fasterxml.jackson.annotation.JsonProperty;

import static com.couchbase.client.core.deps.com.fasterxml.jackson.annotation.JsonProperty.Access.READ_ONLY;

/**
 * An analytics link to S3.
 * 

* Important: When creating a link to the Amazon S3 service, be sure to follow best practices for security. AWS root * account credentials should never be used. The policy for the created IAM User roles should be as strict as * possible and only allow access to the required data and required resources. You only need to know the Access * Key Id and the Secret Access Key for the created IAM User role to access the S3 service. The link will be * able to access whatever is permitted to the IAM User, since it will be using the IAM User credentials to * interact with the AWS S3 service. */ @SuppressWarnings("unused") @SinceCouchbase("7.0") public class S3ExternalAnalyticsLink extends AnalyticsLink { @JsonProperty private String accessKeyId; @JsonProperty(access = READ_ONLY) private String secretAccessKey; @JsonProperty(access = READ_ONLY) private String sessionToken; @JsonProperty private String region; @JsonProperty private String serviceEndpoint; /** * Creates a new Analytics Link to S3. *

* As an alternative to this constructor, {@link AnalyticsLink#s3(String, String)} can be used as well. *

* Please note that additional parameters are required and must be set on {@link S3ExternalAnalyticsLink} in order * for a S3 link to work properly. */ public S3ExternalAnalyticsLink(final String name, final String dataverse) { super(name, dataverse); } // For Jackson private S3ExternalAnalyticsLink() { super("", ""); } @Override public AnalyticsLinkType type() { return AnalyticsLinkType.S3_EXTERNAL; } /** * Returns the S3 access key ID. * * @return the S3 access key ID. */ public String accessKeyId() { return accessKeyId; } /** * Sets the S3 access key ID (required). * * @param accessKeyId the S3 access key ID. * @return this {@link S3ExternalAnalyticsLink} instance for chaining. */ public S3ExternalAnalyticsLink accessKeyId(final String accessKeyId) { this.accessKeyId = accessKeyId; return this; } /** * Returns the S3 secret access key. * * @return the S3 access key. */ public String secretAccessKey() { return secretAccessKey; } /** * Sets the S3 secret access key (required). * * @param secretAccessKey the S3 secret access key. * @return this {@link S3ExternalAnalyticsLink} instance for chaining. */ public S3ExternalAnalyticsLink secretAccessKey(final String secretAccessKey) { this.secretAccessKey = secretAccessKey; return this; } /** * Returns the S3 region. * * @return the S3 region. */ public String region() { return region; } /** * Sets the S3 region (required). * * @param region the S3 region. * @return this {@link S3ExternalAnalyticsLink} instance for chaining. */ public S3ExternalAnalyticsLink region(final String region) { this.region = region; return this; } /** * Returns the S3 service endpoint. * * @return the S3 service endpoint. */ public String serviceEndpoint() { return serviceEndpoint; } /** * Sets the S3 service endpoint. * * @param serviceEndpoint the service endpoint. * @return this {@link S3ExternalAnalyticsLink} instance for chaining. */ public S3ExternalAnalyticsLink serviceEndpoint(final String serviceEndpoint) { this.serviceEndpoint = serviceEndpoint; return this; } /** * Returns the S3 session token. * * @return the S3 session token. */ public String sessionToken() { return sessionToken; } /** * Sets the S3 session token. * * @param sessionToken the S3 session token. * @return this {@link S3ExternalAnalyticsLink} instance for chaining. */ public S3ExternalAnalyticsLink sessionToken(final String sessionToken) { this.sessionToken = sessionToken; return this; } @Override public String toString() { return "S3ExternalAnalyticsLink{" + "dataverse='" + dataverse() + '\'' + ", name='" + name() + '\'' + ", accessKeyId='" + accessKeyId + '\'' + ", hasSecretAccessKey=" + (secretAccessKey != null) + ", hasSessionToken=" + (sessionToken != null) + ", region='" + region + '\'' + ", serviceEndpoint='" + serviceEndpoint + '\'' + '}'; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy