Newer
Older
3001
3002
3003
3004
3005
3006
3007
3008
3009
3010
3011
3012
3013
3014
3015
3016
3017
3018
3019
3020
3021
3022
3023
3024
3025
3026
3027
3028
3029
3030
3031
3032
3033
3034
3035
3036
3037
3038
3039
3040
3041
3042
3043
3044
3045
3046
3047
3048
3049
" return self._prediction_area\n",
" @prediction_area.setter\n",
" def prediction_area(self, prediction_area):\n",
" self._prediction_area = prediction_area\n",
" @property\n",
" def routes(self):\n",
" return self._routes\n",
" @routes.setter\n",
" def routes(self, routes):\n",
" self._routes = routes\n",
" def to_dict(self):\n",
" result = {}\n",
" for attr, _ in six.iteritems(self.swagger_types):\n",
" value = getattr(self, attr)\n",
" if isinstance(value, list):\n",
" result[attr] = list(map(\n",
" lambda x: x.to_dict() if hasattr(x, 'to_dict') else x,\n",
" value\n",
" ))\n",
" elif hasattr(value, 'to_dict'):\n",
" result[attr] = value.to_dict()\n",
" elif isinstance(value, dict):\n",
" result[attr] = dict(map(\n",
" lambda item: (item[0], item[1].to_dict())\n",
" if hasattr(item[1], 'to_dict') else item,\n",
" value.items()\n",
" ))\n",
" else:\n",
" result[attr] = value\n",
" if issubclass(PredictedQos, dict):\n",
" for key, value in self.items():\n",
" result[key] = value\n",
" return result\n",
" def to_str(self):\n",
" return pprint.pformat(self.to_dict())\n",
" def __repr__(self):\n",
" return self.to_str()\n",
" def __eq__(self, other):\n",
" if not isinstance(other, PredictedQos):\n",
" return False\n",
" return self.__dict__ == other.__dict__\n",
" def __ne__(self, other):\n",
" return not self == other\n"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Here is the V2X Prediscted QoS function.\n",
"\n",
"Reference: ETSI GS MEC 030 V3.2.1 (2024-02) Clause 5.5.5 Sending a request for journey-specific QoS predictions\n"
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
" \"\"\"\n",
" Request to predictede QoS\n",
" :param sandbox_name: The MEC Sandbox instance to use\n",
" :return The HTTP response, the HTTP response status and the HTTP response headers on success, None otherwise\n",
" :see ETSI GS MEC 030 V3.2.1 (2024-02) Clause 5.5.5 Sending a request for journey-specific QoS predictions\n",
" \"\"\"\n",
" global MEC_PLTF, logger, service_api\n",
3070
3071
3072
3073
3074
3075
3076
3077
3078
3079
3080
3081
3082
3083
3084
3085
3086
3087
3088
3089
3090
3091
3092
3093
3094
" logger.debug('>>> get_qos_prediction: sandbox_name: ' + sandbox_name)\n",
" try:\n",
" url = '/{sandbox_name}/{mec_pltf}/vis/v2/provide_predicted_qos'\n",
" logger.debug('send_uu_unicast_provisioning_info: url: ' + url)\n",
" path_params = {}\n",
" path_params['sandbox_name'] = sandbox_name\n",
" path_params['mec_pltf'] = MEC_PLTF\n",
" # HTTP header `Accept`\n",
" header_params = {}\n",
" header_params['Accept'] = 'application/json' # noqa: E501\n",
" # HTTP header `Content-Type`\n",
" header_params['Content-Type'] = 'application/json' # noqa: E501\n",
" # Body request\n",
" loc1 = LocationInfo(geo_area=LocationInfoGeoArea(latitude=43.729416, longitude=7.414853))\n",
" loc2 = LocationInfo(geo_area=LocationInfoGeoArea(latitude=43.732456, longitude=7.418417))\n",
" routeInfo1 = RouteInfo(loc1, TimeStamp(nano_seconds=0, seconds=1653295620))\n",
" routeInfo2 = RouteInfo(loc2, TimeStamp(nano_seconds=0, seconds=1653299220))\n",
" routesInfo = [routeInfo1, routeInfo2]\n",
" predictedQos = PredictedQos(prediction_target=\"SINGLE_UE_PREDICTION\", location_granularity=\"30\", routes=[Routes(routesInfo)])\n",
" (result, status, headers) = service_api.call_api(url, 'POST', header_params=header_params, path_params=path_params, body=predictedQos, async_req=False)\n",
" return (result, status, headers)\n",
" except ApiException as e:\n",
" logger.error('Exception when calling call_api: %s\\n' % e)\n",
" return None\n",
" # End of function send_uu_unicast_provisioning_info"
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Grouping all together provides the process_main funtion.. The sequence is the following:\n",
"- Mec application setup\n",
"- V2X QoS request\n",
"- Mec application termination\n",
"\n",
"The expected response should be:\n",
"- RSRP: 55\n",
"- RSRQ: 13"
"execution_count": null,
"outputs": [],
"def process_main():\n",
" \"\"\"\n",
" This is the second sprint of our skeleton of our MEC application:\n",
" - Mec application setup\n",
" - Mec application termination\n",
" \"\"\" \n",
"\n",
" logger.debug('Starting at ' + time.strftime('%Y%m%d-%H%M%S'))\n",
" logger.debug('\\t pwd= ' + os.getcwd())\n",
"\n",
" # Setup the MEC application\n",
" # QoS Prediction\n",
" (result, status, headers) = get_qos_prediction(sandbox_name)\n",
" if status != 200:\n",
" logger.error('Failed to get UU unicast provisioning information')\n",
" else:\n",
" logger.info('UU unicast provisioning information: result: %s', str(result.data))\n",
" \n",
" # Any processing here\n",
" logger.info('body: ' + str(result.data))\n",
" data = json.loads(result.data)\n",
" logger.info('data: %s', str(data))\n",
" time.sleep(STABLE_TIME_OUT)\n",
"\n",
" # Terminate the MEC application\n",
" mec_app_termination(sandbox_name, app_inst_id, sub_id)\n",
"\n",
" logger.debug('Stopped at ' + time.strftime('%Y%m%d-%H%M%S'))\n",
" # End of function process_main\n",
"\n",
"if __name__ == '__main__':\n",
" process_main()\n"
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Our third MEC application: how to create a new MEC Services\n",
"The purpose of this MEC Service application is to provide a custom MEC service that can be use by other MEC applications. For the purpose of this tutorial, our MEC service is simulating some complex calculation based on a set of data provided by the MEC use. \n",
"We will use a second MEC application to exploit the features of our new MEC services.\n",
"In this clause, we use the following functionalities provided by MEC-011:\n",
"- Register a new service\n",
"- Retrieve the list of the MEC services exposed by the MEC platform\n",
"- Check that our new MEC service is present in the list of the MEC platform services\n",
"- Execute a request to the MEC service\n",
"- Delete the newly created service\n",
"\n",
"Reference: ETSI GS MEC 011 V3.2.1 (2024-04) Clause 5.2.4 Service availability update and new service registration\n",
"\n",
"<b>Note:</b> We will use a second MEC application to exploit the features of our new MEC services.\n"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Bases of the creation of a MEC service\n",
"\n",
"#### Introduction\n",
"\n",
"From the user perspective, a MEC service provides a set of endpoints which describe the interface of the MEC service (see [HTTP REST APIs \n",
"concepts](https://blog.postman.com/rest-api-examples/)). These endpoints come usually with a set of data structures used by the one or more endpoints.\n",
"\n",
"Our service is really basic: it provide one endpoint:\n",
"- GET /statistic/v1/quantity: it computes statistical quantities of a set of data (such as average, max, min, standard deviation)\n",
"\n",
"The body of this GET method is a list of datas:\n",
"{\"time\":20180124,\"data1\":\"[1516752000,11590.6,11616.9,11590.4,11616.9,0.25202387,1516752060,11622.4,11651.7,11622.4,11644.6,1.03977764]\"}\n",
"```\n",
"\n",
"The response body is the list of statistical quantities:\n",
"```json\n",
"{\"time\":20180124,\"avg\": 0.0,\"max\": 0.0,\"min\": 0.0,\"stddev\": 0.0 }\n",
"```\n",
"\n",
"#### MEC mechanisms to create a new service\n",
"\n",
"As described in ETSI GS MEC 011 Clause 5.2.4 Service availability update and new service registration, to create a new MEC service, the following information is required:\n",
"- A MEC Aplication instance: this is the MEC application providing the new MEC service (ETSI GS MEC 011 V3.2.1 Clause 8.2.6.3.4 POST)\n",
"- A ServiceInfo instance which describe the MEC service (ETSI GS MEC 011 V3.2.1 Clause 8.1.2.2 Type: ServiceInfo)\n",
"- As part of the ServiceInfo instance, a TransportInfo (ETSI GS MEC 011 V3.2.1 Clause 8.1.2.3 Type: TransportInfo) instance descibes the endpoints to use the MEC service\n",
"\n",
"When created and available, all the other MEC applications are notified about the existance of this MEC service."
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
3218
3219
3220
3221
3222
3223
3224
3225
3226
3227
3228
3229
3230
3231
3232
3233
3234
3235
3236
3237
3238
3239
3240
3241
3242
3243
3244
3245
3246
3247
3248
3249
3250
3251
3252
3253
3254
3255
3256
3257
3258
3259
3260
3261
3262
3263
3264
3265
3266
3267
3268
3269
3270
3271
3272
3273
3274
3275
3276
3277
3278
3279
3280
3281
3282
3283
3284
3285
3286
3287
3288
3289
3290
3291
3292
3293
3294
3295
3296
3297
3298
3299
3300
3301
3302
3303
3304
3305
3306
3307
3308
3309
3310
3311
3312
3313
3314
3315
3316
3317
3318
3319
3320
"class ServiceInfo(object):\n",
" swagger_types = {'ser_instance_id': 'str','ser_name': 'str','ser_category': 'CategoryRef','version': 'str','state': 'str','transport_id': 'str','transport_info': 'TransportInfo','serializer': 'string','scope_of_locality': 'LocalityType','consumed_local_only': 'bool','is_local': 'bool','liveness_interval': 'int','links': 'ServiceInfoLinks'}\n",
" attribute_map = {'ser_instance_id': 'serInstanceId','ser_name': 'serName','ser_category': 'serCategory','version': 'version','state': 'state','transport_id': 'transportId','transport_info': 'transportInfo','serializer': 'serializer','scope_of_locality': 'scopeOfLocality','consumed_local_only': 'consumedLocalOnly','is_local': 'isLocal','liveness_interval': 'livenessInterval','links': '_links'}\n",
" def __init__(self, ser_instance_id=None, ser_name=None, ser_category=None, version=None, state=None, transport_id=None, transport_info=None, serializer=None, scope_of_locality=None, consumed_local_only=None, is_local=None, liveness_interval=None, links=None): # noqa: E501\n",
" self._ser_instance_id = None\n",
" self._ser_name = None\n",
" self._ser_category = None\n",
" self._version = None\n",
" self._state = None\n",
" self._transport_id = None\n",
" self._transport_info = None\n",
" self._serializer = None\n",
" self._scope_of_locality = None\n",
" self._consumed_local_only = None\n",
" self._is_local = None\n",
" self._liveness_interval = None\n",
" self._links = None\n",
" self.discriminator = None\n",
" if ser_instance_id is not None:\n",
" self.ser_instance_id = ser_instance_id\n",
" self.ser_name = ser_name\n",
" if ser_category is not None:\n",
" self.ser_category = ser_category\n",
" self.version = version\n",
" self.state = state\n",
" if transport_id is not None:\n",
" self.transport_id = transport_id\n",
" self.transport_info = transport_info\n",
" self.serializer = serializer\n",
" if scope_of_locality is not None:\n",
" self.scope_of_locality = scope_of_locality\n",
" if consumed_local_only is not None:\n",
" self.consumed_local_only = consumed_local_only\n",
" if is_local is not None:\n",
" self.is_local = is_local\n",
" if liveness_interval is not None:\n",
" self.liveness_interval = liveness_interval\n",
" if links is not None:\n",
" self.links = links\n",
" @property\n",
" def ser_instance_id(self):\n",
" return self._ser_instance_id\n",
" @ser_instance_id.setter\n",
" def ser_instance_id(self, ser_instance_id):\n",
" self._ser_instance_id = ser_instance_id\n",
" @property\n",
" def ser_name(self):\n",
" return self._ser_name\n",
" @ser_name.setter\n",
" def ser_name(self, ser_name):\n",
" if ser_name is None:\n",
" raise ValueError(\"Invalid value for `ser_name`, must not be `None`\") # noqa: E501\n",
" self._ser_name = ser_name\n",
" @property\n",
" def ser_category(self):\n",
" return self._ser_category\n",
" @ser_category.setter\n",
" def ser_category(self, ser_category):\n",
" self._ser_category = ser_category\n",
" @property\n",
" def version(self):\n",
" return self._version\n",
" @version.setter\n",
" def version(self, version):\n",
" if version is None:\n",
" raise ValueError(\"Invalid value for `version`, must not be `None`\") # noqa: E501\n",
" self._version = version\n",
" @property\n",
" def state(self):\n",
" return self._state\n",
" @state.setter\n",
" def state(self, state):\n",
" if state is None:\n",
" raise ValueError(\"Invalid value for `state`, must not be `None`\") # noqa: E501\n",
" self._state = state\n",
" @property\n",
" def transport_id(self):\n",
" return self._transport_id\n",
" @transport_id.setter\n",
" def transport_id(self, transport_id):\n",
" self._transport_id = transport_id\n",
" @property\n",
" def transport_info(self):\n",
" return self._transport_info\n",
" @transport_info.setter\n",
" def transport_info(self, transport_info):\n",
" if transport_info is None:\n",
" raise ValueError(\"Invalid value for `transport_info`, must not be `None`\") # noqa: E501\n",
" self._transport_info = transport_info\n",
" @property\n",
" def serializer(self):\n",
" return self._serializer\n",
" @serializer.setter\n",
" def serializer(self, serializer):\n",
" if serializer is None:\n",
" raise ValueError(\"Invalid value for `serializer`, must not be `None`\") # noqa: E501\n",
" self._serializer = serializer\n",
" @property\n",
" def scope_of_locality(self):\n",
" return self._scope_of_locality\n",
" @scope_of_locality.setter\n",
" def scope_of_locality(self, scope_of_locality):\n",
" self._scope_of_locality = scope_of_locality\n",
3322
3323
3324
3325
3326
3327
3328
3329
3330
3331
3332
3333
3334
3335
3336
3337
3338
3339
3340
3341
3342
3343
3344
" def consumed_local_only(self):\n",
" return self._consumed_local_only\n",
" @consumed_local_only.setter\n",
" def consumed_local_only(self, consumed_local_only):\n",
" self._consumed_local_only = consumed_local_only\n",
" @property\n",
" def is_local(self):\n",
" return self._is_local\n",
" @is_local.setter\n",
" def is_local(self, is_local):\n",
" self._is_local = is_local\n",
" @property\n",
" def liveness_interval(self):\n",
" return self._liveness_interval\n",
" @liveness_interval.setter\n",
" def liveness_interval(self, liveness_interval):\n",
" self._liveness_interval = liveness_interval\n",
" @property\n",
" def links(self):\n",
" return self._links\n",
" @links.setter\n",
" def links(self, links):\n",
" self._links = links\n",
" def to_dict(self):\n",
" result = {}\n",
" for attr, _ in six.iteritems(self.swagger_types):\n",
" value = getattr(self, attr)\n",
" if isinstance(value, list):\n",
" result[attr] = list(map(\n",
" lambda x: x.to_dict() if hasattr(x, \"to_dict\") else x,\n",
" value\n",
" ))\n",
" elif hasattr(value, \"to_dict\"):\n",
" result[attr] = value.to_dict()\n",
" elif isinstance(value, dict):\n",
" result[attr] = dict(map(\n",
" lambda item: (item[0], item[1].to_dict())\n",
" value.items()\n",
" ))\n",
" else:\n",
" result[attr] = value\n",
" for key, value in self.items():\n",
" result[key] = value\n",
" return result\n",
" def to_str(self):\n",
" return pprint.pformat(self.to_dict())\n",
" def __repr__(self):\n",
" return self.to_str()\n",
" def __eq__(self, other):\n",
" return False\n",
" return self.__dict__ == other.__dict__\n",
" def __ne__(self, other):\n",
" return not self == other\n",
"class CategoryRef(object):\n",
" swagger_types = {'href': 'str','id': 'str','name': 'str','version': 'str'}\n",
" attribute_map = {'href': 'href','id': 'id','name': 'name','version': 'version'}\n",
" def __init__(self, href=None, id=None, name=None, version=None): # noqa: E501\n",
" self._href = None\n",
" self._id = None\n",
" self._name = None\n",
" self._version = None\n",
" self.discriminator = None\n",
" self.href = href\n",
" self.id = id\n",
" self.name = name\n",
" self.version = version\n",
" def href(self):\n",
" return self._href\n",
" @href.setter\n",
" def href(self, href):\n",
" if href is None:\n",
" raise ValueError(\"Invalid value for `href`, must not be `None`\") # noqa: E501\n",
" self._href = href\n",
3401
3402
3403
3404
3405
3406
3407
3408
3409
3410
3411
3412
3413
3414
3415
3416
3417
3418
3419
3420
3421
3422
3423
" def id(self):\n",
" return self._id\n",
" @id.setter\n",
" def id(self, id):\n",
" if id is None:\n",
" raise ValueError(\"Invalid value for `id`, must not be `None`\") # noqa: E501\n",
" self._id = id\n",
" @property\n",
" def name(self):\n",
" return self._name\n",
" @name.setter\n",
" def name(self, name):\n",
" if name is None:\n",
" raise ValueError(\"Invalid value for `name`, must not be `None`\") # noqa: E501\n",
" self._name = name\n",
" @property\n",
" def version(self):\n",
" return self._version\n",
" @version.setter\n",
" def version(self, version):\n",
" if version is None:\n",
" raise ValueError(\"Invalid value for `version`, must not be `None`\") # noqa: E501\n",
" self._version = version\n",
" def to_dict(self):\n",
" result = {}\n",
" for attr, _ in six.iteritems(self.swagger_types):\n",
" value = getattr(self, attr)\n",
" if isinstance(value, list):\n",
" result[attr] = list(map(\n",
" lambda x: x.to_dict() if hasattr(x, \"to_dict\") else x,\n",
" value\n",
" ))\n",
" elif hasattr(value, \"to_dict\"):\n",
" result[attr] = value.to_dict()\n",
" elif isinstance(value, dict):\n",
" result[attr] = dict(map(\n",
" lambda item: (item[0], item[1].to_dict())\n",
" value.items()\n",
" ))\n",
" else:\n",
" result[attr] = value\n",
" for key, value in self.items():\n",
" result[key] = value\n",
" def to_str(self):\n",
" return pprint.pformat(self.to_dict())\n",
" def __repr__(self):\n",
" return self.to_str()\n",
" def __eq__(self, other):\n",
" return False\n",
" return self.__dict__ == other.__dict__\n",
" def __ne__(self, other):\n",
" return not self == other\n",
"\n",
3458
3459
3460
3461
3462
3463
3464
3465
3466
3467
3468
3469
3470
3471
3472
3473
3474
3475
3476
3477
3478
3479
3480
3481
3482
3483
"class TransportInfo(object):\n",
" swagger_types = {\n",
" 'id': 'str','name': 'str','description': 'str','type': 'str','protocol': 'str','version': 'str','endpoint': 'OneOfTransportInfoEndpoint','security': 'SecurityInfo','impl_specific_info': 'str'}\n",
" attribute_map = {'id': 'id','name': 'name','description': 'description','type': 'type','protocol': 'protocol','version': 'version','endpoint': 'endpoint','security': 'security','impl_specific_info': 'implSpecificInfo'}\n",
" def __init__(self, id=None, name=None, description=None, type=None, protocol=None, version=None, endpoint=None, security=None, impl_specific_info=None): # noqa: E501\n",
" self._id = None\n",
" self._name = None\n",
" self._description = None\n",
" self._type = None\n",
" self._protocol = None\n",
" self._version = None\n",
" self._endpoint = None\n",
" self._security = None\n",
" self._impl_specific_info = None\n",
" self.discriminator = None\n",
" self.id = id\n",
" self.name = name\n",
" if description is not None:\n",
" self.description = description\n",
" self.type = type\n",
" self.protocol = protocol\n",
" self.version = version\n",
" self.endpoint = endpoint\n",
" self.security = security\n",
" if impl_specific_info is not None:\n",
" self.impl_specific_info = impl_specific_info\n",
" def id(self):\n",
" return self._id\n",
" @id.setter\n",
" def id(self, id):\n",
" if id is None:\n",
" raise ValueError(\"Invalid value for `id`, must not be `None`\") # noqa: E501\n",
" self._id = id\n",
3493
3494
3495
3496
3497
3498
3499
3500
3501
3502
3503
3504
3505
3506
3507
3508
3509
3510
3511
3512
3513
3514
3515
3516
3517
3518
3519
3520
3521
3522
3523
3524
3525
3526
3527
3528
3529
3530
3531
3532
3533
3534
3535
3536
3537
3538
3539
3540
3541
3542
3543
3544
3545
3546
3547
3548
3549
3550
3551
" def name(self):\n",
" return self._name\n",
" @name.setter\n",
" def name(self, name):\n",
" if name is None:\n",
" raise ValueError(\"Invalid value for `name`, must not be `None`\") # noqa: E501\n",
" self._name = name\n",
" @property\n",
" def description(self):\n",
" return self._description\n",
" @description.setter\n",
" def description(self, description):\n",
" self._description = description\n",
" @property\n",
" def type(self):\n",
" return self._type\n",
" @type.setter\n",
" def type(self, type):\n",
" if type is None:\n",
" raise ValueError(\"Invalid value for `type`, must not be `None`\") # noqa: E501\n",
" self._type = type\n",
" @property\n",
" def protocol(self):\n",
" return self._protocol\n",
" @protocol.setter\n",
" def protocol(self, protocol):\n",
" if protocol is None:\n",
" raise ValueError(\"Invalid value for `protocol`, must not be `None`\") # noqa: E501\n",
" self._protocol = protocol\n",
" @property\n",
" def version(self):\n",
" return self._version\n",
" @version.setter\n",
" def version(self, version):\n",
" if version is None:\n",
" raise ValueError(\"Invalid value for `version`, must not be `None`\") # noqa: E501\n",
" self._version = version\n",
" @property\n",
" def endpoint(self):\n",
" return self._endpoint\n",
" @endpoint.setter\n",
" def endpoint(self, endpoint):\n",
" if endpoint is None:\n",
" raise ValueError(\"Invalid value for `endpoint`, must not be `None`\") # noqa: E501\n",
" self._endpoint = endpoint\n",
" @property\n",
" def security(self):\n",
" return self._security\n",
" @security.setter\n",
" def security(self, security):\n",
" if security is None:\n",
" raise ValueError(\"Invalid value for `security`, must not be `None`\") # noqa: E501\n",
" self._security = security\n",
" @property\n",
" def impl_specific_info(self):\n",
" return self._impl_specific_info\n",
" @impl_specific_info.setter\n",
" def impl_specific_info(self, impl_specific_info):\n",
" self._impl_specific_info = impl_specific_info\n",
" def to_dict(self):\n",
" result = {}\n",
" for attr, _ in six.iteritems(self.swagger_types):\n",
" value = getattr(self, attr)\n",
" if isinstance(value, list):\n",
" result[attr] = list(map(\n",
" lambda x: x.to_dict() if hasattr(x, \"to_dict\") else x,\n",
" value\n",
" ))\n",
" elif hasattr(value, \"to_dict\"):\n",
" result[attr] = value.to_dict()\n",
" elif isinstance(value, dict):\n",
" result[attr] = dict(map(\n",
" lambda item: (item[0], item[1].to_dict())\n",
" value.items()\n",
" ))\n",
" else:\n",
" result[attr] = value\n",
" for key, value in self.items():\n",
" result[key] = value\n",
" return result\n",
" def to_str(self):\n",
" return pprint.pformat(self.to_dict())\n",
" def __repr__(self):\n",
" return self.to_str()\n",
" def __eq__(self, other):\n",
" return False\n",
" return self.__dict__ == other.__dict__\n",
" def __ne__(self, other):\n",
" return not self == other\n",
"\n",
"class SecurityInfo(object):\n",
" swagger_types = {'o_auth2_info': 'SecurityInfoOAuth2Info'}\n",
" attribute_map = {'o_auth2_info': 'oAuth2Info'}\n",
" def __init__(self, o_auth2_info=None): # noqa: E501\n",
" self._o_auth2_info = None\n",
" self.discriminator = None\n",
" if o_auth2_info is not None:\n",
" self.o_auth2_info = o_auth2_info\n",
" def o_auth2_info(self):\n",
" return self._o_auth2_info\n",
" @o_auth2_info.setter\n",
" def o_auth2_info(self, o_auth2_info):\n",
" self._o_auth2_info = o_auth2_info\n",
" def to_dict(self):\n",
" result = {}\n",
" for attr, _ in six.iteritems(self.swagger_types):\n",
" value = getattr(self, attr)\n",
" if isinstance(value, list):\n",
" result[attr] = list(map(\n",
" lambda x: x.to_dict() if hasattr(x, \"to_dict\") else x,\n",
" value\n",
" ))\n",
" elif hasattr(value, \"to_dict\"):\n",
" result[attr] = value.to_dict()\n",
" elif isinstance(value, dict):\n",
" result[attr] = dict(map(\n",
" lambda item: (item[0], item[1].to_dict())\n",
" value.items()\n",
" ))\n",
" else:\n",
" result[attr] = value\n",
" for key, value in self.items():\n",
" result[key] = value\n",
" return result\n",
" def to_str(self):\n",
" return pprint.pformat(self.to_dict())\n",
" def __repr__(self):\n",
" return self.to_str()\n",
" def __eq__(self, other):\n",
" return False\n",
" return self.__dict__ == other.__dict__\n",
" def __ne__(self, other):\n",
" return not self == other\n",
"\n",
"class SecurityInfoOAuth2Info(object):\n",
" swagger_types = {'grant_types': 'list[str]','token_endpoint': 'str'}\n",
" attribute_map = {'grant_types': 'grantTypes','token_endpoint': 'tokenEndpoint'}\n",
" def __init__(self, grant_types=None, token_endpoint=None): # noqa: E501\n",
" self._grant_types = None\n",
" self._token_endpoint = None\n",
" self.discriminator = None\n",
" self.grant_types = grant_types\n",
" self.token_endpoint = token_endpoint\n",
" def grant_types(self):\n",
" return self._grant_types\n",
" @grant_types.setter\n",
" def grant_types(self, grant_types):\n",
" if grant_types is None:\n",
" raise ValueError(\"Invalid value for `grant_types`, must not be `None`\") # noqa: E501\n",
" self._grant_types = grant_types\n",
" def token_endpoint(self):\n",
" return self._token_endpoint\n",
" @token_endpoint.setter\n",
" def token_endpoint(self, token_endpoint):\n",
" if token_endpoint is None:\n",
" raise ValueError(\"Invalid value for `token_endpoint`, must not be `None`\") # noqa: E501\n",
" self._token_endpoint = token_endpoint\n",
" def to_dict(self):\n",
" result = {}\n",
" for attr, _ in six.iteritems(self.swagger_types):\n",
" value = getattr(self, attr)\n",
" if isinstance(value, list):\n",
" result[attr] = list(map(\n",
" lambda x: x.to_dict() if hasattr(x, \"to_dict\") else x,\n",
" value\n",
" ))\n",
" elif hasattr(value, \"to_dict\"):\n",
" result[attr] = value.to_dict()\n",
" elif isinstance(value, dict):\n",
" result[attr] = dict(map(\n",
" lambda item: (item[0], item[1].to_dict())\n",
" value.items()\n",
" ))\n",
" else:\n",
" result[attr] = value\n",
" for key, value in self.items():\n",
" result[key] = value\n",
" return result\n",
" def to_str(self):\n",
" return pprint.pformat(self.to_dict())\n",
" def __repr__(self):\n",
" return self.to_str()\n",
" def __eq__(self, other):\n",
" return False\n",
" return self.__dict__ == other.__dict__\n",
" def __ne__(self, other):\n",
" return not self == other\n",
"\n",
"class OneOfTransportInfoEndpoint(object):\n",
" swagger_types = {}\n",
" attribute_map = {}\n",
" def __init__(self): # noqa: E501\n",
" self.discriminator = None\n",
" def uris(self):\n",
" return self._uris\n",
" @uris.setter\n",
" def uris(self, uris):\n",
" self._uris = uris\n",
" def to_dict(self):\n",
" result = {}\n",
" for attr, _ in six.iteritems(self.swagger_types):\n",
" value = getattr(self, attr)\n",
" if isinstance(value, list):\n",
" result[attr] = list(map(\n",
" lambda x: x.to_dict() if hasattr(x, \"to_dict\") else x,\n",
" value\n",
" ))\n",
" elif hasattr(value, \"to_dict\"):\n",
" result[attr] = value.to_dict()\n",
" elif isinstance(value, dict):\n",
" result[attr] = dict(map(\n",
" lambda item: (item[0], item[1].to_dict())\n",
" value.items()\n",
" ))\n",
" else:\n",
" result[attr] = value\n",
" for key, value in self.items():\n",
" result[key] = value\n",
" return result\n",
" def to_str(self):\n",
" return pprint.pformat(self.to_dict())\n",
" def __repr__(self):\n",
" return self.to_str()\n",
" def __eq__(self, other):\n",
" if not isinstance(other, OneOfTransportInfoEndpoint):\n",
" return False\n",
" return self.__dict__ == other.__dict__\n",
" def __ne__(self, other):\n",
" return not self == other\n",
"\n",
"class EndPointInfoUris(object):\n",
" swagger_types = {'_uris': 'list[str]'}\n",
" attribute_map = {'_uris': 'uris'}\n",
" def __init__(self, uris:list): # noqa: E501\n",
" self._uris = None\n",
" self.uris = uris\n",
" def uris(self):\n",
" return self._uris\n",
" @uris.setter\n",
" def uris(self, uris):\n",
" self._uris = uris\n",
" def to_dict(self):\n",
" result = {}\n",
" for attr, _ in six.iteritems(self.swagger_types):\n",
" value = getattr(self, attr)\n",
" if isinstance(value, list):\n",
" result[attr] = list(map(lambda x: x.to_dict() if hasattr(x, 'to_dict') else x,value))\n",
" elif hasattr(value, 'to_dict'):\n",
" result[attr] = value.to_dict()\n",
" elif isinstance(value, dict):\n",
" result[attr] = dict(map(\n",
" lambda item: (item[0], item[1].to_dict())\n",
" if hasattr(item[1], 'to_dict') else item,\n",
" value.items()\n",
" ))\n",
" else:\n",
" result[attr] = value\n",
" for key, value in self.items():\n",
" result[key] = value\n",
" return result\n",
" def to_str(self):\n",
" return pprint.pformat(self.to_dict())\n",
" def __repr__(self):\n",
" return self.to_str()\n",
" def __eq__(self, other):\n",
" return False\n",
" return self.__dict__ == other.__dict__\n",
" def __ne__(self, other):\n",
" return not self == other\n",
"\n",
"class EndPointInfoFqdn(object):\n",
" swagger_types = {'_fqdn': 'list[str]'}\n",
" attribute_map = {'_fqdn': 'fqdn'}\n",
" def __init__(self, fqdn:list): # noqa: E501\n",
" self._fqdn = None\n",
" self.fqdn = fqdn\n",
" def fqdn(self):\n",
" return self._fqdn\n",
" @fqdn.setter\n",
" def fqdn(self, fqdn):\n",
" self._fqdn = fqdn\n",
" def to_dict(self):\n",
" result = {}\n",
" for attr, _ in six.iteritems(self.swagger_types):\n",
" value = getattr(self, attr)\n",
" if isinstance(value, list):\n",
" result[attr] = list(map(lambda x: x.to_dict() if hasattr(x, 'to_dict') else x,value))\n",
" elif hasattr(value, 'to_dict'):\n",
" result[attr] = value.to_dict()\n",
" elif isinstance(value, dict):\n",
" result[attr] = dict(map(\n",
" lambda item: (item[0], item[1].to_dict())\n",
" if hasattr(item[1], 'to_dict') else item,\n",
" value.items()\n",
" ))\n",
" else:\n",
" result[attr] = value\n",
" for key, value in self.items():\n",
" result[key] = value\n",
" return result\n",
" def to_str(self):\n",
" return pprint.pformat(self.to_dict())\n",
" def __repr__(self):\n",
" return self.to_str()\n",
" def __eq__(self, other):\n",
" return False\n",
" return self.__dict__ == other.__dict__\n",
" def __ne__(self, other):\n",
" return not self == other\n",
"\n",
"class EndPointInfoAddress(object):\n",
" swagger_types = {'_host': 'str', '_port': 'int'}\n",
" attribute_map = {'_host': 'host', '_port': 'port'}\n",
" def __init__(self, host:str, port:list): # noqa: E501\n",
" self._host = None\n",
" self._port = None\n",
" self.host = host\n",
" self.port = port\n",
" def host(self):\n",
" return self.host\n",
" @host.setter\n",
" def host(self, host):\n",
" self._host = host\n",
" def port(self):\n",
" return self._port\n",
" @port.setter\n",
" def port(self, port):\n",
" self._port = qosport_kpi\n",
" def to_dict(self):\n",
" result = {}\n",
" for attr, _ in six.iteritems(self.swagger_types):\n",
" value = getattr(self, attr)\n",
" if isinstance(value, list):\n",
" result[attr] = list(map(\n",
" lambda x: x.to_dict() if hasattr(x, 'to_dict') else x,\n",
" value\n",
" ))\n",
" elif hasattr(value, 'to_dict'):\n",
" result[attr] = value.to_dict()\n",
" elif isinstance(value, dict):\n",
" result[attr] = dict(map(\n",
" lambda item: (item[0], item[1].to_dict())\n",
" if hasattr(item[1], 'to_dict') else item,\n",
" value.items()\n",
" ))\n",
" else:\n",
" result[attr] = value\n",
" for key, value in self.items():\n",
" result[key] = value\n",
" return result\n",
" def to_str(self):\n",
" return pprint.pformat(self.to_dict())\n",
" def __repr__(self):\n",
" return self.to_str()\n",
" def __eq__(self, other):\n",
" return False\n",
" return self.__dict__ == other.__dict__\n",
" def __ne__(self, other):\n",
" return not self == other\n",
"\n",
"class EndPointInfoAddresses(object):\n",
" swagger_types = {'_addresses': 'list[EndPointInfoAddress]'}\n",
" attribute_map = {'_addresses': 'addresses'}\n",
" def __init__(self, addresses:list): # noqa: E501\n",
" self._addresses = None\n",
" self.addresses = addresses\n",
" def addresses(self):\n",
" return self._addresses\n",
" @addresses.setter\n",
" def addresses(self, addresses):\n",
" self._addresses = addresses\n",
" def to_dict(self):\n",
" result = {}\n",
" for attr, _ in six.iteritems(self.swagger_types):\n",
" value = getattr(self, attr)\n",
" if isinstance(value, list):\n",
" result[attr] = list(map(lambda x: x.to_dict() if hasattr(x, 'to_dict') else x,value))\n",
" elif hasattr(value, 'to_dict'):\n",
" result[attr] = value.to_dict()\n",
" elif isinstance(value, dict):\n",
" result[attr] = dict(map(\n",
" lambda item: (item[0], item[1].to_dict())\n",
" if hasattr(item[1], 'to_dict') else item,\n",
" value.items()\n",
" ))\n",
" else:\n",
" result[attr] = value\n",
" for key, value in self.items():\n",
" result[key] = value\n",
" return result\n",
" def to_str(self):\n",
" return pprint.pformat(self.to_dict())\n",
" def __repr__(self):\n",
" return self.to_str()\n",
" def __eq__(self, other):\n",
" return False\n",
" return self.__dict__ == other.__dict__\n",
" def __ne__(self, other):\n",
" return not self == other\n",
"\n",
"class EndPointInfoAlternative(object):\n",
" swagger_types = {'alternative': 'object'}\n",
" attribute_map = {'alternative': 'alternative'}\n",
" def __init__(self, alternative=None): # noqa: E501\n",
" self._alternative = None\n",
" self.discriminator = None\n",
" self.alternative = alternative\n",
" def alternative(self):\n",
" return self._alternative\n",
" @alternative.setter\n",
" def alternative(self, alternative):\n",
" if alternative is None:\n",
" raise ValueError(\"Invalid value for `alternative`, must not be `None`\") # noqa: E501\n",
" self._alternative = alternative\n",
" def to_dict(self):\n",
" result = {}\n",
" for attr, _ in six.iteritems(self.swagger_types):\n",
" value = getattr(self, attr)\n",
" if isinstance(value, list):\n",
" result[attr] = list(map(\n",
" lambda x: x.to_dict() if hasattr(x, \"to_dict\") else x,\n",
" result[attr] = value.to_dict()\n",
" elif isinstance(value, dict):\n",
" result[attr] = dict(map(\n",
" lambda item: (item[0], item[1].to_dict())\n",
" value.items()\n",
" ))\n",
" else:\n",
" result[attr] = value\n",
" for key, value in self.items():\n",
" result[key] = value\n",
" return result\n",
" def to_str(self):\n",
" return pprint.pformat(self.to_dict())\n",
" def __repr__(self):\n",
" return self.to_str()\n",
" def __eq__(self, other):\n",
" return False\n",
" return self.__dict__ == other.__dict__\n",
" def __ne__(self, other):\n",
" return not self == other\n"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"The function below is creating an application MEC services\n",
"\n",
"<b>Note:</b> This is call application MEC service in opposition of a standardized MEC service exposed by the MEC Sanbox such as MEC 013, MEC 030..."
]
},
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"def create_mec_service(sandbox_name: str, app_inst_id: swagger_client.models.application_info.ApplicationInfo) -> object:\n",
" global MEC_PLTF, CALLBACK_URI, logger\n",
" url = '/{sandbox_name}/{mec_pltf}/mec_service_mgmt/v1/applications/{app_inst_id}/services'\n",
" logger.debug('create_mec_service: url: ' + url)\n",
" path_params = {}\n",
" path_params['sandbox_name'] = sandbox_name\n",
" path_params['mec_pltf'] = MEC_PLTF\n",
" header_params['Accept'] = 'application/json' # noqa: E501\n",
" # HTTP header `Content-Type`\n",