# vim: tabstop=4 expandtab shiftwidth=4 softtabstop=4
#
# Copyright (c) 2014, Arista Networks, Inc.
# All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are
# met:
#
# Redistributions of source code must retain the above copyright notice,
# this list of conditions and the following disclaimer.
#
# Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in the
# documentation and/or other materials provided with the distribution.
#
# Neither the name of Arista Networks nor the names of its
# contributors may be used to endorse or promote products derived from
# this software without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL ARISTA NETWORKS
# BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
# BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
# OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
# IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#
[docs]class String(object):
def __init__(self, choices=None):
if choices:
choices = [str(c) for c in choices]
self.choices = choices
def __call__(self, value):
value = str(value)
if self.choices and value not in self.choices:
raise ValueError('Invalid string value: %s is not one of %s' %
(value, self.choices))
return value
def __repr__(self):
obj = 'String'
if self.choices:
obj += '(choices=%s)' % ','.join(self.choices)
return obj
[docs]class Boolean(object):
TRUEVALUES = ['yes', 'true', '1', 'on']
FALSEVALUES = ['no', 'false', '0', 'off']
def __call__(self, value):
if str(value).lower() in self.TRUEVALUES:
return True
elif str(value).lower() in self.FALSEVALUES:
return False
else:
raise ValueError('Invalid boolean value: %s' % value)
def __repr__(self):
return 'Boolean'
[docs]class Integer(object):
def __init__(self, min_value=None, max_value=None):
self.min_value = min_value
self.max_value = max_value
def __call__(self, value):
try:
value = int(value)
except ValueError:
raise ValueError('Invalid integer value: %s' % value)
if self.min_value is not None and value < self.min_value:
raise ValueError('Invalid integer value: %s (min is %s)' %
(value, self.min_value))
if self.max_value is not None and value > self.max_value:
raise ValueError('Invalid integer value: %s (max is %s)' %
(value, self.max_value))
return value
def __repr__(self):
return 'Integer(min_value=%s, max_value=%s)' % \
(self.min_value, self.max_value)
[docs]class List(object):
def __init__(self, delimiter=','):
self.delimiter = delimiter
def __call__(self, value):
if isinstance(value, list):
return value
return str(value).split(self.delimiter)
def __repr__(self):
return 'List(delimiter=%s)' % self.delimiter