Package com.amazonaws.resources.ec2.internal

Source Code of com.amazonaws.resources.ec2.internal.SecurityGroupImpl$Codec

/*
* Copyright 2014 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 com.amazonaws.resources.ec2.internal;

import java.util.List;

import com.amazonaws.resources.ResultCapture;
import com.amazonaws.resources.ec2.SecurityGroup;
import com.amazonaws.resources.internal.ActionResult;
import com.amazonaws.resources.internal.CodecUtils;
import com.amazonaws.resources.internal.ResourceCodec;
import com.amazonaws.resources.internal.ResourceImpl;
import com.amazonaws.services.ec2.model.AuthorizeSecurityGroupEgressRequest;
import com.amazonaws.services.ec2.model.AuthorizeSecurityGroupIngressRequest;
import com.amazonaws.services.ec2.model.CreateTagsRequest;
import com.amazonaws.services.ec2.model.DeleteSecurityGroupRequest;
import com.amazonaws.services.ec2.model.DescribeSecurityGroupsRequest;
import com.amazonaws.services.ec2.model.DescribeSecurityGroupsResult;
import com.amazonaws.services.ec2.model.IpPermission;
import com.amazonaws.services.ec2.model.RevokeSecurityGroupEgressRequest;
import com.amazonaws.services.ec2.model.RevokeSecurityGroupIngressRequest;
import com.amazonaws.services.ec2.model.Tag;

class SecurityGroupImpl implements SecurityGroup {
    public static final ResourceCodec<SecurityGroup> CODEC = new Codec();

    private final ResourceImpl resource;

    public SecurityGroupImpl(ResourceImpl resource) {
        this.resource = resource;
    }

    @Override
    public boolean isLoaded() {
        return resource.isLoaded();
    }

    @Override
    public boolean load() {
        return load(null, null);
    }

    @Override
    public boolean load(DescribeSecurityGroupsRequest request) {
        return load(request, null);
    }

    @Override
    public boolean load(DescribeSecurityGroupsRequest request,
            ResultCapture<DescribeSecurityGroupsResult> extractor) {

        return resource.load(request, extractor);
    }

    @Override
    public String getId() {
        return (String) resource.getIdentifier("Id");
    }

    @Override
    public List<Tag> getTags() {
        return (List<Tag>) resource.getAttribute("Tags");
    }

    @Override
    public List<IpPermission> getIpPermissions() {
        return (List<IpPermission>) resource.getAttribute("IpPermissions");
    }

    @Override
    public String getDescription() {
        return (String) resource.getAttribute("Description");
    }

    @Override
    public String getGroupName() {
        return (String) resource.getAttribute("GroupName");
    }

    @Override
    public String getOwnerId() {
        return (String) resource.getAttribute("OwnerId");
    }

    @Override
    public String getVpcId() {
        return (String) resource.getAttribute("VpcId");
    }

    @Override
    public List<IpPermission> getIpPermissionsEgress() {
        return (List<IpPermission>)
                resource.getAttribute("IpPermissionsEgress");
    }

    @Override
    public void revokeIngress(RevokeSecurityGroupIngressRequest request) {
        revokeIngress(request, null);
    }

    @Override
    public void revokeIngress(RevokeSecurityGroupIngressRequest request,
            ResultCapture<Void> extractor) {

        resource.performAction("RevokeIngress", request, extractor);
    }

    @Override
    public void revokeEgress(RevokeSecurityGroupEgressRequest request) {
        revokeEgress(request, null);
    }

    @Override
    public void revokeEgress(RevokeSecurityGroupEgressRequest request,
            ResultCapture<Void> extractor) {

        resource.performAction("RevokeEgress", request, extractor);
    }

    @Override
    public void authorizeEgress(AuthorizeSecurityGroupEgressRequest request) {
        authorizeEgress(request, null);
    }

    @Override
    public void authorizeEgress(AuthorizeSecurityGroupEgressRequest request,
            ResultCapture<Void> extractor) {

        resource.performAction("AuthorizeEgress", request, extractor);
    }

    @Override
    public void authorizeIngress(AuthorizeSecurityGroupIngressRequest request) {
        authorizeIngress(request, null);
    }

    @Override
    public void authorizeIngress(AuthorizeSecurityGroupIngressRequest request,
            ResultCapture<Void> extractor) {

        resource.performAction("AuthorizeIngress", request, extractor);
    }

    @Override
    public void delete(DeleteSecurityGroupRequest request) {
        delete(request, null);
    }

    @Override
    public void delete(DeleteSecurityGroupRequest request, ResultCapture<Void>
            extractor) {

        resource.performAction("Delete", request, extractor);
    }

    @Override
    public List<com.amazonaws.resources.ec2.Tag> createTags(CreateTagsRequest
            request) {

        return createTags(request, null);
    }

    @Override
    public List<com.amazonaws.resources.ec2.Tag> createTags(CreateTagsRequest
            request, ResultCapture<Void> extractor) {

        ActionResult result = resource.performAction("CreateTags", request,
                extractor);

        if (result == null) return null;
        return CodecUtils.transform(result.getResources(), TagImpl.CODEC);
    }

    @Override
    public List<com.amazonaws.resources.ec2.Tag> createTags(List<Tag> tags) {
        return createTags(tags, (ResultCapture<Void>)null);
    }

    @Override
    public List<com.amazonaws.resources.ec2.Tag> createTags(List<Tag> tags,
            ResultCapture<Void> extractor) {

        CreateTagsRequest request = new CreateTagsRequest()
            .withTags(tags);
        return createTags(request, extractor);
    }

    private static class Codec implements ResourceCodec<SecurityGroup> {
        @Override
        public SecurityGroup transform(ResourceImpl resource) {
            return new SecurityGroupImpl(resource);
        }
    }
}
TOP

Related Classes of com.amazonaws.resources.ec2.internal.SecurityGroupImpl$Codec

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.