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

software.amazon.awssdk.services.workmail.model.AssociateDelegateToResourceRequest Maven / Gradle / Ivy

/*
 * 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.workmail.model;

import java.util.Arrays;
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.awscore.AwsRequestOverrideConfiguration;
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.LocationTrait;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;

/**
 */
@Generated("software.amazon.awssdk:codegen")
public final class AssociateDelegateToResourceRequest extends WorkMailRequest implements
        ToCopyableBuilder {
    private static final SdkField ORGANIZATION_ID_FIELD = SdkField. builder(MarshallingType.STRING)
            .memberName("OrganizationId").getter(getter(AssociateDelegateToResourceRequest::organizationId))
            .setter(setter(Builder::organizationId))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("OrganizationId").build()).build();

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

    private static final SdkField ENTITY_ID_FIELD = SdkField. builder(MarshallingType.STRING)
            .memberName("EntityId").getter(getter(AssociateDelegateToResourceRequest::entityId))
            .setter(setter(Builder::entityId))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("EntityId").build()).build();

    private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(ORGANIZATION_ID_FIELD,
            RESOURCE_ID_FIELD, ENTITY_ID_FIELD));

    private final String organizationId;

    private final String resourceId;

    private final String entityId;

    private AssociateDelegateToResourceRequest(BuilderImpl builder) {
        super(builder);
        this.organizationId = builder.organizationId;
        this.resourceId = builder.resourceId;
        this.entityId = builder.entityId;
    }

    /**
     * 

* The organization under which the resource exists. *

* * @return The organization under which the resource exists. */ public final String organizationId() { return organizationId; } /** *

* The resource for which members (users or groups) are associated. *

*

* The identifier can accept ResourceId, Resourcename, or email. The following identity formats * are available: *

*
    *
  • *

    * Resource ID: r-0123456789a0123456789b0123456789 *

    *
  • *
  • *

    * Email address: [email protected] *

    *
  • *
  • *

    * Resource name: resource *

    *
  • *
* * @return The resource for which members (users or groups) are associated.

*

* The identifier can accept ResourceId, Resourcename, or email. The following identity * formats are available: *

*
    *
  • *

    * Resource ID: r-0123456789a0123456789b0123456789 *

    *
  • *
  • *

    * Email address: [email protected] *

    *
  • *
  • *

    * Resource name: resource *

    *
  • */ public final String resourceId() { return resourceId; } /** *

    * The member (user or group) to associate to the resource. *

    *

    * The entity ID can accept UserId or GroupID, Username or Groupname, or email. *

    *
      *
    • *

      * Entity: 12345678-1234-1234-1234-123456789012 or S-1-1-12-1234567890-123456789-123456789-1234 *

      *
    • *
    • *

      * Email address: [email protected] *

      *
    • *
    • *

      * Entity: entity *

      *
    • *
    * * @return The member (user or group) to associate to the resource.

    *

    * The entity ID can accept UserId or GroupID, Username or Groupname, or email. *

    *
      *
    • *

      * Entity: 12345678-1234-1234-1234-123456789012 or S-1-1-12-1234567890-123456789-123456789-1234 *

      *
    • *
    • *

      * Email address: [email protected] *

      *
    • *
    • *

      * Entity: entity *

      *
    • */ public final String entityId() { return entityId; } @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 + super.hashCode(); hashCode = 31 * hashCode + Objects.hashCode(organizationId()); hashCode = 31 * hashCode + Objects.hashCode(resourceId()); hashCode = 31 * hashCode + Objects.hashCode(entityId()); return hashCode; } @Override public final boolean equals(Object obj) { return super.equals(obj) && equalsBySdkFields(obj); } @Override public final boolean equalsBySdkFields(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (!(obj instanceof AssociateDelegateToResourceRequest)) { return false; } AssociateDelegateToResourceRequest other = (AssociateDelegateToResourceRequest) obj; return Objects.equals(organizationId(), other.organizationId()) && Objects.equals(resourceId(), other.resourceId()) && Objects.equals(entityId(), other.entityId()); } /** * 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("AssociateDelegateToResourceRequest").add("OrganizationId", organizationId()) .add("ResourceId", resourceId()).add("EntityId", entityId()).build(); } public final Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "OrganizationId": return Optional.ofNullable(clazz.cast(organizationId())); case "ResourceId": return Optional.ofNullable(clazz.cast(resourceId())); case "EntityId": return Optional.ofNullable(clazz.cast(entityId())); default: return Optional.empty(); } } @Override public final List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((AssociateDelegateToResourceRequest) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends WorkMailRequest.Builder, SdkPojo, CopyableBuilder { /** *

      * The organization under which the resource exists. *

      * * @param organizationId * The organization under which the resource exists. * @return Returns a reference to this object so that method calls can be chained together. */ Builder organizationId(String organizationId); /** *

      * The resource for which members (users or groups) are associated. *

      *

      * The identifier can accept ResourceId, Resourcename, or email. The following identity * formats are available: *

      *
        *
      • *

        * Resource ID: r-0123456789a0123456789b0123456789 *

        *
      • *
      • *

        * Email address: [email protected] *

        *
      • *
      • *

        * Resource name: resource *

        *
      • *
      * * @param resourceId * The resource for which members (users or groups) are associated.

      *

      * The identifier can accept ResourceId, Resourcename, or email. The following * identity formats are available: *

      *
        *
      • *

        * Resource ID: r-0123456789a0123456789b0123456789 *

        *
      • *
      • *

        * Email address: [email protected] *

        *
      • *
      • *

        * Resource name: resource *

        *
      • * @return Returns a reference to this object so that method calls can be chained together. */ Builder resourceId(String resourceId); /** *

        * The member (user or group) to associate to the resource. *

        *

        * The entity ID can accept UserId or GroupID, Username or Groupname, or email. *

        *
          *
        • *

          * Entity: 12345678-1234-1234-1234-123456789012 or S-1-1-12-1234567890-123456789-123456789-1234 *

          *
        • *
        • *

          * Email address: [email protected] *

          *
        • *
        • *

          * Entity: entity *

          *
        • *
        * * @param entityId * The member (user or group) to associate to the resource.

        *

        * The entity ID can accept UserId or GroupID, Username or Groupname, or email. *

        *
          *
        • *

          * Entity: 12345678-1234-1234-1234-123456789012 or S-1-1-12-1234567890-123456789-123456789-1234 *

          *
        • *
        • *

          * Email address: [email protected] *

          *
        • *
        • *

          * Entity: entity *

          *
        • * @return Returns a reference to this object so that method calls can be chained together. */ Builder entityId(String entityId); @Override Builder overrideConfiguration(AwsRequestOverrideConfiguration overrideConfiguration); @Override Builder overrideConfiguration(Consumer builderConsumer); } static final class BuilderImpl extends WorkMailRequest.BuilderImpl implements Builder { private String organizationId; private String resourceId; private String entityId; private BuilderImpl() { } private BuilderImpl(AssociateDelegateToResourceRequest model) { super(model); organizationId(model.organizationId); resourceId(model.resourceId); entityId(model.entityId); } public final String getOrganizationId() { return organizationId; } public final void setOrganizationId(String organizationId) { this.organizationId = organizationId; } @Override public final Builder organizationId(String organizationId) { this.organizationId = organizationId; 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 getEntityId() { return entityId; } public final void setEntityId(String entityId) { this.entityId = entityId; } @Override public final Builder entityId(String entityId) { this.entityId = entityId; return this; } @Override public Builder overrideConfiguration(AwsRequestOverrideConfiguration overrideConfiguration) { super.overrideConfiguration(overrideConfiguration); return this; } @Override public Builder overrideConfiguration(Consumer builderConsumer) { super.overrideConfiguration(builderConsumer); return this; } @Override public AssociateDelegateToResourceRequest build() { return new AssociateDelegateToResourceRequest(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy