summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorfujinhua <fu.jinhua@zte.com.cn>2019-04-04 08:40:41 +0800
committerfujinhua <fu.jinhua@zte.com.cn>2019-04-04 08:54:28 +0800
commitef2d340df0bcb7a662628884b7506df9ccf85bd5 (patch)
tree44895a01c7b2366bf74b45eed70dbfc398440e61
parentefb04f24ecf3bd3282ad75c8e1dea38280d119df (diff)
Add vm port operate interface
Change-Id: Icc0602dab58334229b032ba51d13ffbc57131e6b Issue-ID: VFC-1306 Signed-off-by: fujinhua <fu.jinhua@zte.com.cn>
-rw-r--r--lcm/lcm/pub/vimapi/adaptor.py128
-rw-r--r--lcm/lcm/pub/vimapi/api.py19
2 files changed, 147 insertions, 0 deletions
diff --git a/lcm/lcm/pub/vimapi/adaptor.py b/lcm/lcm/pub/vimapi/adaptor.py
index bc71aac7..27b64336 100644
--- a/lcm/lcm/pub/vimapi/adaptor.py
+++ b/lcm/lcm/pub/vimapi/adaptor.py
@@ -409,3 +409,131 @@ def create_vm(vim_cache, res_cache, data, vm, do_notify, res_type):
time.sleep(2)
retry_count = retry_count + 1
raise VimException("Failed to create Vm(%s): %s." % (vm_name, opt_vm_status), ERR_CODE)
+
+
+def list_port_of_vm(vim_cache, res_cache, data, port, do_notify, res_type):
+ location_info = None
+ vm_id = ignore_case_get(port, "vm_id")
+ port_ref_vdu_id = ignore_case_get(port, "vdu_id")
+ for vdu in ignore_case_get(data, "vdus"):
+ if vdu["vdu_id"] == port_ref_vdu_id:
+ location_info = vdu["properties"]["location_info"]
+ if port["cp_id"] not in vdu["cps"]:
+ vdu["cps"].append(port["cp_id"])
+ break
+ if not location_info:
+ err_msg = "vdu_id(%s) for cp(%s) is not defined."
+ raise VimException(err_msg % (port_ref_vdu_id, port["cp_id"]), ERR_CODE)
+
+ vim_id, tenant_name = location_info["vimid"], location_info["tenant"]
+ tenant_id = get_tenant_id(vim_cache, vim_id, tenant_name)
+ ret = api.list_vm_port(vim_id, tenant_id, vm_id)
+ ret["nodeId"] = port["cp_id"]
+ do_notify(res_type, ret)
+ set_res_cache(res_cache, res_type, port["cp_id"], ret["id"])
+
+ return ret
+
+
+def get_port_of_vm(vim_cache, res_cache, data, port, do_notify, res_type):
+ location_info = None
+ vm_id = ignore_case_get(port, "vm_id")
+ port_id = ignore_case_get(port, "cp_id")
+ port_ref_vdu_id = ignore_case_get(port, "vdu_id")
+ for vdu in ignore_case_get(data, "vdus"):
+ if vdu["vdu_id"] == port_ref_vdu_id:
+ location_info = vdu["properties"]["location_info"]
+ if port["cp_id"] not in vdu["cps"]:
+ vdu["cps"].append(port["cp_id"])
+ break
+ if not location_info:
+ err_msg = "vdu_id(%s) for cp(%s) is not defined."
+ raise VimException(err_msg % (port_ref_vdu_id, port["cp_id"]), ERR_CODE)
+
+ vim_id, tenant_name = location_info["vimid"], location_info["tenant"]
+ tenant_id = get_tenant_id(vim_cache, vim_id, tenant_name)
+ ret = api.get_vm_port(vim_id, tenant_id, vm_id, port_id)
+ ret["nodeId"] = port["cp_id"]
+ do_notify(res_type, ret)
+ set_res_cache(res_cache, res_type, port["cp_id"], ret["id"])
+
+ return ret
+
+
+def create_port_of_vm(vim_cache, res_cache, data, port, do_notify, res_type):
+ location_info = None
+ vm_id = ignore_case_get(port, "vm_id")
+ port_id = ignore_case_get(port, "port_id")
+ port_ref_vdu_id = ignore_case_get(port, "vdu_id")
+ for vdu in ignore_case_get(data, "vdus"):
+ if vdu["vdu_id"] == port_ref_vdu_id:
+ location_info = vdu["properties"]["location_info"]
+ if port["cp_id"] not in vdu["cps"]:
+ vdu["cps"].append(port["cp_id"])
+ break
+ if not location_info:
+ err_msg = "vdu_id(%s) for cp(%s) is not defined."
+ raise VimException(err_msg % (port_ref_vdu_id, port["cp_id"]), ERR_CODE)
+ network_id = ignore_case_get(port, "networkId")
+ # subnet_id = ignore_case_get(port, "subnetId")
+ if not network_id:
+ network_id = get_res_id(res_cache, RES_NETWORK, port["vl_id"])
+ # subnet_id = get_res_id(res_cache, RES_SUBNET, port["vl_id"])
+ # param = {
+ # "networkId": network_id,
+ # "name": port["cp_id"]
+ # }
+ # set_opt_val(param, "subnetId", subnet_id)
+ # set_opt_val(param, "macAddress", ignore_case_get(port["properties"], "mac_address"))
+ # ip_address = []
+ # for one_protocol_data in port["properties"]["protocol_data"]:
+ # l3_address_data = one_protocol_data["address_data"]["l3_address_data"] # l3 is not 13
+ # fixed_ip_address = ignore_case_get(l3_address_data, "fixed_ip_address")
+ # ip_address.extend(fixed_ip_address)
+ # for one_virtual_network_interface in port["properties"].get("virtual_network_interface_requirements", []):
+ # interfaceTypeString = one_virtual_network_interface["network_interface_requirements"]["interfaceType"]
+ # interfaceType = json.loads(interfaceTypeString)["configurationValue"]
+ # vnic_type = ignore_case_get(port["properties"], "vnic_type")
+ # if vnic_type == "":
+ # if interfaceType == "SR-IOV":
+ # set_opt_val(param, "vnicType", "direct")
+ # else:
+ # set_opt_val(param, "vnicType", vnic_type)
+ #
+ # set_opt_val(param, "ip", ",".join(ip_address))
+ # set_opt_val(param, "securityGroups", "") # TODO
+ vim_id, tenant_name = location_info["vimid"], location_info["tenant"]
+ tenant_id = get_tenant_id(vim_cache, vim_id, tenant_name)
+
+ # ip_address = ignore_case_get(ignore_case_get(port, "properties"), "ip_address")
+ param = {
+ "interfaceAttachment": {
+ "port_id": port_id
+ }
+ }
+ ret = api.create_vm_port(vim_id, tenant_id, vm_id, param)
+ ret["nodeId"] = port["cp_id"]
+ do_notify(res_type, ret)
+
+
+def delete_port_of_vm(vim_cache, res_cache, data, port, do_notify, res_type):
+ location_info = None
+ vm_id = ignore_case_get(port, "vm_id")
+ port_id = ignore_case_get(port, "cp_id")
+ port_ref_vdu_id = ignore_case_get(port, "vdu_id")
+ for vdu in ignore_case_get(data, "vdus"):
+ if vdu["vdu_id"] == port_ref_vdu_id:
+ location_info = vdu["properties"]["location_info"]
+ if port["cp_id"] not in vdu["cps"]:
+ vdu["cps"].append(port["cp_id"])
+ break
+ if not location_info:
+ err_msg = "vdu_id(%s) for cp(%s) is not defined."
+ raise VimException(err_msg % (port_ref_vdu_id, port["cp_id"]), ERR_CODE)
+
+ vim_id, tenant_name = location_info["vimid"], location_info["tenant"]
+ tenant_id = get_tenant_id(vim_cache, vim_id, tenant_name)
+ ret = api.delete_vm_port(vim_id, tenant_id, vm_id, port_id)
+ ret["nodeId"] = port["cp_id"]
+ do_notify("delete", res_type, port_id)
+ set_res_cache(res_cache, res_type, port["cp_id"], ret["id"])
diff --git a/lcm/lcm/pub/vimapi/api.py b/lcm/lcm/pub/vimapi/api.py
index ba84442f..74fae1c6 100644
--- a/lcm/lcm/pub/vimapi/api.py
+++ b/lcm/lcm/pub/vimapi/api.py
@@ -162,6 +162,25 @@ def list_vm(vim_id, tenant_id):
def action_vm(vim_id, tenant_id, vm_id, data):
return call(vim_id, tenant_id, "servers/%s/action" % vm_id, "POST", data)
+
+# List port interfaces, show port interface details of the given server.
+# Create a port interface and uses it to attach a port to the given server,
+# detach a port interface from the given server
+def list_vm_port(vim_id, tenant_id, vm_id):
+ return call(vim_id, tenant_id, "servers/%s/os-interface" % vm_id, "GET")
+
+
+def create_vm_port(vim_id, tenant_id, vm_id, data):
+ return call(vim_id, tenant_id, "servers/%s/os-interface" % vm_id, "POST", data)
+
+
+def get_vm_port(vim_id, tenant_id, vm_id, port_id):
+ return call(vim_id, tenant_id, "servers/%s/os-interface/%s" % (vm_id, port_id), "GET")
+
+
+def delete_vm_port(vim_id, tenant_id, vm_id, port_id):
+ return call(vim_id, tenant_id, "servers/%s/os-interface/%s" % (vm_id, port_id), "DELETE")
+
######################################################################