Search in sources :

Example 16 with NetworkACLItem

use of com.cloud.network.vpc.NetworkACLItem in project cosmic by MissionCriticalCloud.

the class ApiResponseHelper method createNetworkACLItemResponse.

@Override
public NetworkACLItemResponse createNetworkACLItemResponse(final NetworkACLItem aclItem) {
    final NetworkACLItemResponse response = new NetworkACLItemResponse();
    response.setId(aclItem.getUuid());
    response.setProtocol(aclItem.getProtocol());
    if (aclItem.getSourcePortStart() != null) {
        response.setStartPort(Integer.toString(aclItem.getSourcePortStart()));
    }
    if (aclItem.getSourcePortEnd() != null) {
        response.setEndPort(Integer.toString(aclItem.getSourcePortEnd()));
    }
    response.setCidrList(StringUtils.join(aclItem.getSourceCidrList(), ","));
    response.setTrafficType(aclItem.getTrafficType().toString());
    final NetworkACLItem.State state = aclItem.getState();
    String stateToSet = state.toString();
    if (state.equals(NetworkACLItem.State.Revoke)) {
        stateToSet = "Deleting";
    }
    response.setIcmpCode(aclItem.getIcmpCode());
    response.setIcmpType(aclItem.getIcmpType());
    response.setState(stateToSet);
    response.setNumber(aclItem.getNumber());
    response.setAction(aclItem.getAction().toString());
    response.setForDisplay(aclItem.isDisplay());
    final NetworkACL acl = ApiDBUtils.findByNetworkACLId(aclItem.getAclId());
    if (acl != null) {
        response.setAclId(acl.getUuid());
    }
    // set tag information
    final List<? extends ResourceTag> tags = ApiDBUtils.listByResourceTypeAndId(ResourceObjectType.NetworkACL, aclItem.getId());
    final List<ResourceTagResponse> tagResponses = new ArrayList<>();
    for (final ResourceTag tag : tags) {
        final ResourceTagResponse tagResponse = createResourceTagResponse(tag, true);
        CollectionUtils.addIgnoreNull(tagResponses, tagResponse);
    }
    response.setTags(tagResponses);
    response.setObjectName("networkacl");
    return response;
}
Also used : NetworkACLItem(com.cloud.network.vpc.NetworkACLItem) ResourceTag(com.cloud.server.ResourceTag) ResourceTagResponse(com.cloud.api.response.ResourceTagResponse) ArrayList(java.util.ArrayList) NetworkACL(com.cloud.network.vpc.NetworkACL) NetworkACLItemResponse(com.cloud.api.response.NetworkACLItemResponse)

Example 17 with NetworkACLItem

use of com.cloud.network.vpc.NetworkACLItem in project cosmic by MissionCriticalCloud.

the class ListNetworkACLsCmd method execute.

// ///////////////////////////////////////////////////
// ///////////// API Implementation///////////////////
// ///////////////////////////////////////////////////
@Override
public void execute() {
    final Pair<List<? extends NetworkACLItem>, Integer> result = _networkACLService.listNetworkACLItems(this);
    final ListResponse<NetworkACLItemResponse> response = new ListResponse<>();
    final List<NetworkACLItemResponse> aclResponses = new ArrayList<>();
    for (final NetworkACLItem acl : result.first()) {
        final NetworkACLItemResponse ruleData = _responseGenerator.createNetworkACLItemResponse(acl);
        aclResponses.add(ruleData);
    }
    response.setResponses(aclResponses, result.second());
    response.setResponseName(getCommandName());
    setResponseObject(response);
}
Also used : NetworkACLItem(com.cloud.network.vpc.NetworkACLItem) ListResponse(com.cloud.api.response.ListResponse) ArrayList(java.util.ArrayList) ArrayList(java.util.ArrayList) List(java.util.List) NetworkACLItemResponse(com.cloud.api.response.NetworkACLItemResponse)

Example 18 with NetworkACLItem

use of com.cloud.network.vpc.NetworkACLItem in project cosmic by MissionCriticalCloud.

the class CreateNetworkACLCmd method execute.

@Override
public void execute() throws ResourceUnavailableException {
    boolean success = false;
    NetworkACLItem rule = _networkACLService.getNetworkACLItem(getEntityId());
    try {
        CallContext.current().setEventDetails("Rule ID: " + getEntityId());
        success = _networkACLService.applyNetworkACL(rule.getAclId());
        // State is different after the rule is applied, so get new object here
        rule = _networkACLService.getNetworkACLItem(getEntityId());
        NetworkACLItemResponse aclResponse = new NetworkACLItemResponse();
        if (rule != null) {
            aclResponse = _responseGenerator.createNetworkACLItemResponse(rule);
            setResponseObject(aclResponse);
        }
        aclResponse.setResponseName(getCommandName());
    } finally {
        if (!success || rule == null) {
            _networkACLService.revokeNetworkACLItem(getEntityId());
            throw new ServerApiException(ApiErrorCode.INTERNAL_ERROR, "Failed to create network ACL Item");
        }
    }
}
Also used : NetworkACLItem(com.cloud.network.vpc.NetworkACLItem) ServerApiException(com.cloud.api.ServerApiException) NetworkACLItemResponse(com.cloud.api.response.NetworkACLItemResponse)

Aggregations

NetworkACLItem (com.cloud.network.vpc.NetworkACLItem)18 ArrayList (java.util.ArrayList)9 NetworkACLItemResponse (org.apache.cloudstack.api.response.NetworkACLItemResponse)5 NetworkACLItemResponse (com.cloud.api.response.NetworkACLItemResponse)4 NicTO (com.cloud.agent.api.to.NicTO)3 SetNetworkACLCommand (com.cloud.agent.api.routing.SetNetworkACLCommand)2 NetworkACLTO (com.cloud.agent.api.to.NetworkACLTO)2 ServerApiException (com.cloud.api.ServerApiException)2 Zone (com.cloud.db.model.Zone)2 ResourceUnavailableException (com.cloud.exception.ResourceUnavailableException)2 Network (com.cloud.network.Network)2 NetworkACL (com.cloud.network.vpc.NetworkACL)2 ResourceTag (com.cloud.server.ResourceTag)2 URI (java.net.URI)2 List (java.util.List)2 SubnetUtils (org.apache.commons.net.util.SubnetUtils)2 Answer (com.cloud.agent.api.Answer)1 ApplyAclRuleVspCommand (com.cloud.agent.api.element.ApplyAclRuleVspCommand)1 SetPublicIpACLCommand (com.cloud.agent.api.routing.SetPublicIpACLCommand)1 PublicIpACLTO (com.cloud.agent.api.to.PublicIpACLTO)1