cloudstack-dev mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From jburwell <...@git.apache.org>
Subject [GitHub] cloudstack pull request: OSPF: adding dynamically routing capabili...
Date Tue, 10 May 2016 20:53:59 GMT
Github user jburwell commented on a diff in the pull request:

    https://github.com/apache/cloudstack/pull/1371#discussion_r62750209
  
    --- Diff: api/src/com/cloud/network/vpc/OSPFZoneConfig.java ---
    @@ -0,0 +1,329 @@
    +// Licensed to the Apache Software Foundation (ASF) under one
    +// or more contributor license agreements.  See the NOTICE file
    +// distributed with this work for additional information
    +// regarding copyright ownership.  The ASF licenses this file
    +// to you 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.cloud.network.vpc;
    +
    +import java.util.Arrays;
    +import java.util.HashMap;
    +import java.util.Map;
    +
    +import org.apache.commons.lang.ArrayUtils;
    +import org.apache.commons.lang.StringUtils;
    +
    +import com.cloud.exception.InvalidParameterValueException;
    +import com.cloud.utils.net.NetUtils;
    +import com.cloud.utils.net.cidr.BadCIDRException;
    +import com.cloud.utils.net.cidr.CIDR;
    +
    +public class OSPFZoneConfig {
    +
    +    private long zoneId;
    +    private Protocol protocol;
    +    private String ospfArea;
    +    private Short helloInterval;
    +    private Short deadInterval;
    +    private Short retransmitInterval;
    +    private Short transitDelay;
    +    private Authentication authentication;
    +    private String password;
    +    private CIDR[] superCIDRList;
    +    private Boolean enabled;
    +
    +    public static final String s_protocol = "protocol";
    +    public static final String s_area = "area";
    +    public static final String s_helloInterval = "hellointerval";
    +    public static final String s_deadInterval = "deadinterval";
    +    public static final String s_retransmitInterval = "retransmitinterval";
    +    public static final String s_transitDelay = "transitdelay";
    +    public static final String s_authentication = "authentication";
    +    public static final String s_superCIDR = "supercidr";
    +    public static final String s_password = "password";
    +    public static final String s_enabled = "enabled";
    +
    +    public Protocol getProtocol() {
    +        return protocol;
    +    }
    +
    +    public void setProtocol(Protocol protocol) {
    +        this.protocol = protocol;
    +    }
    +
    +    public String getOspfArea() {
    +        return ospfArea;
    +    }
    +
    +    public void setOspfArea(String ospfArea) {
    +        this.ospfArea = ospfArea;
    +    }
    +
    +    public Short getHelloInterval() {
    +        return helloInterval;
    +    }
    +
    +    public void setHelloInterval(Short helloInterval) {
    +        this.helloInterval = helloInterval;
    +    }
    +
    +    public Short getDeadInterval() {
    +        return deadInterval;
    +    }
    +
    +    public void setDeadInterval(Short deadInterval) {
    +        this.deadInterval = deadInterval;
    +    }
    +
    +    public Short getRetransmitInterval() {
    +        return retransmitInterval;
    +    }
    +
    +    public void setRetransmitInterval(Short retransmitInterval) {
    +        this.retransmitInterval = retransmitInterval;
    +    }
    +
    +    public Short getTransitDelay() {
    +        return transitDelay;
    +    }
    +
    +    public void setTransitDelay(Short transitDelay) {
    +        this.transitDelay = transitDelay;
    +    }
    +
    +    public Authentication getAuthentication() {
    +        return authentication;
    +    }
    +
    +    public void setAuthentication(Authentication authentication) {
    +        this.authentication = authentication;
    +    }
    +
    +    public String getPassword() {
    +        return password;
    +    }
    +
    +    public void setPassword(String password) {
    +        this.password = password;
    +    }
    +
    +    public CIDR[] getSuperCIDR() {
    +        return superCIDRList;
    +    }
    +
    +    public void setSuperCIDR(CIDR[] superCIDR) {
    +        this.superCIDRList = superCIDR;
    +    }
    +
    +    public Boolean getEnabled() {
    +        return enabled;
    +    }
    +
    +    public void setEnabled(Boolean enabled) {
    +        this.enabled = enabled;
    +    }
    +
    +    public enum Params {
    +        PROTOCOL, AREA, HELLO_INTERVAL, DEAD_INTERVAL, RETRANSMIT_INTERVAL, TRANSIT_DELAY,
AUTHENTICATION, SUPER_CIDR, PASSWORD, ENABLED
    +    }
    +
    +    public enum Protocol {
    +        OSPF
    +    }
    +
    +    public enum Authentication {
    +        MD5, PLAIN_TEXT
    +    }
    +
    +    public OSPFZoneConfig() {
    +    }
    +
    +    public void setDefaultValues(final Map<String, String> details) throws BadCIDRException
{
    +        this.protocol = details.get(Params.PROTOCOL.name()) == null ? Protocol.OSPF :
Protocol.valueOf(details.get(Params.PROTOCOL.name()));
    +        this.ospfArea = details.get(Params.AREA.name()) == null ? "0" : details.get(Params.AREA.name());
    +        this.helloInterval = Short.valueOf(details.get(Params.HELLO_INTERVAL.name())
== null ? "10" : details.get(Params.HELLO_INTERVAL.name()));
    +        this.deadInterval = Short.valueOf(details.get(Params.DEAD_INTERVAL.name()) ==
null ? "40" : details.get(Params.DEAD_INTERVAL.name()));
    +        this.retransmitInterval = Short.valueOf(details.get(Params.RETRANSMIT_INTERVAL.name())
== null ? "5" : details.get(Params.RETRANSMIT_INTERVAL.name()));
    +        this.transitDelay = Short.valueOf(details.get(Params.TRANSIT_DELAY.name()) ==
null ? "1" : details.get(Params.TRANSIT_DELAY.name()));
    +        this.authentication = details.get(Params.AUTHENTICATION.name()) == null ? Authentication.MD5
: Authentication.valueOf(details.get(Params.AUTHENTICATION.name()));
    +        this.password = details.get(Params.PASSWORD.name()) == null ? "" : details.get(Params.PASSWORD.name());
    +        this.superCIDRList = details.get(Params.SUPER_CIDR.name()) == null ? new CIDR[0]
: NetUtils.convertToCIDR(details.get(Params.SUPER_CIDR.name()).split(","));
    +        this.enabled = details.get(Params.ENABLED.name()) == null ? Boolean.FALSE : Boolean.valueOf(details.get(Params.ENABLED.name()));
    +    }
    +
    +    public void setValues(final String protocol, final String ospfArea, final Short helloInterval,
final Short deadInterval, final Short retransmitInterval,
    +            final Short transitDelay, final String authentication, final String quaggaPassword,
final String superCIDRList, final Boolean enabled) throws BadCIDRException {
    +        if (protocol != null) {
    +            if ((Protocol.OSPF.name().equals(protocol))) {
    +                this.protocol = Protocol.valueOf(protocol);
    +            } else {
    +                throw new InvalidParameterValueException("The quagga protocal can have
values of OSPF only " + protocol);
    +            }
    +        }
    +        if (ospfArea != null) {
    +            this.ospfArea = ospfArea;
    +        }
    +        if (helloInterval != null) {
    +            this.helloInterval = helloInterval;
    +        }
    +        if (deadInterval != null) {
    +            this.deadInterval = deadInterval;
    +        }
    +        if (retransmitInterval != null) {
    +            this.retransmitInterval = retransmitInterval;
    +        }
    +        if (transitDelay != null) {
    +            this.transitDelay = transitDelay;
    +        }
    +        if (authentication != null) {
    +            if (Authentication.MD5.name().equals(authentication) || Authentication.PLAIN_TEXT.name().equals(authentication))
{
    +                this.authentication = Authentication.valueOf(authentication);
    +            } else {
    +                throw new InvalidParameterValueException("The quagga authentication can
have values of MD5 or PLAIN_TEXT and not " + protocol);
    +            }
    +        }
    +        if (quaggaPassword != null) {
    +            this.password = quaggaPassword;
    +        }
    +        if (superCIDRList != null) {
    +            String[] cidr_list = superCIDRList.split(",");
    +            for (String cidr : cidr_list) {
    +                if (!NetUtils.isValidCIDR(cidr)) {
    +                    throw new InvalidParameterValueException("The super CIDR is not a
valid cidr " + cidr);
    +                }
    +            }
    +            CIDR[] v_cidr = NetUtils.convertToCIDR(cidr_list);
    +            if (!NetUtils.cidrListConsistency(v_cidr)) {
    --- End diff --
    
    Looking at Line 206 and this line, I am wondering if a CIDR range or collection type would
be useful since we operate ordered sets of CIDRs.


---
If your project is set up for it, you can reply to this email and have your
reply appear on GitHub as well. If your project does not have this feature
enabled and wishes so, or if the feature is enabled but not working, please
contact infrastructure at infrastructure@apache.org or file a JIRA ticket
with INFRA.
---

Mime
View raw message