Fix bug of cli command error when onboard vnf
[integration.git] / test / hpa_automation / tosca / hpa_automation.py
1 #!/usr/bin/python
2
3 #Prerequisites for machine to run this
4 #Put in required parameters in hpa_automation_config.json
5 #Install python-pip (apt install python-pip)
6 #Install python mysql.connector (pip install mysql-connector-python)
7 #Install ONAP CLI
8 #Must have connectivity to the ONAP, a k8s vm already running is recommended
9 #Create Preload File, the script will modify the parameters required from serivce model, service instance
10 #and vnf instance
11 #Create policies for homing
12 #Put in CSAR file
13 #modify so-bpmn configmap and change version to v2
14
15 import json
16 import os
17 import time
18 import argparse
19 import sys
20 import requests
21 import mysql.connector
22
23 def get_parameters(file):
24     parameters = json.load(file)
25     return parameters
26
27 def get_out_helper(in_string):
28     out_list = (((in_string.replace('-','')).replace('|', '')).replace('+', '')).split()
29     return out_list
30
31 def get_out_helper_2(in_string):
32     out_list = ((in_string.replace('|', '')).replace('+', '')).split()
33     return out_list
34
35 def set_open_cli_env(parameters):
36     os.environ["OPEN_CLI_PRODUCT_IN_USE"] = parameters["open_cli_product"]
37     os.environ["OPEN_CLI_HOME"] = parameters["open_cli_home"]
38
39 def create_complex(parameters):
40     complex_create_string = "oclip complex-create -j {} -r {} -x {} -y {} -lt {} -l {} -i {} -lo {} \
41                          -S {} -la {} -g {} -w {} -z {} -k {} -o {} -q {} -m {} -u {} -p {}".format(parameters["street2"], \
42                           parameters["physical_location"], parameters["complex_name"], \
43                           parameters["data_center_code"], parameters["latitude"], parameters["region"], \
44                           parameters["street1"], parameters["longitude"], parameters["state"], \
45                           parameters["lata"], parameters["city"], parameters["postal-code"], \
46                           parameters["complex_name"], parameters["country"], parameters["elevation"], \
47                           parameters["identity_url"], parameters["aai_url"], parameters["aai_username"], \
48                           parameters["aai_password"])
49
50     os.system(complex_create_string)
51
52 def create_vlm(parameters):
53     vlm_create_string = "oclip vlm-create -x {} -u {} -p {} -m {}".format(parameters["vendor-name"], \
54       parameters["sdc_creator"], parameters["sdc_password"], parameters["sdc_onboarding_url"])
55     command_out = (os.popen(vlm_create_string)).read()
56     out_list = get_out_helper(command_out)
57     vlm_id = out_list[3]
58     vlm_version = out_list[5]
59
60     entitlement_string = "oclip vlm-entitlement-pool-create -x {} -y {} -e {} -z {} -k {} -g {} -l {} -u {} -p {} -m {}".format( \
61       parameters["entitlement-pool-name"], vlm_id, vlm_version, parameters["entitlement-description"], parameters["vendor-name"], \
62       parameters["expiry-date"], parameters["start-date"],  parameters["sdc_creator"], parameters["sdc_password"], \
63       parameters["sdc_onboarding_url"])
64     command_out = (os.popen(entitlement_string)).read()
65     entitlement_id = (get_out_helper(command_out))[3]
66
67
68     key_group_string = "oclip vlm-key-group-create -c {} -e {} -x {} -y {} -u {} -p {} -m {}".format(vlm_id, vlm_version, \
69       parameters["key-group-name"], parameters["key-group-type"],  parameters["sdc_creator"], parameters["sdc_password"], \
70       parameters["sdc_onboarding_url"])
71     command_out = (os.popen(key_group_string)).read()
72     key_group_id = (get_out_helper(command_out))[3]
73
74     feature_group_string = "oclip vlm-feature-group-create -x {} -y {} -e {} -z {} -g {} -b {} -c {} -u {} -p {} -m {}".format(
75       parameters["feature-grp-name"], vlm_id, vlm_version, parameters["feature-grp-desc"], key_group_id, entitlement_id, \
76       parameters["part-no"], parameters["sdc_creator"], parameters["sdc_password"], parameters["sdc_onboarding_url"])
77     command_out = (os.popen(feature_group_string)).read()
78     feature_group_id = (get_out_helper(command_out))[3]
79
80     agreement_string = "oclip vlm-aggreement-create -x {} -y {} -e {} -z {} -g {} -u {} -p {} -m {}".format(parameters["agreement-name"], \
81       vlm_id, vlm_version, parameters["agreement-desc"], feature_group_id, parameters["sdc_creator"], parameters["sdc_password"], \
82       parameters["sdc_onboarding_url"])
83     command_out = (os.popen(agreement_string)).read()
84     agreement_id = (get_out_helper(command_out))[3]
85
86     submit_string = "oclip vlm-submit -x {} -y {} -u {} -p {} -m {}".format(vlm_id, vlm_version, parameters["sdc_creator"], \
87       parameters["sdc_password"], parameters["sdc_onboarding_url"])
88     os.system(submit_string)
89
90     output = [feature_group_id, agreement_id, vlm_version, vlm_id ]
91     return output
92
93 def create_vsp(parameters, in_list):
94     vnfs = parameters["vnf"]
95     vsp_dict = {}
96     for name, value in vnfs.iteritems():
97         create_string = "oclip vsp-create -j {} -o {} -e {} -x {} -y {} -i {} -c {} -g {} -u {} -p {} -m {}".format( in_list[0], \
98           parameters["onboarding-method"], parameters["vendor-name" ], value.get("vsp-name"), value.get("vsp-desc"), in_list[1], \
99           in_list[2], in_list[3], parameters["sdc_creator"], parameters["sdc_password"], parameters["sdc_onboarding_url"] )
100         command_out = (os.popen(create_string)).read()
101         out_list = get_out_helper(command_out)
102         vsp_id = out_list[3]
103         vsp_version = out_list[5]
104
105         os.system("oclip vsp-add-artifact -x {} -y {} -z {} -u {} -p {} -m {}".format(vsp_id, vsp_version, value.get("path"), \
106           parameters["sdc_creator"], parameters["sdc_password"], parameters["sdc_onboarding_url"]))
107
108         os.system("oclip vsp-validate -x {} -y {} -u {} -p {} -m {}".format(vsp_id, vsp_version, parameters["sdc_creator"], \
109           parameters["sdc_password"], parameters["sdc_onboarding_url"]))
110
111         os.system("oclip vsp-submit -x {} -y {} -u {} -p {} -m {}".format(vsp_id, vsp_version, parameters["sdc_creator"], \
112           parameters["sdc_password"], parameters["sdc_onboarding_url"]))
113
114         os.system("oclip vsp-package -x {} -y {} -u {} -p {} -m {}".format(vsp_id, vsp_version, parameters["sdc_creator"], \
115           parameters["sdc_password"], parameters["sdc_onboarding_url"]))
116
117         vsp_ids[name] = vsp_id
118     return vsp_ids
119
120 def create_vf_model(parameters, vsp_dict):
121     vnfs = parameters["vnfs"]
122     vf_dict = {}
123     for name, value in vnfs.iteritems():
124         create_string = "oclip vf-model-create -y {} -g {} -x {} -z {} -b {} -u {} -p {} -m {}".format(value.get("vf-description"), \
125           value.get("vsp-version"), value.get("vf-name"), parameters["vendor-name"], vsp_dict[name], \
126           parameters["sdc_creator"], parameters["sdc_password"], parameters["sdc_catalog_url"])
127         os.system(create_string)
128
129         output = (os.popen("oclip vf-model-list -m {} -u {} -p {} | grep {}".format(parameters["sdc_catalog_url"], \
130           parameters["sdc_creator"], parameters["sdc_password"], value.get("vf-name")))).read()
131         output = (get_out_helper_2(output))
132
133         vf_unique_id = output[1]
134
135         os.system("oclip vf-model-certify -b {} -r {} -u {} -p {} -m {}".format(vf_unique_id, value.get("vf-remarks"), \
136           parameters["sdc_creator"], parameters["sdc_password"], parameters["sdc_catalog_url"]))
137
138         #Check for new parameters after certification
139         output = (os.popen("oclip vf-model-list -m {} -u {} -p {} | grep {}".format(parameters["sdc_catalog_url"], \
140                               parameters["sdc_creator"], parameters["sdc_password"], value.get("vf-name")))).read()
141         output = (get_out_helper_2(output))
142
143         vf_dict[name] = output[1]
144
145     return vf_dict
146
147
148 def create_service_model(parameters, vf_dict):
149     vnfs = parameters["vnfs"]
150
151     create_string = "oclip service-model-create -z {} -y {} -e {} -x {} -c {} -b {} -u {} -p {} -m {} |grep ID".format(parameters["project-code"], \
152     parameters["service-model-desc"], parameters["icon-id"], parameters["service-model-name"], parameters["category-display"], \
153     parameters["category"],parameters["sdc_creator"], parameters["sdc_password"], parameters["sdc_catalog_url"])
154
155     service_model_id = (get_out_helper_2((os.popen(create_string)).read()))[1]
156
157     for name, value in vnfs.iteritems():
158         os.system("oclip service-model-add-vf -x {} -b {} -y {} -z {} -u {} -p {} -m {}".format(service_model_id, \
159                    parameters["vf-version"], vf_dict[name], value.get("vf-name"), parameters["sdc_creator"], \
160                    parameters["sdc_password"], parameters["sdc_catalog_url"] ))
161
162     os.system("oclip service-model-test-request -b {} -r {} -u {} -p {} -m {}".format(service_model_id, parameters["service-test-remarks"], \
163     parameters["sdc_creator"], parameters["sdc_password"], parameters["sdc_catalog_url"]))
164
165     os.system("oclip service-model-test-start -b {} -u {} -p {} -m {}".format(service_model_id, parameters["sdc_tester"], \
166     parameters["sdc_password"], parameters["sdc_catalog_url"]))
167
168     os.system("oclip service-model-test-accept -b {} -r {} -u {} -p {} -m {}".format(service_model_id, parameters["service-accept-remarks"], \
169     parameters["sdc_tester"], parameters["sdc_password"], parameters["sdc_catalog_url"]))
170
171     #Get uniqueId for the service model
172     service_model_values = (os.popen("oclip service-model-list -u {} -p {} -m {} |grep {}".format(parameters["sdc_creator"], \
173       parameters["sdc_password"], parameters["sdc_catalog_url"], parameters["service-model-name"]))).read()
174     service_model_values = get_out_helper_2(service_model_values)
175     service_model_uniqueId = (service_model_values)[1]
176
177     os.system("oclip service-model-approve -b {} -r {} -u {} -p {} -m {}".format(service_model_uniqueId, parameters["service-approve-remarks"], \
178     parameters["sdc_governor"], parameters["sdc_password"], parameters["sdc_catalog_url"]))
179
180     os.system("oclip service-model-distribute -b {} -u {} -p {} -m {}".format(service_model_uniqueId, parameters["sdc_operator"], \
181     parameters["sdc_password"], parameters["sdc_catalog_url"]))
182
183     return service_model_values
184
185 def register_cloud_helper(cloud_region, values, parameters):
186     #Create Cloud
187     cloud_create_string = 'oclip cloud-create -e {} -b {} -I {{\\\\\\"openstack-region-id\\\\\\":\\\\\\"{}\\\\\\"}} \
188     -x {} -y {} -j {} -w {} -l {} -url {} -n {} -q {} -r {} -Q {} -i {} -g {} -z {} -k {} -c {} -m {} -u {} -p {}'.format(
189       values.get("esr-system-info-id"), values.get("user-name"), cloud_region, parameters["cloud-owner"], \
190       cloud_region, values.get("password"), values.get("cloud-region-version"), values.get("default-tenant"), \
191       values.get("service-url"), parameters["complex_name"], values.get("cloud-type"), parameters["owner-defined-type"], \
192       values.get("system-type"), values.get("identity-url"), parameters["cloud-zone"], values.get("ssl-insecure"), \
193       values.get("system-status"), values.get("cloud-domain"), parameters["aai_url"], parameters["aai_username"], \
194       parameters["aai_password"])
195
196
197     os.system(cloud_create_string)
198
199     #Associate Cloud with complex
200     complex_associate_string = "oclip complex-associate -x {} -y {} -z {} -m {} -u {} -p {}".format(parameters["complex_name"], \
201       cloud_region, parameters["cloud-owner"], parameters["aai_url"], parameters["aai_username"], parameters["aai_password"])
202     os.system(complex_associate_string)
203
204     #Register Cloud with Multicloud
205     multicloud_register_string = "oclip multicloud-register-cloud -y {} -x {} -m {}".format(parameters["cloud-owner"], \
206       cloud_region, parameters["multicloud_url"])
207     os.system(multicloud_register_string)
208
209 def register_all_clouds(parameters):
210     cloud_dictionary = parameters["cloud_region_data"]
211     for cloud_region, cloud_region_values in cloud_dictionary.iteritems():
212         register_cloud_helper(cloud_region, cloud_region_values, parameters)
213
214 def create_service_type(parameters):
215     create_string = "oclip service-type-create -x {} -m {} -u {} -p {}".format( parameters["service_name"], \
216       parameters["aai_url"], parameters["aai_username"], parameters["aai_password"])
217     os.system(create_string)
218
219 def create_customer(parameters):
220     create_string = "oclip customer-create -x {} -y {} -m {} -u {} -p {}".format( parameters["customer_name"], \
221     parameters["subscriber_name"], parameters["aai_url"], parameters["aai_username"], parameters["aai_password"])
222     os.system(create_string)
223
224 def add_customer_subscription(parameters):
225     subscription_check = 0
226     for cloud_region, cloud_region_values in (parameters["cloud_region_data"]).iteritems():
227       if subscription_check == 0 :
228         subscription_string = "oclip subscription-create -x {} -c {} -z {} -e {} -y {} -r {} -m {} -u {} -p {}".format(\
229           parameters["customer_name"], cloud_region_values.get("tenant-id"), parameters["cloud-owner"], parameters["service_name"],\
230           cloud_region_values.get("default-tenant"), cloud_region, parameters["aai_url"], parameters["aai_username"], parameters["aai_password"] )
231       else:
232         subscription_string = "oclip subscription-cloud-add -x {} -c {} -z {} -e {} -y {} -r {} -m {} -u {} -p {}".format(\
233           parameters["customer_name"], cloud_region_values.get("tenant-id"), parameters["cloud-owner"], parameters["service_name"],\
234           cloud_region_values.get("default-tenant"), cloud_region, parameters["aai_url"], parameters["aai_username"], parameters["aai_password"] )
235       os.system(subscription_string)
236       subscription_check+=1
237
238 def register_vnfm_helper(vnfm_key, values, parameters):
239     #Create vnfm
240     vnfm_create_string = 'oclip vnfm-create -b {} -c {} -e {} -v {} -g {} -x {} -i {} -j {} -q {} \
241     -m {} -u {} -p {}'.format(vnfm_key, values.get("type"), values.get("vendor"), \
242       values.get("version"), values.get("url"), values.get("vim-id"), \
243       values.get("user-name"), values.get("user-password"), values.get("vnfm-version"), \
244       parameters["aai_url"], parameters["aai_username"], parameters["aai_password"])
245
246     os.system(vnfm_create_string)
247
248 def register_vnfm(parameters):
249     vnfm_params = parameters["vnfm_params"]
250     for vnfm_key, vnfm_values in vnfm_params.iteritems():
251         register_vnfm_helper(vnfm_key, vnfm_values, parameters)
252
253 def add_policy_models(parameters):
254     mydb = mysql.connector.connect(
255       host="policydb",
256       user="policy_user",
257       passwd="policy_user",
258       database="onap_sdk",
259     )
260
261     mycursor = mydb.cursor()
262     hpa_sql = "INSERT INTO optimizationmodels (modelname, description, dependency, imported_by, \
263               attributes, ref_attributes, sub_attributes, version, annotation, enumValues, \
264               dataOrderInfo) VALUES (%s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s)"
265     hpa_val = ('hpaPolicy', 'HPA Tests Model', '[]', 'demo', 'identity=string:defaultValue-null:required-true:MANY-false:description-null', \
266          'policyScope=MANY-true,policyType=POLICYTYPE:MANY-false,resources=MANY-true,flavorFeatures=flavorFeatures_properties:MANY-true:description-null', \
267          '{"directives_properties":{"attributes":"directives_attributes_properties:required-false:MANY-true:description-null",\
268          "type":"string:defaultValue-null:required-false:MANY-false:description-null"},\
269          "directives_attributes_properties":{"attribute_name":"string:defaultValue-null:required-false:MANY-false:description-null",\
270          "attribute_value":"string:defaultValue-null:required-false:MANY-false:description-null"},\
271          "flavorProperties_properties":{"score":"string:defaultValue-null:required-false:MANY-false:description-null",\
272          "hpa-feature-attributes":"hpa-feature-attributes_properties:required-true:MANY-true:description-null",\
273          "directives":"directives_properties:required-true:MANY-true:description-null",\
274          "hpa-version":"string:defaultValue-null:required-true:MANY-false:description-null",\
275          "hpa-feature":"string:defaultValue-null:required-true:MANY-false:description-null",\
276          "mandatory":"string:defaultValue-null:required-true:MANY-false:description-null",\
277          "architecture":"string:defaultValue-null:required-true:MANY-false:description-null"},\
278          "flavorFeatures_properties":{"directives":"directives_properties:required-true:MANY-true:description-null",\
279          "flavorProperties":"flavorProperties_properties:required-true:MANY-true:description-null",\
280          "id":"string:defaultValue-null:required-true:MANY-false:description-null",\
281          "type":"string:defaultValue-null:required-true:MANY-false:description-null"},\
282          "hpa-feature-attributes_properties":{"unit":"string:defaultValue-null:required-false:MANY-false:description-null",\
283          "hpa-attribute-value":"string:defaultValue-null:required-true:MANY-false:description-null",\
284          "hpa-attribute-key":"string:defaultValue-null:required-true:MANY-false:description-null",\
285          "operator":"OPERATOR:defaultValue-null:required-false:MANY-false:description-null"}}', \
286          'test1', 'policyScope=matching-true, policyType=matching-true', \
287          'OPERATOR=[<,<equal-sign,>,>equal-sign,equal-sign,!equal-sign,any,all,subset,], POLICYTYPE=[hpa,]', '""')
288
289     mycursor.execute(hpa_sql, hpa_val)
290     
291     sql = "INSERT INTO microservicemodels (modelname, description, dependency, imported_by, \
292           attributes, ref_attributes, sub_attributes, version, annotation, enumValues, \
293           dataOrderInfo) VALUES (%s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s)"
294     val = [
295         ('distancePolicy', 'distancePolicy', '[]', 'demo', 'identity=string:defaultValue-null:required-true:MANY-false:description-null', \
296          'policyScope=MANY-true,distanceProperties=distanceProperties_properties:MANY-false:description-null,policyType=POLICYTYPE:MANY-false,\
297           resources=MANY-true,applicableResources=APPLICABLERESOURCES:MANY-false', \
298          '{"distanceProperties_properties":{"locationInfo":"string:defaultValue-null:required-true:MANY-false:description-null",\
299            "distance":"distance_properties:required-true:MANY-false:description-null"},\
300            "distance_properties":{"unit":"UNIT:defaultValue-null:required-true:MANY-false:description-null",\
301            "value":"string:defaultValue-null:required-true:MANY-false:description-null","operator":"OPERATOR:defaultValue-null:required-true:MANY-false:description-null"}}', \
302            'test1', 'policyScope=matching-true, policyType=matching-true', \
303            'OPERATOR=[<,<equal-sign,>,>equal-sign,equal-sign,], APPLICABLERESOURCES=[any,all,], POLICYTYPE=[distance_to_location,] ', '""'),
304         ('optimizationPolicy', 'Optimization policy model', '[]', 'demo', 'identity=string:defaultValue-null:required-true:MANY-false:description-null', \
305          'objectiveParameter=objectiveParameter_properties:MANY-false:description-null,policyScope=MANY-true,policyType=POLICYTYPE:MANY-false,\
306           objective=objectiveParameter_properties:MANY-false:description-null', \
307          '{"parameterAttributes_properties":{"customerLocationInfo":"string:defaultValue-null:required-true:MANY-false:description-null",\
308            "parameter":"string:defaultValue-null:required-true:MANY-false:description-null",\
309            "resources":"string:defaultValue-null:required-true:MANY-false:description-null",\
310            "weight":"string:defaultValue-null:required-true:MANY-false:description-null",\
311            "operator":"OPERATOR:defaultValue-null:required-true:MANY-false:description-null"},\
312            "objectiveParameter_properties":{"parameterAttributes":"parameterAttributes_properties:required-true:MANY-true:description-null",\
313            "operator":"OPERATOR:defaultValue-null:required-true:MANY-false:description-null"}}', \
314            'test1', 'policyScope=matching-true, policyType=matching-true', 'OPERATOR=[*,+,-,/,%,], POLICYTYPE=[placement_optimization,]', '""'),
315         ('queryPolicy', 'Query policy model', '[]', 'demo', 'identity=string:defaultValue-null:required-true:MANY-false:description-null', \
316          'policyScope=MANY-true,policyType=POLICYTYPE:MANY-false,queryProperties=queryProperties_properties:MANY-true:description-null', \
317          '{"queryProperties_properties":{"attribute_location":"string:defaultValue-null:required-true:MANY-false:description-null",\
318            "attribute":"string:defaultValue-null:required-true:MANY-false:description-null","value":"string:defaultValue-null:required-true:MANY-false:description-null"}}', \
319          'test1', 'policyScope=matching-true, policyType=matching-true', 'POLICYTYPE=[request_param_query,]', '""'),
320         ('vnfPolicy', 'VnfPolicy model', '[]', 'demo', 'identity=string:defaultValue-null:required-true:MANY-false:description-null', \
321          'policyScope=MANY-true,policyType=POLICYTYPE:MANY-false,resources=MANY-true,\
322           vnfProperties=vnfProperties_properties:MANY-true:description-null,applicableResources=APPLICABLERESOURCES:MANY-false', \
323          '{"vnfProperties_properties":{"serviceType":"string:defaultValue-null:required-true:MANY-false:description-null",\
324            "inventoryProvider":"string:defaultValue-null:required-true:MANY-false:description-null",\
325            "inventoryType":"INVENTORYTYPE:defaultValue-null:required-true:MANY-false:description-null",\
326          "customerId":"string:defaultValue-null:required-true:MANY-false:description-null"}}', \
327          'test1', 'policyScope=matching-true, policyType=matching-true', \
328          'INVENTORYTYPE=[serviceInstanceId,vnfName,cloudRegionId,vimId,], APPLICABLERESOURCES=[any,all,], POLICYTYPE=[vnfPolicy,]', '""'),
329         ('vim_fit', 'Capacity policy model', '[]', 'demo', 'identity=string:defaultValue-null:required-true:MANY-false:description-null', \
330          'policyScope=MANY-true,policyType=POLICYTYPE:MANY-false,capacityProperties=capacityProperties_properties:MANY-false:description-null,\
331           resources=MANY-true,applicableResources=APPLICABLERESOURCES:MANY-false', \
332          '{"capacityProperties_properties":{"request":"string:defaultValue-null:required-true:MANY-false:description-null",\
333            "controller":"string:defaultValue-null:required-true:MANY-false:description-null"}}', \
334            'test1', 'policyScope=matching-true, policyType=matching-true ', ' APPLICABLERESOURCES=[any,all,], POLICYTYPE=[vim_fit,]', '""'),
335         ('affinityPolicy', 'Affinity policy model', '[]', 'demo', 'identity=string:defaultValue-null:required-true:MANY-false:description-null', \
336          'policyScope=MANY-true,policyType=POLICYTYPE:MANY-false,affinityProperties=affinityProperties_properties:MANY-false:description-null,\
337           resources=MANY-true,applicableResources=APPLICABLERESOURCES:MANY-false', \
338          '{"affinityProperties_properties":{"qualifier":"QUALIFIER:defaultValue-null:required-true:MANY-false:description-null",\
339            "category":"string:defaultValue-null:required-true:MANY-false:description-null"}}', \
340            'test1', 'policyScope=matching-true, policyType=matching-true ', ' APPLICABLERESOURCES=[any,all,], POLICYTYPE=[zone,], QUALIFIER=[same,different,]', '""'),
341         ('pciPolicy', 'Pci policy model', '[]', 'demo', 'identity=string:defaultValue-null:required-true:MANY-false:description-null', \
342          'policyScope=MANY-true,policyType=POLICYTYPE:MANY-false,resources=MANY-true,pciProperties=pciProperties_properties:MANY-true:description-null', \
343          '{"pciProperties_properties":{"pciOptimizationTimeConstraint":"string:defaultValue-null:required-false:MANY-false:description-null",\
344            "pciOptimizationNwConstraint":"string:defaultValue-null:required-false:MANY-false:description-null",\
345            "algoCategory":"string:defaultValue-null:required-false:MANY-false:description-null",\
346            "pciOptmizationAlgoName":"string:defaultValue-null:required-false:MANY-false:description-null",\
347            "pciOptimizationPriority":"string:defaultValue-null:required-false:MANY-false:description-null"}}', \
348            'test1', 'olicyScope=matching-true, policyType=matching-true ', ' POLICYTYPE=[pciPolicy,]', '""'),
349         ('subscriberPolicy', 'Subscriber Policy Model', '[]', 'demo', 'identity=string:defaultValue-null:required-true:MANY-false:description-null', \
350          'policyScope=MANY-true,policyType=POLICYTYPE:MANY-false,properties=properties_properties:MANY-false:description-type of a policy', \
351          '{"properties_properties":{"provStatus":"PROVSTATUS:defaultValue-null:required-true:MANY-false:description-null",\
352            "subscriberName":"SUBSCRIBERNAME:defaultValue-null:required-true:MANY-false:description-null",\
353            "subscriberRole":"SUBSCRIBERROLE:defaultValue-null:required-true:MANY-false:description-null"}}', \
354          'test1', 'policyScope=matching-true, policyType=matching-true, properties=matching-true ', \
355          ' SUBSCRIBERNAME=[], SUBSCRIBERROLE=[], POLICYTYPE=[subscriberPolicy,], PROVSTATUS=[]', '""')
356     ]
357
358     mycursor.executemany(sql, val)
359     mydb.commit()
360     print(mycursor.rowcount, "was inserted.")
361     
362 def add_policies(parameters):
363     #Loop through policy, put in resource_model_name and create policies
364     for policy in os.listdir(parameters["policy_directory"]):
365       policy_name = "{}.{}".format(parameters["policy_scope"], os.path.splitext(policy)[0])
366       policy_file = (os.path.join(parameters["policy_directory"], policy))
367       #Create policy
368       os.system("oclip policy-create-outdated -m {} -u {} -p {} -x {} -S {} -T {} -o {} -b $(cat {})".format(parameters["policy_url"],\
369       parameters["policy_username"], parameters["policy_password"], policy_name, parameters["policy_scope"], \
370       parameters["policy_config_type"], parameters["policy_onapName"], policy_file))
371
372       #Push policy
373       os.system("oclip policy-push-outdated -m {} -u {} -p {} -x {} -b {} -c {}".format(parameters["policy_url"], \
374         parameters["policy_username"], parameters["policy_password"], policy_name, parameters["policy_config_type"],\
375         parameters["policy_pdp_group"]))
376
377 def onboard_vnf(parameters):
378     vnfs = parameters["vnfs"]
379     vnf_onboard_outputs = {}
380
381     for key, value in vnfs.items():
382         vnf_onboard_string = 'oclip vfc-catalog-onboard-vnf -m {} -c {}'\
383             .format(value.get("url"), value.get("csar-id"))
384         vnf_onboard_outputs[key] = (os.popen(vnf_onboard_string)).read()
385     return vnf_onboard_outputs
386
387 def onboard_ns(parameters):
388     ns_onboard_string = 'oclip vfc-catalog-onboard-ns -c {}'.format(parameters["ns-csar-id"])
389     ns_onboard_out = (os.popen(ns_onboard_string)).read()
390     return ns_onboard_out
391
392 def create_ns(parameters, csar_id):
393     ns = parameters["ns"]
394     ns_create_string = 'oclip vfc-nslcm-create -m {} -c {} -n {} -q {} -S {}'.format(parameters["vfc-url"], \
395        csar_id, ns.get("name"), parameters["customer_name"], parameters["service_name"])
396     print ns_create_string
397     ns_create_out = (os.popen(ns_create_string)).read()
398     print ns_create_out
399     ns_instance_id = (get_out_helper_2(ns_create_out))[3]
400     return ns_instance_id
401
402 def instantiate_ns(parameters, ns_instance_id):
403     ns_instantiate_string = 'oclip vfc-nslcm-instantiate -m {} -i {} -c {} -n {}'.format(parameters["vfc-url"], \
404         ns_instance_id, parameters["location"], parameters["sdc-controller-id"])
405     print ns_instantiate_string
406
407     ns_instantiate_out = (os.popen(ns_instantiate_string)).read()
408     return ns_instantiate_out
409
410 def create_ns_package(parameters):
411     ns = parameters["ns"]
412     create_ns_string = 'oclip vfc-catalog-create-ns -m {} -c {} -e {}'.format(parameters["vfc-url"], \
413       ns.get("key"), ns.get("value"))
414     cmd_out = (os.popen(create_ns_string)).read()
415     out_list =  get_out_helper_2(cmd_out) 
416     return out_list[4]
417
418 def create_vnf_package(parameters):
419     vnfs = parameters["vnfs"]
420     outputs = {}
421
422     for vnf_key, vnf_values in vnfs.iteritems():
423         create_vnf_string = 'oclip vfc-catalog-create-vnf -m {} -c {} -e {}'.format(parameters["vfc-url"], \
424           vnf_values.get("key"), vnf_values.get("value"))
425         cmd_out = (os.popen(create_vnf_string)).read()
426         out_list =  get_out_helper_2(cmd_out) 
427         outputs[vnf_key] = out_list[4]
428
429     return outputs
430
431 def upload_ns_package(parameters, ns_package_output):
432     ns = parameters["ns"]
433     ns_upload_string = '{}/api/nsd/v1/ns_descriptors/{}/nsd_content'.format(parameters["vfc-url"], ns_package_output)
434     print ns_upload_string
435     print ns.get("path")
436     resp = requests.put(ns_upload_string, files={'file': open(ns.get("path"), 'rb')})
437     return resp
438
439 def upload_vnf_package(parameters, vnf_package_output):
440     vnfs = parameters["vnfs"]
441     for vnf_key, vnf_values in vnfs.iteritems():
442         vnf_upload_str = '{}/api/vnfpkgm/v1/vnf_packages/{}/package_content'.format(parameters["vfc-url"], \
443           vnf_package_output[vnf_key], vnf_package_output[vnf_key])
444         resp = requests.put(vnf_upload_str, files={'file': open(vnf_values.get("path"), 'rb')})
445     return resp
446
447
448 #Run Functions
449 parser = argparse.ArgumentParser()
450 parser.add_argument('-f', action='store', dest='config_file_path', help='Store config file path')
451 parser.add_argument('-t', action='store', dest='model', help='Store config file path')
452
453 parser.add_argument('--version', action='version', version='%(prog)s 1.0')
454
455 results = parser.parse_args()
456
457 config_file_path = results.config_file_path
458 model = results.model
459 if config_file_path is None:
460     sys.exit(1)
461 config_file = open(config_file_path)
462 parameters = get_parameters(config_file)
463
464 # 1.Set cli command envionment
465 set_open_cli_env(parameters)
466
467 # 2.Create cloud complex
468 create_complex(parameters)
469
470 # 3.1 Register all clouds
471 register_all_clouds(parameters)
472
473 # 3.2 create service and customer
474 create_service_type(parameters)
475 create_customer(parameters)
476 add_customer_subscription(parameters)
477
478 # 4.Register vnfm
479 register_vnfm(parameters)
480
481 # 5.create csar file
482 # 5.1 upload csar file to catalog
483 # 5.2 FIXME:Because SDC internal API will change without notice, so I will maually design VNF and Service.
484 # SDC output data model is not align with VFC, we use an workaround method
485 # We just do run time automation 
486 ns_package_output = ""
487
488 if model == "sdc":
489     print "use csar file is distributed by sdc"
490     # output = create_vlm(parameters)
491     # vsp_dict = create_vsp(parameters, output)
492     # vf_dict = create_vf_model(parameters, vsp_dict)
493     # service_model_list = create_service_model(parameters, vf_dict)
494    
495     vnf_onboard_output = onboard_vnf(parameters)
496     print vnf_onboard_output
497     ns_onboard_out = onboard_ns(parameters)
498     print ns_onboard_out
499 else:
500     print "use csar file is uploaded by local"
501     vnf_package_output = create_vnf_package(parameters)
502     print vnf_package_output
503     ns_package_output = create_ns_package(parameters)
504     print ns_package_output
505     upload_vnf_out = upload_vnf_package(parameters, vnf_package_output)
506     print upload_vnf_out
507     upload_ns_out = upload_ns_package(parameters, ns_package_output)
508     print upload_ns_out
509
510 # 6.add_policies function not currently working, using curl commands
511 add_policy_models(parameters)
512 add_policies(parameters)
513
514 # 7. VFC part
515 ns_instance_id = create_ns(parameters, ns_package_output)
516 print ns_instance_id
517 instantiate_ns_output = instantiate_ns(parameters, ns_instance_id)
518 print instantiate_ns_output