aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAdam Hassick <ahassick@iol.unh.edu>2021-07-27 13:05:16 +0000
committerSawyer Bergeron <sbergeron@iol.unh.edu>2021-07-27 09:20:35 -0400
commitd93346a716bde5237b7cfef5c10ea56e4922b59a (patch)
tree5d9d47c84e99e6040d8c2eb7c3921369b83964b4
parent6ffb1fdf6ce7825770148bada5a4c54899e4ed36 (diff)
Make C-I serialization work with current netconf rules
Signed-off-by: Sawyer Bergeron <sbergeron@iol.unh.edu> Change-Id: If967e5e1f268c5bee3ad4496847662cf4de1187c Signed-off-by: Sawyer Bergeron <sbergeron@iol.unh.edu>
-rw-r--r--src/api/models.py40
-rw-r--r--src/api/urls.py6
-rw-r--r--src/api/views.py6
3 files changed, 42 insertions, 10 deletions
diff --git a/src/api/models.py b/src/api/models.py
index a207044..3098111 100644
--- a/src/api/models.py
+++ b/src/api/models.py
@@ -390,24 +390,50 @@ class CloudInitFile(models.Model):
user_array.append(userdict)
+ user_array.append({
+ "name": "opnfv",
+ "plain_text_passwd": "OPNFV_HOST",
+ "ssh_redirect_user": True,
+ "sudo": "ALL=(ALL) NOPASSWD:ALL",
+ "groups": "sudo",
+ })
+
return user_array
def _serialize_netconf_v1(self):
+ interfaces = {} # map from iface_name => dhcp_config
+ #vlans = {} # map from vlan_id => dhcp_config
+
config_arr = []
for interface in self._resource().interfaces.all():
interface_name = interface.profile.name
interface_mac = interface.mac_address
+ iface_dict_entry = {
+ "type": "physical",
+ "name": interface_name,
+ "mac_address": interface_mac,
+ }
+
+
for vlan in interface.config.all():
- vlan_dict_entry = {'type': 'vlan'}
- vlan_dict_entry['name'] = str(interface_name) + "." + str(vlan.vlan_id)
- vlan_dict_entry['link'] = str(interface_name)
- vlan_dict_entry['vlan_id'] = int(vlan.vlan_id)
- vlan_dict_entry['mac_address'] = str(interface_mac)
+ if vlan.tagged:
+ vlan_dict_entry = {'type': 'vlan'}
+ vlan_dict_entry['name'] = str(interface_name) + "." + str(vlan.vlan_id)
+ vlan_dict_entry['vlan_link'] = str(interface_name)
+ vlan_dict_entry['vlan_id'] = int(vlan.vlan_id)
+ vlan_dict_entry['mac_address'] = str(interface_mac)
+ if vlan.public:
+ vlan_dict_entry["subnets"] = [ { "type": "dhcp" } ]
+ config_arr.append(vlan_dict_entry)
+ if (not vlan.tagged) and vlan.public:
+ iface_dict_entry["subnets"] = [ { "type": "dhcp" } ]
+
#vlan_dict_entry['mtu'] = # TODO, determine override MTU if needed
- config_arr.append(vlan_dict_entry)
+ config_arr.append(iface_dict_entry)
+
ns_dict = {
'type': 'nameserver',
@@ -443,7 +469,7 @@ class CloudInitFile(models.Model):
return main_dict
def serialize(self) -> str:
- return yaml.dump(self._to_dict())
+ return str("#cloud-config\n") + yaml.dump(self._to_dict())
class Job(models.Model):
"""
diff --git a/src/api/urls.py b/src/api/urls.py
index e5ddd97..970ecf2 100644
--- a/src/api/urls.py
+++ b/src/api/urls.py
@@ -46,7 +46,8 @@ from api.views import (
lab_user,
GenerateTokenView,
analytics_job,
- resource_cidata,
+ resource_ci_metadata,
+ resource_ci_userdata,
all_images,
all_opsyss,
single_image,
@@ -68,7 +69,8 @@ urlpatterns = [
path('labs/<slug:lab_name>/booking/<int:booking_id>/idf', get_idf, name="get-idf"),
path('labs/<slug:lab_name>/jobs/<int:job_id>', specific_job),
path('labs/<slug:lab_name>/jobs/<int:job_id>/<slug:task_id>', specific_task),
- path('labs/<slug:lab_name>/jobs/<int:job_id>/cidata/<slug:resource_id>', resource_cidata),
+ path('labs/<slug:lab_name>/jobs/<int:job_id>/cidata/<slug:resource_id>/user-data', resource_ci_userdata),
+ path('labs/<slug:lab_name>/jobs/<int:job_id>/cidata/<slug:resource_id>/meta-data', resource_ci_metadata),
path('labs/<slug:lab_name>/jobs/new', new_jobs),
path('labs/<slug:lab_name>/jobs/current', current_jobs),
path('labs/<slug:lab_name>/jobs/done', done_jobs),
diff --git a/src/api/views.py b/src/api/views.py
index 4b887e6..7add23e 100644
--- a/src/api/views.py
+++ b/src/api/views.py
@@ -248,7 +248,7 @@ def specific_job(request, lab_name="", job_id=""):
return JsonResponse(lab_manager.get_job(job_id), safe=False)
@csrf_exempt
-def resource_cidata(request, lab_name="", job_id="", resource_id=""):
+def resource_ci_userdata(request, lab_name="", job_id="", resource_id=""):
#lab_token = request.META.get('HTTP_AUTH_TOKEN')
#lab_manager = LabManagerTracker.get(lab_name, lab_token)
@@ -263,6 +263,10 @@ def resource_cidata(request, lab_name="", job_id="", resource_id=""):
return HttpResponse(cifile.serialize(), status=200)
+@csrf_exempt
+def resource_ci_metadata(request, lab_name="", job_id="", resource_id=""):
+ return HttpResponse("#cloud-config", status=200)
+
def new_jobs(request, lab_name=""):
lab_token = request.META.get('HTTP_AUTH_TOKEN')