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

software.amazon.awssdk.services.mediapackage.model.SpekeKeyProvider Maven / Gradle / Ivy

Go to download

The AWS Java SDK for AWS Elemental MediaPackage module holds the client classes that are used for communicating with AWS Elemental MediaPackage Service

There is a newer version: 2.29.39
Show newest version
/*
 * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
 * the License. A copy of the License is located at
 * 
 * http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file 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 software.amazon.awssdk.services.mediapackage.model;

import java.io.Serializable;
import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.function.BiConsumer;
import java.util.function.Consumer;
import java.util.function.Function;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.core.SdkField;
import software.amazon.awssdk.core.SdkPojo;
import software.amazon.awssdk.core.protocol.MarshallLocation;
import software.amazon.awssdk.core.protocol.MarshallingType;
import software.amazon.awssdk.core.traits.ListTrait;
import software.amazon.awssdk.core.traits.LocationTrait;
import software.amazon.awssdk.core.util.DefaultSdkAutoConstructList;
import software.amazon.awssdk.core.util.SdkAutoConstructList;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;

/**
 * A configuration for accessing an external Secure Packager and Encoder Key Exchange (SPEKE) service that will provide
 * encryption keys.
 */
@Generated("software.amazon.awssdk:codegen")
public final class SpekeKeyProvider implements SdkPojo, Serializable,
        ToCopyableBuilder {
    private static final SdkField CERTIFICATE_ARN_FIELD = SdkField. builder(MarshallingType.STRING)
            .memberName("CertificateArn").getter(getter(SpekeKeyProvider::certificateArn))
            .setter(setter(Builder::certificateArn))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("certificateArn").build()).build();

    private static final SdkField ENCRYPTION_CONTRACT_CONFIGURATION_FIELD = SdkField
            . builder(MarshallingType.SDK_POJO)
            .memberName("EncryptionContractConfiguration")
            .getter(getter(SpekeKeyProvider::encryptionContractConfiguration))
            .setter(setter(Builder::encryptionContractConfiguration))
            .constructor(EncryptionContractConfiguration::builder)
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("encryptionContractConfiguration")
                    .build()).build();

    private static final SdkField RESOURCE_ID_FIELD = SdkField. builder(MarshallingType.STRING)
            .memberName("ResourceId").getter(getter(SpekeKeyProvider::resourceId)).setter(setter(Builder::resourceId))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("resourceId").build()).build();

    private static final SdkField ROLE_ARN_FIELD = SdkField. builder(MarshallingType.STRING)
            .memberName("RoleArn").getter(getter(SpekeKeyProvider::roleArn)).setter(setter(Builder::roleArn))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("roleArn").build()).build();

    private static final SdkField> SYSTEM_IDS_FIELD = SdkField
            .> builder(MarshallingType.LIST)
            .memberName("SystemIds")
            .getter(getter(SpekeKeyProvider::systemIds))
            .setter(setter(Builder::systemIds))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("systemIds").build(),
                    ListTrait
                            .builder()
                            .memberLocationName(null)
                            .memberFieldInfo(
                                    SdkField. builder(MarshallingType.STRING)
                                            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD)
                                                    .locationName("member").build()).build()).build()).build();

    private static final SdkField URL_FIELD = SdkField. builder(MarshallingType.STRING).memberName("Url")
            .getter(getter(SpekeKeyProvider::url)).setter(setter(Builder::url))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("url").build()).build();

    private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(CERTIFICATE_ARN_FIELD,
            ENCRYPTION_CONTRACT_CONFIGURATION_FIELD, RESOURCE_ID_FIELD, ROLE_ARN_FIELD, SYSTEM_IDS_FIELD, URL_FIELD));

    private static final long serialVersionUID = 1L;

    private final String certificateArn;

    private final EncryptionContractConfiguration encryptionContractConfiguration;

    private final String resourceId;

    private final String roleArn;

    private final List systemIds;

    private final String url;

    private SpekeKeyProvider(BuilderImpl builder) {
        this.certificateArn = builder.certificateArn;
        this.encryptionContractConfiguration = builder.encryptionContractConfiguration;
        this.resourceId = builder.resourceId;
        this.roleArn = builder.roleArn;
        this.systemIds = builder.systemIds;
        this.url = builder.url;
    }

    /**
     * An Amazon Resource Name (ARN) of a Certificate Manager certificate that MediaPackage will use for enforcing
     * secure end-to-end data transfer with the key provider service.
     *
     * @return An Amazon Resource Name (ARN) of a Certificate Manager certificate that MediaPackage will use for
     *         enforcing secure end-to-end data transfer with the key provider service.
     */
    public final String certificateArn() {
        return certificateArn;
    }

    /**
     * Returns the value of the EncryptionContractConfiguration property for this object.
     * 
     * @return The value of the EncryptionContractConfiguration property for this object.
     */
    public final EncryptionContractConfiguration encryptionContractConfiguration() {
        return encryptionContractConfiguration;
    }

    /**
     * The resource ID to include in key requests.
     * 
     * @return The resource ID to include in key requests.
     */
    public final String resourceId() {
        return resourceId;
    }

    /**
     * An Amazon Resource Name (ARN) of an IAM role that AWS Elemental MediaPackage will assume when accessing the key
     * provider service.
     *
     * @return An Amazon Resource Name (ARN) of an IAM role that AWS Elemental MediaPackage will assume when accessing
     *         the key provider service.
     */
    public final String roleArn() {
        return roleArn;
    }

    /**
     * For responses, this returns true if the service returned a value for the SystemIds property. This DOES NOT check
     * that the value is non-empty (for which, you should check the {@code isEmpty()} method on the property). This is
     * useful because the SDK will never return a null collection or map, but you may need to differentiate between the
     * service returning nothing (or null) and the service returning an empty collection or map. For requests, this
     * returns true if a value for the property was specified in the request builder, and false if a value was not
     * specified.
     */
    public final boolean hasSystemIds() {
        return systemIds != null && !(systemIds instanceof SdkAutoConstructList);
    }

    /**
     * The system IDs to include in key requests.
     * 

* Attempts to modify the collection returned by this method will result in an UnsupportedOperationException. *

*

* This method will never return null. If you would like to know whether the service returned this field (so that * you can differentiate between null and empty), you can use the {@link #hasSystemIds} method. *

* * @return The system IDs to include in key requests. */ public final List systemIds() { return systemIds; } /** * The URL of the external key provider service. * * @return The URL of the external key provider service. */ public final String url() { return url; } @Override public Builder toBuilder() { return new BuilderImpl(this); } public static Builder builder() { return new BuilderImpl(); } public static Class serializableBuilderClass() { return BuilderImpl.class; } @Override public final int hashCode() { int hashCode = 1; hashCode = 31 * hashCode + Objects.hashCode(certificateArn()); hashCode = 31 * hashCode + Objects.hashCode(encryptionContractConfiguration()); hashCode = 31 * hashCode + Objects.hashCode(resourceId()); hashCode = 31 * hashCode + Objects.hashCode(roleArn()); hashCode = 31 * hashCode + Objects.hashCode(hasSystemIds() ? systemIds() : null); hashCode = 31 * hashCode + Objects.hashCode(url()); return hashCode; } @Override public final boolean equals(Object obj) { return equalsBySdkFields(obj); } @Override public final boolean equalsBySdkFields(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (!(obj instanceof SpekeKeyProvider)) { return false; } SpekeKeyProvider other = (SpekeKeyProvider) obj; return Objects.equals(certificateArn(), other.certificateArn()) && Objects.equals(encryptionContractConfiguration(), other.encryptionContractConfiguration()) && Objects.equals(resourceId(), other.resourceId()) && Objects.equals(roleArn(), other.roleArn()) && hasSystemIds() == other.hasSystemIds() && Objects.equals(systemIds(), other.systemIds()) && Objects.equals(url(), other.url()); } /** * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be * redacted from this string using a placeholder value. */ @Override public final String toString() { return ToString.builder("SpekeKeyProvider").add("CertificateArn", certificateArn()) .add("EncryptionContractConfiguration", encryptionContractConfiguration()).add("ResourceId", resourceId()) .add("RoleArn", roleArn()).add("SystemIds", hasSystemIds() ? systemIds() : null).add("Url", url()).build(); } public final Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "CertificateArn": return Optional.ofNullable(clazz.cast(certificateArn())); case "EncryptionContractConfiguration": return Optional.ofNullable(clazz.cast(encryptionContractConfiguration())); case "ResourceId": return Optional.ofNullable(clazz.cast(resourceId())); case "RoleArn": return Optional.ofNullable(clazz.cast(roleArn())); case "SystemIds": return Optional.ofNullable(clazz.cast(systemIds())); case "Url": return Optional.ofNullable(clazz.cast(url())); default: return Optional.empty(); } } @Override public final List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((SpekeKeyProvider) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends SdkPojo, CopyableBuilder { /** * An Amazon Resource Name (ARN) of a Certificate Manager certificate that MediaPackage will use for enforcing * secure end-to-end data transfer with the key provider service. * * @param certificateArn * An Amazon Resource Name (ARN) of a Certificate Manager certificate that MediaPackage will use for * enforcing secure end-to-end data transfer with the key provider service. * @return Returns a reference to this object so that method calls can be chained together. */ Builder certificateArn(String certificateArn); /** * Sets the value of the EncryptionContractConfiguration property for this object. * * @param encryptionContractConfiguration * The new value for the EncryptionContractConfiguration property for this object. * @return Returns a reference to this object so that method calls can be chained together. */ Builder encryptionContractConfiguration(EncryptionContractConfiguration encryptionContractConfiguration); /** * Sets the value of the EncryptionContractConfiguration property for this object. * * This is a convenience method that creates an instance of the {@link EncryptionContractConfiguration.Builder} * avoiding the need to create one manually via {@link EncryptionContractConfiguration#builder()}. * *

* When the {@link Consumer} completes, {@link EncryptionContractConfiguration.Builder#build()} is called * immediately and its result is passed to * {@link #encryptionContractConfiguration(EncryptionContractConfiguration)}. * * @param encryptionContractConfiguration * a consumer that will call methods on {@link EncryptionContractConfiguration.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #encryptionContractConfiguration(EncryptionContractConfiguration) */ default Builder encryptionContractConfiguration( Consumer encryptionContractConfiguration) { return encryptionContractConfiguration(EncryptionContractConfiguration.builder() .applyMutation(encryptionContractConfiguration).build()); } /** * The resource ID to include in key requests. * * @param resourceId * The resource ID to include in key requests. * @return Returns a reference to this object so that method calls can be chained together. */ Builder resourceId(String resourceId); /** * An Amazon Resource Name (ARN) of an IAM role that AWS Elemental MediaPackage will assume when accessing the * key provider service. * * @param roleArn * An Amazon Resource Name (ARN) of an IAM role that AWS Elemental MediaPackage will assume when * accessing the key provider service. * @return Returns a reference to this object so that method calls can be chained together. */ Builder roleArn(String roleArn); /** * The system IDs to include in key requests. * * @param systemIds * The system IDs to include in key requests. * @return Returns a reference to this object so that method calls can be chained together. */ Builder systemIds(Collection systemIds); /** * The system IDs to include in key requests. * * @param systemIds * The system IDs to include in key requests. * @return Returns a reference to this object so that method calls can be chained together. */ Builder systemIds(String... systemIds); /** * The URL of the external key provider service. * * @param url * The URL of the external key provider service. * @return Returns a reference to this object so that method calls can be chained together. */ Builder url(String url); } static final class BuilderImpl implements Builder { private String certificateArn; private EncryptionContractConfiguration encryptionContractConfiguration; private String resourceId; private String roleArn; private List systemIds = DefaultSdkAutoConstructList.getInstance(); private String url; private BuilderImpl() { } private BuilderImpl(SpekeKeyProvider model) { certificateArn(model.certificateArn); encryptionContractConfiguration(model.encryptionContractConfiguration); resourceId(model.resourceId); roleArn(model.roleArn); systemIds(model.systemIds); url(model.url); } public final String getCertificateArn() { return certificateArn; } public final void setCertificateArn(String certificateArn) { this.certificateArn = certificateArn; } @Override public final Builder certificateArn(String certificateArn) { this.certificateArn = certificateArn; return this; } public final EncryptionContractConfiguration.Builder getEncryptionContractConfiguration() { return encryptionContractConfiguration != null ? encryptionContractConfiguration.toBuilder() : null; } public final void setEncryptionContractConfiguration( EncryptionContractConfiguration.BuilderImpl encryptionContractConfiguration) { this.encryptionContractConfiguration = encryptionContractConfiguration != null ? encryptionContractConfiguration .build() : null; } @Override public final Builder encryptionContractConfiguration(EncryptionContractConfiguration encryptionContractConfiguration) { this.encryptionContractConfiguration = encryptionContractConfiguration; return this; } public final String getResourceId() { return resourceId; } public final void setResourceId(String resourceId) { this.resourceId = resourceId; } @Override public final Builder resourceId(String resourceId) { this.resourceId = resourceId; return this; } public final String getRoleArn() { return roleArn; } public final void setRoleArn(String roleArn) { this.roleArn = roleArn; } @Override public final Builder roleArn(String roleArn) { this.roleArn = roleArn; return this; } public final Collection getSystemIds() { if (systemIds instanceof SdkAutoConstructList) { return null; } return systemIds; } public final void setSystemIds(Collection systemIds) { this.systemIds = ___listOf__stringCopier.copy(systemIds); } @Override public final Builder systemIds(Collection systemIds) { this.systemIds = ___listOf__stringCopier.copy(systemIds); return this; } @Override @SafeVarargs public final Builder systemIds(String... systemIds) { systemIds(Arrays.asList(systemIds)); return this; } public final String getUrl() { return url; } public final void setUrl(String url) { this.url = url; } @Override public final Builder url(String url) { this.url = url; return this; } @Override public SpekeKeyProvider build() { return new SpekeKeyProvider(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy