blob: 84add1904919b0ef45f0a9bc1831586faad642b3 [file] [log] [blame]
Vince Lehmanb8b18062015-07-14 13:07:22 -05001# -*- Mode:python; c-file-style:"gnu"; indent-tabs-mode:nil -*- */
2#
3# Copyright (C) 2015 The University of Memphis,
4# Arizona Board of Regents,
5# Regents of the University of California.
6#
7# This file is part of Mini-NDN.
8# See AUTHORS.md for a complete list of Mini-NDN authors and contributors.
9#
10# Mini-NDN is free software: you can redistribute it and/or modify
11# it under the terms of the GNU General Public License as published by
12# the Free Software Foundation, either version 3 of the License, or
13# (at your option) any later version.
14#
15# Mini-NDN is distributed in the hope that it will be useful,
16# but WITHOUT ANY WARRANTY; without even the implied warranty of
17# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18# GNU General Public License for more details.
19#
20# You should have received a copy of the GNU General Public License
21# along with Mini-NDN, e.g., in COPYING.md file.
22# If not, see <http://www.gnu.org/licenses/>.
23#
24# This file incorporates work covered by the following copyright and
25# permission notice:
26#
27# Mininet 2.2.1 License
28#
29# Copyright (c) 2013-2015 Open Networking Laboratory
30# Copyright (c) 2009-2012 Bob Lantz and The Board of Trustees of
31# The Leland Stanford Junior University
32#
33# Original authors: Bob Lantz and Brandon Heller
34#
35# We are making Mininet available for public use and benefit with the
36# expectation that others will use, modify and enhance the Software and
37# contribute those enhancements back to the community. However, since we
38# would like to make the Software available for broadest use, with as few
39# restrictions as possible permission is hereby granted, free of charge, to
40# any person obtaining a copy of this Software to deal in the Software
41# under the copyrights without restriction, including without limitation
42# the rights to use, copy, modify, merge, publish, distribute, sublicense,
43# and/or sell copies of the Software, and to permit persons to whom the
44# Software is furnished to do so, subject to the following conditions:
45#
46# The above copyright notice and this permission notice shall be included
47# in all copies or substantial portions of the Software.
48#
49# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
50# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
51# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
52# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
53# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
54# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
55# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
56#
57# The name and trademarks of copyright holder(s) may NOT be used in
58# advertising or publicity pertaining to the Software or any derivatives
59# without specific, written prior permission.
60
carlosmscabral29432252013-02-04 11:54:16 -020061import ConfigParser, re
Ashlesh Gawande557cb842015-07-01 15:39:44 -050062import shlex
carlosmscabralf40ecd12013-02-01 18:15:58 -020063
ashuef3490b2015-02-17 11:01:04 -060064class confNDNHost():
carlosmscabral6d3dd602013-03-23 11:12:34 -030065
ashuef3490b2015-02-17 11:01:04 -060066 def __init__(self, name, app='', params='', cpu=None, cores=None, cache=None):
carlosmscabralf40ecd12013-02-01 18:15:58 -020067 self.name = name
68 self.app = app
ashuef3490b2015-02-17 11:01:04 -060069 self.uri_tuples = params
Ashlesh Gawande3a4afb12015-07-09 09:23:30 -050070 self.params = params
carlosmscabral29432252013-02-04 11:54:16 -020071 self.cpu = cpu
carlosmscabrale121a7b2013-02-18 18:14:53 -030072 self.cores = cores
ashuef3490b2015-02-17 11:01:04 -060073 self.cache = cache
74
75 # For now assume leftovers are NLSR configuration parameters
76 self.nlsrParameters = params
carlosmscabral6d3dd602013-03-23 11:12:34 -030077
carlosmscabralf40ecd12013-02-01 18:15:58 -020078 def __repr__(self):
ashuef3490b2015-02-17 11:01:04 -060079 return 'Name: ' + self.name + \
80 ' App: ' + self.app + \
81 ' URIS: ' + str(self.uri_tuples) + \
82 ' CPU: ' + str(self.cpu) + \
83 ' Cores: ' + str(self.cores) + \
84 ' Cache: ' + str(self.cache) + \
85 ' Radius: ' + str(self.radius) + \
86 ' Angle: ' + str(self.angle) + \
87 ' NLSR Parameters: ' + self.nlsrParameters
carlosmscabralf40ecd12013-02-01 18:15:58 -020088
ashuef3490b2015-02-17 11:01:04 -060089class confNDNLink():
carlosmscabral6d3dd602013-03-23 11:12:34 -030090
carlosmscabralf40ecd12013-02-01 18:15:58 -020091 def __init__(self,h1,h2,linkDict=None):
92 self.h1 = h1
93 self.h2 = h2
94 self.linkDict = linkDict
carlosmscabral6d3dd602013-03-23 11:12:34 -030095
carlosmscabralf40ecd12013-02-01 18:15:58 -020096 def __repr__(self):
97 return 'h1: ' + self.h1 + ' h2: ' + self.h2 + ' params: ' + str(self.linkDict)
carlosmscabral6d3dd602013-03-23 11:12:34 -030098
carlosmscabral29432252013-02-04 11:54:16 -020099def parse_hosts(conf_arq):
100 'Parse hosts section from the conf file.'
carlosmscabralf40ecd12013-02-01 18:15:58 -0200101 config = ConfigParser.RawConfigParser()
102 config.read(conf_arq)
carlosmscabral6d3dd602013-03-23 11:12:34 -0300103
carlosmscabralf40ecd12013-02-01 18:15:58 -0200104 hosts = []
carlosmscabral6d3dd602013-03-23 11:12:34 -0300105
ashuef3490b2015-02-17 11:01:04 -0600106 items = config.items('nodes')
carlosmscabral6d3dd602013-03-23 11:12:34 -0300107
ashuef3490b2015-02-17 11:01:04 -0600108 #makes a first-pass read to hosts section to find empty host sections
109 for item in items:
110 name = item[0]
111 rest = item[1].split()
112 if len(rest) == 0:
113 config.set('nodes', name, '_')
114 #updates 'items' list
115 items = config.items('nodes')
116
117 #makes a second-pass read to hosts section to properly add hosts
carlosmscabralf40ecd12013-02-01 18:15:58 -0200118 for item in items:
119
120 name = item[0]
carlosmscabral6d3dd602013-03-23 11:12:34 -0300121
Ashlesh Gawande557cb842015-07-01 15:39:44 -0500122 rest = shlex.split(item[1])
carlosmscabral6d3dd602013-03-23 11:12:34 -0300123
carlosmscabralf40ecd12013-02-01 18:15:58 -0200124 uris = rest
ashuef3490b2015-02-17 11:01:04 -0600125 params = {}
carlosmscabral29432252013-02-04 11:54:16 -0200126 cpu = None
carlosmscabrale121a7b2013-02-18 18:14:53 -0300127 cores = None
ashuef3490b2015-02-17 11:01:04 -0600128 cache = None
carlosmscabral6d3dd602013-03-23 11:12:34 -0300129
carlosmscabralf40ecd12013-02-01 18:15:58 -0200130 for uri in uris:
carlosmscabral29432252013-02-04 11:54:16 -0200131 if re.match("cpu",uri):
132 cpu = float(uri.split('=')[1])
carlosmscabrale121a7b2013-02-18 18:14:53 -0300133 elif re.match("cores",uri):
134 cores = uri.split('=')[1]
ashuef3490b2015-02-17 11:01:04 -0600135 elif re.match("cache",uri):
136 cache = uri.split('=')[1]
137 elif re.match("mem",uri):
138 mem = uri.split('=')[1]
Ashlesh Gawande557cb842015-07-01 15:39:44 -0500139 elif re.match("app",uri):
140 app = uri.split('=')[1]
141 elif re.match("_", uri):
142 app = ""
carlosmscabral29432252013-02-04 11:54:16 -0200143 else:
ashuef3490b2015-02-17 11:01:04 -0600144 params[uri.split('=')[0]] = uri.split('=')[1]
carlosmscabral6d3dd602013-03-23 11:12:34 -0300145
ashuef3490b2015-02-17 11:01:04 -0600146 hosts.append(confNDNHost(name, app, params, cpu, cores, cache))
carlosmscabral6d3dd602013-03-23 11:12:34 -0300147
carlosmscabralf40ecd12013-02-01 18:15:58 -0200148 return hosts
149
carlosmscabral29432252013-02-04 11:54:16 -0200150def parse_links(conf_arq):
151 'Parse links section from the conf file.'
carlosmscabralf40ecd12013-02-01 18:15:58 -0200152 arq = open(conf_arq,'r')
carlosmscabral6d3dd602013-03-23 11:12:34 -0300153
carlosmscabralf40ecd12013-02-01 18:15:58 -0200154 links = []
carlosmscabral6d3dd602013-03-23 11:12:34 -0300155
carlosmscabralf40ecd12013-02-01 18:15:58 -0200156 while True:
157 line = arq.readline()
158 if line == '[links]\n':
159 break
carlosmscabral6d3dd602013-03-23 11:12:34 -0300160
carlosmscabralf40ecd12013-02-01 18:15:58 -0200161 while True:
162 line = arq.readline()
163 if line == '':
164 break
carlosmscabral6d3dd602013-03-23 11:12:34 -0300165
carlosmscabralf40ecd12013-02-01 18:15:58 -0200166 args = line.split()
ashuef3490b2015-02-17 11:01:04 -0600167
168 #checks for non-empty line
169 if len(args) == 0:
170 continue
Caio Eliasc6b56032014-09-19 14:12:48 -0300171
carlosmscabralf40ecd12013-02-01 18:15:58 -0200172 h1, h2 = args.pop(0).split(':')
carlosmscabral6d3dd602013-03-23 11:12:34 -0300173
carlosmscabralf40ecd12013-02-01 18:15:58 -0200174 link_dict = {}
carlosmscabral6d3dd602013-03-23 11:12:34 -0300175
carlosmscabralf40ecd12013-02-01 18:15:58 -0200176 for arg in args:
177 arg_name, arg_value = arg.split('=')
178 key = arg_name
179 value = arg_value
carlosmscabral6d3dd602013-03-23 11:12:34 -0300180 if key in ['bw','jitter','max_queue_size']:
carlosmscabralf40ecd12013-02-01 18:15:58 -0200181 value = int(value)
carlosmscabral6d3dd602013-03-23 11:12:34 -0300182 if key in ['loss']:
183 value = float(value)
carlosmscabralf40ecd12013-02-01 18:15:58 -0200184 link_dict[key] = value
carlosmscabral6d3dd602013-03-23 11:12:34 -0300185
ashuef3490b2015-02-17 11:01:04 -0600186 links.append(confNDNLink(h1,h2,link_dict))
carlosmscabral6d3dd602013-03-23 11:12:34 -0300187
188
carlosmscabralf40ecd12013-02-01 18:15:58 -0200189 return links